:root{
  --green:#1ea88a; --green-d:#12806a;
  --bg:#f4f6f8; --panel:#ffffff; --text:#0f172a; --mut:#64748b;
  --blue:#1e3a8a; --red:#b91c1c; --soft:#e9eef4;
}
*{box-sizing:border-box}
html,body{margin:0;background:var(--bg);color:var(--text);font:16px/1.55 system-ui,-apple-system,Segoe UI,Roboto,Arial}
body{overflow-x:hidden} /* убираем горизонтальный скролл на мобиле */

/* ===== layout ===== */
.layout{display:grid;grid-template-columns:260px 1fr;gap:24px;max-width:1200px;margin:0 auto;padding:18px}
@media(max-width:880px){.layout{grid-template-columns:1fr;gap:14px;padding:12px}}
@media(max-width:880px){.side{display:none}}

.side{
  background:linear-gradient(180deg,#1ea88a 0%, #138d74 100%);
  color:#e6fffb;border-radius:16px;padding:20px;position:sticky;top:12px;height:max-content
}
.logo{font-weight:900;margin-bottom:18px}
.steps-vert{list-style:none;margin:0;padding:0}
.steps-vert li{position:relative;margin:14px 0;padding:12px 14px 12px 44px;border-radius:12px;background:rgba(255,255,255,.06);transition:background .2s}
.steps-vert li::before{content:'';position:absolute;left:14px;top:50%;transform:translateY(-50%);width:16px;height:16px;border-radius:50%;border:2px solid #fff}
.steps-vert li.active{background:#fff;color:#145a56}
.steps-vert li.active::before{background:#10b981;border-color:#10b981}

.content{background:var(--panel);border-radius:16px;padding:22px}

/* ===== intro header ===== */
#intro.compact{display:none} /* скрываем шапку на этапах ввода */
.intro-title{margin:0 0 6px;font-size:36px;letter-spacing:.3px}
@media(max-width:520px){.intro-title{font-size:28px}}
.intro-sub{margin:0;color:var(--mut)}
.intro-meta{display:flex;gap:14px;flex-wrap:wrap;margin:14px 0 10px}
.intro-chip{background:#fff;border:1px solid var(--soft);border-radius:14px;padding:12px 14px;min-width:220px;box-shadow:0 10px 30px rgba(0,0,0,.06)}
.intro-chip .k{color:var(--mut);font-weight:700}
.intro-chip .v{font-size:22px;font-weight:900}

/* ===== panel / inputs (wizard) ===== */
.panel{background:#fff;border:1.5px solid var(--soft);border-radius:16px;padding:22px}
.center{text-align:center}
.muted{color:var(--mut)} .small{font-size:14px} .mt{margin-top:10px}
.nowrap{white-space:nowrap}
@media(max-width:520px){.nowrap{white-space:normal}} /* на мобиле переносим строку */

.slide-in{animation:slide .28s ease}
@keyframes slide{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

.stepbox{max-width:760px;margin:0 auto}
.sep{height:1px;background:var(--soft);margin:16px 0;border:0}

label{display:block;font-weight:800;margin:0 0 6px}
.input{
  width:100%;padding:16px 14px;border-radius:14px;border:1.5px solid var(--soft);
  background:#fbfdff;font-size:16px;transition:border .18s, box-shadow .18s, transform .18s
}
.input:focus{outline:none;border-color:#bcd0ee;box-shadow:0 0 0 4px rgba(80,125,255,.12)}
.row{display:flex;gap:14px;flex-wrap:wrap}
.col{flex:1 1 240px}

.btn{border:0;border-radius:14px;padding:14px 18px;font-weight:900;cursor:pointer;transition:transform .15s ease, box-shadow .15s ease}
.btn:active{transform:translateY(1px)}
.btn.primary{background:var(--green);color:#fff}
.btn.primary:disabled{opacity:.5;cursor:not-allowed}
.btn.primary:hover{background:var(--green-d)}
.btn.ghost{background:#fff;border:1.5px solid var(--soft)}
.btn.dark{background:#0f172a;color:#fff}
.actions{display:flex;gap:12px;justify-content:center;margin-top:16px}

.legal-line{color:var(--mut);font-size:14px;text-align:center;word-break:break-word}

/* segmented control */
.seg{display:inline-flex;background:#f3f6fb;border:1.5px solid var(--soft);border-radius:14px;padding:6px;gap:8px}
.seg .opt{padding:10px 16px;border-radius:12px;font-weight:900;cursor:pointer;user-select:none;transition:background .15s,color .15s, transform .12s}
.seg .opt:active{transform:scale(.98)}
.seg .opt.active{background:#0f172a;color:#fff}

/* ===== LOADER ===== */
.loader-overlay{position:fixed;inset:0;background:rgba(15,23,42,.55);display:none;align-items:center;justify-content:center;z-index:9999;backdrop-filter:saturate(120%) blur(2px)}
.loader-overlay.show{display:flex}
.loader-box{background:#fff;border-radius:16px;box-shadow:0 15px 40px rgba(0,0,0,.22);padding:22px 26px;display:flex;align-items:center;gap:14px}
.spinner{width:28px;height:28px;border-radius:50%;border:3px solid #e2e8f0;border-top-color:#1ea88a;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.loader-text{font-weight:800}

/* ===== HIDDEN PDF sheet ===== */
.visually-hidden{position:absolute;left:-99999px;top:0;opacity:0;pointer-events:none}
.sheet{background:#fff;color:#111;border-radius:12px;padding:12mm;overflow:hidden}
.brand{color:#ff2e63;font-weight:900;font-size:26px;text-align:center;margin:0 0 2mm}
.addr{text-align:center;font-weight:700;margin:0 0 2mm}
h2{text-align:center;margin:8px 0 10px}
.center{text-align:center}
.bold{font-weight:700}
.rule{border:0;border-top:2px solid #111;margin:10px 0}

/* Ровные линии текста и полей (PDF) */
.sheet .row{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}
.sheet .row label{display:inline-block;margin:0 6px 0 0;font-weight:700}
.sheet .row input,
.sheet .row select,
.sheet .row .print-value{vertical-align:baseline}

/* таблицы */
.row-table{width:100%;border-collapse:collapse;table-layout:fixed;margin:8px 0}
.row-table td{padding:0 8px 0 0;vertical-align:middle}
.row-table td:last-child{padding-right:0}
.td-label{white-space:nowrap}
.exp-row{display:flex;gap:8px;align-items:center}
.warn{font-weight:900;color:#d92525}
.note-blue{font-weight:900;color:#1d4ed8}

/* значения в PDF — без серого фона */
.print-value{
  display:inline-flex;align-items:center;border:1px solid #cbd5e1;border-radius:6px;
  padding:8px 10px;min-height:34px;line-height:1.25;background:#fff;color:#111;font-weight:600;white-space:nowrap
}

/* подпись */
.sig-wrap{display:flex;flex-direction:column;align-items:flex-start;gap:6px}
.sig-wrap img{margin-left:0;margin-right:auto}

/* размеры полей */
.small{width:90px}.med{width:160px}.lg{width:100%;max-width:420px}

/* мелкая приписка в конце PDF */
.sheet .fine-print{
  font-size: 10px;
  line-height: 1.35;
  color: #222;
  margin-top: 8px;
}

/* запрет разрыва абзаца между страницами в PDF */
.avoid-break{
  page-break-inside: avoid;
  break-inside: avoid;
}



/* компакт/суперкомпакт для PDF */
.sheet.compact{padding:10mm}
.sheet.compact h2{margin:6px 0 8px}
.sheet.compact .rule{margin:8px 0}
.sheet.extra-compact{padding:9mm}
.sheet.extra-compact .print-value{padding:6px 8px;min-height:28px}
.sheet.extra-compact h2{margin:4px 0 6px}
.sheet.extra-compact .rule{margin:6px 0}

/* ===== MOBILE PDF TUNING ===== */
.sheet.pdf-mobile{padding:8mm 9mm 12mm}
.sheet.pdf-mobile .brand{font-size:24px;margin:0 0 2mm}
.sheet.pdf-mobile .addr{margin:0 0 2mm}
.sheet.pdf-mobile h2{font-size:16px;margin:2mm 0 3mm}
.sheet.pdf-mobile p{margin:0 0 3mm}
.sheet.pdf-mobile .warn{margin:2mm 0}
.sheet.pdf-mobile .note-blue{margin:1mm 0 2mm}
.sheet.pdf-mobile .row-table{margin:2mm 0}
.sheet.pdf-mobile .sig-table{margin-top:3mm;margin-bottom:7mm}
.sheet.pdf-mobile .print-value{padding:7px 9px;min-height:30px}

/* печать — белый фон */
@media print{
  body{background:#fff !important}
  .print-value{background:#fff !important}
}

/* подпись: не прокручивать страницу пальцем */
canvas#sigCanvas{touch-action:none}

/* удобные размеры на мобиле */
@media (max-width:520px){
  .input{padding:16px}
  .btn{padding:14px 18px}
}
