/* ============================================================
   funnel.css — стили React-воронки ЖКХ.
   Сейчас: состояния загрузки/ошибки (funnel-loader.js).
   Экраны воронки (чат/согласия/проверка/превью/заглушка) — добавляются
   на подшаге вёрстки воронки. Опирается на tokens.css.
   ============================================================ */

/* --- Состояние загрузки --- */
.funnel-loading{
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:var(--sp-3);
  min-height:50svh; min-height:50dvh;
  color:var(--c-text-muted);
  text-align:center;
}
.funnel-loading__spinner{
  width:32px; height:32px;
  border:3px solid var(--c-border);
  border-top-color:var(--c-blue);
  border-radius:50%;
  animation:funnel-spin .8s linear infinite;
}
@keyframes funnel-spin{ to{ transform:rotate(360deg); } }
@media (prefers-reduced-motion:reduce){
  .funnel-loading__spinner{ animation:none; }   /* пользователь просил меньше движения — убираем вращение, текст «Загружаем…» сохраняет смысл */
}

/* --- Состояние ошибки загрузки --- */
.funnel-error{
  max-width:480px; margin:var(--sp-7) auto;
  padding:var(--sp-5);
  background:var(--c-bg-soft);
  border:1px solid var(--c-border-control);
  border-radius:var(--r-lg);
  text-align:center;
}
.funnel-error p{ margin-bottom:var(--sp-4); color:var(--c-text); }
.funnel-error .btn--cta{ max-width:280px; }

/* --- Каркас воронки (блок 2.1): контейнер и заглушки экранов --- */
.funnel{
  max-width:var(--container);
  margin-inline:auto;
  padding:var(--sp-5) var(--gutter);
  min-height:60svh; min-height:60dvh;
}
.funnel__placeholder{
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:var(--sp-4);
  min-height:50svh; min-height:50dvh;
  text-align:center;
}
.funnel__ph-title{ color:var(--c-blue); margin:0; }
.funnel__ph-note{ color:var(--c-text-muted); margin:0; }
.funnel__placeholder .btn--cta{ max-width:360px; }

/* ============================================================
   ЧАТ (блок 2.2)
   ============================================================ */
.chat{ display:flex; flex-direction:column; min-height:70svh; min-height:70dvh; }

/* Прогресс */
.chat__header{ position:sticky; top:0; background:var(--c-bg); padding-bottom:var(--sp-3); z-index:2; }
.chat__progress{ font-size:var(--fs-small); color:var(--c-text-muted); margin-bottom:var(--sp-2); font-weight:600; }
.chat__progress-bar{ height:4px; background:var(--c-border); border-radius:2px; overflow:hidden; }
.chat__progress-fill{ height:100%; background:var(--c-blue); transition:width var(--t-mid); }

/* Лента */
.chat__feed{ flex:1; display:flex; flex-direction:column; gap:var(--sp-3); padding-block:var(--sp-4); }
.chat__row{ display:flex; }
.chat__row--bot{ justify-content:flex-start; }
.chat__row--user{ justify-content:flex-end; }
.chat__bubble{
  max-width:80%; padding:var(--sp-3) var(--sp-4); border-radius:var(--r-lg);
  font-size:var(--fs-body); line-height:1.45; white-space:pre-line;
}
.chat__bubble--bot{ background:var(--c-blue); color:#fff; border-bottom-left-radius:4px; }
.chat__bubble--user{ background:var(--c-bg-soft); color:var(--c-text); border-bottom-right-radius:4px; }
.chat__bubble--ai{ background:#16306a; }

/* Индикатор «печатает» */
.chat__typing{ display:inline-flex; gap:4px; align-items:center; }
.chat__typing span{ width:7px; height:7px; border-radius:50%; background:rgba(255,255,255,.7); animation:chat-typing 1.2s infinite; }
.chat__typing span:nth-child(2){ animation-delay:.2s; }
.chat__typing span:nth-child(3){ animation-delay:.4s; }
@keyframes chat-typing{ 0%,60%,100%{ opacity:.3; transform:translateY(0);} 30%{ opacity:1; transform:translateY(-3px);} }
@media (prefers-reduced-motion:reduce){ .chat__typing span{ animation:none; } }

/* Skeleton документа */
.chat__skeleton{
  align-self:flex-start; max-width:90%;
  background:var(--c-bg); border:1px solid var(--c-blue-link);
  border-radius:var(--r-lg); padding:var(--sp-4);
}
.chat__skeleton-title{ font-weight:600; color:var(--c-blue); margin:0 0 var(--sp-2); }
.chat__skeleton-list{ margin:0; padding-left:var(--sp-4); color:var(--c-text-muted); display:grid; gap:var(--sp-1); }

/* Дисклеймер перед описанием */
.chat__disclaimer{
  font-size:13px; color:var(--c-text-muted);
  background:var(--c-bg-soft); border-radius:var(--r-md);
  padding:var(--sp-3); margin:0 0 var(--sp-3);
}

/* Зона ввода */
.chat__inputzone{ position:sticky; bottom:0; background:var(--c-bg); padding-top:var(--sp-3);
  padding-bottom:max(var(--sp-3), env(safe-area-inset-bottom)); }

/* Chips */
.chat__chips{ display:flex; flex-wrap:wrap; gap:var(--sp-2); }
.chat__chip{
  min-height:var(--h-control); padding:var(--sp-2) var(--sp-4);
  border:1px solid var(--c-blue-link); background:var(--c-bg); color:var(--c-blue);
  border-radius:24px; font-size:var(--fs-small); cursor:pointer; font-family:inherit;
  transition:background var(--t-fast);
}
@media (hover:hover){ .chat__chip:hover{ background:var(--c-bg-soft); } }
.chat__chip:active{ background:#E8EEF8; }

/* Поле ввода + кнопка отправки */
.chat__free{ display:flex; gap:var(--sp-2); width:100%; }
.chat__input{
  flex:1; min-height:var(--h-control); padding:0 var(--sp-4);
  border:1px solid var(--c-border-control); border-radius:var(--r-md);
  font-size:var(--fs-body); background:var(--c-bg); color:var(--c-text);
}
.chat__send{
  width:var(--h-control); height:var(--h-control); flex:none;
  border:0; border-radius:var(--r-md); background:var(--c-cta); color:var(--c-on-cta);
  font-size:20px; cursor:pointer;
}
.chat__send:disabled{ opacity:.5; cursor:not-allowed; }

/* Textarea (описание) */
.chat__textarea-wrap{ display:flex; flex-direction:column; gap:var(--sp-3); }
.chat__textarea{
  width:100%; padding:var(--sp-3) var(--sp-4); resize:vertical;
  border:1px solid var(--c-border-control); border-radius:var(--r-md);
  font-size:var(--fs-body); font-family:inherit; background:var(--c-bg); color:var(--c-text); line-height:1.5;
}
.chat__textarea-send{ align-self:stretch; }

/* ============================================================
   СОГЛАСИЯ (блок 2.3)
   ============================================================ */
.consent{ max-width:560px; margin-inline:auto; padding-block:var(--sp-4); }
.consent__title{ color:var(--c-blue); margin:0 0 var(--sp-3); }
.consent__lead{ color:var(--c-text-muted); margin:0 0 var(--sp-5); font-size:var(--fs-small); }

.consent__list{ display:grid; gap:var(--sp-3); margin-bottom:var(--sp-6); }
.consent__item{
  display:flex; gap:var(--sp-3); align-items:flex-start; cursor:pointer;
  padding:var(--sp-3); border:1px solid var(--c-border); border-radius:var(--r-md);
}
.consent__cb{
  width:22px; height:22px; flex:none; margin-top:2px; cursor:pointer;
  accent-color:var(--c-blue);
}
.consent__text{ font-size:var(--fs-small); line-height:1.45; color:var(--c-text); }
.consent__text a{ color:var(--c-blue-link); }
.consent__req{ color:var(--c-danger); font-weight:700; }

.consent__pep{
  background:var(--c-bg-soft); border-radius:var(--r-lg);
  padding:var(--sp-4); margin-bottom:var(--sp-5);
}
.consent__pep-title{ margin:0 0 var(--sp-3); color:var(--c-blue); font-size:var(--fs-h3); }
.consent__phone-hint{ font-size:13px; color:var(--c-text-muted); margin:0 0 var(--sp-3); }
.consent__phone-row{ display:flex; gap:var(--sp-2); }
.consent__phone-row .chat__input{ flex:1; }
.consent__phone--ok{ display:flex; align-items:center; }
.consent__phone-ok{ color:var(--c-success-text); font-weight:600; }

.consent__err{ color:var(--c-danger); font-size:var(--fs-small); margin:0 0 var(--sp-3); }
.consent__submit{ margin-top:var(--sp-2); }
.consent__hint{ font-size:13px; color:var(--c-text-muted); text-align:center; margin-top:var(--sp-3); }

/* ============================================================
   ПРОВЕРКА ДАННЫХ (блок 2.4) — material-style поля
   ============================================================ */
.review{ max-width:560px; margin-inline:auto; padding-block:var(--sp-4); }
.review__title{ color:var(--c-blue); margin:0 0 var(--sp-2); }
.review__lead{ color:var(--c-text-muted); font-size:var(--fs-small); margin:0 0 var(--sp-5); }

.review__card{
  background:var(--c-bg); border:1px solid var(--c-border);
  border-radius:var(--r-lg); padding:var(--sp-5);
  display:grid; gap:var(--sp-5); margin-bottom:var(--sp-5);
}
.review__field{ display:flex; flex-direction:column; gap:var(--sp-1); }
.review__label{ font-size:13px; font-weight:600; color:var(--c-text-muted); }
.review__field-note{ font-size:12px; color:var(--c-text-muted); margin:0 0 var(--sp-1); }

/* material-инпут: только нижняя линия */
.review__input{
  border:0; border-bottom:1px solid var(--c-border-control);
  padding:var(--sp-2) 0; font-size:var(--fs-body); background:transparent; color:var(--c-text);
  border-radius:0;
}
.review__input:focus-visible{ outline:3px solid var(--c-focus); outline-offset:2px; border-bottom-color:var(--c-blue); }
.review__textarea:focus-visible{ outline:3px solid var(--c-focus); outline-offset:2px; border-color:var(--c-blue); }
.review__field-err{ color:var(--c-danger); font-size:13px; margin:var(--sp-1) 0 0; }

/* textarea — в рамке */
.review__textarea{
  border:1px solid var(--c-border-control); border-radius:var(--r-md);
  padding:var(--sp-3); font-size:var(--fs-body); font-family:inherit;
  background:var(--c-bg); color:var(--c-text); line-height:1.5; resize:vertical;
}
.review__submit{ margin-top:var(--sp-2); }

/* ============================================================
   ПРЕВЬЮ + PAYWALL (блок 2.5)
   ============================================================ */
.preview{ max-width:600px; margin-inline:auto; padding-block:var(--sp-4); }
.preview__title{ color:var(--c-blue); margin:0 0 var(--sp-2); }
.preview__lead{ color:var(--c-text-muted); font-size:var(--fs-small); margin:0 0 var(--sp-5); }

/* Лист A4 */
.preview__sheet{
  aspect-ratio:210/297; min-height:760px;
  background:#fff; border:1px solid var(--c-border); border-radius:var(--r-md);
  box-shadow:0 4px 24px rgba(16,35,63,.10);
  padding:var(--sp-6) var(--sp-5); position:relative; overflow:hidden;
  font-family:var(--font-doc);
}
/* Открытая часть документа */
.doc__head{ margin-bottom:var(--sp-4); }
.doc__to{ font-weight:700; color:var(--c-text); margin:0 0 var(--sp-2); }
.doc__from{ font-size:var(--fs-small); color:var(--c-text); margin:0; }
.doc__title{ text-align:center; color:var(--c-blue); font-size:26px; letter-spacing:1px; margin:var(--sp-5) 0 var(--sp-1); font-family:var(--font-ui); }
.doc__subtitle{ text-align:center; color:var(--c-text-muted); font-size:var(--fs-small); margin:0 0 var(--sp-4); }
.doc__preamble{ color:var(--c-text); line-height:1.6; margin:0; }

/* Blur-зона (ядро) */
.preview__blurwrap{ position:relative; margin-top:var(--sp-4); }
.preview__blur{
  filter:blur(4.5px); opacity:.55; user-select:none; pointer-events:none;
  color:var(--c-text); line-height:1.6;
  -webkit-mask-image:linear-gradient(to bottom, rgba(0,0,0,.9), rgba(0,0,0,.5));
          mask-image:linear-gradient(to bottom, rgba(0,0,0,.9), rgba(0,0,0,.5));
}
.preview__blur p{ margin:0 0 var(--sp-3); }
.preview__watermark{
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  transform:rotate(-24deg); font-family:var(--font-ui); font-size:28px; font-weight:700;
  color:rgba(26,61,124,.10); pointer-events:none; letter-spacing:2px;
}
.preview__lock{
  position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);
  display:flex; align-items:center; gap:var(--sp-2);
  background:var(--c-bg); border:1px solid var(--c-border-control);
  padding:var(--sp-2) var(--sp-4); border-radius:24px;
  font-family:var(--font-ui); font-size:var(--fs-small); font-weight:600; color:var(--c-blue);
  box-shadow:0 2px 12px rgba(16,35,63,.12);
}

.preview__edit{
  display:block; margin:var(--sp-4) auto; background:none; border:0;
  color:var(--c-blue-link); font-size:var(--fs-small); cursor:pointer; text-decoration:underline;
  font-family:inherit;
}

/* Paywall */
.paywall{
  background:var(--c-bg-soft); border-radius:var(--r-lg);
  padding:var(--sp-5); display:flex; flex-direction:column; gap:var(--sp-3); text-align:center;
}
.paywall__pay{ width:100%; }
.paywall__sbp{
  width:100%; height:var(--h-cta); background:var(--c-bg);
  border:1px solid var(--c-blue-link); color:var(--c-blue); font-size:18px;
}
@media (hover:hover){ .paywall__sbp:hover{ background:#fff; } }
.paywall__terms{ font-size:13px; color:var(--c-text-muted); margin:var(--sp-2) 0 0; }
.paywall__refund{ font-size:13px; color:var(--c-text); margin:0; }
.paywall__logos{ display:flex; gap:var(--sp-2); justify-content:center; flex-wrap:wrap; margin-top:var(--sp-2); }
.paywall__anchor{ font-size:13px; color:var(--c-text-muted); margin:0; }

/* ============================================================
   ЗАГЛУШКА ОПЛАТЫ (блок 2.5)
   ============================================================ */
.unavail{ max-width:480px; margin-inline:auto; padding:var(--sp-7) var(--gutter); text-align:center;
  display:flex; flex-direction:column; align-items:center; gap:var(--sp-4); }
.unavail__icon{ width:72px; height:72px; color:var(--c-blue); }
.unavail__icon svg{ width:100%; height:100%; }
.unavail__title{ color:var(--c-blue); margin:0; }
.unavail__text{ color:var(--c-text-muted); margin:0; line-height:1.55; }
.unavail__saved{
  display:flex; align-items:center; gap:var(--sp-2); justify-content:center;
  background:var(--c-bg-soft); border-radius:var(--r-md); padding:var(--sp-3) var(--sp-4); width:100%;
}
.unavail__saved-icon{ color:var(--c-success-text); font-weight:700; font-size:18px; }
.unavail__btn{ width:100%; max-width:320px; }
.unavail__home{ background:none; border:0; color:var(--c-blue-link); cursor:pointer;
  font-size:var(--fs-small); font-family:inherit; }

/* --- Доработки аудита блока 2 (a11y, новые элементы) --- */
.consent__label{ cursor:pointer; }
.consent__links{ margin-top:var(--sp-1); display:flex; flex-wrap:wrap; gap:var(--sp-3); }
.consent__links a{ font-size:13px; color:var(--c-blue-link); }
.consent__phone-change{
  background:none; border:0; color:var(--c-blue-link); cursor:pointer;
  font-size:13px; font-family:inherit; margin-top:var(--sp-2); padding:0; text-decoration:underline;
}
.consent__text{ cursor:pointer; }
