/* ============================================================
   Pro Agent AI (сервис «ИИ-Агент Про») — единая дизайн-система
   Self-contained: без CDN/внешних шрифтов/скриптов (152-ФЗ).
   Один файл на все страницы: index / pay / pay-success / юр-доки.
   ============================================================ */

/* ---------- 1. Design tokens ---------- */
:root{
  /* Палитра */
  --ink:#0B1220;            /* чернильный сине-графит: текст + тёмные блоки */
  --ink-2:#1E293B;
  --muted:#56607A;
  --faint:#67718A;   /* мелкие подписи: ≥4.5:1 на --bg и --bg-soft (WCAG AA) */
  --bg:#FFFFFF;
  --bg-soft:#F6F7F9;
  --line:#E6E9F0;
  --primary:#1D4ED8;        /* действия (AA на белом и для белого текста) */
  --primary-hover:#1E40AF;
  --primary-soft:#EEF3FE;
  --on-dark:#F8FAFC;
  --on-dark-muted:#A9B4C8;
  --line-dark:rgba(255,255,255,.14);
  --amber:#B45309;          /* точечный тёплый акцент (бейджи/маркеры) */
  --amber-soft:#FFF6E9;
  --ok:#15803D;
  --ok-soft:#EAF6EF;
  --err:#B42318;
  --err-soft:#FEF2F2;
  --err-line:#F2C4C0;

  /* Типошкала (fluid) */
  --fs-xs:.8125rem;
  --fs-s:.9375rem;
  --fs-base:1.0625rem;
  --fs-l:clamp(1.125rem, 1.02rem + .45vw, 1.3125rem);
  --fs-h3:clamp(1.1875rem, 1.08rem + .5vw, 1.4375rem);
  --fs-h2:clamp(1.625rem, 1.32rem + 1.45vw, 2.375rem);
  --fs-h1:clamp(2.125rem, 1.55rem + 2.9vw, 3.625rem);

  /* Spacing scale */
  --s1:.25rem; --s2:.5rem; --s3:.75rem; --s4:1rem;
  --s5:1.5rem; --s6:2rem;  --s7:3rem;  --s8:4.5rem; --s9:6.5rem;

  /* Форма */
  --r-s:10px; --r-m:14px; --r-l:20px; --r-pill:999px;
  --shadow-s:0 1px 2px rgba(11,18,32,.06);
  --shadow-m:0 1px 2px rgba(11,18,32,.05), 0 12px 32px -14px rgba(11,18,32,.14);
  --shadow-l:0 2px 4px rgba(11,18,32,.06), 0 28px 64px -28px rgba(11,18,32,.28);
  --maxw:1080px;

  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",
         Arial,"Noto Sans",sans-serif;
  --mono:ui-monospace,"SF Mono",Menlo,Consolas,monospace;
}

/* ---------- 2. База ---------- */
*{box-sizing:border-box}
html{scroll-behavior:smooth; -webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){ html{scroll-behavior:auto} }
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:var(--sans); font-size:var(--fs-base); line-height:1.65;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
img,svg{display:block; max-inline-size:100%}
a{color:var(--primary); text-decoration:none}
a:hover{text-decoration:underline; text-underline-offset:3px}
:focus-visible{outline:3px solid var(--primary); outline-offset:2px; border-radius:4px}
.wrap{max-inline-size:var(--maxw); margin-inline:auto; padding-inline:clamp(1.125rem,4vw,2rem)}

h1,h2,h3,h4{line-height:1.15; letter-spacing:-.022em; margin:0}

/* Scroll-reveal: активен ТОЛЬКО при html.js (JS+IntersectionObserver) и
   только без prefers-reduced-motion. Без JS контент виден сразу. */
@media (prefers-reduced-motion:no-preference){
  html.js .reveal{opacity:0; transform:translateY(16px);
    transition:opacity .6s cubic-bezier(.2,.7,.3,1), transform .6s cubic-bezier(.2,.7,.3,1)}
  html.js .reveal.is-in{opacity:1; transform:none}
}

/* ---------- 3. Кнопки / бейджи ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  padding:.875rem 1.5rem; border-radius:var(--r-s);
  font-weight:700; font-size:1rem; line-height:1.2;
  border:1px solid transparent; cursor:pointer;
  transition:background .18s ease, border-color .18s ease,
             transform .18s ease, box-shadow .18s ease;
}
.btn--primary{background:var(--primary); color:#fff; box-shadow:var(--shadow-s)}
.btn--primary:hover{background:var(--primary-hover); text-decoration:none;
  transform:translateY(-1px); box-shadow:var(--shadow-m)}
.btn--ghost{background:transparent; color:var(--ink); border-color:var(--line)}
.btn--ghost:hover{border-color:var(--primary); color:var(--primary); text-decoration:none}
/* на тёмном фоне */
.btn--light{background:#fff; color:var(--ink)}
.btn--light:hover{background:var(--bg-soft); text-decoration:none; transform:translateY(-1px)}
.btn--outline-dark{background:transparent; color:var(--on-dark); border-color:var(--line-dark)}
.btn--outline-dark:hover{border-color:var(--on-dark); text-decoration:none}
@media (prefers-reduced-motion:reduce){ .btn{transition:none} .btn:hover{transform:none} }

.pill{
  display:inline-flex; align-items:center; gap:.45rem;
  padding:.42rem .85rem; border-radius:var(--r-pill);
  font-size:var(--fs-xs); font-weight:600;
}
.pill svg{inline-size:14px; block-size:14px; flex:none}

.kicker{
  display:inline-block; font-size:var(--fs-xs); font-weight:800;
  letter-spacing:.13em; text-transform:uppercase; color:var(--primary);
  margin-block-end:var(--s3);
}

/* ---------- 4. Шапка ---------- */
.top{
  position:sticky; inset-block-start:0; z-index:20;
  background:rgba(255,255,255,.88); backdrop-filter:blur(10px) saturate(150%);
  border-block-end:1px solid var(--line);
}
.top .wrap{display:flex; align-items:center; justify-content:space-between;
  gap:var(--s4); block-size:64px}
.brand{display:inline-flex; align-items:center; gap:.625rem;
  font-weight:800; font-size:1.125rem; letter-spacing:-.01em; color:var(--ink)}
.brand:hover{text-decoration:none}
.logo{
  inline-size:32px; block-size:32px; border-radius:9px; flex:none;
  background:linear-gradient(135deg,var(--primary) 0%,#3B6FE8 100%);
  display:inline-flex; align-items:center; justify-content:center; color:#fff;
}
.logo svg{inline-size:18px; block-size:18px}
.nav{display:flex; align-items:center; gap:1.4rem; font-size:var(--fs-s); font-weight:600}
.nav a:not(.btn){color:var(--muted)}
.nav a:not(.btn):hover{color:var(--ink); text-decoration:none}
.nav a.btn--primary{color:#fff}
.nav a.btn--primary:hover{text-decoration:none}
.nav .btn{padding:.55rem 1.05rem; font-size:var(--fs-s)}
@media (max-width:760px){ .nav a:not(.btn){display:none} }

/* тёмная шапка поверх тёмного hero */
.top--dark{background:rgba(11,18,32,.78); border-color:var(--line-dark)}
.top--dark .brand{color:var(--on-dark)}
.top--dark .nav a:not(.btn){color:var(--on-dark-muted)}
.top--dark .nav a:not(.btn):hover{color:var(--on-dark)}

/* ---------- 5. Hero (тёмный) ---------- */
.hero{
  background:
    radial-gradient(110% 90% at 85% -20%, rgba(59,111,232,.32) 0%, rgba(59,111,232,0) 55%),
    radial-gradient(80% 70% at -10% 110%, rgba(29,78,216,.22) 0%, rgba(29,78,216,0) 50%),
    var(--ink);
  color:var(--on-dark);
  padding-block:clamp(3.5rem,8vw,6rem) clamp(3rem,7vw,5rem);
}
.hero .wrap{display:grid; gap:clamp(2rem,5vw,4rem); align-items:center;
  grid-template-columns:1fr}
@media (min-width:920px){ .hero .wrap{grid-template-columns:1.08fr .92fr} }
.hero h1{font-size:var(--fs-h1); font-weight:800; color:#fff;
  text-wrap:balance; margin-block-end:var(--s5)}
.hero .lead{font-size:var(--fs-l); color:var(--on-dark-muted);
  max-inline-size:34rem; margin:0 0 var(--s6)}
.hero .lead b{color:var(--on-dark); font-weight:600}
.hero .cta{display:flex; flex-wrap:wrap; gap:var(--s3); margin-block-end:var(--s6)}
.hero .kicker{color:#9DB6F5}

.trust{display:flex; flex-wrap:wrap; gap:var(--s2)}
.trust .pill{background:rgba(255,255,255,.07); color:var(--on-dark-muted);
  border:1px solid var(--line-dark)}
.trust .pill svg{color:#86B0F8}

/* Чат-мокап продукта (CSS-визуал вместо стоковых картинок) */
.chatcard{
  background:#0F1A2E; border:1px solid var(--line-dark); border-radius:var(--r-l);
  box-shadow:var(--shadow-l); padding:var(--s5); display:grid; gap:var(--s4);
}
.chatcard__head{display:flex; align-items:center; gap:.7rem;
  padding-block-end:var(--s4); border-block-end:1px solid var(--line-dark)}
.chatcard__dot{inline-size:9px; block-size:9px; border-radius:50%; background:#34D399; flex:none}
.chatcard__title{font-size:var(--fs-s); font-weight:700; color:var(--on-dark)}
.chatcard__sub{font-size:var(--fs-xs); color:var(--on-dark-muted)}
.msg{max-inline-size:88%; padding:.7rem .95rem; border-radius:14px;
  font-size:var(--fs-s); line-height:1.5}
.msg--in{background:rgba(255,255,255,.08); color:var(--on-dark);
  border-start-start-radius:4px; justify-self:start}
.msg--out{background:var(--primary); color:#fff;
  border-start-end-radius:4px; justify-self:end}
.msg__meta{display:block; margin-block-start:.35rem; font-size:.71rem; opacity:.72}
.msg--note{justify-self:center; background:transparent; color:var(--on-dark-muted);
  font-size:var(--fs-xs); padding:.1rem 0}
.msg__btn{display:block; inline-size:max-content; margin-block-start:.6rem;
  padding:.42rem .8rem; background:#fff; color:var(--primary); font-weight:700;
  font-size:var(--fs-xs); border-radius:8px}

/* ---------- 6. Секции ---------- */
.section{padding-block:clamp(3rem,7vw,5.5rem)}
.section--soft{background:var(--bg-soft)}
.section__head{max-inline-size:44rem; margin-block-end:clamp(2rem,4.5vw,3.25rem)}
.section__head h2{font-size:var(--fs-h2); font-weight:800; margin-block-end:var(--s3);
  text-wrap:balance}
.section__head p{color:var(--muted); font-size:var(--fs-l); margin:0}

/* Возможности */
.features{display:grid; gap:var(--s4);
  grid-template-columns:repeat(auto-fit,minmax(17rem,1fr))}
.feature{
  background:var(--bg); border:1px solid var(--line); border-radius:var(--r-m);
  padding:var(--s5); transition:transform .18s ease, box-shadow .18s ease,
  border-color .18s ease;
}
.feature:hover{transform:translateY(-3px); box-shadow:var(--shadow-m);
  border-color:#CBD7F3}
@media (prefers-reduced-motion:reduce){ .feature{transition:none}
  .feature:hover{transform:none} }
.feature__ic{
  inline-size:42px; block-size:42px; border-radius:11px;
  background:var(--primary-soft); color:var(--primary);
  display:flex; align-items:center; justify-content:center;
  margin-block-end:var(--s4);
}
.feature__ic svg{inline-size:22px; block-size:22px}
.feature h3{font-size:var(--fs-h3); font-weight:700; margin-block-end:var(--s2)}
.feature p{margin:0; color:var(--muted); font-size:var(--fs-s)}

/* Кейс */
.case{display:grid; gap:clamp(1.5rem,4vw,3rem); align-items:start}
@media (min-width:880px){ .case{grid-template-columns:.95fr 1.05fr} }
.case__badge{display:inline-flex; align-items:center; gap:.5rem;
  background:var(--amber-soft); color:var(--amber); font-weight:700;
  font-size:var(--fs-xs); padding:.45rem .9rem; border-radius:var(--r-pill);
  margin-block-end:var(--s4)}
.case h2{font-size:var(--fs-h2); font-weight:800; margin-block-end:var(--s4);
  text-wrap:balance}
.case .about{color:var(--muted); margin:0 0 var(--s4)}
.case-list{list-style:none; margin:0; padding:0; display:grid; gap:var(--s3)}
.case-list li{
  background:var(--bg); border:1px solid var(--line); border-radius:var(--r-m);
  padding:var(--s4) var(--s5); display:flex; gap:.8rem; align-items:flex-start;
}
.case-list svg{inline-size:20px; block-size:20px; flex:none; color:var(--ok);
  margin-block-start:.18rem}
.case-list b{display:block}
.case-list span{color:var(--muted); font-size:var(--fs-s)}

/* Шаги */
.steps{counter-reset:step; display:grid; gap:var(--s4);
  grid-template-columns:repeat(auto-fit,minmax(13.5rem,1fr))}
.step{
  position:relative; background:var(--bg); border:1px solid var(--line);
  border-radius:var(--r-m); padding:var(--s5);
}
.step::before{
  counter-increment:step; content:counter(step);
  display:inline-flex; align-items:center; justify-content:center;
  inline-size:34px; block-size:34px; border-radius:50%;
  background:var(--ink); color:#fff; font-weight:800; font-size:var(--fs-s);
  margin-block-end:var(--s3);
}
.step h3{font-size:1.0625rem; font-weight:700; margin-block-end:var(--s2)}
.step p{margin:0; color:var(--muted); font-size:var(--fs-s)}

/* ---------- 7. Тарифы ---------- */
.plans{display:grid; gap:var(--s4); align-items:stretch;
  grid-template-columns:repeat(auto-fit,minmax(16.5rem,1fr))}
.plan{
  background:var(--bg); border:1px solid var(--line); border-radius:var(--r-l);
  padding:var(--s6) var(--s5); display:flex; flex-direction:column;
  box-shadow:var(--shadow-s);
  transition:transform .18s ease, box-shadow .18s ease;
}
.plan:hover{transform:translateY(-3px); box-shadow:var(--shadow-m)}
@media (prefers-reduced-motion:reduce){ .plan{transition:none}
  .plan:hover{transform:none} }
.plan--featured{border:2px solid var(--primary);
  box-shadow:0 0 0 4px var(--primary-soft), var(--shadow-m)}
.plan .badge{align-self:flex-start; font-size:var(--fs-xs); font-weight:800;
  color:var(--primary); background:var(--primary-soft);
  padding:.3rem .8rem; border-radius:var(--r-pill); margin-block-end:var(--s3)}
.plan h3{font-size:var(--fs-h3); font-weight:800}
.plan .price{font-size:clamp(1.9rem,3.5vw,2.375rem); font-weight:800;
  letter-spacing:-.03em; margin-block:var(--s2) var(--s1)}
.plan .price small{font-size:var(--fs-s); font-weight:600; color:var(--muted);
  letter-spacing:0}
.plan ul{list-style:none; padding:0; margin:var(--s4) 0 0;
  color:var(--muted); font-size:var(--fs-s)}
.plan li{padding:.42rem 0 .42rem 1.7rem; position:relative}
.plan li::before{
  content:""; position:absolute; inset-inline-start:0; inset-block-start:.72rem;
  inline-size:1rem; block-size:.55rem;
  border-inline-start:2.5px solid var(--ok); border-block-end:2.5px solid var(--ok);
  transform:rotate(-50deg); border-radius:1px;
}
.plan__pay{margin-block-start:auto; padding-block-start:var(--s5)}
.plan__pay .btn{inline-size:100%}
.plans-note{margin-block-start:var(--s5); text-align:center;
  color:var(--faint); font-size:var(--fs-s)}

/* ---------- 8. FAQ ---------- */
.faq{max-inline-size:46rem; margin-inline:auto; display:grid; gap:var(--s3)}
.faq details{
  background:var(--bg); border:1px solid var(--line); border-radius:var(--r-m);
  padding:0; overflow:hidden;
}
.faq details[open]{border-color:#CBD7F3; box-shadow:var(--shadow-s)}
.faq summary{
  cursor:pointer; list-style:none; display:flex; align-items:center;
  justify-content:space-between; gap:var(--s4);
  padding:var(--s4) var(--s5); font-weight:700; font-size:1.0625rem;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:""; inline-size:.65rem; block-size:.65rem; flex:none;
  border-inline-end:2.5px solid var(--faint); border-block-end:2.5px solid var(--faint);
  transform:rotate(45deg) translateY(-2px); transition:transform .2s ease;
}
.faq details[open] summary::after{transform:rotate(225deg) translateY(-2px)}
@media (prefers-reduced-motion:reduce){ .faq summary::after{transition:none} }
.faq .a{padding:0 var(--s5) var(--s5); color:var(--muted); font-size:var(--fs-s)}
.faq .a p{margin:0 0 .6rem}
.faq .a p:last-child{margin:0}

/* ---------- 9. Финальный CTA ---------- */
.cta-final{
  background:
    radial-gradient(100% 120% at 80% -30%, rgba(59,111,232,.35) 0%, rgba(59,111,232,0) 55%),
    var(--ink);
  color:var(--on-dark); border-radius:var(--r-l);
  padding:clamp(2.5rem,6vw,4rem); text-align:center;
  box-shadow:var(--shadow-l);
}
.cta-final h2{font-size:var(--fs-h2); font-weight:800; color:#fff;
  margin-block-end:var(--s3); text-wrap:balance}
.cta-final p{color:var(--on-dark-muted); max-inline-size:36rem;
  margin:0 auto var(--s6); font-size:var(--fs-l)}
.cta-final .cta{display:flex; flex-wrap:wrap; gap:var(--s3); justify-content:center}

/* ---------- 10. Футер ---------- */
.foot{background:var(--ink); color:var(--on-dark-muted);
  padding-block:var(--s7) var(--s6); font-size:var(--fs-s); margin-block-start:var(--s8)}
.foot a{color:var(--on-dark)}
.foot .cols{display:flex; flex-wrap:wrap; gap:var(--s6); justify-content:space-between}
.foot h5{color:#fff; margin:0 0 var(--s3); font-size:1rem}
.foot .req{max-inline-size:34rem; line-height:1.75}
.foot .links{display:flex; flex-direction:column; gap:.45rem}
.foot .copy{border-block-start:1px solid var(--line-dark); margin-block-start:var(--s6);
  padding-block-start:var(--s4); color:var(--on-dark-muted); font-size:var(--fs-xs)}
/* страницы без отступа перед футером (оплата/юр) */
.foot--tight{margin-block-start:var(--s7)}

/* ---------- 11. Юридические страницы ---------- */
.legal{padding-block:clamp(2.5rem,6vw,4rem) var(--s6)}
.legal .doc{max-inline-size:50rem; margin-inline:auto}
.legal h1{font-size:clamp(1.75rem,3.6vw,2.5rem); font-weight:800;
  margin-block-end:var(--s2)}
.legal .lead{color:var(--muted); margin:0 0 var(--s2); font-size:var(--fs-l)}
.legal .updated{color:var(--faint); font-size:var(--fs-s); margin:0 0 var(--s6)}
.legal h2{font-size:1.375rem; font-weight:800; margin:var(--s7) 0 var(--s3);
  padding-block-start:var(--s5); border-block-start:1px solid var(--line)}
.legal h3{font-size:1.125rem; margin:var(--s5) 0 var(--s2)}
.legal p,.legal li{color:var(--ink-2)}
.legal ul{padding-inline-start:1.35rem}
.legal li{margin-block:.4rem}
.legal table{border-collapse:collapse; inline-size:100%; margin-block:var(--s4);
  font-size:var(--fs-s)}
.legal th,.legal td{border:1px solid var(--line); padding:.65rem .85rem;
  text-align:start; vertical-align:top}
.legal th{background:var(--bg-soft); inline-size:38%; font-weight:700}
.legal code{font-family:var(--mono); font-size:.9em; background:var(--bg-soft);
  padding:.1em .4em; border-radius:6px}
.legal .back{display:inline-block; margin-block-end:var(--s5);
  color:var(--muted); font-size:var(--fs-s)}
.legal .back:hover{color:var(--primary)}

/* ---------- 12. Страница оплаты ---------- */
.pay{max-inline-size:36rem; margin-inline:auto}
.pay h1{font-size:clamp(1.75rem,3.6vw,2.375rem); font-weight:800;
  margin-block-end:var(--s2)}
.pay .lead{color:var(--muted); margin:0 0 var(--s6)}
.pay-err{background:var(--err-soft); border:1px solid var(--err-line);
  color:var(--err); border-radius:var(--r-s); padding:.85rem 1.05rem;
  margin:0 0 var(--s4); font-size:var(--fs-s); font-weight:600}
.pay-form{background:var(--bg-soft); border:1px solid var(--line);
  border-radius:var(--r-l); padding:var(--s6) var(--s5)}
.pay-form .group{margin-block-end:var(--s5)}
.pay-form label.lbl{display:block; font-weight:700; margin-block-end:var(--s3)}
.pay-opt{
  display:flex; align-items:center; gap:.85rem;
  border:1px solid var(--line); background:var(--bg); border-radius:var(--r-s);
  padding:.95rem 1.05rem; margin-block-end:var(--s2); cursor:pointer;
  transition:border-color .15s ease, box-shadow .15s ease;
}
.pay-opt:hover{border-color:var(--primary)}
.pay-opt:has(input:checked){border-color:var(--primary);
  box-shadow:0 0 0 3px var(--primary-soft)}
.pay-opt input{accent-color:var(--primary); inline-size:18px; block-size:18px; flex:none}
.pay-opt .nm{font-weight:700}
.pay-opt .qt{display:block; color:var(--muted); font-size:var(--fs-xs); font-weight:400}
.pay-opt .pr{margin-inline-start:auto; font-weight:800; font-size:1.125rem;
  white-space:nowrap}
.pay-opt .pr small{font-size:.75rem; font-weight:600; color:var(--muted)}
.pay-form input[type=email]{
  inline-size:100%; padding:.85rem .95rem; border:1px solid var(--line);
  border-radius:var(--r-s); font-size:1rem; font-family:inherit; background:var(--bg);
}
.pay-form input[type=email]:focus{outline:none; border-color:var(--primary);
  box-shadow:0 0 0 3px var(--primary-soft)}
.pay-form .agree{display:flex; gap:.7rem; align-items:flex-start;
  font-size:var(--fs-xs); color:var(--muted)}
.pay-form .agree + .agree{margin-block-start:var(--s3)}
.pay-form .agree input{margin-block-start:3px; accent-color:var(--primary); flex:none}
.pay-form .btn-pay{
  inline-size:100%; padding:1rem; font-size:1.0625rem; font-weight:800;
  color:#fff; background:var(--primary); border:none; border-radius:var(--r-s);
  cursor:pointer; margin-block-start:var(--s2); font-family:inherit;
  transition:background .18s ease, transform .18s ease, box-shadow .18s ease;
}
.pay-form .btn-pay:hover{background:var(--primary-hover); transform:translateY(-1px);
  box-shadow:var(--shadow-m)}
@media (prefers-reduced-motion:reduce){ .pay-form .btn-pay{transition:none}
  .pay-form .btn-pay:hover{transform:none} }
.pay-form .secure{display:flex; align-items:center; justify-content:center; gap:.45rem;
  text-align:center; color:var(--faint); font-size:var(--fs-xs);
  margin:var(--s4) 0 0}
.pay-form .secure svg{inline-size:14px; block-size:14px; flex:none}

.pay-overlay{display:none; position:fixed; inset:0; background:rgba(11,18,32,.6);
  z-index:50; align-items:center; justify-content:center; padding:var(--s4)}
.pay-overlay.on{display:flex}
.pay-overlay .box{background:#fff; border-radius:var(--r-l);
  padding:var(--s7) var(--s6); text-align:center; max-inline-size:380px;
  box-shadow:var(--shadow-l)}
.pay-overlay .spin{inline-size:42px; block-size:42px; border:4px solid var(--line);
  border-block-start-color:var(--primary); border-radius:50%;
  margin:0 auto var(--s4); animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
@media (prefers-reduced-motion:reduce){ .pay-overlay .spin{animation:none} }
.pay-overlay h3{margin:0 0 var(--s2); font-size:1.1875rem}
.pay-overlay p{margin:0; color:var(--muted); font-size:var(--fs-s)}

/* ---------- 13. Страница результата оплаты ---------- */
.pay-result{max-inline-size:36rem; margin-inline:auto; text-align:center}
.pay-result .ic{inline-size:64px; block-size:64px; border-radius:50%;
  background:var(--ok-soft); color:var(--ok); display:inline-flex;
  align-items:center; justify-content:center; margin-block-end:var(--s4)}
.pay-result .ic svg{inline-size:30px; block-size:30px}
.pay-result h1{font-size:clamp(1.625rem,3.4vw,2.25rem); font-weight:800;
  margin-block-end:var(--s3)}
.pay-result p{color:var(--muted); margin:0 auto var(--s3); max-inline-size:29rem}
.pay-result .actions{margin-block-start:var(--s6); display:flex; gap:var(--s3);
  justify-content:center; flex-wrap:wrap}

/* ---------- 14. Печать (юр-доки для юриста) ---------- */
@media print{
  .top,.foot,.back{display:none !important}
  body{background:#fff; font-size:11pt}
  .legal{padding:0}
  a{color:#000}
}
