/* app.css — слой app-компонентов Nelvo (вынесен из index.html <style>). Токены — из /ds/styles.css. */
  /* ── Token-shim: старые имена → Nelvo DS (advisor.js /js + inline-стили берут бренд) ── */
  :root{
    --c-paper:var(--canvas); --c-paper-2:var(--ink-50); --c-snow:var(--paper);
    --c-mist:var(--ink-150); --c-smoke:var(--ink-200); --c-fog:var(--ink-300);
    --c-ink:var(--ink-900); --c-ink-2:var(--ink-600); --c-ink-3:var(--ink-400);
    --c-ember:var(--accent-500); --c-ember-deep:var(--accent-700); --c-ember-soft:var(--accent-100);
    --c-good:var(--accent-500); --c-good-soft:var(--accent-100);
    --c-bad:var(--danger-600); --c-bad-soft:var(--danger-100);
    --c-warn:var(--warn-600); --c-warn-soft:var(--warn-100);
    --ff-body:var(--font-sans); --ff-display:var(--font-sans); --ff-mono:var(--font-mono);
  }
  *{box-sizing:border-box}
  body{margin:0;font-family:var(--font-sans);font-size:15px;line-height:1.5;
       background:var(--canvas);color:var(--ink-900);-webkit-font-smoothing:antialiased}
  button{font:inherit;cursor:pointer}
  input,select,textarea{font:inherit}
  /* #7г: iOS Safari зумит при focus если font-size<16px — ограничиваем только мобилку */
  @media(max-width:767px){input,select,textarea{font-size:max(16px,1em) !important}}
  ::selection{background:var(--accent-100)}
  /* #8 единый тонкий серый скроллбар ВЕЗДЕ (поп-апы, таблицы, прокручиваемые области).
     !important — жёсткий «блок»: никакой попап/элемент не может вернуть широкий нативный скроллбар. */
  *{scrollbar-width:thin !important;scrollbar-color:var(--ink-200) transparent !important}
  *::-webkit-scrollbar,::-webkit-scrollbar{width:8px !important;height:8px !important}
  *::-webkit-scrollbar-track,::-webkit-scrollbar-track{background:transparent !important}
  *::-webkit-scrollbar-thumb,::-webkit-scrollbar-thumb{background:var(--ink-200) !important;border-radius:999px !important;border:2px solid transparent !important;background-clip:padding-box !important}
  *::-webkit-scrollbar-thumb:hover,::-webkit-scrollbar-thumb:hover{background:var(--ink-300) !important}
  ::-webkit-scrollbar-corner{background:transparent !important}

  /* Кнопки — keycap-стиль (клавиша, которую жмёшь): верхний блик + нижняя «грань» + press.
     Primary = тёмная ink-клавиша; ghost = светлая клавиша; emerald зарезервирован под approve. */
  .btn{background:linear-gradient(180deg,var(--ink-700),var(--ink-900));color:var(--paper);border:0;border-radius:10px;
    padding:11px 18px;font-weight:600;letter-spacing:-.005em;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.16),0 3px 0 #0c0e10,0 5px 12px rgba(20,23,26,.26);
    transition:transform var(--dur-1) var(--ease-out),box-shadow var(--dur-1) var(--ease-out),background var(--dur-1) var(--ease-out)}
  .btn:hover{background:linear-gradient(180deg,var(--ink-600),var(--ink-800))}
  .btn:active{transform:translateY(2px);box-shadow:inset 0 1px 0 rgba(255,255,255,.14),0 1px 0 #0c0e10,0 2px 6px rgba(20,23,26,.26)}
  .btn-ghost{background:linear-gradient(180deg,var(--paper),var(--ink-50));color:var(--ink-900);border:1px solid var(--ink-200);
    border-radius:10px;padding:10px 16px;font-weight:600;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.9),0 2px 0 var(--ink-150),0 3px 8px rgba(20,23,26,.06);
    transition:transform var(--dur-1) var(--ease-out),box-shadow var(--dur-1) var(--ease-out),background var(--dur-1) var(--ease-out)}
  .btn-ghost:hover{background:linear-gradient(180deg,var(--paper),var(--ink-100))}
  .btn-ghost:active{transform:translateY(2px);box-shadow:inset 0 1px 0 rgba(255,255,255,.9),0 1px 0 var(--ink-150),0 1px 4px rgba(20,23,26,.06)}
  /* #13/#16: единое фокус-кольцо (один мягкий halo, без двойного штриха от outline-offset/браузерного дефолта) */
  .btn:focus-visible{outline:none;box-shadow:inset 0 1px 0 rgba(255,255,255,.16),0 3px 0 #0c0e10,0 0 0 3px var(--accent-200)}
  .btn-ghost:focus-visible{outline:none;box-shadow:inset 0 1px 0 rgba(255,255,255,.9),0 2px 0 var(--ink-150),0 0 0 3px var(--accent-200)}

/* =====================================================================
   NELVO — TOPBAR (header#topbar). Финал. Self-contained, на токенах Nelvo DS.
   Заменяет старые правила header#topbar / .brand / #header-actions /
   .usage-meter* / .um-* / .tb-btn / .tb-accent / .tb-icon / .tb-quit.
   НЕ накладывать поверх — это единый слой (no layered CSS).

   Одна кнопка-примитив (высота 40, радиус --r-sm, единый ghost, единый
   focus-ring). Из неё выведены чип-статус, power-кнопка и «Выйти».
   Десктоп — тихий ghost в один ряд. Мобайл ≤560px — иконки 40px, один ряд.
   ===================================================================== */

header#topbar{background:var(--paper);border-bottom:1px solid var(--ink-150);
  position:sticky;top:0;z-index:10;font-family:var(--font-sans)}
header#topbar *{box-sizing:border-box}
header#topbar .tb-inner{display:flex;align-items:center;gap:var(--sp-2);padding:10px 20px;min-height:60px}
header#topbar .hidden{display:none!important}

/* наследие — оставлено в DOM, скрыто */
#header-title{display:none}
#header-actions{display:none}

/* --- бренд (якорь) --- */
header#topbar .brand{display:flex;align-items:center;margin-right:auto;flex:0 0 auto}
header#topbar .brand img{height:30px;width:auto;display:block}

/* --- кнопка-примитив (ghost) --- */
header#topbar .tb-btn{height:40px;padding:0 14px;display:inline-flex;align-items:center;
  justify-content:center;gap:8px;border:1px solid transparent;border-radius:var(--r-sm);
  background:transparent;font:600 13.5px/1 var(--font-sans);color:var(--ink-700);
  letter-spacing:-.005em;white-space:nowrap;cursor:pointer;
  transition:background var(--dur-1) var(--ease-out),color var(--dur-1) var(--ease-out),
    border-color var(--dur-1) var(--ease-out),box-shadow var(--dur-1) var(--ease-out)}
header#topbar .tb-btn svg{width:17px;height:17px;flex:0 0 auto;color:var(--ink-400);
  transition:color var(--dur-1) var(--ease-out)}
header#topbar .tb-btn:hover{background:var(--ink-50);color:var(--ink-900)}
header#topbar .tb-btn:hover svg{color:var(--ink-600)}
header#topbar .tb-btn:active{background:var(--ink-100)}
header#topbar .tb-btn:focus-visible{outline:none;border-color:var(--accent-500);box-shadow:0 0 0 3px var(--accent-100)}

/* --- иконка-помощь (Тур), третичная --- */
header#topbar .tb-icon{width:40px;height:40px;padding:0;display:inline-flex;align-items:center;
  justify-content:center;border:1px solid transparent;border-radius:var(--r-sm);
  background:transparent;color:var(--ink-400);cursor:pointer;
  transition:background var(--dur-1) var(--ease-out),color var(--dur-1) var(--ease-out)}
header#topbar .tb-icon svg{width:18px;height:18px;flex:0 0 auto}
header#topbar .tb-icon:hover{background:var(--ink-50);color:var(--ink-700)}
header#topbar .tb-icon:focus-visible{outline:none;border-color:var(--accent-500);box-shadow:0 0 0 3px var(--accent-100)}

/* --- Выйти (тихая, краснеет на hover) --- */
header#topbar .tb-quit{height:40px;padding:0 12px;display:inline-flex;align-items:center;
  justify-content:center;gap:7px;border:1px solid transparent;border-radius:var(--r-sm);
  background:transparent;font:600 13.5px/1 var(--font-sans);color:var(--ink-500);
  letter-spacing:-.005em;white-space:nowrap;cursor:pointer;
  transition:background var(--dur-1) var(--ease-out),color var(--dur-1) var(--ease-out),transform var(--dur-1) var(--ease-out)}
header#topbar .tb-quit svg{width:17px;height:17px;flex:0 0 auto}
header#topbar .tb-quit:hover{background:var(--danger-100);color:var(--danger-600)}
header#topbar .tb-quit:active{transform:translateY(1px)}
header#topbar .tb-quit:focus-visible{outline:none;border-color:var(--danger-600);box-shadow:0 0 0 3px var(--danger-100)}

/* --- power: Админка (единственная доминанта) --- */
header#topbar .tb-accent{height:40px;padding:0 16px;display:inline-flex;align-items:center;
  gap:8px;border:1px solid var(--ink-900);border-radius:var(--r-sm);background:var(--ink-900);
  color:var(--paper);font:600 13.5px/1 var(--font-sans);letter-spacing:-.005em;white-space:nowrap;
  cursor:pointer;box-shadow:var(--sh-sm),inset 0 1px 0 rgba(255,255,255,.08);
  transition:transform var(--dur-1) var(--ease-out),box-shadow var(--dur-2) var(--ease-out)}
header#topbar .tb-accent svg{width:18px;height:18px;flex:0 0 auto;color:#fff}
header#topbar .tb-accent:hover{transform:translateY(-1px);
  box-shadow:var(--sh-md),inset 0 1px 0 rgba(255,255,255,.10)}
header#topbar .tb-accent:active{transform:translateY(0);box-shadow:var(--sh-xs)}
header#topbar .tb-accent:focus-visible{outline:none;box-shadow:0 0 0 3px var(--accent-200)}

/* --- чип расхода / статус «Безлимит» --- */
header#topbar .usage-meter{height:40px;display:inline-flex;align-items:center;gap:8px;
  padding:0 8px 0 14px;border:1px solid var(--ink-150);border-radius:var(--r-pill);
  background:var(--ink-50);font:500 12.5px/1 var(--font-mono);color:var(--ink-600);
  letter-spacing:.01em;cursor:pointer;flex:0 0 auto;
  transition:border-color var(--dur-1) var(--ease-out),background var(--dur-1) var(--ease-out)}
header#topbar .usage-meter:hover{border-color:var(--ink-200);background:var(--paper)}
header#topbar .um-text{display:inline-flex;align-items:center;white-space:nowrap}
header#topbar .um-bar{width:54px;height:6px;border-radius:999px;background:var(--ink-150);overflow:hidden;flex:0 0 auto}
header#topbar .um-fill{display:block;height:100%;width:0;border-radius:999px;background:var(--good-500);
  transition:width var(--dur-3) var(--ease-out),background var(--dur-2) var(--ease-out)}
header#topbar .um-cta{font-family:var(--font-sans);font-weight:700;font-size:11px;color:var(--paper);
  background:var(--ink-900);border-radius:999px;padding:4px 10px;white-space:nowrap}
/* состояния чипа (JS добавляет .warn / .over) */
header#topbar .usage-meter.warn{color:var(--warn-600);border-color:#E7D3AE}
header#topbar .usage-meter.warn .um-fill{background:var(--warn-600)}
header#topbar .usage-meter.over{color:var(--danger-600);border-color:#E6BDB9}
header#topbar .usage-meter.over .um-fill{background:var(--danger-600)}
header#topbar .usage-meter.over .um-cta{background:var(--danger-600)}
header#topbar .usage-meter:focus-visible{outline:none;border-color:var(--accent-500);box-shadow:0 0 0 3px var(--accent-100)}
/* статус «Безлимит» (JS добавляет .is-status) — чистый чип, без действия */
/* приглушённый чип (не бросается в глаза): light-ghost как остальные кнопки шапки */
header#topbar .usage-meter.is-status{cursor:default;padding:0 13px 0 11px;background:var(--ink-50);
  border-color:var(--ink-150);box-shadow:none;color:var(--ink-600);font-family:var(--font-sans);font-weight:600}
header#topbar .usage-meter.is-status:hover{border-color:var(--ink-150);background:var(--ink-50)}
header#topbar .usage-meter.is-status .um-text{gap:8px}
header#topbar .usage-meter.is-status .um-bar,
header#topbar .usage-meter.is-status .um-cta{display:none}
header#topbar .um-inf{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;width:19px;height:19px;color:var(--accent-500);font:800 17px/1 var(--font-sans)}
header#topbar .um-inf svg{width:100%;height:100%}
header#topbar .um-div{width:1px;height:13px;background:var(--ink-200);flex:0 0 auto}
header#topbar .um-lbl{font:600 12.5px/1 var(--font-sans);color:var(--ink-600);letter-spacing:-.004em}

/* =========================== МОБАЙЛ ≤560 — иконки, один ряд ===================== */
@media (max-width:560px){
  header#topbar .tb-inner{gap:6px;padding:12px 14px}
  header#topbar .brand img{height:24px}
  header#topbar .tb-btn{width:40px;padding:0;gap:0}
  header#topbar .tb-btn span{display:none}
  header#topbar .tb-quit{width:40px;padding:0;gap:0}
  header#topbar .tb-quit span{display:none}
  header#topbar .tb-accent{padding:0;width:44px;justify-content:center;gap:0}
  header#topbar .tb-accent span{display:none}
  header#topbar .usage-meter{padding:0 12px;min-width:0;flex:0 1 auto}
  header#topbar .usage-meter .um-bar{display:none}
  /* MOB-1: чип расхода на узком экране не распирает топбар (длинный «баланс · 1 500 ₽» выносил «Выйти» за край). */
  header#topbar .um-text{max-width:96px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:inline-block}
  header#topbar .usage-meter.is-status{padding:0;width:44px;justify-content:center}
  header#topbar .usage-meter.is-status .um-lbl,
  header#topbar .usage-meter.is-status .um-div{display:none}
  header#topbar .usage-meter.is-status .um-text{gap:0}
}
  /* #B21 алёрт под счётчиком расхода — «баланс/лимит скоро закончится» */
  .nlv-lowbal{position:fixed;z-index:190;display:inline-flex;align-items:center;gap:10px;max-width:min(360px,calc(100vw - 16px));
    background:var(--paper);border:1px solid var(--ink-200);border-radius:12px;padding:10px 10px 10px 13px;
    box-shadow:var(--sh-lg),inset 0 1px 0 rgba(255,255,255,.7);font-size:13px;font-weight:600;color:var(--ink-800);
    animation:nlvLowbalIn .26s cubic-bezier(.34,1.4,.5,1) both}
  @keyframes nlvLowbalIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}
  .nlv-lowbal .lb-ic{flex:0 0 auto;display:grid;place-items:center;width:26px;height:26px;border-radius:8px}
  .nlv-lowbal.lb-warn{border-color:var(--warn-600)} .nlv-lowbal.lb-warn .lb-ic{background:var(--warn-100,#fdf0d6);color:var(--warn-600)}
  .nlv-lowbal.lb-danger{border-color:var(--danger-600)} .nlv-lowbal.lb-danger .lb-ic{background:var(--danger-50,#fdecec);color:var(--danger-600)}
  .nlv-lowbal .lb-msg{flex:1;min-width:0;line-height:1.3}
  .nlv-lowbal .lb-cta{flex:0 0 auto;font:600 12px/1 var(--font-sans);color:var(--paper);background:var(--ink-900);
    border:0;border-radius:8px;padding:7px 11px;cursor:pointer;white-space:nowrap}
  .nlv-lowbal.lb-danger .lb-cta{background:var(--danger-600)}
  .nlv-lowbal .lb-cta:hover{opacity:.9}
  .nlv-lowbal .lb-x{flex:0 0 auto;display:grid;place-items:center;width:24px;height:24px;border-radius:7px;
    background:transparent;border:0;color:var(--ink-400);cursor:pointer}
  .nlv-lowbal .lb-x:hover{background:var(--ink-100);color:var(--ink-700)}
  @media(prefers-reduced-motion:reduce){.nlv-lowbal{animation:none}}
  /* Страница «Тариф и оплата» */
  /* #B22 единый экран подписки = модал-попап (дизайн как у остальных попапов), не отдельная страница */
  #billing-page{position:fixed;inset:0;background:rgba(20,23,26,.42);z-index:60;display:grid;place-items:center;padding:20px;animation:nlvFade .18s ease both}
  .bp-modal{position:relative;display:flex;flex-direction:column;width:min(720px,calc(100vw - 40px));
    max-height:min(90vh,calc(100vh - 40px));background:var(--paper);border:1px solid var(--ink-150);border-radius:var(--r-xl);
    box-shadow:var(--sh-lg),inset 0 1px 0 rgba(255,255,255,.7);overflow:hidden;
    animation:nlvPop .26s cubic-bezier(.34,1.4,.5,1) both}
  .bp-close{margin-left:auto;position:static;flex:0 0 auto}
  /* #B20 топбар «Тариф и оплата» — иерархия и воздух (был сжат: назад+лого+заголовок в кучу) */
  .bp-topbar{display:flex;align-items:center;gap:16px;padding:14px 24px;border-bottom:1px solid var(--ink-150);
    background:linear-gradient(180deg,var(--paper),var(--ink-50));position:sticky;top:0;z-index:5}
  .bp-back{display:inline-flex;align-items:center;gap:6px;background:transparent;border:1px solid var(--ink-200);
    border-radius:10px;padding:8px 13px 8px 10px;color:var(--ink-600);font-weight:600;font-size:13.5px;cursor:pointer;
    transition:color var(--dur-1) var(--ease-out),border-color var(--dur-1) var(--ease-out),background var(--dur-1) var(--ease-out)}
  .bp-back:hover{color:var(--ink-900);border-color:var(--ink-300);background:var(--paper)}
  .bp-back:active{transform:translateY(1px)}
  .bp-tb-div{width:1px;height:26px;background:var(--ink-150);flex:0 0 auto}
  .bp-topbar .brand img{height:26px;display:block}
  .bp-tb-title{display:flex;flex-direction:column;line-height:1.1;margin-left:2px}
  .bp-tb-eyebrow{font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-400);font-weight:600}
  .bp-tb-title h1{margin:2px 0 0;font-size:19px;font-weight:800;letter-spacing:-.02em;color:var(--ink-900)}
  .bp-wrap{max-width:none;margin:0;padding:22px 22px 26px;display:flex;flex-direction:column;gap:16px;overflow-y:auto;flex:1;min-height:0}
  .bp-card{border:1px solid var(--ink-150);border-radius:14px;padding:20px;background:var(--paper)}
  .bp-card h3{margin:0 0 4px;font-size:16px;letter-spacing:-.01em}
  .bp-muted{color:var(--ink-400);font-size:13.5px;line-height:1.55}
  .bp-price{font-size:30px;font-weight:800;letter-spacing:-.02em}
  .bp-bar{height:10px;border-radius:999px;background:var(--ink-150);overflow:hidden;margin:10px 0}
  .bp-bar i{display:block;height:100%;border-radius:999px;background:var(--good-500);transition:width .35s,background .25s}
  .bp-bar.warn i{background:var(--warn-600)} .bp-bar.over i{background:var(--danger-600)}
  .bp-row{display:flex;justify-content:space-between;gap:12px;padding:6px 0;font-size:14px}
  .bp-row .k{color:var(--ink-400)} .bp-row .v{font-weight:600}
  .bp-mode-row{display:flex;gap:10px;align-items:flex-start;padding:9px 0;cursor:pointer}
  /* Пополнение кошелька (предоплата): пресеты сумм */
  .bp-topup-row{display:flex;gap:8px;flex-wrap:wrap}
  .bp-topup-btn{padding:8px 14px;font-size:13px}
  .bp-topup-btn:disabled{opacity:.55;cursor:default}
  /* #B17 поле своей суммы пополнения */
  .bp-topup-custom{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
  .bp-amt-field{position:relative;flex:1;min-width:150px;display:inline-flex;align-items:center}
  .bp-amt-inp{width:100%;font:600 14px/1.2 var(--font-sans);color:var(--ink-900);background:var(--paper);
    border:1px solid var(--ink-200);border-radius:10px;padding:10px 30px 10px 13px;-moz-appearance:textfield}
  .bp-amt-inp::-webkit-outer-spin-button,.bp-amt-inp::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
  .bp-amt-inp::placeholder{color:var(--ink-300);font-weight:500}
  .bp-amt-inp:focus{outline:none;border-color:var(--ink-300);box-shadow:0 0 0 3px rgba(20,23,26,.05)}
  .bp-amt-inp.bp-amt-bad{border-color:var(--danger-600);box-shadow:0 0 0 3px rgba(214,57,57,.12);animation:nlvShake .3s}
  .bp-amt-cur{position:absolute;right:12px;color:var(--ink-400);font-weight:600;font-size:13px;pointer-events:none}
  .bp-topup-pay{padding:10px 20px;font-size:13.5px;white-space:nowrap}
  @keyframes nlvShake{0%,100%{transform:translateX(0)}25%{transform:translateX(-4px)}75%{transform:translateX(4px)}}
  .bp-banner{border:1px solid var(--danger-600);background:var(--danger-50,#fde8e8);color:var(--danger-600);border-radius:12px;padding:14px 16px;font-size:14px;font-weight:600}
  /* Инлайн-сообщение под кнопками пополнения кошелька (вместо нативного alert) */
  .bp-topup-msg{font-size:13px;line-height:1.45;margin-top:8px;min-height:0}
  .bp-topup-msg:empty{display:none}
  .bp-topup-msg.err{color:var(--danger-600)}
  .bp-topup-msg.info{color:var(--ink-500)}
  .bp-hist{font-size:13.5px;border-collapse:collapse;width:100%}
  .bp-hist td,.bp-hist th{padding:7px 6px;text-align:left;border-top:1px solid var(--ink-150)}
  /* #B19 история платежей — статус-бейдж + название как РАЗНЫЕ блоки, воздух в строках */
  .bp-hist th{font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-400);font-weight:600;padding-bottom:10px;border-top:0}
  .bp-hist td{padding:14px 6px;vertical-align:middle}
  .bp-hist td:last-child,.bp-hist th:last-child{text-align:right}
  .bp-hist .bp-cell{display:flex;align-items:center;gap:11px;min-width:0}
  .bp-stat{flex:0 0 auto;display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;
    color:var(--accent-700,#1f7a4d);background:var(--accent-50,#eefaf3);border:1px solid var(--accent-300,#86d3ab);
    border-radius:999px;padding:3px 9px 3px 8px;line-height:1.2;white-space:nowrap}
  .bp-stat::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent-600,#22a463)}
  .bp-what{color:var(--ink-800);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .bp-amt{font-family:var(--font-mono);font-weight:600;color:var(--ink-900);white-space:nowrap}
  /* 02 — Админка: статкарты биллинга */
  .ab-totals{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin:6px 0 16px}
  .ab-stat{border:1px solid var(--ink-150);border-radius:var(--r-md);background:var(--paper);padding:14px 15px;
    box-shadow:var(--sh-xs);transition:transform var(--dur-1) var(--ease-out),box-shadow var(--dur-1) var(--ease-out);min-width:0}
  .ab-stat:hover{transform:translateY(-1px);box-shadow:var(--sh-md)}
  .ab-stat.accent{border-color:var(--accent-300)}
  .ab-stat .n{font-family:var(--font-mono);font-size:21px;font-weight:600;letter-spacing:-.02em;color:var(--ink-900);font-variant-numeric:tabular-nums}
  .ab-stat.accent .n{color:var(--accent-700)} .ab-stat.warn .n{color:var(--warn-600)}
  .ab-stat .l{font-family:var(--font-mono);font-size:9.5px;color:var(--ink-400);text-transform:uppercase;letter-spacing:.05em;margin-top:4px}
  /* grid-таблицы (аккаунты / клиенты) */
  .ad-sub{font-family:var(--font-mono);font-size:11px;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-400);font-weight:600;margin:6px 0 10px}
  .ad-tbl{border:1px solid var(--ink-150);border-radius:var(--r-md);overflow:hidden;margin-bottom:18px}
  .ad-thead,.ad-trow{display:grid;align-items:center;gap:10px;padding:9px 13px}
  .ad-thead{background:var(--ink-50);border-bottom:1px solid var(--ink-150)}
  .ad-thead span{font-family:var(--font-mono);font-size:10px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-400)}
  .ad-trow{border-top:1px solid var(--ink-100);font-size:13px;color:var(--ink-700);transition:background var(--dur-2) var(--ease-out)}
  /* #20/S1#11 мягкая подсветка строки при in-place изменении (realtime, без reload; плавно через transition выше) */
  .ad-trow.ad-row-flash{background:var(--accent-100,#D8F0E2)}
  .ad-uai{transition:color var(--dur-1) var(--ease-out)}
  .ad-trow:first-child{border-top:0}
  .ad-trow.click{cursor:pointer;transition:background var(--dur-1) var(--ease-out)}
  .ad-trow.click:hover{background:var(--ink-50)}
  .ad-trow.payg{background:linear-gradient(90deg,rgba(18,165,107,.05),transparent 55%)}
  .ad-em{font-weight:600;color:var(--ink-900);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .ad-num{font-family:var(--font-mono);font-size:12.5px;font-variant-numeric:tabular-nums;text-align:right}
  /* В попапе админки все колонки выровнены ОДИНАКОВО — по левому краю (как и шапка).
     Так на каждой колонке заголовок стоит ровно над содержимым, без разнобоя «лево/право». */
  #admin-modal .ad-num{text-align:left}
  /* «Расход AI» в одну строку (#31); если длинно (есть «· креативы $X») — вторичный хвост
     схлопывается в …, основное «$потрачено / $лимит» всегда видно, полный разбор — в тултипе. */
  .ad-uai{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .ad-num.bad{color:var(--danger-600)} .ad-num.warn{color:var(--warn-600)}
  .ad-rb{font-family:var(--font-mono);font-size:9.5px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;border-radius:6px;padding:3px 8px;display:inline-block}
  .ad-rb.admin{background:var(--ink-900);color:#fff}
  .ad-rb.dir{background:var(--ink-100);color:var(--ink-600)}
  .ad-rb.client{background:transparent;border:1px solid var(--ink-200);color:var(--ink-500)}
  .ad-st{font-size:11.5px;font-weight:600;border-radius:999px;padding:3px 10px;display:inline-block;white-space:nowrap}
  .ad-st.ok{background:var(--accent-100);color:var(--accent-700)}
  .ad-st.payg{background:var(--ink-100);color:var(--ink-700)}
  .ad-st.demo{background:transparent;border:1px solid var(--ink-200);color:var(--ink-500)}
  .ad-st.due{background:var(--warn-100);color:var(--warn-600)}
  .ad-pill{font-family:var(--font-mono);font-size:9px;text-transform:uppercase;color:var(--ink-700);background:var(--ink-100);border:1px solid var(--ink-200);border-radius:5px;padding:2px 6px;margin-left:6px}
  .ad-sel{font:600 12.5px var(--font-sans);color:var(--ink-900);background:var(--paper);border:1px solid var(--ink-200);border-radius:8px;padding:6px 26px 6px 10px;
    appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none'%3E%3Cpath d='M6 9l6 6 6-6' stroke='%23767D87' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;cursor:pointer;max-width:100%}
  .ad-sel:focus{outline:none;border-color:var(--ink-300);box-shadow:0 0 0 3px rgba(20,23,26,.05)}
  .ad-mini-btn{display:inline-flex;align-items:center;gap:6px;font-weight:600;font-size:12px;color:var(--ink-700);background:var(--paper);border:1px solid var(--ink-200);border-radius:7px;padding:5px 10px;transition:background var(--dur-1) var(--ease-out),border-color var(--dur-1) var(--ease-out),color var(--dur-1) var(--ease-out)}
  .ad-mini-btn:hover{background:var(--ink-50)}
  .ad-mini-btn svg{width:13px;height:13px;flex:0 0 auto}
  /* #11 row-action кнопки админки: семантические акценты вместо моно-одинаковых.
     «Пароль» — нейтральный ключ (рутинное), «Обнулить» — danger-cue (полу-деструктив, сброс расхода). */
  .ad-mini-btn--key svg{color:var(--ink-400)}
  .ad-mini-btn--key:hover{border-color:var(--ink-300);color:var(--ink-900)}
  .ad-mini-btn--key:hover svg{color:var(--ink-600)}
  .ad-mini-btn--reset{color:var(--ink-600)}
  .ad-mini-btn--reset svg{color:var(--ink-400)}
  .ad-mini-btn--reset:hover{background:var(--danger-100);border-color:#F0C9C5;color:var(--danger-600)}
  .ad-mini-btn--reset:hover svg{color:var(--danger-600)}
  /* разворот клиента — мини фин-отчёт */
  .ad-det{grid-column:1/-1;padding:14px 4px 6px;border-top:1px dashed var(--ink-200);margin-top:4px}
  /* #23 карточки итогов клиента — дифференцированы по смыслу (деньги/AI/баланс), иконки, иерархия */
  .ad-det-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
  .ad-mc{display:flex;align-items:flex-start;gap:10px;border:1px solid var(--ink-150);background:var(--paper);border-radius:11px;padding:11px 12px;position:relative;box-shadow:var(--sh-xs)}
  .ad-mc-ic{flex:0 0 auto;width:28px;height:28px;border-radius:8px;display:grid;place-items:center;background:var(--ink-50);color:var(--ink-500)}
  .ad-mc-ic svg{width:15px;height:15px}
  .ad-mc-t{min-width:0}
  .ad-mc .l{font-family:var(--font-mono);font-size:9px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-400)}
  .ad-mc .v{font-family:var(--font-mono);font-size:15px;font-weight:600;color:var(--ink-900);margin-top:3px;font-variant-numeric:tabular-nums}
  .ad-mc .v.warn{color:var(--warn-600)}
  .ad-mc--rev{border-color:#CFEBDD} .ad-mc--rev .ad-mc-ic{background:var(--accent-50,#EFF9F3);color:var(--accent-700,#0B6E47)} .ad-mc--rev .v{color:var(--accent-700,#0B6E47)}
  .ad-mc--ai .ad-mc-ic{background:var(--ink-100);color:var(--ink-600)}
  .ad-mc--hero{background:linear-gradient(160deg,var(--accent-50,#EFF9F3),var(--paper))}
  .ad-det-note{display:flex;align-items:flex-start;gap:9px;font-size:12px;line-height:1.5;color:var(--ink-500);background:var(--ink-50);border:1px solid var(--ink-100);border-radius:9px;padding:10px 13px;margin-top:12px}
  .ad-det-note svg{flex:0 0 auto;color:var(--ink-400);margin-top:1px}
  /* QA-fix: состояния загрузки/ошибки/пусто для 02 + скелет */
  .sk{border-radius:7px;background:linear-gradient(90deg,var(--ink-100) 25%,var(--ink-50) 37%,var(--ink-100) 63%);background-size:400% 100%;animation:shimmer 1.4s ease-in-out infinite}
  .ad-errbox{border:1px solid #F0C9C5;background:var(--danger-100);color:var(--ink-700);border-radius:var(--r-md);padding:14px 16px;font-size:13px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
  .ad-zero{border:1px dashed var(--ink-200);background:var(--ink-50);color:var(--ink-500);border-radius:var(--r-md);padding:18px 16px;font-size:13px;text-align:center}
  /* QA-fix 07: длинный email не должен распирать модалку (375px) */
  .set-row .v{min-width:0}
  #set-email{overflow-wrap:anywhere;text-align:right}
  @media(max-width:600px){
    .ab-totals{grid-template-columns:repeat(2,1fr)}
    .ad-thead{display:none}
    .ad-trow{grid-template-columns:1fr!important;gap:6px;padding:12px 13px}
    .ad-trow>*[data-l]::before{content:attr(data-l) " · ";font-family:var(--font-mono);font-size:9px;text-transform:uppercase;color:var(--ink-400)}
    .ad-num{text-align:left}
    .ad-det-cards{grid-template-columns:repeat(2,1fr)}
  }

  /* Модалка апгрейда / докупки кредитов */
  .up-banner{background:var(--warn-100);border:1px solid var(--warn-600);border-radius:var(--r-md);
    padding:12px 14px;margin-bottom:16px;font-size:13.5px;line-height:1.5;color:var(--ink-700)}
  .up-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
  .up-card{border:1px solid var(--ink-150);border-radius:var(--r-md);padding:18px 16px;display:flex;
    flex-direction:column;gap:4px;transition:border-color .15s,box-shadow .15s}
  .up-card:hover{border-color:var(--ink-300);box-shadow:0 6px 22px -14px rgba(20,23,26,.5)}
  .up-card.current{border-color:var(--accent-500);background:var(--accent-50)}
  .up-card .up-name{font-weight:700;font-size:15px;color:var(--ink-900)}
  .up-card .up-price{font-size:24px;font-weight:800;letter-spacing:-.02em;color:var(--ink-900);margin:2px 0}
  .up-card .up-price small{font-size:13px;font-weight:600;color:var(--ink-400)}
  .up-card .up-sub{font-size:12.5px;color:var(--ink-500);line-height:1.45;margin-bottom:10px}
  .up-card .btn,.up-card .btn-ghost{width:100%;margin-top:auto;padding:9px;font-size:13px}
  .up-badge{align-self:flex-start;font-family:var(--font-mono);font-size:10px;text-transform:uppercase;
    letter-spacing:.06em;font-weight:700;color:var(--accent-700);background:var(--accent-100);
    border-radius:999px;padding:2px 8px;margin-bottom:2px}
  @media (max-width:560px){ .up-cards{grid-template-columns:1fr} }

  /* Кабинет/Настройки */
  .set-sec{border-top:1px solid var(--ink-150);padding:20px 0}
  .set-sec:first-of-type{border-top:0;padding-top:4px}
  .set-label{font-family:var(--font-mono);font-size:11px;letter-spacing:.07em;text-transform:uppercase;
    color:var(--ink-400);font-weight:600;margin-bottom:12px}
  .set-row{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:10px}
  .set-row .k{font-size:13px;color:var(--ink-500)} .set-row .v{font-size:14px;color:var(--ink-900);font-weight:600}
  .set-mono{font-family:var(--font-mono)}
  .set-bar{height:8px;border-radius:999px;background:var(--ink-150);overflow:hidden;margin:8px 0 6px}
  .set-bar i{display:block;height:100%;background:var(--good-500);border-radius:999px;transition:width .35s}
  .set-bar.warn i{background:var(--warn-600)} .set-bar.over i{background:var(--danger-600)}
  .set-dot{width:9px;height:9px;border-radius:50%;display:inline-block;margin-right:7px;vertical-align:middle}
  .set-pwd{display:flex;flex-direction:column;gap:10px;margin-top:8px}
  .set-pwd .pwd-wrap{flex:none;width:100%}
  .set-pwd input{width:100%;box-sizing:border-box;padding:10px 12px;border:1px solid var(--ink-200);border-radius:var(--r-sm);font-size:13px}
  .set-pwd .btn-ghost{align-self:flex-start;margin-top:2px}   /* S1#29: кнопки форм по левому краю */
  .set-hint{font-size:12.5px;color:var(--ink-400);line-height:1.5;margin-top:6px}
  /* 07 — бейдж роли / чип тарифа / блок кредитов / подключения */
  .set-badge{font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;
    background:var(--ink-900);color:#fff;border-radius:6px;padding:3px 8px}
  .set-badge.dir{background:var(--ink-100);color:var(--ink-600)}
  .set-chip{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:600;border-radius:999px;
    padding:4px 12px;background:var(--ink-100);color:var(--ink-700)}
  .set-chip.ok{background:var(--accent-100);color:var(--accent-700)}
  .set-credits{border:1px solid var(--ink-150);background:var(--ink-50);border-radius:var(--r-md);padding:14px 16px;margin-top:10px}
  .set-cr-top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}
  .set-cr-lab{font-size:12.5px;color:var(--ink-500)}
  .set-cr-val{font-family:var(--font-mono);font-size:14px;font-weight:600;color:var(--ink-900);font-variant-numeric:tabular-nums}
  .set-cr-status{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-600)}
  .set-sc{font-family:var(--font-mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;
    color:var(--accent-700);background:var(--accent-50);border:1px solid var(--accent-300);border-radius:6px;padding:3px 9px}
  .set-sc.payg{color:var(--ink-700);background:var(--ink-100);border-color:var(--ink-200)}
  .set-conn{display:flex;align-items:center;gap:12px;padding:2px 0 4px}
  .set-ci{flex:0 0 auto;width:32px;height:32px;display:grid;place-items:center;background:var(--ink-50);
    border:1px solid var(--ink-150);border-radius:9px;color:var(--ink-500)}
  .set-cn{min-width:0}
  .set-cn-t{font-size:13.5px;font-weight:600;color:var(--ink-900)}
  .set-cs{font-family:var(--font-mono);font-size:10.5px;color:var(--ink-400);display:flex;align-items:center;gap:6px;margin-top:2px}
  .set-cs .set-dot{margin-right:0}

  /* 06 — Доступ клиента */
  .ca-wrap{max-width:680px}
  .ca-top{display:flex;align-items:center;gap:12px;margin-bottom:8px;flex-wrap:wrap}
  .ca-h{margin:0;font-size:23px;font-weight:800;letter-spacing:-.02em;color:var(--ink-900)}
  .ca-badge{font-size:12px;font-weight:600;border-radius:999px;padding:4px 12px;background:var(--ink-100);color:var(--ink-500)}
  .ca-badge.on{background:var(--accent-100);color:var(--accent-700)}
  .ca-sub{color:var(--ink-500);font-size:14px;line-height:1.55;margin:0 0 18px;max-width:560px}
  .ca-card{border:1px solid var(--ink-150);background:var(--paper);border-radius:var(--r-md);
    box-shadow:var(--sh-sm),inset 0 1px 0 rgba(255,255,255,.7);padding:22px;margin-bottom:18px}
  .ca-fld{margin-bottom:16px}
  .ca-fld label{display:block;font-size:13px;font-weight:600;color:var(--ink-800);margin-bottom:7px}
  .ca-fld label .h{font-weight:500;font-size:12px;color:var(--ink-400);margin-left:6px}
  .ca-inp{width:100%;font:500 14px/1.2 var(--font-sans);color:var(--ink-900);background:var(--paper);
    border:1px solid var(--ink-200);border-radius:var(--r-sm);padding:12px 13px}
  .ca-inp::placeholder{color:var(--ink-300)}
  .ca-inp:focus{outline:none;border-color:var(--ink-300);box-shadow:0 0 0 3px rgba(20,23,26,.05)}
  /* #B4 «Выдать кабинет» — единая высота инпутов / селекта тарифа / кнопки (был разнобой) */
  /* #13 «Выдать кабинет» — детализированная секция (была плоская .nu-row из голых инпутов) */
  .nu-block{margin-top:20px;padding:18px 18px 16px;border:1px solid var(--ink-150);border-radius:var(--r-lg,14px);
    background:linear-gradient(180deg,var(--paper),var(--ink-50));box-shadow:var(--sh-xs),inset 0 1px 0 rgba(255,255,255,.7)}
  .nu-blk-h{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;margin-bottom:15px}
  .nu-grid{display:grid;grid-template-columns:1.5fr 1.5fr 1fr;gap:14px;align-items:end}
  .nu-fld{margin-bottom:0}
  .nu-fld label{display:flex;align-items:center;gap:7px}
  .nu-fld label svg{width:15px;height:15px;color:var(--ink-400);flex:0 0 auto}
  .nu-fld .ca-inp{height:44px;box-sizing:border-box}
  .nu-fld #nu-tariff-wrap{display:flex}
  .nu-fld #nu-tariff-wrap .dsel{width:100%}
  .nu-fld #nu-tariff-wrap .dsel,.nu-fld #nu-tariff-wrap .dsel-tg{height:44px;box-sizing:border-box}
  .nu-fld #nu-tariff-wrap .dsel-tg{padding-top:0;padding-bottom:0}
  /* #32/#33 окошко ошибки выдачи кабинета — детализированное, с иконкой и пояснением */
  .nu-errbox{display:none;align-items:flex-start;gap:11px;margin-top:14px;padding:12px 14px;border-radius:11px;
    background:var(--danger-100);border:1px solid #F0C9C5;animation:nlvPopIn .16s var(--ease-out) both}
  .nu-errbox.show{display:flex}
  .nu-err-ic{flex:0 0 auto;display:grid;place-items:center;width:28px;height:28px;border-radius:8px;color:#fff;
    background:linear-gradient(155deg,var(--danger-600),#a8362e);box-shadow:inset 0 1px 0 rgba(255,255,255,.2)}
  .nu-err-t{font-size:13px;line-height:1.5;color:var(--ink-700)}
  .nu-err-t b{display:block;font-size:13.5px;font-weight:700;color:var(--danger-600);margin-bottom:2px}
  .nu-foot{display:flex;align-items:center;gap:14px;margin-top:16px}
  .nu-foot .btn{height:44px;padding:0 18px;box-sizing:border-box;white-space:nowrap;display:inline-flex;align-items:center;justify-content:center;gap:7px}
  .nu-foot .btn svg{flex:none}
  .nu-foot .foot-hint{margin-left:0}
  @media(max-width:560px){ .nu-grid{grid-template-columns:1fr} .nu-foot{flex-direction:column-reverse;align-items:stretch} .nu-foot .foot-hint{text-align:center} }
  .ca-msg{font-size:13px;min-height:0;margin:0 0 10px}
  .ca-acts{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
  /* «Отозвать доступ» — текстовая danger-кнопка с hover (раньше инлайн-стили без :hover) */
  .ca-revoke{background:none;border:1px solid transparent;color:var(--danger-600);font-weight:600;font-size:13.5px;margin-left:auto;border-radius:8px;padding:8px 12px;cursor:pointer;transition:background var(--dur-1) var(--ease-out),border-color var(--dur-1) var(--ease-out)}
  .ca-revoke:hover{background:var(--danger-100);border-color:#F0C9C5}
  .ca-grow{display:flex;align-items:center;gap:12px;padding:13px 0;border-top:1px solid var(--ink-100)}
  .ca-grow:first-child{border-top:0;padding-top:0}
  .ca-gl{font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-400);width:120px;flex:0 0 auto}
  .ca-chip{flex:1 1 0;min-width:0;display:flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:13px;color:var(--ink-800);
    background:var(--ink-50);border:1px solid var(--ink-150);border-radius:8px;padding:9px 12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .ca-copy{font-weight:600;font-size:12.5px;color:var(--ink-800);background:var(--paper);border:1px solid var(--ink-200);
    border-radius:8px;padding:9px 13px;flex:0 0 auto}
  .ca-copy:hover{background:var(--ink-50)}
  .ca-copy.done{color:var(--accent-700);border-color:var(--accent-300);background:var(--accent-50)}
  .ca-link{color:var(--accent-700)}
  /* Превью «что увидит клиент» (бренд Nelvo, без white-label) */
  .ca-pl{font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-400);font-weight:600;margin:0 0 9px}
  .wl{border:1px solid var(--ink-150);border-radius:var(--r-md);overflow:hidden;box-shadow:var(--sh-sm)}
  .wl-bar{display:flex;align-items:center;gap:7px;padding:9px 13px;background:var(--ink-50);border-bottom:1px solid var(--ink-150)}
  .wl-dots{display:flex;gap:5px}
  .wl-dots i{width:9px;height:9px;background:var(--ink-200);border-radius:50%}
  .wl-url{font-family:var(--font-mono);font-size:10.5px;color:var(--ink-400);background:var(--paper);border:1px solid var(--ink-150);border-radius:6px;padding:3px 9px}
  .wl-body{padding:16px}
  .wl-brand{display:flex;align-items:center;gap:9px;margin-bottom:14px;min-width:0}
  /* #35: свежий вид — светлый чистый контейнер с фирменным mark, без «чёрного квадрата» */
  .wl-logo{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;flex:0 0 auto;
    background:var(--paper);border:1px solid var(--ink-150);box-shadow:var(--sh-xs)}
  .wl-logo img{display:block}
  .wl-bn-wrap{display:flex;flex-direction:column;min-width:0;line-height:1.2}
  .wl-bn{font-weight:700;font-size:14px;color:var(--ink-900);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .wl-sub{font-size:11px;color:var(--ink-400);margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .wl-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
  .wl-kpi{border:1px solid var(--ink-150);background:var(--paper);border-radius:8px;padding:9px 10px}
  .wl-kl{font-family:var(--font-mono);font-size:9px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-400)}
  .wl-kv{font-family:var(--font-mono);font-size:16px;font-weight:600;color:var(--ink-900);margin-top:3px}
  .wl-kt{font-size:10.5px;font-weight:600;margin-top:3px;color:var(--ink-400)}
  .wl-kt.good{color:var(--accent-700,#1f7a4d)}
  .wl-cap{font-size:11.5px;line-height:1.5;color:var(--ink-400);margin-top:12px}
  @media(max-width:560px){ .ca-grow{flex-wrap:wrap} .ca-gl{width:100%} }

  /* Онбординг-тур (coach-marks) */
  #tour{position:fixed;inset:0;z-index:90;display:none}
  #tour.on{display:block}
  .tour-spot{position:absolute;border-radius:12px;box-shadow:0 0 0 9999px rgba(20,23,26,.58);
    transition:all .28s cubic-bezier(.4,0,.2,1);pointer-events:none}
  .tour-card{position:absolute;width:300px;max-width:calc(100vw - 28px);background:var(--paper);
    border:1px solid var(--ink-150);border-radius:var(--r-md);box-shadow:0 18px 50px -18px rgba(20,23,26,.6);
    padding:18px;transition:top .28s,left .28s}
  /* первый показ тура — без анимации (иначе карточка/спот «переезжают» с дефолтной позиции) */
  .tour-spot.tp-instant,.tour-card.tp-instant{transition:none}
  .tour-card .tc-step{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.07em;text-transform:uppercase;
    color:var(--ink-400);font-weight:600;margin-bottom:6px}
  .tour-card h4{margin:0 0 6px;font-size:16px;letter-spacing:-.01em;color:var(--ink-900)}
  .tour-card p{margin:0 0 14px;font-size:13.5px;line-height:1.5;color:var(--ink-600)}
  .tour-foot{display:flex;align-items:center;justify-content:space-between;gap:8px}
  .tour-dots{display:flex;gap:5px}
  .tour-dots i{width:6px;height:6px;border-radius:50%;background:var(--ink-200);transition:background .2s}
  .tour-dots i.on{background:var(--ink-900)}
  .tour-btns{display:flex;gap:7px}
  .tour-btns .btn,.tour-btns .btn-ghost{padding:7px 13px;font-size:13px}
  .tour-skip{position:absolute;top:10px;right:10px;width:28px;height:28px;display:grid;place-items:center;
    border:1px solid var(--ink-200);border-radius:8px;background:var(--paper);color:var(--ink-400);cursor:pointer;
    font-size:13px;line-height:1;transition:background var(--dur-1) var(--ease-out),color var(--dur-1) var(--ease-out),transform .4s var(--ease-out)}
  .tour-skip:hover{background:var(--ink-50);color:var(--ink-900);transform:rotate(90deg)}
  .tour-card .tc-step{padding-right:30px}
  #tour-help{width:30px;height:30px;border-radius:50%;border:1px solid var(--ink-200);background:var(--paper);
    color:var(--ink-500);font-weight:700;cursor:pointer;font-size:14px;line-height:1}
  #tour-help:hover{background:var(--ink-50);color:var(--ink-900)}
  @media (max-width:560px){ .tour-card{width:calc(100vw - 28px)} }

  /* Очередь согласований */
  .q-badge{background:var(--danger-600);color:#fff;border-radius:999px;font-size:10.5px;font-weight:700;
    padding:1px 7px;min-width:18px;text-align:center;font-family:var(--font-mono)}
  .q-head{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}
  .q-h-title{font-size:23px;font-weight:800;letter-spacing:-.02em;color:var(--ink-900)}
  .q-h-count{font-family:var(--font-mono);font-size:11px;font-weight:700;color:#fff;background:var(--danger-600);border-radius:999px;padding:2px 9px}
  .q-hint{margin-left:auto;font-size:12.5px;color:var(--ink-400)}
  .q-hint kbd{font-family:var(--font-mono);font-size:10.5px;background:var(--ink-100);border:1px solid var(--ink-200);border-radius:5px;padding:1px 5px;color:var(--ink-600)}
  .q-list{display:flex;flex-direction:column;gap:14px;max-width:720px}
  .q-card{position:relative;border:1px solid var(--ink-150);border-radius:var(--r-lg);padding:18px 20px;background:var(--paper);
    box-shadow:var(--sh-sm),inset 0 1px 0 rgba(255,255,255,.7);transition:box-shadow var(--dur-1) var(--ease-out)}
  .q-card:hover{box-shadow:var(--sh-md)}
  /* #10: активная карточка для J/K-навигации — акцентная рамка + halo */
  .q-card.is-active{border-color:var(--accent-500);box-shadow:var(--sh-md),0 0 0 3px var(--accent-100)}
  /* #9: «Подробнее» — глубинный просмотр предложения */
  /* S1#33: «Подробнее» — больше воздуха сверху и заметнее (не впритык к контенту) */
  .q-more{margin-top:14px;font-family:var(--font-sans);font-weight:600;font-size:13px;color:var(--ink-700);background:var(--paper);border:1px solid var(--ink-200);border-radius:9px;padding:8px 14px;cursor:pointer;display:inline-flex;align-items:center;gap:7px;transition:background .14s,border-color .14s,color .14s}
  .q-more:hover{background:var(--ink-50);border-color:var(--ink-300);color:var(--ink-900)}
  .q-more:focus-visible{outline:none;box-shadow:0 0 0 3px var(--accent-200)}
  /* S1#34: раскрытый блок деталей — отступ сверху, не впритык к кнопке */
  .q-detail{margin-top:12px}
  .q-detail-inner{border:1px solid var(--ink-150);background:var(--ink-50);border-radius:10px;padding:12px 14px;animation:nlvFade .16s}
  .qd-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:9px;flex-wrap:wrap}
  .qd-title{font-family:var(--font-mono);font-size:10px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-500);font-weight:600}
  .qd-search{font-family:var(--font-sans);font-size:12.5px;color:var(--ink-900);background:var(--paper);border:1px solid var(--ink-200);border-radius:7px;padding:6px 10px;outline:none;min-width:140px}
  .qd-search:focus{border-color:var(--accent-400);box-shadow:0 0 0 3px var(--accent-100)}
  /* S1#35: скроллбар перекрывал ₽-значения справа → резервируем жёлоб + тонкий DS-скроллбар + правый отступ */
  .qd-list{display:flex;flex-direction:column;gap:2px;max-height:260px;overflow-y:auto;scrollbar-gutter:stable;padding-right:4px}
  .qd-list::-webkit-scrollbar{width:8px;height:8px}
  .qd-list::-webkit-scrollbar-thumb{background:var(--ink-200);border:2px solid transparent;background-clip:padding-box;border-radius:999px}
  .qd-list::-webkit-scrollbar-thumb:hover{background:var(--ink-300);border:2px solid transparent;background-clip:padding-box}
  .qd-list::-webkit-scrollbar-track{background:transparent}
  .qd-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:6px 8px;border-radius:6px;font-size:13px;color:var(--ink-800)}
  .qd-row:hover{background:var(--paper)}
  .qd-w{font-weight:500;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .qd-m{font-family:var(--font-mono);font-size:11px;color:var(--ink-400);flex:0 0 auto}
  .qd-ad{padding:8px;border-radius:7px;background:var(--paper);border:1px solid var(--ink-150)}
  .qd-ad-h{font-weight:600;font-size:13px;color:var(--ink-900);margin-bottom:3px}
  .qd-ad-t{font-size:12px;color:var(--ink-500)}
  .q-card.urgent{border-color:#EBC9C5}
  .q-card.urgent::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;border-radius:0 3px 3px 0;background:var(--danger-600)}
  .q-card-top{display:flex;align-items:center;gap:11px;margin-bottom:12px}
  .q-card-top>div{min-width:0}
  .q-ava{width:34px;height:34px;border-radius:9px;background:linear-gradient(157deg,var(--ink-700),var(--ink-900));color:var(--paper);display:grid;
    place-items:center;font-weight:600;font-size:12px;font-family:var(--font-mono);flex:none;box-shadow:inset 0 1px 0 rgba(255,255,255,.12)}
  .q-card.urgent .q-ava{background:linear-gradient(157deg,var(--danger-600),#9A2F28)}
  .q-client{font-weight:700;font-size:14px;color:var(--ink-900);overflow-wrap:anywhere}
  .q-sub{font-family:var(--font-mono);font-size:11px;color:var(--ink-400);text-transform:uppercase;letter-spacing:.04em}
  .q-tag{margin-left:auto;font-size:11px;font-weight:700;color:var(--warn-600);background:var(--warn-100);
    border-radius:999px;padding:4px 10px;white-space:nowrap}
  .q-tag.urgent{color:var(--danger-600);background:var(--danger-100)}
  .q-title{font-weight:700;font-size:16px;color:var(--ink-900);margin-bottom:12px;letter-spacing:-.01em;overflow-wrap:anywhere}
  /* Diff БЫЛО→СТАНЕТ: grid 1fr-auto-1fr */
  .q-diff{display:grid;grid-template-columns:1fr auto 1fr;gap:12px;align-items:stretch;margin-bottom:12px}
  .q-box{border-radius:var(--r-sm);padding:11px 13px;min-width:0;overflow-wrap:anywhere}
  .q-box .ql{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-400);font-weight:600;display:block;margin-bottom:5px}
  .q-was{background:var(--ink-50);border:1px solid var(--ink-150)}
  .q-was s{font-size:12.5px;color:var(--ink-500);text-decoration:line-through}
  .q-will{background:var(--accent-50);border:1px solid var(--accent-300)}
  .q-will .qhero{font-family:var(--font-mono);font-size:15px;font-weight:700;color:var(--accent-700);line-height:1.3}
  .q-will .qhero-num{font-family:var(--font-mono);font-size:22px;font-weight:700;color:var(--accent-700);line-height:1.15;display:block;letter-spacing:-.02em}
  .q-will .qhero-sub{display:block;font-size:12.5px;color:var(--ink-600);margin-top:3px;line-height:1.35}
  .q-arr{display:flex;align-items:center;color:var(--ink-300)}
  .q-gain{font-size:12.5px;color:var(--ink-500);margin:-4px 0 12px}
  .q-stats{display:flex;gap:22px;margin-bottom:10px}
  .q-stat span{display:block;font-size:11px;color:var(--ink-400);margin-bottom:1px} .q-stat b{font-family:var(--font-mono);font-size:18px;color:var(--ink-900)} .q-stat b.acc{color:var(--accent-700)}
  .q-result{font-size:13.5px;color:var(--ink-600);margin-bottom:6px}
  .q-note{font-size:13.5px;color:var(--ink-600);line-height:1.5;margin-bottom:12px}
  .q-conf{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--ink-400);margin-bottom:14px}
  .q-bars{display:inline-flex;gap:2px} .q-bars i{width:4px;height:12px;border-radius:1px;background:var(--ink-150)} .q-bars i.on{background:var(--accent-500)}
  .q-conf b{color:var(--ink-700);font-size:12px} .q-foot{color:var(--ink-400)}
  .q-actions{display:flex;gap:8px;align-items:center}
  .q-ok{background:linear-gradient(180deg,var(--accent-500),var(--accent-700));color:#fff;border:0;border-radius:10px;padding:11px 16px;font-weight:700;font-size:13px;
    display:inline-flex;align-items:center;gap:8px;box-shadow:inset 0 1px 0 rgba(255,255,255,.18),0 2px 6px rgba(11,110,71,.22)}
  .q-ok:hover{background:linear-gradient(180deg,var(--accent-600),var(--accent-700))}
  .q-ok .ek{font-family:var(--font-mono);font-size:10px;font-weight:700;background:rgba(255,255,255,.22);border-radius:5px;padding:1px 6px}
  .q-edit{font-weight:600;font-size:13px;color:var(--ink-700);background:var(--paper);border:1px solid var(--ink-200);border-radius:10px;padding:10px 15px}
  .q-edit:hover{background:var(--ink-50)}
  .q-rej{background:none;border:0;color:var(--danger-600);font-weight:600;font-size:13px;margin-left:auto;padding:8px}
  .q-empty{text-align:center;padding:40px 20px;max-width:480px;margin:0 auto}
  .q-e-check{position:relative;width:64px;height:64px;margin:0 auto 18px;border-radius:18px;display:grid;place-items:center;
    background:var(--accent-50);border:1px solid var(--accent-300);color:var(--accent-600)}
  .q-e-check::after{content:"";position:absolute;inset:-18px;background:radial-gradient(circle,rgba(18,165,107,.18),transparent 65%);z-index:-1;filter:blur(6px)}
  .q-e-h{font-size:22px;font-weight:800;letter-spacing:-.025em;color:var(--ink-900);margin-bottom:6px}
  .q-e-s{font-size:13.5px;color:var(--ink-500);line-height:1.5;margin-bottom:18px}
  .q-e-hint{font-size:12px;color:var(--ink-400)}
  /* masked-превью будущей карточки в пустом состоянии (как в макете) */
  .q-e-preview{position:relative;max-width:420px;margin:26px auto 0;border:1px dashed var(--ink-200);border-radius:var(--r-lg);
    background:linear-gradient(var(--paper),var(--ink-50));padding:16px 18px;text-align:left;overflow:hidden;
    -webkit-mask-image:linear-gradient(180deg,#000 0%,#000 45%,transparent 100%);mask-image:linear-gradient(180deg,#000 0%,#000 45%,transparent 100%)}
  .q-e-pv-top{display:flex;align-items:center;gap:9px;margin-bottom:10px}
  .q-e-pv-ava{width:28px;height:28px;border-radius:8px;background:var(--ink-150)}
  .q-e-pv-line{height:9px;border-radius:5px;background:var(--ink-150)}
  .q-e-pv-diff{display:grid;grid-template-columns:1fr auto 1fr;gap:10px;align-items:center;margin-top:6px}
  .q-e-pv-box{height:46px;border-radius:var(--r-sm);background:var(--ink-50);border:1px solid var(--ink-150)}
  .q-e-pv-box.will{background:var(--accent-50);border-color:var(--accent-300)}
  .q-e-hint kbd{font-family:var(--font-mono);font-size:10.5px;background:var(--ink-100);border:1px solid var(--ink-200);border-radius:5px;padding:1px 5px}
  @media(max-width:560px){
    .q-diff{grid-template-columns:1fr} .q-arr{transform:rotate(90deg);justify-content:center}
    .q-actions{flex-wrap:wrap} .q-ok{flex:1 1 100%;justify-content:center} .q-rej{margin-left:0} .q-list{max-width:100%}
    .q-hint{margin-left:0;flex-basis:100%}
  }

  /* ── Предложения (Founder Review, self-learning Фаза 3) ── */
  /* #5/#15 интро «как это работает» — чистая нейтральная карточка (без зелёного wash), emerald точечно */
  .pr-intro{border:1px solid var(--ink-150);border-radius:var(--r-lg,14px);background:var(--paper);padding:16px 18px;margin-bottom:16px;box-shadow:var(--sh-xs)}
  .pr-intro-h{display:flex;align-items:center;gap:9px;font-weight:700;font-size:14px;color:var(--ink-900);margin-bottom:9px}
  .pr-intro-h svg{color:var(--accent-600,#0E8A57)}
  .pr-intro-p{margin:0 0 13px;font-size:13px;line-height:1.55;color:var(--ink-600)} .pr-intro-p b{color:var(--ink-900)}
  .pr-intro-note{display:flex;align-items:flex-start;gap:8px;font-size:12px;line-height:1.5;color:var(--ink-500);border-top:1px solid var(--ink-100);padding-top:11px}
  .pr-intro-note svg{flex:0 0 auto;color:var(--ink-400);margin-top:1px}
  /* #6 главная навигация «Новые / История» — скользящий БЕЛЫЙ индикатор (единый стиль со всеми табами) */
  .pr-tabs{position:relative;display:inline-flex;gap:0;margin-bottom:14px;padding:3px;background:var(--ink-50);border:1px solid var(--ink-150);border-radius:10px}
  .nlv-thumb{position:absolute;top:3px;bottom:3px;left:0;width:0;border-radius:7px;z-index:0;opacity:0;
    transition:left .42s cubic-bezier(.34,1.2,.4,1),width .42s cubic-bezier(.34,1.2,.4,1),opacity .15s linear}
  .pr-tabs .nlv-thumb{background:var(--paper);box-shadow:var(--sh-sm),inset 0 1px 0 rgba(255,255,255,.8)}
  .pr-tab{position:relative;z-index:1;display:inline-flex;align-items:center;gap:7px;font-weight:600;font-size:13px;color:var(--ink-500);background:transparent;border:0;border-radius:7px;padding:8px 15px;cursor:pointer;white-space:nowrap;transition:color .2s var(--ease-out)}
  .pr-tab:active{transform:scale(.98)}
  .pr-tab:hover:not(.on){color:var(--ink-800)}
  .pr-tab.on{font-weight:700;color:var(--ink-900)}
  .pr-tab:focus-visible{outline:none;box-shadow:0 0 0 2px var(--accent-300)}
  .pr-tab-n{font:600 11px/1 var(--font-mono);background:var(--ink-100);color:var(--ink-500);border-radius:999px;padding:2px 7px;transition:background .2s var(--ease-out),color .2s var(--ease-out)}
  .pr-tab.on .pr-tab-n{background:var(--accent-100);color:var(--accent-700)}
  /* #5 «почему предложено» на карточке */
  .pr-why{font-size:12.5px;line-height:1.5;color:var(--ink-600);background:var(--ink-50);border:1px solid var(--ink-100);border-radius:9px;padding:9px 12px;margin-bottom:12px}
  .pr-why-l{display:block;font:600 10px/1 var(--font-mono);letter-spacing:.07em;text-transform:uppercase;color:var(--ink-400);margin-bottom:4px}
  .pr-list{display:flex;flex-direction:column;gap:12px}
  .pr-card{border:1px solid var(--ink-150);border-radius:var(--r-lg);padding:16px 18px;background:var(--paper);transition:box-shadow .16s}
  .pr-card:hover{box-shadow:var(--sh-md)}
  .pr-card.sk-card:hover{box-shadow:none}
  .pr-top{display:flex;align-items:center;gap:8px;margin-bottom:10px;flex-wrap:wrap}
  .pr-kind{font-family:var(--font-mono);font-size:9.5px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;
    border-radius:6px;padding:3px 8px;background:var(--accent-100);color:var(--accent-700)}
  .pr-kind.idea{background:var(--warn-100);color:var(--warn-600)}
  .pr-st{font-size:11px;font-weight:700;border-radius:7px;padding:3px 9px}
  .pr-st.hyp{background:var(--ink-100);color:var(--ink-600)}
  .pr-st.ok{background:var(--accent-100);color:var(--accent-700)}
  .pr-st.rej{background:var(--danger-100);color:var(--danger-600)}
  .pr-fstatus{margin-left:auto;font-size:11.5px;font-weight:600;color:var(--ink-500);font-family:var(--font-mono)}
  .pr-title{font-size:15px;font-weight:700;line-height:1.4;letter-spacing:-.01em;color:var(--ink-900);margin-bottom:10px}
  .pr-meta{display:flex;align-items:center;gap:14px;flex-wrap:wrap;font-size:12px;color:var(--ink-400);margin-bottom:12px}
  .pr-conf{display:inline-flex;align-items:center;gap:7px}
  .pr-bars{display:inline-flex;gap:2px} .pr-bars i{width:5px;height:12px;border-radius:1px;background:var(--ink-150)} .pr-bars i.on{background:var(--accent-500)}
  .pr-conf b{color:var(--ink-700);font-size:12px;font-weight:700}
  .pr-ev{color:var(--ink-500)}
  .pr-lift{color:var(--accent-700);font-weight:700;font-variant-numeric:tabular-nums}
  .pr-toggle{background:none;border:0;color:var(--ink-500);font-size:12.5px;font-weight:600;padding:0;cursor:pointer;margin-bottom:12px}
  .pr-toggle:hover{color:var(--ink-900)}
  .pr-detail{display:flex;flex-direction:column;gap:7px;margin:4px 0 14px;padding:13px 15px;background:var(--ink-50);border-radius:var(--r-md);border:1px solid var(--ink-100)}
  .pr-detail.hidden{display:none}
  /* #3 развёрнутое обоснование — связный текст, а не одно слово */
  .pr-detail-p{margin:0;font-size:13px;line-height:1.6;color:var(--ink-700)}
  .pr-detail-sub{font:600 10px/1 var(--font-mono);letter-spacing:.07em;text-transform:uppercase;color:var(--ink-400);margin-top:6px}
  .pr-ex{display:flex;gap:6px;flex-wrap:wrap}
  .pr-chip{font-size:11px;font-weight:600;color:var(--ink-600);background:var(--paper);border:1px solid var(--ink-150);border-radius:6px;padding:3px 8px}
  .pr-ex-empty{font-size:12.5px;color:var(--ink-400)}
  .pr-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:14px}
  .pr-ok{background:linear-gradient(180deg,var(--accent-500),var(--accent-700));color:#fff;border:0;border-radius:10px;padding:10px 16px;font-weight:700;font-size:13px;cursor:pointer;transition:background .14s,transform .14s}
  .pr-ok:hover{background:linear-gradient(180deg,var(--accent-600),var(--accent-700));transform:translateY(-1px)}
  .pr-defer,.pr-rej{background:var(--paper);border:1px solid var(--ink-200);border-radius:10px;padding:10px 14px;font-weight:600;font-size:13px;color:var(--ink-700);cursor:pointer;transition:background var(--dur-1) var(--ease-out),border-color var(--dur-1) var(--ease-out),color var(--dur-1) var(--ease-out),transform var(--dur-1) var(--ease-out),box-shadow var(--dur-1) var(--ease-out)}
  .pr-defer:hover{background:var(--ink-50);transform:translateY(-1px);box-shadow:0 2px 8px rgba(20,23,26,.08)}
  /* S1#6: «Одобрить»/«Отклонить» рядом, «Отклонить» — secondary-danger */
  .pr-rej{color:var(--danger-600);border-color:var(--danger-150,var(--danger-100))}
  .pr-rej:hover{background:var(--danger-50,#FDECEC);border-color:var(--danger-300,#EBA8A8);color:var(--danger-700,#C0392B);transform:translateY(-1px);box-shadow:0 2px 8px rgba(192,57,43,.1)}
  /* S1#8 / #6: вторичный суб-фильтр Истории — скользящий БЕЛЫЙ индикатор (единый стиль со всеми табами) */
  .pr-filter{position:relative;display:inline-flex;gap:0;margin-bottom:14px;padding:3px;background:var(--ink-50);border:1px solid var(--ink-100);border-radius:999px}
  .pr-filter .nlv-thumb{background:var(--paper);border-radius:999px;box-shadow:var(--sh-sm),inset 0 1px 0 rgba(255,255,255,.8)}
  .pr-fchip{position:relative;z-index:1;display:inline-flex;align-items:center;gap:6px;background:transparent;border:0;border-radius:999px;padding:6px 13px;font:600 12.5px/1 var(--font-sans);color:var(--ink-500);cursor:pointer;white-space:nowrap;transition:color .2s var(--ease-out)}
  .pr-fchip:active{transform:scale(.98)}
  .pr-fchip:hover:not(.on){color:var(--ink-800)}
  .pr-fchip.on{font-weight:700;color:var(--ink-900)}
  .pr-fchip:focus-visible{outline:none;box-shadow:0 0 0 2px var(--accent-300)}
  .pr-fchip-n{font-family:var(--font-mono);font-size:11px;color:var(--ink-400);transition:color .2s var(--ease-out)}
  .pr-fchip.on .pr-fchip-n{color:var(--ink-600)}
  /* S1#9: отклонённая запись в Истории — нейтрально-красный бейдж */
  .pr-final-badge.rej{background:linear-gradient(160deg,var(--danger-50,#FDECEC),var(--paper));border-color:var(--danger-100,#F7D4D4)}
  .pr-final-badge.rej .pr-fb-ic{background:linear-gradient(155deg,var(--danger-500,#E0564E),var(--danger-600,#C9443D))}
  .pr-final-badge.rej .pr-fb-t b{color:var(--danger-600)}
  /* #4b/#18/#29 финал-запись в «Истории» — бейдж решения с воздухом + кнопка-ghost возврата */
  .pr-final{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
  .pr-final-badge{display:inline-flex;align-items:center;gap:13px;padding:11px 18px 11px 13px;border-radius:14px;
    background:linear-gradient(160deg,var(--accent-50,#EFF9F3),var(--paper));border:1px solid #CFEBDD;
    box-shadow:var(--sh-xs),inset 0 1px 0 rgba(255,255,255,.6)}
  .pr-fb-ic{flex:0 0 auto;display:grid;place-items:center;width:30px;height:30px;border-radius:9px;color:#fff;
    background:linear-gradient(155deg,var(--accent-500,#12A56B),var(--accent-700,#0B6E47));
    box-shadow:inset 0 1px 0 rgba(255,255,255,.25)}
  .pr-fb-ic svg{display:block}
  .pr-fb-t{display:flex;flex-direction:column;gap:5px;line-height:1.2}
  .pr-fb-t b{font-weight:700;font-size:13.5px;letter-spacing:-.01em;color:var(--accent-700,#0B6E47)}
  .pr-fb-t i{font-style:normal;font-size:9.5px;font-weight:600;font-family:var(--font-mono);letter-spacing:.05em;text-transform:uppercase;color:var(--ink-400)}
  .pr-undo{margin-left:auto;display:inline-flex;align-items:center;gap:7px;background:var(--paper);border:1px solid var(--ink-200);
    color:var(--ink-600);font:600 12.5px/1 var(--font-sans);cursor:pointer;padding:9px 13px;border-radius:9px;
    transition:background var(--dur-1) var(--ease-out),border-color var(--dur-1) var(--ease-out),color var(--dur-1) var(--ease-out)}
  .pr-undo svg{color:var(--ink-400);transition:color var(--dur-1) var(--ease-out)}
  .pr-undo:hover{background:var(--ink-50);border-color:var(--ink-300);color:var(--ink-900)}
  .pr-undo:hover svg{color:var(--ink-600)}
  .pr-empty{text-align:center;padding:40px 20px;max-width:460px;margin:0 auto}
  .pr-e-ic{width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;
    background:var(--accent-100);color:var(--accent-700)}
  .pr-e-h{font-size:16px;font-weight:700;color:var(--ink-900);margin-bottom:6px}
  .pr-e-s{font-size:13.5px;color:var(--ink-400);line-height:1.5}
  @media(max-width:560px){
    .pr-actions{flex-wrap:wrap} .pr-ok{flex:1 1 100%;justify-content:center;text-align:center}
    .pr-defer,.pr-rej{flex:1 1 auto;text-align:center} .pr-rej{margin-left:0}
    .pr-meta{gap:10px}
    /* #6 на узком — тёмные табы тянем на всю ширину (главная навигация), серый фильтр остаётся inline */
    .pr-tabs{display:flex;width:100%} .pr-tab{flex:1 1 0;justify-content:center;padding:9px 8px}
    .pr-filter{flex-wrap:nowrap;max-width:100%;overflow:auto} .pr-fchip{padding:6px 11px}
    /* #4b бейдж + кнопка возврата в столбик, чтобы текст дышал */
    .pr-final{flex-direction:column;align-items:stretch;gap:10px}
    .pr-final-badge{width:100%} .pr-undo{margin-left:0;justify-content:center}
  }

  /* Раскладка */
  .layout{display:flex;min-height:calc(100vh - 55px)}
  aside#sidebar{width:264px;flex:0 0 264px;background:var(--paper);
    border-right:1px solid var(--ink-150);padding:16px 14px;display:flex;flex-direction:column;gap:6px}
  main#content{flex:1;padding:22px;min-width:0}
  .side-title{font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.08em;
    color:var(--ink-400);font-weight:600;margin:4px 0}
  /* Шапка секции сайдбара: лейбл + «+ Новый» */
  .side-head{display:flex;align-items:center;justify-content:space-between;margin:2px 2px 8px}
  /* «+ Новый» — ghost (без зелёной обводки): ink-текст, прозрачный фон, mono-плюс */
  .side-add{font-size:12.5px;font-weight:600;color:var(--ink-700);background:transparent;
    border:1px solid transparent;border-radius:8px;padding:5px 10px;cursor:pointer;
    display:inline-flex;align-items:center;gap:6px;transition:background var(--dur-1) var(--ease-out),color var(--dur-1) var(--ease-out)}
  .side-add svg{color:var(--ink-400)}
  .side-add:hover{background:var(--ink-50);color:var(--ink-900)}
  /* Карточка проекта: avatar-tile + имя/ниша + статус-дот подключения */
  .proj{display:flex;align-items:center;gap:10px;padding:9px 14px 9px 11px;border-radius:var(--r-md);cursor:pointer;
    border:1px solid transparent;position:relative;overflow:visible;
    transition:background var(--dur-1) var(--ease-out),border-color var(--dur-1) var(--ease-out),box-shadow var(--dur-1) var(--ease-out)}
  .proj:hover{background:var(--ink-50)}
  /* active = МИНИМАЛ (решение Артёма 2026-06-26): лёгкая серая скруглённая подложка, БЕЗ белой
     карты/рамки/тени/изумрудной грани. Единый вид для всех ролей (demo/admin/директолог). */
  .proj.active{background:var(--ink-100)}
  .proj .ptile{flex:none;width:34px;height:34px;border-radius:9px;display:grid;place-items:center;
    font-family:var(--font-mono);font-size:12px;font-weight:600;color:#fff;letter-spacing:.02em;
    background:linear-gradient(157deg,var(--ink-700),var(--ink-900));
    box-shadow:inset 0 1px 0 rgba(255,255,255,.12)}
  /* активная карточка НЕ перекрашивает аватар в зелёный — остаётся тёмным (минимал-вид Артёма 2026-06-26) */
  .proj .pbody{min-width:0;flex:1}
  .proj .pn{font-weight:600;color:var(--ink-900);font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .proj .pm{font-size:11.5px;color:var(--ink-400);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  /* #35 (пересборка 2026-06-17): точка+шестерёнка в ОДНОЙ фикс-ячейке 26px — в потоке строки,
     не absolute. Ячейка всегда внутри padding-right → шестерёнка физически не вылезает.
     Свап pdot↔pgear через visibility (а не display) → ноль reflow, ширина ячейки константна. */
  .proj .pcell{flex:none;position:relative;width:26px;height:26px;display:grid;place-items:center}
  .proj .pdot{width:8px;height:8px;border-radius:50%;background:var(--ink-300)}
  .proj .pdot.ok{background:var(--accent-500)} .proj .pdot.warn{background:var(--warn-600)} .proj .pdot.off{background:var(--ink-300)}
  /* S1#39 by-design: hover-фон шестерёнки — круг ≈22px с зазором 2px от краёв ячейки (inset:2px,
     border-radius:50%), ряд .proj уже overflow:visible → фон физически не достаёт скруглённый угол карточки. */
  .proj .pgear{position:absolute;inset:2px;visibility:hidden;display:grid;place-items:center;border:0;background:transparent;
    color:var(--ink-400);border-radius:50%;cursor:pointer;transition:background var(--dur-1) var(--ease-out),color var(--dur-1) var(--ease-out)}
  .proj:hover .pgear,.proj.active .pgear{visibility:visible}
  .proj:hover .pdot,.proj.active .pdot{visibility:hidden}
  .proj .pgear:hover{background:var(--ink-100);color:var(--ink-900)}
  .side-empty{font-size:12.5px;color:var(--ink-400);line-height:1.5;padding:10px;border:1px dashed var(--ink-200);
    border-radius:var(--r-md);background:var(--ink-50);text-align:center}
  /* 01 — Пустое состояние после входа (проект не выбран): hero + бенто 2×2 + diff.
     Фон холста: чистый canvas + лёгкий радиальный градиент к центру (без логотипа/сетки). */
  .app-empty{padding:22px;background:radial-gradient(135% 105% at 50% 24%, var(--canvas) 54%, #F2F3F5 100%)}
  /* #37 — субтильная сетка-подложка для пустых экранов (reuse паттерна #auth .keys-bg).
     ::before z-index:-1 рисуется НАД фоном элемента, но ПОД его текстом → работает даже на боксах со своим фоном. */
  .nlv-grid-bg{position:relative;isolation:isolate}
  .nlv-grid-bg::before{content:"";position:absolute;inset:0;pointer-events:none;z-index:-1;border-radius:inherit;
    background-image:linear-gradient(var(--ink-100) 1px,transparent 1px),linear-gradient(90deg,var(--ink-100) 1px,transparent 1px);
    background-size:40px 40px;opacity:.5;
    -webkit-mask:radial-gradient(120% 95% at 50% 28%,#000 16%,transparent 72%);
    mask:radial-gradient(120% 95% at 50% 28%,#000 16%,transparent 72%)}
  .ae-card{max-width:600px;margin:0 auto;display:flex;flex-direction:column;align-items:center;text-align:center;padding:clamp(28px,7vh,72px) 0 40px}
  .ae-mark{position:relative;width:60px;height:60px;margin-bottom:20px;filter:drop-shadow(0 8px 20px rgba(20,23,26,.18))}
  .ae-mark::after{content:"";position:absolute;inset:-26px;background:radial-gradient(circle,rgba(18,165,107,.20),transparent 65%);filter:blur(10px);z-index:-1;animation:glow 6s ease-in-out infinite}
  @keyframes glow{0%,100%{opacity:.5}50%{opacity:.95}}
  @media(prefers-reduced-motion:reduce){.ae-mark::after{animation:none}}
  .ae-eyebrow{font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
    color:var(--ink-400);font-weight:600;margin-bottom:12px}
  .ae-card h1{font-size:clamp(30px,5vw,40px);font-weight:800;letter-spacing:-.03em;line-height:1.05;margin:0 0 12px;color:var(--ink-900)}
  .ae-card p{color:var(--ink-500);font-size:16px;line-height:1.55;max-width:430px;margin:0 0 26px}
  /* Бенто-сетка 2×2 + полноширинная diff-карточка */
  .bento{display:grid;grid-template-columns:1fr 1fr;gap:12px;width:100%;max-width:600px;margin:30px auto 0;text-align:left}
  .bcard{border-radius:var(--r-md);padding:16px 17px;display:flex;flex-direction:column;gap:8px;min-height:120px;
    transition:transform var(--dur-1) var(--ease-out),box-shadow var(--dur-1) var(--ease-out)}
  .bcard:hover{transform:translateY(-2px)}
  .b-paper{background:var(--paper);border:1px solid var(--ink-150);box-shadow:var(--sh-sm),inset 0 1px 0 rgba(255,255,255,.7)}
  .b-paper:hover{box-shadow:var(--sh-md),inset 0 1px 0 rgba(255,255,255,.7)}
  .b-soft{background:var(--ink-50);border:1px solid var(--ink-150)}
  .b-soft:hover{box-shadow:var(--sh-sm)}
  .b-sig{position:relative;overflow:hidden;padding-left:19px;background:var(--paper);border:1px solid var(--ink-150);box-shadow:var(--sh-sm),inset 0 1px 0 rgba(255,255,255,.7)}
  .b-sig::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--accent-500),var(--accent-700))}
  .b-sig:hover{box-shadow:var(--sh-md),inset 0 1px 0 rgba(255,255,255,.7)}
  .bn{width:25px;height:25px;border-radius:7px;display:grid;place-items:center;font-family:var(--font-mono);font-size:11.5px;font-weight:600;background:var(--ink-100);color:var(--ink-500)}
  .b-soft .bn{background:var(--paper);border:1px solid var(--ink-150)}
  .btt{font-weight:600;font-size:14px;line-height:1.25;color:var(--ink-900);display:flex;align-items:center;gap:7px}
  .b-soft .btt{color:var(--ink-800)}
  .btx{font-size:12px;line-height:1.45;color:var(--ink-500)}
  .ekey{font-family:var(--font-mono);font-size:11px;font-weight:700;color:#fff;background:linear-gradient(180deg,var(--ink-700),var(--ink-900));
    border:1px solid var(--ink-900);border-radius:5px;padding:2px 7px;box-shadow:inset 0 1px 0 rgba(255,255,255,.18),0 1px 0 #0C0E10}
  .bcard-cta{justify-content:flex-start}
  .bcta{margin-top:auto;align-self:flex-start;font:700 13px/1 var(--font-sans);color:#fff;border:0;border-radius:9px;padding:11px 16px;cursor:pointer;
    background:linear-gradient(180deg,var(--ink-700),var(--ink-900));display:inline-flex;align-items:center;gap:7px;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.16),0 2px 0 #0C0E10,0 4px 10px rgba(20,23,26,.24);
    transition:transform var(--dur-1) var(--ease-out),background var(--dur-1) var(--ease-out)}
  .bcta:hover{background:linear-gradient(180deg,var(--ink-600),var(--ink-800));transform:translateY(-1px)}
  .bcta .pl{font-family:var(--font-mono);color:rgba(255,255,255,.55);font-size:14px}
  .b-diff{grid-column:1/-1;background:var(--paper);border:1px solid var(--ink-150);box-shadow:var(--sh-sm),inset 0 1px 0 rgba(255,255,255,.7);
    border-radius:var(--r-md);padding:15px 18px;display:flex;align-items:center;gap:16px;flex-wrap:wrap;min-height:0}
  .b-diff .dl{font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-400);font-weight:600;margin-bottom:4px}
  .b-diff .dtx{font-size:12.5px;color:var(--ink-400);text-decoration:line-through}
  .b-diff .dbig{font-family:var(--font-mono);font-size:24px;font-weight:600;letter-spacing:-.02em;color:var(--accent-700);border-left:3px solid var(--accent-500);padding-left:13px}
  .b-diff .dgain{font-size:12px;color:var(--ink-500);white-space:nowrap}
  /* D6 (Claude Design 2026-06-22): превью реального предложения ИИ на главном экране */
  .ae-d6{grid-column:1/-1}
  .ae-d6-cap{font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-400);font-weight:600;margin-bottom:8px}
  .d6card{background:var(--paper);border:1px solid var(--ink-150);border-radius:var(--r-lg);box-shadow:0 1px 2px rgba(20,23,26,.05),0 8px 24px rgba(20,23,26,.07);overflow:hidden;width:100%}
  .d6-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 18px;border-bottom:1px solid var(--ink-100)}
  .d6-ic{flex:none;width:38px;height:38px;border-radius:10px;background:linear-gradient(160deg,var(--ink-700),var(--ink-900));display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-size:13px;color:#fff;font-family:var(--font-mono)}
  .d6-name{font-size:15px;font-weight:700;color:var(--ink-900);letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .d6-sub{font-size:12.5px;color:var(--ink-400);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .d6-tag{flex:none;display:inline-flex;align-items:center;gap:6px;background:var(--warn-100);border:1px solid #ECD9B0;color:var(--warn-600);font-size:11.5px;font-weight:700;padding:5px 10px;border-radius:999px;white-space:nowrap}
  .d6-body{padding:17px 18px}
  .d6-eyebrow{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-400);margin-bottom:8px}
  .d6-title{margin:0 0 5px;font-size:17px;font-weight:800;letter-spacing:-.015em;color:var(--ink-900)}
  .d6-desc{margin:0 0 16px;font-size:13.5px;line-height:1.5;color:var(--ink-600)}
  .d6-mets{display:flex;gap:10px;margin-bottom:16px}
  .d6-met{flex:1;background:var(--ink-50);border:1px solid var(--ink-150);border-radius:var(--r-md);padding:11px 12px;min-width:0}
  .d6-met-l{font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-400);margin-bottom:7px}
  .d6-met-row{display:flex;align-items:baseline;gap:6px;flex-wrap:wrap}
  .d6-old{font-family:var(--font-mono);font-size:13px;color:var(--ink-300);text-decoration:line-through;white-space:nowrap}
  .d6-new{font-family:var(--font-mono);font-size:18px;font-weight:700;color:var(--accent-700);letter-spacing:-.01em;white-space:nowrap;font-variant-numeric:tabular-nums}
  .d6-flat{font-family:var(--font-mono);font-size:16px;font-weight:700;color:var(--ink-900);letter-spacing:-.01em;white-space:nowrap;font-variant-numeric:tabular-nums}
  .d6-note{font-size:10.5px;color:var(--ink-400);margin-top:2px}
  .d6-conf{margin-bottom:18px}
  .d6-conf-top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:7px}
  .d6-conf-l{font-size:13px;color:var(--ink-600)}
  .d6-conf-v{font-family:var(--font-mono);font-size:14px;font-weight:700;color:var(--accent-700)}
  .d6-bar{height:7px;border-radius:9px;background:var(--ink-100);overflow:hidden}
  .d6-bar>i{display:block;height:100%;width:86%;border-radius:9px;background:linear-gradient(90deg,var(--accent-600),var(--accent-500))}
  .d6-acts{display:flex;align-items:center;gap:7px;flex-wrap:wrap}
  .d6-ghost{display:inline-flex;align-items:center;gap:6px;cursor:pointer;border:1px solid var(--ink-200);border-radius:var(--r-sm);padding:11px 13px;font-family:var(--font-sans);font-size:14px;font-weight:600;color:var(--ink-700);background:var(--paper);transition:all var(--dur-1) var(--ease-out)}
  .d6-ghost:hover{background:var(--ink-50);border-color:var(--ink-300)}
  .d6-rej{display:inline-flex;align-items:center;cursor:pointer;border:1px solid transparent;border-radius:var(--r-sm);padding:11px 12px;font-family:var(--font-sans);font-size:14px;font-weight:600;color:var(--ink-500);background:transparent;transition:all var(--dur-1) var(--ease-out)}
  .d6-rej:hover{color:var(--danger-600);background:var(--danger-100)}
  @media(max-width:640px){ .bento{grid-template-columns:1fr} .d6-mets{flex-wrap:wrap} .d6-met{min-width:calc(50% - 5px)} }

  /* ===== Экран входа — СВЕТЛЫЙ ПРЕМИУМ РЕДИЗАЙН (handoff auth_redesign) =====
     Всё заскоуплено под #auth, чтобы не задеть общие .btn/.tabs/.fld-label/.nlv-* приложения.
     code-попап (nlvVerifyCode) и .nlv-* уже стилизованы в проде — не дублируем. */
  #auth{position:fixed;inset:0;z-index:50;display:flex;overflow:auto;background:var(--canvas);
    font-family:"Manrope",system-ui,-apple-system,sans-serif;color:var(--ink-900);
    -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
  /* S1#19 FOUC: с токеном экран логина НЕ отрисовывается до ответа /api/me; нейтральный фон вместо мелькания */
  html.pre-authed #auth{display:none}
  html.pre-authed body{background:var(--canvas)}
  /* левая сцена: форма */
  /* #18: колонка формы сама скроллит и центрирует карточку через margin:auto —
     если контент выше вьюпорта (после resend растёт блок поддержки), верх не обрезается,
     а карточка прижимается к верху и появляется скролл. */
  #auth .auth-center{flex:1 1 46%;min-width:0;display:flex;align-items:flex-start;justify-content:center;
    overflow-y:auto;max-height:100%;padding:48px 40px}
  #auth .auth-card{width:100%;max-width:384px;margin:auto;background:none;border:0;padding:0;box-shadow:none}
  #auth .auth-brand{display:flex;align-items:center;margin-bottom:34px}
  #auth .auth-brand img{height:26px;width:auto;display:block}
  #auth #au-heading{margin:0;font-weight:800;font-size:33px;line-height:1.06;letter-spacing:-.034em;
    color:var(--ink-900);font-feature-settings:"ss01";text-wrap:balance}
  #auth .sub{margin:11px 0 0;font-weight:500;font-size:15px;line-height:1.5;color:var(--ink-500);max-width:33ch;text-wrap:pretty}
  /* сегмент-табы: скользящая белая пилюля */
  #auth .tabs{position:relative;display:grid;grid-template-columns:1fr 1fr;margin:28px 0 24px;padding:4px;
    background:var(--ink-100);border:1px solid var(--ink-150);border-radius:11px}
  #auth .tabs::before{content:"";position:absolute;top:4px;left:4px;width:calc(50% - 4px);height:calc(100% - 8px);
    background:var(--paper);border-radius:8px;box-shadow:var(--sh-xs),inset 0 1px 0 rgba(255,255,255,.8);
    transition:transform .22s cubic-bezier(.22,1,.36,1)}
  #auth .tabs.reg::before{transform:translateX(100%)}
  #auth .tab{position:relative;z-index:1;text-align:center;padding:10px 0;border-radius:8px;
    font-weight:600;font-size:14px;line-height:1;letter-spacing:.005em;color:var(--ink-500);cursor:pointer;
    user-select:none;transition:color .18s ease}
  #auth .tab:hover{color:var(--ink-700)}
  #auth .tab.active{color:var(--ink-900)}
  /* поля */
  #auth .fld-label{display:block;margin:0 0 7px;font-weight:600;font-size:12px;line-height:1;letter-spacing:.01em;color:var(--ink-600)}
  #auth #au-main .fld-label + input{margin-bottom:13px}
  /* S1#20: на экране восстановления поля были впритык к следующему лейблу — единый отступ */
  #auth #au-reset-req .fld-label + input,
  #auth #au-reset-set .fld-label + input{margin-bottom:14px}
  /* #2: лейбл «Электронная почта» в #au-reset-req убран (дублировал подзаголовок+placeholder).
     Поле идёт сразу за подзаголовком (#au-subline) — даём воздух сверху, чтобы не слиплось. */
  #auth #au-reset-req #rr-email{margin-top:22px;margin-bottom:14px}
  /* #3: блок поддержки (Telegram/MAX) на экране запроса при A4-блоке — воздух от кнопки «Отправить код» */
  #auth #au-reset-req #rr-support:not(.hidden){margin-top:16px}
  #auth #au-reset-set .fld-label{margin-top:2px}
  /* #6 (2026-06-25): на reset-экранах между подзаголовком (#au-subline) и ПЕРВЫМ лейблом не было
     воздуха (на #au-main его даёт блок табов) — добавляем единый верхний отступ первому лейблу. */
  #auth #au-reset-set > .fld-label:first-child,
  #auth #au-reset-req > .fld-label:first-child{margin-top:24px}
  /* #16/#17: один экран — код, таймер, новый пароль, подтверждение. Таймер «Код действителен ещё MM:SS»
     стоит между полем кода и лейблом «Новый пароль» — нужен внятный воздух с обеих сторон. */
  #auth .rs-timer{min-height:15px;font-size:12px;line-height:1;color:var(--ink-400);font-family:var(--font-mono)}
  #auth #au-reset-set #rs-code{margin-bottom:8px}            /* код → таймер компактно */
  #auth #au-reset-set #rs-timer{margin:0 0 16px}            /* #17: воздух между таймером и лейблом «Новый пароль» */
  /* «Новый пароль» оборачивается enhancePwdField в .pwd-wrap — задаём отступ до «Повторите пароль» */
  #auth #au-reset-set .fld-label + .pwd-wrap{margin-bottom:14px}
  /* S1#31: обёртка пароля + «глаз» (native, не ломает автозаполнение) */
  #auth #au-main .fld-label + .au-pwd-wrap{margin-bottom:13px}
  #auth .au-pwd-wrap{position:relative}
  /* #24: .auth-card input ниже по каскаду перебивал padding-right → текст лез под «глаз».
     Поднимаем специфичность (.auth-card .au-pwd-wrap input) + запас под кнопку-глаз (right:6+w:42). */
  #auth .auth-card .au-pwd-wrap input{padding-right:52px;margin-bottom:0}
  #auth .au-eye{position:absolute;right:6px;top:0;height:48px;width:42px;display:flex;align-items:center;justify-content:center;background:none;border:0;padding:0;cursor:pointer;color:var(--ink-300);transition:color .14s ease}
  #auth .au-eye:hover{color:var(--ink-600)}
  #auth .au-eye:focus-visible{outline:none;color:var(--ink-700)}
  #auth .auth-card input{width:100%;height:48px;padding:0 14px;border:1px solid var(--ink-150);
    border-radius:var(--r-sm,8px);background:var(--paper);color:var(--ink-900);font-family:inherit;font-weight:500;font-size:15px;line-height:1;
    transition:border-color .14s ease,box-shadow .14s ease,background .14s ease}
  #auth .auth-card input::placeholder{color:var(--ink-300)}
  #auth .auth-card input:hover{border-color:var(--ink-200)}
  #auth .auth-card input:focus{outline:none;border-color:var(--ink-300);box-shadow:0 0 0 3px rgba(20,23,26,.05)}
  /* ошибка (JS красит инлайн — не перебиваем) */
  #auth .auth-err{font-weight:500;font-size:13px;line-height:1.45;color:var(--danger-600)}
  /* #5 (2026-06-25): почта не зарегистрирована — предупреждающий блок + выход на регистрацию. */
  #auth .au-noemail{display:flex;align-items:flex-start;gap:9px;margin:2px 0 10px;padding:11px 13px;
    background:var(--warn-100);border:1px solid #E7D3AE;border-radius:10px;text-align:left}
  #auth .au-noemail-ic{flex:none;margin-top:1px;color:var(--warn-600)}
  #auth .au-noemail-tx{min-width:0;display:flex;flex-direction:column;gap:2px}
  #auth .au-noemail-tx b{font-weight:700;font-size:13px;line-height:1.3;color:var(--ink-900)}
  #auth .au-noemail-tx span{font-weight:500;font-size:12.5px;line-height:1.45;color:var(--ink-600)}
  #auth .au-noemail-cta{width:100%;justify-content:center;margin:0 0 2px}
  #auth .auth-err:not(:empty){margin-top:13px}
  /* кнопка «Войти»: метка слева + keycap-токен со стрелкой справа (::before переживает смену textContent) */
  #auth .btn{position:relative;display:flex;align-items:center;justify-content:center;width:100%;height:54px;margin-top:18px;
    border:none;border-radius:12px;cursor:pointer;font-family:inherit;font-weight:600;font-size:15px;letter-spacing:.005em;color:#fff;
    background:var(--ink-900);
    box-shadow:0 1px 2px rgba(20,23,26,.18),0 10px 22px rgba(20,23,26,.16),inset 0 1px 0 rgba(255,255,255,.10);
    transition:transform .16s ease,box-shadow .22s ease,background .22s ease}
  #auth .btn:hover{background:var(--ink-800);box-shadow:0 2px 4px rgba(20,23,26,.16),0 16px 34px rgba(20,23,26,.22),inset 0 1px 0 rgba(255,255,255,.12)}
  #auth .btn:active{transform:translateY(1px);box-shadow:0 1px 2px rgba(20,23,26,.18),inset 0 1px 0 rgba(255,255,255,.06)}
  #auth .btn:focus-visible{outline:none;box-shadow:0 0 0 3px var(--accent-200),0 10px 22px rgba(20,23,26,.16),inset 0 1px 0 rgba(255,255,255,.10)}
  #auth .btn[disabled]{opacity:.55;cursor:default;transform:none}
  #auth .btn[aria-busy="true"]{color:transparent;pointer-events:none}
  #auth .btn[aria-busy="true"]::after{content:"";position:absolute;inset:0;margin:auto;width:18px;height:18px;border-radius:50%;
    border:2px solid rgba(255,255,255,.32);border-top-color:#fff;animation:nlvSpin .7s linear infinite}
  #auth #au-submit{justify-content:flex-start;padding:0 58px 0 22px}
  #auth #au-submit::before{content:"";position:absolute;right:8px;top:50%;transform:translateY(-50%);width:38px;height:38px;border-radius:10px;
    background-color:rgba(255,255,255,.12);
    background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none'><path d='M5 12h13M12 6l6 6-6 6' stroke='white' stroke-width='1.9' stroke-linecap='round' stroke-linejoin='round'/></svg>");
    background-repeat:no-repeat;background-position:center;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.16),inset 0 -1px 0 rgba(0,0,0,.22);
    transition:transform .22s cubic-bezier(.22,1,.36,1),background-color .2s ease,opacity .16s ease;pointer-events:none}
  #auth #au-submit:hover::before{background-color:rgba(255,255,255,.20);transform:translateY(-50%) translateX(3px)}
  #auth #au-submit:active::before{transform:translateY(-50%) translateX(1px) scale(.95)}
  #auth #au-submit[aria-busy="true"]::before{opacity:0}
  #auth .auth-card a{transition:color .15s ease}
  #auth .auth-card a:hover{color:var(--ink-700) !important}
  #auth .auth-card a:focus-visible{outline:2px solid var(--ink-900);outline-offset:3px;border-radius:3px}
  /* ── Правая сцена: «Ты выходишь из рубки» (бренд-анимация) ───────────── */
  .auth-aside{
    flex:1 1 56%; min-width:0; position:relative; overflow:hidden;
    display:flex; align-items:center; justify-content:center; padding:44px;
    background:var(--ink-50);
    border-left:1px solid var(--ink-150);
  }
  .nlv-stage{ position:relative; width:520px; height:524px; flex:0 0 auto; border-radius:22px; overflow:hidden;
    background:radial-gradient(118% 100% at 82% 26%, #ffffff, var(--canvas) 60%);
    border:1px solid var(--ink-150);
    box-shadow:0 16px 40px rgba(20,23,26,.12), 0 4px 10px rgba(20,23,26,.05); }
  .nlv-keys{ position:absolute; inset:0; pointer-events:none; opacity:.5;
    background-image:linear-gradient(var(--ink-100) 1px,transparent 1px),linear-gradient(90deg,var(--ink-100) 1px,transparent 1px);
    background-size:48px 48px;
    -webkit-mask:radial-gradient(92% 80% at 20% 30%,#000 18%,transparent 68%);
            mask:radial-gradient(92% 80% at 20% 30%,#000 18%,transparent 68%); }
  .nlv-life-glow{ position:absolute; left:300px; top:42px; width:212px; height:212px; border-radius:50%;
    pointer-events:none; opacity:0; transform:scale(.72); transform-origin:center;
    transition:opacity 1s ease, transform 1.1s cubic-bezier(.22,1,.36,1);
    background:radial-gradient(circle, rgba(18,165,107,.17), rgba(18,165,107,.05) 44%, rgba(18,165,107,0) 68%); }
  .nlv-stage.nlv-life .nlv-life-glow{ opacity:1; transform:none; }
  .nlv-eyebrow{ position:absolute; top:24px; left:30px; z-index:8;
    font-family:"JetBrains Mono",monospace; font-weight:600; font-size:10.5px;
    letter-spacing:.15em; text-transform:uppercase; color:var(--ink-400); }

  .nlv-path-svg{ position:absolute; inset:0; width:520px; height:524px; pointer-events:none; z-index:2; }
  .nlv-path-line{ fill:none; stroke:var(--ink-200); stroke-width:2; stroke-dasharray:5 7; stroke-linecap:round; }
  .nlv-path-prog{ fill:none; stroke:var(--accent-500); stroke-width:2.5; stroke-linecap:round;
    stroke-dasharray:200; stroke-dashoffset:200; transition:stroke-dashoffset 1.9s cubic-bezier(.5,0,.2,1); }
  .nlv-stage.nlv-walk .nlv-path-prog{ stroke-dashoffset:0; }

  .nlv-trail{ position:absolute; z-index:3; border-radius:50%; pointer-events:none;
    background:radial-gradient(circle, rgba(18,165,107,.55), rgba(18,165,107,0) 70%);
    opacity:0; transform:scale(.4); transition:opacity .5s ease, transform .5s ease; }
  .nlv-stage.nlv-walk .nlv-trail{ transform:none; }
  .nlv-stage.nlv-walk .nlv-t1{ opacity:.12; transition-delay:.5s; }
  .nlv-stage.nlv-walk .nlv-t2{ opacity:.22; transition-delay:.85s; }
  .nlv-stage.nlv-walk .nlv-t3{ opacity:.34; transition-delay:1.2s; }

  .nlv-console{ position:absolute; left:30px; top:80px; width:206px; z-index:4;
    background:var(--paper); border:1px solid var(--ink-150); border-radius:16px;
    box-shadow:0 1px 2px rgba(20,23,26,.05), 0 10px 24px rgba(20,23,26,.07);
    padding:15px 15px 16px; }
  .nlv-ct{ display:flex; align-items:center; gap:8px; margin-bottom:13px; }
  .nlv-ct .nlv-mk{ width:22px; height:22px; border-radius:6px; display:block; }
  .nlv-ct b{ font-weight:700; font-size:12.5px; letter-spacing:-.01em; color:var(--ink-800); }
  .nlv-live{ margin-left:auto; display:flex; align-items:center; gap:5px;
    font-family:"JetBrains Mono",monospace; font-size:9px; letter-spacing:.08em; text-transform:uppercase; color:var(--accent-700); }
  .nlv-live i{ width:6px; height:6px; border-radius:50%; background:var(--accent-500); animation:nlvCdot 2.2s ease-out infinite; }
  @keyframes nlvCdot{ 0%{ box-shadow:0 0 0 0 rgba(18,165,107,.45);} 70%,100%{ box-shadow:0 0 0 6px rgba(18,165,107,0);} }
  .nlv-crow{ display:flex; align-items:center; gap:9px; margin:10px 0; }
  .nlv-crow .nlv-nm{ font-family:"JetBrains Mono",monospace; font-size:9px; letter-spacing:.05em; color:var(--ink-400); width:34px; flex:0 0 auto; }
  .nlv-ctrack{ flex:1; height:7px; border-radius:999px; background:var(--ink-100); overflow:hidden; position:relative; }
  .nlv-cfill{ position:absolute; inset:0 auto 0 0; border-radius:999px; width:var(--w,70%);
    background:linear-gradient(90deg, var(--accent-300), var(--accent-500), var(--accent-300));
    background-size:200% 100%; animation:nlvCflow 2.6s linear infinite; }
  @keyframes nlvCflow{ to{ background-position:-200% 0; } }
  .nlv-crow .nlv-ck{ width:15px; height:15px; flex:0 0 auto; color:var(--accent-600); opacity:0; transition:opacity .4s ease; }
  .nlv-stage.nlv-self .nlv-crow .nlv-ck{ opacity:1; }

  .nlv-you{ position:absolute; left:0; top:0; z-index:6; width:44px; height:44px; margin:-22px;
    offset-path:path('M 238 150 C 312 130, 356 134, 404 150'); offset-distance:30%;
    offset-rotate:0deg; transition:offset-distance 1.9s cubic-bezier(.5,0,.2,1); }
  .nlv-stage.nlv-walk .nlv-you{ offset-distance:100%; }
  .nlv-you .nlv-av{ width:44px; height:44px; border-radius:50%;
    background:linear-gradient(180deg,var(--ink-700),var(--ink-900)); color:#fff;
    display:flex; align-items:center; justify-content:center;
    box-shadow:0 6px 16px rgba(20,23,26,.30), inset 0 1px 0 rgba(255,255,255,.18);
    transition:background .6s ease, box-shadow .6s ease; }
  .nlv-stage.nlv-life .nlv-you .nlv-av{ box-shadow:0 6px 18px rgba(18,165,107,.35), 0 0 0 6px rgba(18,165,107,.12), inset 0 1px 0 rgba(255,255,255,.2); }

  .nlv-sun{ position:absolute; right:58px; top:62px; z-index:5; color:var(--accent-500);
    opacity:0; transform:scale(.6); transition:opacity .8s ease, transform .8s cubic-bezier(.22,1,.36,1); }
  .nlv-stage.nlv-life .nlv-sun{ opacity:.95; transform:scale(1); }

  .nlv-guard-unit{ position:absolute; left:50%; bottom:58px; transform:translateX(-50%); z-index:6;
    display:flex; align-items:center; gap:26px; }
  .nlv-guard{ position:relative; width:116px; height:116px; flex:0 0 auto; }
  .nlv-guard svg{ display:block; }
  .nlv-guard .nlv-track{ fill:none; stroke:var(--ink-150); stroke-width:7; }
  .nlv-guard .nlv-prog{ fill:none; stroke:var(--accent-500); stroke-width:7; stroke-linecap:round;
    stroke-dasharray:320.4; stroke-dashoffset:320.4; transform:rotate(-90deg); transform-origin:50% 50%;
    transition:stroke-dashoffset 2.4s linear; }
  .nlv-stage.nlv-guardfill .nlv-guard .nlv-prog{ stroke-dashoffset:0; }
  .nlv-guard .nlv-count{ position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center;
    font-family:"JetBrains Mono",monospace; font-weight:700; font-size:38px; line-height:1;
    letter-spacing:-.03em; color:var(--ink-800); transition:opacity .3s ease; }
  .nlv-guard .nlv-count small{ display:block; font-size:11px; font-weight:600; letter-spacing:.04em; color:var(--ink-400); margin-top:4px; }
  .nlv-guard .nlv-shield{ position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:7px;
    opacity:0; transform:scale(.7); transition:opacity .4s ease, transform .45s cubic-bezier(.22,1,.36,1); }
  .nlv-guard .nlv-shield .nlv-sh{ position:relative; width:26px; height:29px; display:flex; align-items:center; justify-content:center; color:var(--accent-500); }
  .nlv-guard .nlv-shield .nlv-sh svg{ width:26px; height:29px; }
  .nlv-guard .nlv-shield .nlv-sh .nlv-tick{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; }
  .nlv-guard .nlv-shield .nlv-sh .nlv-tick svg{ width:12px; height:12px; color:#fff; }
  .nlv-guard .nlv-shield b{ font-family:"JetBrains Mono",monospace; font-weight:700; font-size:16px; line-height:1; letter-spacing:-.02em; color:var(--ink-900); }
  .nlv-stage.nlv-done .nlv-guard .nlv-count{ opacity:0; }
  .nlv-stage.nlv-done .nlv-guard .nlv-shield{ opacity:1; transform:none; }
  .nlv-guard-text{ display:flex; flex-direction:column; gap:4px; flex:0 0 180px;
    opacity:0; transform:translateX(-8px); transition:opacity .55s ease, transform .55s cubic-bezier(.22,1,.36,1); }
  .nlv-stage.nlv-done .nlv-guard-text{ opacity:1; transform:none; }
  .nlv-guard-text b{ font-weight:700; font-size:15px; letter-spacing:-.01em; color:var(--ink-900); }
  .nlv-guard-text span{ font-weight:500; font-size:12.5px; line-height:1.4; color:var(--ink-400); }

  .nlv-cap{ position:absolute; z-index:7; display:flex; align-items:center; gap:8px;
    font-weight:600; font-size:13px; color:var(--ink-700); white-space:nowrap;
    opacity:0; transition:opacity .5s ease, transform .5s cubic-bezier(.22,1,.36,1); }
  .nlv-cap .nlv-pin{ width:6px; height:6px; border-radius:50%; background:var(--accent-500); flex:0 0 auto; }
  .nlv-cap-self{ left:30px; top:262px; transform:translateY(6px); }
  .nlv-cap-self.nlv-show{ opacity:1; transform:none; }
  .nlv-cap-free{ left:383px; top:183px; transform:translate(-50%,6px); }
  .nlv-cap-free.nlv-show{ opacity:1; transform:translateX(-50%); }

  /* мид-ширина: ужать сцену, чтобы помещалась в панель */
  @media (max-width:1180px){ .nlv-stage{ transform:scale(.85); } }
  @keyframes nlvSpin{to{transform:rotate(360deg)}}
  @keyframes nlvDrift{from{transform:translate(-12px,-8px) scale(.96)}to{transform:translate(18px,10px) scale(1.06)}}
  @keyframes nlvPulse{0%{box-shadow:0 0 0 0 rgba(18,165,107,.42)}70%,100%{box-shadow:0 0 0 7px rgba(18,165,107,0)}}
  @media (max-width:900px){
    #auth{display:block}
    #auth .auth-aside{display:none}
    #auth .auth-center{min-height:100%;padding:40px 22px}
    #auth .auth-card{max-width:400px;margin:0 auto}
    #auth #au-heading{font-size:30px}
  }
  @media (prefers-reduced-motion:reduce){
    .nlv-cfill,.nlv-live i{animation:none}   /* панель «выходишь из рубки» — без зацикленных анимаций (JS даёт статичный финал) */
  }
  .hidden{display:none!important}

  /* Модалки — единый паттерн: затемнение + клик-вне + крестик (Esc тоже) */
  .nlv-overlay{position:fixed;inset:0;background:rgba(20,23,26,.42);z-index:60;display:grid;place-items:center;padding:20px;
    animation:nlvFade .12s ease both}
  .nlv-modal{position:relative;background:var(--paper);border:1px solid var(--ink-150);border-radius:var(--r-xl);
    box-shadow:var(--sh-lg),inset 0 1px 0 rgba(255,255,255,.7);max-height:min(88vh,calc(100vh - 40px));overflow:auto;
    animation:nlvPop .19s cubic-bezier(.34,1.26,.5,1) both}
  /* DS-скроллбар внутри модалок */
  .nlv-modal::-webkit-scrollbar{width:8px;height:8px} .nlv-modal::-webkit-scrollbar-thumb{background:var(--ink-200);border:2px solid transparent;background-clip:padding-box;border-radius:999px}
  .nlv-modal::-webkit-scrollbar-thumb:hover{background:var(--ink-300);border:2px solid transparent;background-clip:padding-box}
  /* #B7 трек не должен залезать на скруглённые углы модалки — инсет сверху/снизу под радиус */
  .nlv-modal::-webkit-scrollbar-track{margin:16px 0;background:transparent}
  @keyframes nlvFade{from{opacity:0}to{opacity:1}}
  @keyframes nlvPop{from{opacity:0;transform:translateY(10px) scale(.985)}to{opacity:1;transform:none}}
  @media(prefers-reduced-motion:reduce){.nlv-overlay,.nlv-modal{animation:none}}
  /* Скролл-лок фона, пока открыта любая модалка (без JS) */
  /* #21: добавлены JS-оверлеи сравнения периодов (#rv-compare-modal директологу, #cli-cmp-ov клиенту) — они fixed, но НЕ .nlv-overlay, поэтому фон скроллился. */
  body:has(.nlv-overlay:not(.hidden)),body:has(#billing-page:not(.hidden)),body:has(#rv-compare-modal),body:has(#cli-cmp-ov){overflow:hidden}
  /* D13: плашка-уведомление (nlv-lowbal) не должна висеть ПОВЕРХ открытого попапа настроек/биллинга.
     Селекторы ТОЧНЫЕ (#account-modal/#billing-page), не общий .nlv-overlay — иначе «осиротевшие» оверлеи ложно скрывают плашку. */
  body:has(#account-modal:not(.hidden)) #nlv-lowbal,body:has(#billing-page:not(.hidden)) #nlv-lowbal{display:none !important}
  .nlv-x{position:absolute;top:14px;right:14px;width:34px;height:34px;display:grid;place-items:center;
    border:1px solid var(--ink-200);border-radius:9px;background:var(--paper);color:var(--ink-400);cursor:pointer;
    transition:background var(--dur-1) var(--ease-out),color var(--dur-1) var(--ease-out),transform .4s var(--ease-out)}
  .nlv-x:hover{background:var(--ink-50);color:var(--ink-900);transform:rotate(90deg)}
  .nlv-x:focus-visible{outline:none;box-shadow:0 0 0 3px var(--accent-200)}

  /* ===== Стандарт «дорогого» попапа (референс handoff_popup_modal) — модификатор .nlv-form ===== */
  /* Применяется ТОЛЬКО к обычным попапам (project/connect/settings/upgrade); исключённые
     (admin/pay/retention/proposals/billing) остаются на базовом .nlv-modal. */
  .nlv-modal.nlv-form{display:flex;flex-direction:column;overflow:hidden;transform-origin:center 30%;
    width:min(600px,100%);max-height:min(88vh,860px);padding:0}
  .nlv-form .nlv-mhead{position:relative;flex:0 0 auto;padding:24px 26px 18px;border-bottom:1px solid var(--ink-150)}
  /* #17 МЕЛКИЕ попапы (confirm/prompt/код): без фикс-шапки и разделительной линии — цельная карточка */
  .nlv-modal.nlv-compact{overflow:visible}
  .nlv-compact .nlv-mhead{border-bottom:0;padding:24px 26px 4px}
  .nlv-compact .nlv-mbody{padding:14px 26px 22px}
  @media(max-width:560px){ .nlv-compact .nlv-mhead{padding:18px 18px 4px} .nlv-compact .nlv-mbody{padding:12px 18px 18px} }
  .nlv-form .nlv-eyebrow{position:static;font-family:var(--font-mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-400);font-weight:600;margin:0 0 7px}
  .nlv-form .nlv-mhead h2{font-size:21px;font-weight:800;letter-spacing:-.02em;margin:0;padding-right:44px;color:var(--ink-900)}
  .nlv-form .nlv-mhead p{margin:7px 0 0;color:var(--ink-500);font-size:14px;line-height:1.5;max-width:90%}
  .nlv-form .nlv-x{top:20px;right:20px;width:34px;height:34px;border-radius:9px}
  .nlv-form .nlv-mbody{flex:1 1 auto;overflow-y:auto;padding:6px 26px 22px;scrollbar-width:thin;scrollbar-color:var(--ink-200) transparent}
  /* единый DS-скроллбар (как глобальный): 8px, серый ink-200, 2px прозрачная рамка */
  .nlv-form .nlv-mbody::-webkit-scrollbar{width:8px;height:8px}
  .nlv-form .nlv-mbody::-webkit-scrollbar-thumb{background:var(--ink-200);border-radius:999px;border:2px solid transparent;background-clip:padding-box}
  .nlv-form .nlv-mbody::-webkit-scrollbar-thumb:hover{background:var(--ink-300);border:2px solid transparent;background-clip:padding-box}
  .nlv-form .nlv-mbody::-webkit-scrollbar-track{background:transparent;margin:8px 0}
  .nlv-section{padding:18px 0 4px;border-top:1px solid var(--ink-100)}
  .nlv-section:first-child{border-top:0}
  #project-modal .nlv-section{border-top:0}   /* #B11 убрать линию-разделитель в «Новый проект» */
  .nlv-section-h{display:flex;align-items:baseline;gap:10px;margin-bottom:14px}
  .nlv-section-l{font-family:var(--font-mono);font-size:11px;letter-spacing:.09em;text-transform:uppercase;color:var(--ink-400);font-weight:600}
  .nlv-section-note{font-size:12px;color:var(--ink-400)}
  .fld{margin-bottom:14px;position:relative} .fld:last-child{margin-bottom:0}
  .fld-lab{display:flex;align-items:center;gap:9px;margin-bottom:7px;flex-wrap:wrap}
  .fld-lab label{font-size:13px;font-weight:600;color:var(--ink-700);white-space:nowrap}
  .nlv-inp{width:100%;font:500 14px/1.2 var(--font-sans);color:var(--ink-900);background:var(--paper);border:1px solid var(--ink-200);border-radius:9px;padding:11px 13px;transition:border-color var(--dur-1) var(--ease-out),box-shadow var(--dur-1) var(--ease-out)}
  .nlv-inp::placeholder{color:var(--ink-300)}
  .nlv-inp:focus{outline:0;border-color:var(--ink-300);box-shadow:0 0 0 3px rgba(20,23,26,.05)}
  .nlv-inp.mono{font-family:var(--font-mono);font-feature-settings:"tnum" 1}
  .nlv-inp.err{border-color:var(--danger-600);box-shadow:0 0 0 3px rgba(199,58,46,.1)}
  /* «как взять?» поповер */
  .qlink{font:600 12.5px/1 var(--font-sans);color:var(--accent-700);background:none;border:0;cursor:pointer;display:inline-flex;align-items:center;gap:5px;padding:2px 0;text-underline-offset:2px}
  .qlink:hover{text-decoration:underline}
  .qlink .qm{width:14px;height:14px;border-radius:50%;border:1.4px solid var(--accent-500);color:var(--accent-700);font-size:9px;font-weight:700;display:grid;place-items:center;font-family:var(--font-mono)}
  .qpop{position:absolute;z-index:60;top:30px;left:0;width:278px;max-width:calc(100% - 4px);background:var(--paper);border:1px solid var(--ink-150);border-radius:12px;box-shadow:var(--sh-lg),inset 0 1px 0 rgba(255,255,255,.7);padding:13px 15px;animation:nlvPopIn .16s var(--ease-out) both}
  /* #B10 портал-режим: fixed у триггера, не обрезается overflow тела модалки */
  .qpop.qpop-fixed{position:fixed;z-index:210;top:auto;width:min(278px,calc(100vw - 20px))}
  @keyframes nlvPopIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}
  .qpop::before{content:"";position:absolute;top:-6px;left:var(--qarrow,22px);width:11px;height:11px;background:var(--paper);border-left:1px solid var(--ink-150);border-top:1px solid var(--ink-150);transform:rotate(45deg)}
  .qpop.qpop-up::before{top:auto;bottom:-6px;border-left:0;border-top:0;border-right:1px solid var(--ink-150);border-bottom:1px solid var(--ink-150)}
  .qpop .ql{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-400);font-weight:600;margin-bottom:6px}
  .qpop .qt{font-size:12.5px;line-height:1.55;color:var(--ink-700)} .qpop .qt b{color:var(--ink-900);font-weight:600}
  .qpop .qx{margin-top:10px;font:600 11.5px/1 var(--font-sans);color:var(--ink-500);background:var(--ink-50);border:1px solid var(--ink-150);border-radius:7px;padding:6px 10px;cursor:pointer}
  .qpop .qx:hover{background:var(--ink-100);color:var(--ink-900)}
  /* #12 поле пароля: тулбар (сгенерировать/показать/требования) + поповер требований с живыми галочками */
  .pwd-wrap{position:relative;flex:1 1 auto;min-width:0}
  .pwd-wrap .pwd-inp{width:100%;padding-right:108px!important;box-sizing:border-box}
  /* full-вариант (генератор: ⟳ генер + копировать + показать + ?) — 4 кнопки, нужно больше места справа */
  .pwd-wrap.pwd-wrap--full .pwd-inp{padding-right:146px!important}
  .pwd-bar{position:absolute;top:50%;right:7px;transform:translateY(-50%);display:flex;align-items:center;gap:2px}
  .pwd-ic{display:grid;place-items:center;width:30px;height:30px;border-radius:7px;border:1px solid transparent;background:transparent;color:var(--ink-400);font:700 13px/1 var(--font-mono);transition:background var(--dur-1) var(--ease-out),color var(--dur-1) var(--ease-out),border-color var(--dur-1) var(--ease-out)}
  .pwd-ic svg{width:16px;height:16px}
  .pwd-ic:hover{background:var(--ink-50);color:var(--ink-700);border-color:var(--ink-150)}
  .pwd-ic.on{color:var(--accent-700);background:var(--accent-50);border-color:var(--accent-300)}
  .pwd-ic.pwd-q{border:1.4px solid var(--ink-200);color:var(--ink-500);width:26px;height:26px;border-radius:50%;font-size:12px}
  .pwd-ic.pwd-q:hover{border-color:var(--accent-500);color:var(--accent-700);background:var(--accent-50)}
  .pwd-pop{padding:12px 14px}
  .qpop.qpop-fixed.pwd-pop{z-index:10001}
  /* #24: маскировка значения для type=text-полей пароля (менеджер браузера не цепляется) */
  .pwd-inp.pwd-mask{-webkit-text-security:disc;text-security:disc}   /* #21 выше оверлея модалки (nlvPrompt inline z9999); спецификация бьёт .qpop.qpop-fixed=210 */
  .pwd-pop::before{display:none}   /* #21: у pwd-поповера свой right-align reposition — стрелка-указатель не нужна */
  .pwd-rule{display:flex;align-items:center;gap:9px;font-size:12.5px;line-height:1.7;color:var(--ink-500)}
  .pwd-rule.ok{color:var(--ink-800)}
  .pwd-rule .pwd-rk{display:grid;place-items:center;width:17px;height:17px;border-radius:50%;flex:0 0 auto;font-size:10px;font-weight:700;background:var(--ink-100);color:var(--ink-400);transition:background var(--dur-1) var(--ease-out),color var(--dur-1) var(--ease-out)}
  .pwd-rule.ok .pwd-rk{background:var(--accent-100);color:var(--accent-700)}
  /* футер формы */
  .nlv-form .nlv-mfoot{flex:0 0 auto;padding:16px 26px;border-top:1px solid var(--ink-150);background:linear-gradient(180deg,var(--paper),var(--ink-50))}
  .nlv-err{display:flex;align-items:center;gap:9px;color:var(--danger-600);font-size:13px;font-weight:500;margin-bottom:12px;padding:9px 12px;background:var(--danger-100);border:1px solid #F0C9C5;border-radius:9px}
  .nlv-err svg{flex:0 0 auto}
  .nlv-actions{display:flex;align-items:center;gap:10px}
  .foot-hint{margin-left:auto;display:inline-flex;align-items:center;gap:8px;font-size:12px;color:var(--ink-400);white-space:nowrap}
  .foot-hint.ok{color:var(--accent-700);font-weight:600}
  /* #25 индикатор готовности у «Создать кабинет»: ○ → ✓ */
  .fh-dot{flex:0 0 auto;display:grid;place-items:center;width:16px;height:16px;border-radius:50%;border:1.6px solid var(--ink-300);color:#fff;transition:background var(--dur-2) var(--ease-out),border-color var(--dur-2) var(--ease-out)}
  .foot-hint.ok .fh-dot{background:var(--accent-500);border-color:var(--accent-500)}
  .fh-dot svg{display:block}
  /* карточки подключений */
  .intg{position:relative;border:1px solid var(--ink-150);border-radius:var(--r-md);background:var(--paper);box-shadow:var(--sh-sm),inset 0 1px 0 rgba(255,255,255,.7);padding:15px 16px;margin-bottom:12px;overflow:hidden;transition:border-color var(--dur-2) var(--ease-out),box-shadow var(--dur-2) var(--ease-out)}
  .intg:last-child{margin-bottom:0}
  .intg::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--ink-150);transition:background var(--dur-2) var(--ease-out)}
  .intg.on{border-color:var(--accent-300)} .intg.on::before{background:linear-gradient(180deg,var(--accent-500),var(--accent-700))}
  .intg-head{display:flex;align-items:center;gap:11px;margin-bottom:14px}
  .intg-ic{width:32px;height:32px;border-radius:9px;display:grid;place-items:center;background:var(--ink-50);border:1px solid var(--ink-150);color:var(--ink-600);flex:0 0 auto;transition:background var(--dur-2) var(--ease-out),color var(--dur-2) var(--ease-out),border-color var(--dur-2) var(--ease-out)}
  .intg.on .intg-ic{background:var(--accent-50);border-color:var(--accent-300);color:var(--accent-700)}
  .intg-name{font-weight:700;font-size:14px;color:var(--ink-900)}
  .intg-name span{display:block;font-family:var(--font-mono);font-size:10px;letter-spacing:.03em;color:var(--ink-400);font-weight:500;margin-top:1px}
  .ichip{margin-left:auto;display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;border-radius:999px;padding:4px 11px;background:var(--ink-100);color:var(--ink-500);white-space:nowrap;transition:background var(--dur-2) var(--ease-out),color var(--dur-2) var(--ease-out)}
  .ichip::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--ink-300)}
  .intg.on .ichip{background:var(--accent-100);color:var(--accent-700)}
  .intg.on .ichip::before{background:var(--accent-500);box-shadow:0 0 0 3px var(--accent-50)}
  /* «← К проектам» — возврат из открытого проекта к списку */
  .proj-back{display:inline-flex;align-items:center;gap:7px;margin-bottom:14px;padding:7px 13px 7px 10px;border-radius:9px;border:1px solid var(--ink-150);background:var(--paper);color:var(--ink-600);font-size:13px;font-weight:600;cursor:pointer;transition:background var(--dur-2) var(--ease-out),color var(--dur-2) var(--ease-out),border-color var(--dur-2) var(--ease-out)}
  .proj-back:hover{background:var(--ink-50);color:var(--ink-900);border-color:var(--ink-300)}
  /* тост */
  .toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%);z-index:10060;display:inline-flex;align-items:center;gap:10px;background:var(--ink-900);color:#fff;border-radius:11px;padding:12px 17px;box-shadow:var(--sh-lg);font-size:13.5px;font-weight:600;animation:nlvToast .3s var(--ease-out) both}
  .toast .tk{width:20px;height:20px;border-radius:50%;background:var(--accent-500);display:grid;place-items:center;color:#fff;flex:0 0 auto}
  /* #B13 типы тостов — иконка-кружок по смыслу (не всегда зелёная галочка) */
  .toast.toast-error .tk{background:var(--danger-600)}
  .toast.toast-warn .tk,.toast.toast-warning .tk{background:var(--warn-600)}
  @keyframes nlvToast{from{opacity:0;transform:translateX(-50%) translateY(12px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
  /* Плашка «Доступно обновление» — новый деплой при открытой вкладке (все аккаунты, любой роли) */
  .nlv-update{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(150%);z-index:300;
    display:flex;align-items:center;gap:14px;max-width:min(560px,calc(100vw - 32px));
    background:linear-gradient(180deg,var(--ink-800),var(--ink-900));color:var(--paper);
    border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:13px 14px 13px 16px;
    box-shadow:0 18px 50px -12px rgba(20,23,26,.6),inset 0 1px 0 rgba(255,255,255,.08);
    opacity:0;transition:transform .42s var(--ease-out),opacity .42s var(--ease-out)}
  .nlv-update.show{transform:translateX(-50%) translateY(0);opacity:1}
  .nlv-update__icon{flex:0 0 auto;width:40px;height:40px;border-radius:11px;display:grid;place-items:center;
    background:linear-gradient(155deg,var(--accent-600,#0E8A57),var(--accent-700,#0B6E47));color:#fff;
    box-shadow:inset 0 0 0 1px rgba(255,255,255,.14),0 4px 12px -4px rgba(18,165,107,.6)}
  .nlv-update__icon svg{width:21px;height:21px;animation:nlvUpdSpin 9s linear infinite}
  @keyframes nlvUpdSpin{to{transform:rotate(360deg)}}
  .nlv-update__txt{min-width:0;margin-right:4px}
  .nlv-update__title{font-weight:700;font-size:15px;line-height:1.2;letter-spacing:-.01em}
  .nlv-update__sub{font-size:12.5px;color:rgba(255,255,255,.58);margin-top:2px;line-height:1.3}
  .nlv-update__btn{flex:0 0 auto;margin-left:auto;font-weight:700;font-size:14px;color:#fff;
    background:linear-gradient(180deg,var(--accent-500,#12A56B),var(--accent-600,#0E8A57));
    border:0;border-radius:999px;padding:10px 22px;cursor:pointer;white-space:nowrap;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.22),0 4px 12px -4px rgba(18,165,107,.55);
    transition:filter var(--dur-1) var(--ease-out),transform .08s}
  .nlv-update__btn:hover{filter:brightness(1.08)}
  .nlv-update__btn:active{transform:translateY(1px)}
  .nlv-update__close{flex:0 0 auto;width:30px;height:30px;border-radius:8px;background:transparent;border:0;
    color:rgba(255,255,255,.5);font-size:21px;line-height:1;cursor:pointer;display:grid;place-items:center;
    transition:color var(--dur-1) var(--ease-out),background var(--dur-1) var(--ease-out),transform var(--dur-1) var(--ease-out)}
  .nlv-update__close:hover{color:#fff;background:rgba(255,255,255,.1);transform:rotate(90deg)}   /* #1: единый hover крестика */
  @media(max-width:560px){
    .nlv-update{left:14px;right:14px;bottom:14px;transform:translateY(150%);flex-wrap:wrap;max-width:none;padding-top:16px}
    .nlv-update.show{transform:translateY(0)}
    .nlv-update__txt{flex:1 1 auto}
    .nlv-update__btn{flex:1 1 100%;margin-left:0;order:3}
    .nlv-update__close{position:absolute;top:8px;right:8px}
  }
  @media(prefers-reduced-motion:reduce){.nlv-update{transition:opacity .3s} .nlv-update__icon svg{animation:none}}
  @media(max-width:560px){
    .nlv-form .pm-row{grid-template-columns:1fr}
    .nlv-form .nlv-actions{flex-direction:column-reverse;align-items:stretch}
    .nlv-form .foot-hint{display:none}
    .nlv-form .nlv-mhead{padding:18px 18px 14px} .nlv-form .nlv-mbody{padding:6px 18px 18px} .nlv-form .nlv-mfoot{padding:14px 18px}
  }
  @media(prefers-reduced-motion:reduce){.qpop,.toast{animation:none}}

  /* ===== Модал результата оплаты (5 состояний) ===== */
  @keyframes nlv-spin{to{transform:rotate(360deg)}}
  @keyframes nlv-pop{0%{transform:scale(.72)}60%{transform:scale(1.05)}100%{transform:scale(1)}}
  @keyframes nlv-glow{from{opacity:0;transform:scale(.7)}to{opacity:.5;transform:scale(1)}}
  @keyframes nlv-pulse{0%,100%{box-shadow:0 0 0 0 rgba(90,97,107,.28)}50%{box-shadow:0 0 0 8px rgba(90,97,107,0)}}
  @keyframes nlv-blink{0%,100%{opacity:.25}50%{opacity:1}}
  .nlv-pay{width:100%;max-width:420px;box-sizing:border-box;padding:0;border-radius:var(--r-xl);overflow:hidden}
  .nlv-pay-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 14px 18px;border-bottom:1px solid var(--ink-100)}
  .nlv-pay-brand{display:flex;align-items:center;gap:9px}
  .nlv-pay-name{font-weight:800;font-size:15px;letter-spacing:-.02em;color:var(--ink-900)}
  .nlv-pay-tag{font-family:var(--font-mono);font-size:10px;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-300);border:1px solid var(--ink-150);border-radius:5px;padding:2px 6px;margin-left:2px}
  .nlv-pay-body{padding:26px 22px 20px}
  .nlv-pay-col{display:flex;flex-direction:column;align-items:center;text-align:center;gap:16px}
  .nlv-pay-h{margin:0;font-weight:800;font-size:23px;letter-spacing:-.018em;color:var(--ink-900)}
  .nlv-pay-sub{margin:0;font-size:14.5px;line-height:1.5;color:var(--ink-500)}
  .nlv-pay-card{width:100%;box-sizing:border-box;border:1px solid var(--ink-150);border-radius:var(--r-md);padding:2px 16px;background:var(--paper);text-align:left}
  .nlv-pay-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0}
  .nlv-pay-row+.nlv-pay-row{border-top:1px solid var(--ink-100)}
  .nlv-pay-k{font-size:13px;color:var(--ink-500);flex:0 0 auto}
  /* #31: значение не вылазит за карточку — может ужаться и обрезаться троеточием */
  .nlv-pay-v{font-family:var(--font-mono);font-size:13px;color:var(--ink-900);white-space:nowrap;font-feature-settings:'tnum' 1;min-width:0;overflow:hidden;text-overflow:ellipsis;text-align:right}
  .nlv-pay-note{width:100%;box-sizing:border-box;background:var(--ink-50);border:1px solid var(--ink-150);border-radius:var(--r-md);padding:12px 14px;display:flex;gap:10px;align-items:flex-start;text-align:left;font-size:12.5px;line-height:1.5;color:var(--ink-500)}
  .nlv-pay-big{font-family:var(--font-mono);font-weight:600;font-size:36px;letter-spacing:-.02em;color:var(--accent-600);white-space:nowrap;font-feature-settings:'tnum' 1}
  .nlv-pay-trust{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:18px;padding-top:14px;border-top:1px solid var(--ink-100);font-size:11px;color:var(--ink-300)}
  .nlv-pay-link{display:inline-flex;align-items:center;gap:5px;font-size:12.5px;color:var(--ink-400);text-decoration:none;border-top:1px solid var(--ink-100);width:100%;box-sizing:border-box;justify-content:center;padding-top:14px;line-height:1.4}
  .nlv-pay-link:hover{color:var(--ink-700)}
  .nlv-pay .btn,.nlv-pay .btn-ghost{width:100%;box-sizing:border-box;justify-content:center}
  .nlv-pay-textbtn{background:none;border:none;cursor:pointer;font:500 13px/1 var(--font-sans);color:var(--ink-500);padding:2px}
  .nlv-pay-textbtn:hover{color:var(--ink-800)}
  /* Инлайн-сообщение об ошибке внутри pay/retention-модала (вместо нативного alert) */
  .nlv-pay-msg{font-size:13px;line-height:1.45;text-align:center;width:100%}
  .nlv-pay-msg:empty{display:none}
  .nlv-pay-msg.err{color:var(--danger-600)}
  .nlv-pay-msg.ok{color:var(--accent-700)}
  .ret-opt{display:flex;align-items:center;gap:10px;padding:11px 12px;border:1px solid var(--ink-150);border-radius:10px;cursor:pointer;font-size:14px;color:var(--ink-800)}
  .ret-opt:hover{background:var(--ink-50)}
  .ret-opt input{accent-color:var(--ink-900);margin:0}
  /* Юр.дисклоуз автопродления (обязателен перед оплатой рекуррента) */
  .bp-disclosure{margin-top:12px;padding:11px 13px;border:1px solid var(--ink-150);border-radius:10px;background:var(--ink-50);font-size:12px;line-height:1.5;color:var(--ink-500)}
  .bp-disclosure a{color:var(--ink-700);text-decoration:underline;text-underline-offset:2px}
  .bp-disclosure b{color:var(--ink-700);font-weight:600}

  /* #26 без чёрной обводки при клике мышью — фокус-ring только с клавиатуры; на клик — мягко/без */
  input:focus,select:focus{outline:none}
  :focus:not(:focus-visible){outline:none}
  button:focus:not(:focus-visible),a:focus:not(:focus-visible),[tabindex]:focus:not(:focus-visible),
  .qlink:focus,.pwd-q:focus,.pwd-ic:focus,.tab:focus,.dsel-tg:focus,.ad-mini-btn:focus{outline:none;box-shadow:none}

  /* ===== Единый toggle-switch: плавный слайд knob + смена цвета (для ВСЕХ переключателей) ===== */
  .nlv-switch{position:relative;flex:0 0 auto;display:inline-block;width:40px;height:23px;vertical-align:middle}
  .nlv-switch input{position:absolute;inset:0;width:100%;height:100%;margin:0;opacity:0;cursor:pointer;z-index:2}
  .nlv-switch .track{position:absolute;inset:0;border-radius:999px;background:var(--ink-200);
    box-shadow:inset 0 1px 2px rgba(20,23,26,.14);transition:background .26s var(--ease-out)}
  .nlv-switch .knob{position:absolute;top:2px;left:2px;width:19px;height:19px;border-radius:50%;background:#fff;
    box-shadow:0 1px 3px rgba(20,23,26,.32),inset 0 1px 0 rgba(255,255,255,.9);
    transition:transform .26s var(--ease-out)}
  .nlv-switch input:checked~.track{background:var(--accent-500)}
  .nlv-switch input:checked~.knob{transform:translateX(17px)}
  .nlv-switch input:active~.knob{width:22px}           /* лёгкое «растягивание» при нажатии */
  .nlv-switch input:focus-visible~.track{outline:none;box-shadow:0 0 0 3px var(--accent-200)}
  @media (prefers-reduced-motion:reduce){ .nlv-switch .track,.nlv-switch .knob{transition:none} }

  /* ===== Модалка проекта (per-project подключение) ===== */
  .pmodal{padding:28px 28px 24px;width:min(560px,calc(100vw - 36px))}
  .pm-eyebrow{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
    color:var(--ink-400);font-weight:600;margin-bottom:7px}
  .pmodal h2{font-weight:800;letter-spacing:-.02em;font-size:22px;margin:0 0 5px;padding-right:38px}
  .pm-sub{color:var(--ink-400);font-size:13.5px;line-height:1.5;margin:0 0 20px}
  .pm-group{padding:16px 0;border-top:1px solid var(--ink-100)}
  .pm-group:first-of-type{border-top:0;padding-top:4px}
  .pm-glabel{font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;
    color:var(--ink-500);font-weight:600;margin-bottom:12px;display:flex;align-items:center;gap:8px}
  .pm-opt{font-family:var(--font-sans);text-transform:none;letter-spacing:0;font-weight:500;
    font-size:11.5px;color:var(--ink-400)}
  .pm-field{margin-bottom:12px}
  .pm-field:last-child{margin-bottom:0}
  .pm-field>label{display:flex;align-items:center;gap:8px;font-size:12.5px;font-weight:600;
    color:var(--ink-700);margin-bottom:5px}
  .pmodal input{width:100%;padding:10px 12px;border:1px solid var(--ink-200);border-radius:var(--r-sm);
    background:var(--paper);color:var(--ink-900);font-size:14px;transition:border-color var(--dur-1) var(--ease-out)}
  .pmodal input::placeholder{color:var(--ink-300)}
  .pm-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
  .pm-help{font-size:11.5px;font-weight:600;color:var(--accent-700);background:none;border:0;padding:0;
    cursor:pointer;text-decoration:underline;text-underline-offset:2px}
  .pm-instr{margin-top:7px;font-size:12.5px;line-height:1.6;color:var(--ink-500);background:var(--ink-50);
    border:1px solid var(--ink-150);border-radius:var(--r-sm);padding:10px 12px}
  .pm-instr ol{margin:6px 0 4px 18px;padding:0}
  .pm-instr li{margin:2px 0}
  .pm-instr code{font-family:var(--font-mono);font-size:11.5px;background:var(--ink-100);padding:1px 4px;border-radius:4px;word-break:break-all}
  /* Визард подключения — шаговый индикатор + навигация */
  .wiz-steps{display:flex;align-items:center;gap:8px;margin:2px 0 20px}
  .wiz-dot{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:var(--ink-400);flex:0 0 auto}
  .wiz-dot .wiz-n{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;
    background:var(--ink-100);color:var(--ink-400);font-size:12.5px;font-weight:700;transition:all var(--dur-1) var(--ease-out)}
  .wiz-dot.active{color:var(--ink-900)}
  .wiz-dot.active .wiz-n{background:var(--accent-700,#0a7d4f);color:#fff}
  .wiz-dot.done .wiz-n{background:var(--accent-100,#d6f0e3);color:var(--accent-700,#0a7d4f)}
  .wiz-sep{flex:1 1 auto;height:2px;background:var(--ink-150);border-radius:2px;min-width:12px}
  .pm-token-toggle{display:inline-block;background:none;border:0;padding:8px 0 0;cursor:pointer;font-size:13px;color:var(--accent-700,#0a7d4f);font-weight:600}
  .pm-token-toggle:hover{text-decoration:underline}
  .pm-more{margin-top:8px;border-top:1px solid var(--ink-100);padding-top:6px}
  .pm-more>summary{cursor:pointer;font-size:13px;color:var(--ink-500);font-weight:600;list-style:none;padding:6px 0}
  .pm-more>summary::-webkit-details-marker{display:none}
  .pm-more>summary::before{content:'▸ ';color:var(--ink-400)}
  .pm-more[open]>summary::before{content:'▾ '}
  #project-modal .nlv-actions{display:flex;align-items:center;gap:10px}
  #project-modal #pf-back{margin-right:auto}
  /* OAuth-подключение «в один клик» */
  .pm-oauth-btn{width:100%;font-size:14px;font-weight:700;color:#fff;
    background:var(--accent-700,#0a7d4f);border:0;border-radius:var(--r-sm);padding:12px 16px;cursor:pointer;
    transition:filter var(--dur-1) var(--ease-out)}
  .pm-oauth-btn:hover{filter:brightness(1.06)}
  .pm-oauth-or{text-align:center;font-size:12px;color:var(--ink-400);margin:9px 0 2px;position:relative}
  /* Каскад подключения: probe-кнопка, статус, дропдауны, чекбоксы целей */
  .pm-probe{margin-top:8px;font-size:12.5px;font-weight:600;color:var(--accent-700);background:var(--accent-50,var(--ink-50));
    border:1px solid var(--accent-200,var(--ink-200));border-radius:var(--r-sm);padding:8px 14px;cursor:pointer;transition:background var(--dur-1) var(--ease-out)}
  .pm-probe:hover:not(:disabled){background:var(--accent-100,var(--ink-100))}
  .pm-probe:disabled{opacity:.5;cursor:not-allowed}
  .pm-probe-status{margin-top:6px;font-size:12px;line-height:1.5;color:var(--ink-500);min-height:0}
  .pm-probe-status.ok{color:var(--accent-700)}
  .pm-probe-status.warn{color:var(--warn-600,#b45309)}
  .pm-probe-status.err{color:var(--danger-600,#dc2626)}
  /* Неяркая пометка про пропуск подключения на шаге 1 визарда */
  .pm-skip-note{margin-top:8px;font-size:12px;line-height:1.5;color:var(--ink-400);background:var(--ink-50);border-radius:var(--r-md,10px);padding:9px 11px}
  .pm-field select{width:100%;font:inherit;font-size:13px;color:var(--ink-900);background:var(--surface,#fff);
    border:1px solid var(--ink-200);border-radius:var(--r-sm);padding:9px 11px;margin-bottom:7px;cursor:pointer}
  .pm-field select:focus{outline:none;border-color:var(--accent-500,var(--accent-700));box-shadow:0 0 0 3px var(--accent-100,rgba(0,0,0,.06))}
  .pm-goals{display:flex;flex-direction:column;gap:2px;margin-bottom:7px;max-height:180px;overflow-y:auto}
  .pm-goals-hint{font-size:12px;color:var(--ink-400);line-height:1.5}
  .pm-goal{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-700);padding:5px 8px;border-radius:var(--r-sm);cursor:pointer}
  .pm-goal:hover{background:var(--ink-50)}
  .pm-goal input{margin:0;cursor:pointer;flex:0 0 auto}
  .pm-goal-id{margin-left:auto;font-family:var(--font-mono);font-size:11px;color:var(--ink-400)}
  /* Пояснение шага визарда (items 2,3) */
  .pm-step-hint{font-size:12.5px;line-height:1.55;color:var(--ink-500);background:var(--ink-50);border-radius:var(--r-md,10px);padding:10px 12px;margin:0 0 14px}
  .pm-step-hint b{color:var(--ink-700)}
  .pm-step-hint code{font-family:var(--font-mono);font-size:11.5px;background:var(--ink-100);padding:1px 4px;border-radius:4px}
  /* Цели «плюсиком» (item 4) */
  .pm-goal-rows{display:flex;flex-direction:column;gap:6px;margin-bottom:6px}
  .pm-goal-row{display:flex;align-items:center;gap:6px}
  .pm-goal-row input{flex:1 1 auto}
  .pm-goal-x{flex:0 0 auto;width:30px;height:30px;border:1px solid var(--ink-150);background:var(--paper);border-radius:var(--r-sm,8px);color:var(--ink-400);font-size:18px;line-height:1;cursor:pointer}
  .pm-goal-x:hover{border-color:var(--danger-600);color:var(--danger-600)}
  .pm-goal-add{font-size:12.5px;font-weight:600;color:var(--accent-700);background:none;border:0;padding:2px 0;cursor:pointer;text-align:left}
  .pm-goal-add:hover{text-decoration:underline}
  .pm-actions{display:flex;gap:8px;margin-top:18px;padding-top:16px;border-top:1px solid var(--ink-100)}
  .pm-actions .btn{padding:11px 20px}

  /* Карточки ДС: premium inset-highlight; статкарты с hover-lift */
  .nlv-card{box-shadow:var(--sh-sm),inset 0 1px 0 rgba(255,255,255,.7)}
  .statcard{transition:transform var(--dur-1) var(--ease-out),box-shadow var(--dur-1) var(--ease-out)}
  .statcard:hover{transform:translateY(-1px);box-shadow:var(--sh-md),inset 0 1px 0 rgba(255,255,255,.7)}
  /* Сетка статкарт отчёта: класс (не инлайн grid-template) — чтобы медиазапрос мог свернуть на мобайле.
     min-width:0 на ячейках — иначе длинные метрики (48 000 ₽) распирают треки и карта уезжает за viewport (375px). */
  .rep-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
  .rep-grid>*{min-width:0}
  @media(max-width:560px){.rep-grid{grid-template-columns:repeat(2,1fr)}}
  /* 05 — KPI / чарты / тёмный summary / комментарий Nelvo / zero */
  .rep-head{display:flex;align-items:flex-end;gap:14px;margin-bottom:12px;flex-wrap:wrap}
  .rep-head>div:first-child{min-width:0;flex:1 1 auto}
  .rep-eyebrow{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-400);font-weight:600}
  .rep-h{margin:4px 0 0;font-size:24px;font-weight:800;letter-spacing:-.022em;color:var(--ink-900);overflow-wrap:anywhere}
  .rep-acts{margin-left:auto;display:flex;gap:8px;align-items:center;flex-wrap:wrap}
  .rep-act{font-weight:600;font-size:13px;color:var(--ink-700);background:var(--paper);border:1px solid var(--ink-200);border-radius:9px;padding:8px 12px;display:inline-flex;gap:6px;align-items:center}
  .rep-act:hover{background:var(--ink-50)}
  .rep-src{display:flex;align-items:center;gap:10px;margin:12px 0 18px}
  .rep-src-chip{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-600);background:var(--ink-50);border:1px solid var(--ink-150);border-radius:999px;padding:4px 11px}
  .rep-src-chip .dot{width:6px;height:6px;border-radius:50%;background:var(--accent-500)}
  .kpi{border:1px solid var(--ink-150);border-radius:var(--r-md);background:var(--paper);box-shadow:var(--sh-sm),inset 0 1px 0 rgba(255,255,255,.7);padding:15px 16px;transition:transform var(--dur-1) var(--ease-out),box-shadow var(--dur-1) var(--ease-out)}
  .kpi:hover{transform:translateY(-1px);box-shadow:var(--sh-md)}
  .kl{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-400);margin-bottom:9px}
  .kv{font-family:var(--font-mono);font-size:27px;font-weight:600;color:var(--ink-900);letter-spacing:-.02em;font-variant-numeric:tabular-nums;line-height:1;overflow-wrap:anywhere}
  .kv.muted{color:var(--ink-300)}
  .kd{font-family:var(--font-mono);font-size:11px;margin-top:9px;display:inline-flex;gap:5px;align-items:center;color:var(--ink-400)}
  .kd.good{color:var(--accent-700)} .kd.bad{color:var(--danger-600)}
  .rep-charts{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;margin:12px 0 18px}
  .rep-charts>*{min-width:0}
  .rch{border:1px solid var(--ink-150);background:var(--paper);border-radius:var(--r-md);box-shadow:var(--sh-sm),inset 0 1px 0 rgba(255,255,255,.7);padding:15px 16px;display:flex;flex-direction:column}
  .rch-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:12px;gap:8px}
  .rch-l{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-400)}
  .rch-v{font-family:var(--font-mono);font-size:17px;font-weight:600;color:var(--ink-900);font-variant-numeric:tabular-nums}
  .rch .spark{width:100%;height:58px;display:block;margin-top:auto}
  .rbars{display:flex;gap:5px;height:58px;margin-top:auto;align-items:flex-end}
  .rbar{flex:1 1 0;background:linear-gradient(180deg,var(--accent-300),var(--accent-500));border-radius:3px 3px 0 0;min-height:3px}
  .rbar.last{background:linear-gradient(180deg,var(--accent-500),var(--accent-700))}
  .rdays{display:flex;gap:5px;margin-top:6px}
  .rdays span{flex:1;text-align:center;font-family:var(--font-mono);font-size:8.5px;color:var(--ink-300)}
  .rep-sum{background:linear-gradient(160deg,var(--ink-800),var(--ink-900));border:1px solid var(--ink-900);border-radius:var(--r-md);box-shadow:var(--sh-md);padding:16px 18px;color:#fff;display:flex;flex-direction:column}
  .rep-sum .se{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-300)}
  .rep-sum .sb{font-family:var(--font-mono);font-size:30px;font-weight:600;letter-spacing:-.02em;font-variant-numeric:tabular-nums;margin-top:6px}
  .rep-sum .su{font-size:12.5px;color:var(--ink-300);margin-top:3px}
  .rep-sum .ssub{font-family:var(--font-mono);font-size:12px;margin-top:auto;padding-top:10px;display:inline-flex;gap:7px;align-items:center}
  .rep-sum .ssub .em{color:var(--accent-300)}
  .rep-sum .ssub .em.down{color:#F2A9A2}
  .rep-note{display:flex;gap:13px;border:1px solid var(--ink-150);background:var(--ink-50);border-radius:var(--r-md);padding:15px 17px;margin-bottom:12px}
  .rep-note .av{flex:0 0 auto;width:30px;height:30px;border-radius:8px;display:grid;place-items:center;background:linear-gradient(157deg,var(--ink-700),var(--ink-900))}
  .rep-note .nl{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-400);margin-bottom:4px}
  .rep-note .nt{font-size:13.5px;color:var(--ink-700);line-height:1.55}
  .rep-foot{font-size:12px;color:var(--ink-400)}
  .rep-zero{border:1px dashed var(--ink-200);background:var(--ink-50);border-radius:var(--r-md);padding:30px 26px;text-align:center;margin:12px 0 18px}
  .rep-zero .zi{width:46px;height:46px;margin:0 auto 14px;border-radius:12px;display:grid;place-items:center;background:var(--paper);border:1px solid var(--ink-150);color:var(--ink-300)}
  .rep-zero .zb{font-size:14.5px;font-weight:700;color:var(--ink-800);margin-bottom:4px}
  .rep-zero .zs{font-size:13px;color:var(--ink-500);line-height:1.5;max-width:360px;margin:0 auto 14px}
  .rep-zero .zbar{height:8px;max-width:240px;margin:0 auto;border-radius:999px;background:linear-gradient(90deg,var(--ink-100) 25%,var(--ink-50) 37%,var(--ink-100) 63%);background-size:400% 100%;animation:shimmer 1.4s ease-in-out infinite}
  @media(max-width:560px){ .rep-charts{grid-template-columns:1fr} .rep-acts{margin-left:0} }
  @keyframes shimmer{0%{background-position:100% 0}100%{background-position:-100% 0}}

  /* Панель запуска кампании — нумерованный пайплайн */
  .lp-card{background:var(--paper);border:1px solid var(--ink-150);border-radius:var(--r-md);padding:18px 20px;
    margin-bottom:18px;box-shadow:var(--sh-sm),inset 0 1px 0 rgba(255,255,255,.7)}
  .lp-head{display:flex;align-items:flex-start;gap:12px;margin-bottom:15px}
  .lp-title{margin:6px 0 0;font-size:17px;font-weight:700;letter-spacing:-.012em}
  .lp-flow-note{margin-left:auto;font-family:var(--font-mono);font-size:11px;color:var(--ink-400);white-space:nowrap;padding-top:3px}
  .lp-steps{display:flex;gap:8px;flex-wrap:wrap}
  .lp-step{display:inline-flex;align-items:center;gap:9px;font-size:13.5px;font-weight:600;color:var(--ink-700);
    background:var(--paper);border:1px solid var(--ink-200);border-radius:10px;padding:9px 14px;cursor:pointer;
    transition:background var(--dur-1) var(--ease-out),border-color var(--dur-1) var(--ease-out),transform var(--dur-1) var(--ease-out)}
  .lp-step:hover{background:var(--ink-50);transform:translateY(-1px)}
  .lp-n{display:grid;place-items:center;width:20px;height:20px;border-radius:6px;font-family:var(--font-mono);
    font-size:11px;font-weight:600;background:var(--ink-100);color:var(--ink-500)}
  .lp-step-primary{color:#fff;background:var(--ink-900);border-color:var(--ink-900)}
  .lp-step-primary .lp-n{background:rgba(255,255,255,.16);color:#fff}
  .lp-step-primary:hover{background:var(--ink-800)}
  .lp-step-go{color:#fff;background:linear-gradient(180deg,var(--accent-500),var(--accent-700));border-color:var(--accent-700);
    box-shadow:inset 0 1px 0 rgba(255,255,255,.2)}
  .lp-step-go .lp-n{background:rgba(255,255,255,.2);color:#fff}
  .lp-out{font-size:13px;margin-top:12px}
  /* 04 — единый степпер запуска (4 узла, связанные линией; «Показы» = боевой узел) */
  .lp-stepper{display:flex;gap:8px;margin-bottom:6px}
  .lp-snw{flex:1 1 0;position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;gap:9px;background:none;border:0;padding:8px 6px 4px;cursor:pointer;min-width:0}
  .lp-snw::before{content:"";position:absolute;top:26px;left:-50%;width:100%;height:2px;background:var(--ink-150);z-index:0}
  .lp-snw:first-child::before{display:none}
  .lp-snode{position:relative;z-index:1;width:36px;height:36px;border-radius:50%;display:grid;place-items:center;font-family:var(--font-mono);font-size:14px;font-weight:600;background:var(--paper);border:2px solid var(--ink-200);color:var(--ink-500);transition:border-color var(--dur-1) var(--ease-out),color var(--dur-1) var(--ease-out)}
  .lp-snw:hover .lp-snode{border-color:var(--ink-400);color:var(--ink-900)}
  .lp-snw.battle .lp-snode{background:linear-gradient(180deg,var(--accent-500),var(--accent-700));border-color:var(--accent-700);color:#fff;box-shadow:0 0 0 4px rgba(18,165,107,.15)}
  .lp-slabel{font-size:12.5px;font-weight:600;color:var(--ink-700);line-height:1.25}
  .lp-ss{display:block;font-family:var(--font-mono);font-size:9px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-400);margin-top:2px}
  @media(max-width:560px){
    .lp-stepper{flex-direction:column;gap:10px}
    .lp-snw{flex-direction:row;justify-content:flex-start;text-align:left;gap:11px;padding:4px 0}
    .lp-snw::before{display:none}
    .lp-head{flex-wrap:wrap}
    .lp-flow-note{margin-left:0;flex-basis:100%;padding-top:6px;white-space:normal}
  }

  /* Nelvo-scoped полировка модуля Советчика (advisor.js — ОБЩИЙ компонент с Эталоном;
     правим ТОЛЬКО внутри #content = контекст Nelvo, агентскую версию не трогаем) */
  #content .adv-chat-toggle{background:linear-gradient(180deg,var(--ink-800),var(--ink-900))!important;
    border-color:var(--ink-900)!important;border-radius:10px!important;padding:11px 16px!important;
    box-shadow:var(--sh-sm),inset 0 1px 0 rgba(255,255,255,.08)!important}
  #content .adv-chat-toggle:hover{background:var(--ink-800)!important;box-shadow:var(--sh-md)!important}
  #content .adv-chat-toggle[aria-expanded="true"]{background:var(--ink-700)!important;border-color:var(--ink-700)!important}
  #content .adv-history-toggle{border-radius:10px!important}
  #content .adv-card{box-shadow:var(--sh-sm),inset 0 1px 0 rgba(255,255,255,.7)!important;border-radius:var(--r-md)!important}
  #content .adv-pill{border-radius:10px!important;
    transition:transform var(--dur-1) var(--ease-out),background var(--dur-1) var(--ease-out),border-color var(--dur-1) var(--ease-out)!important}
  #content .adv-pill:hover:not(.adv-pill-locked){transform:translateY(-1px)}

  /* Mobile 375 */
  /* Вход: стек на планшете/телефоне (тёмная панель сверху, форма снизу) */
  @media (max-width:640px){
    .layout{flex-direction:column}
    aside#sidebar{width:100%;flex:none;border-right:0;border-bottom:1px solid var(--ink-150)}
  }
  /* ── Mobile 375: внутренние экраны после логина без оверфлоу ── */
  @media (max-width:430px){
    /* (топбар-мобайл вынесен в topbar.css — @media 560px) */
    /* рабочая область: меньше боковых полей, ничего не вылезает */
    .layout>main{padding:16px 14px!important}
    /* страница «Тариф и оплата»: шапка тарифа в столбик, цена слева */
    /* #B22 попап подписки на узком — почти-фуллскрин шит */
    #billing-page{padding:0;place-items:stretch}
    .bp-modal{width:100%;max-height:100vh;max-height:100dvh;border-radius:0;border:0}
    .bp-wrap{padding:16px 14px 40px}
    /* #B20 топбар на узком: компактнее, прячем разделитель и лого, оставляем «Назад»+заголовок */
    .bp-topbar{gap:10px;padding:11px 14px}
    .bp-tb-div,.bp-topbar .brand{display:none}
    .bp-back>span{display:none}
    .bp-back{padding:8px 10px}
    .bp-tb-title h1{font-size:17px}
    .bp-card{padding:16px 15px}
    .bp-card>div[style*="space-between"]{flex-direction:column;align-items:flex-start!important}
    .bp-card>div[style*="space-between"]>div[style*="right"]{text-align:left!important}
    /* доступ клиента: чипы со ссылкой/логином не растягивают карточку */
    .ca-chip,.ca-link{max-width:100%;overflow:hidden;text-overflow:ellipsis}
    .ca-top{flex-wrap:wrap;gap:8px}
    /* очередь: дифф «было → станет» в столбик, стрелка горизонтальной */
    .q-card{padding:16px 15px}
    .q-actions{flex-wrap:wrap}
    .q-actions .q-ok,.q-actions .q-edit,.q-actions .q-rej{flex:1 1 auto}
    /* отчётность: KPI в 2 колонки уже задано (≤560) — действия в столбик */
    .rep-acts{width:100%}
    .rep-acts .rep-act{flex:1 1 auto;justify-content:center}
    /* предложения / админ: действия карточки переносятся, не выходят за край */
    .pr-actions{flex-wrap:wrap}
    .pr-actions>button{flex:1 1 auto}
    /* модалки: шире по экрану, внутр. отступы скромнее */
    .nlv-overlay{padding:12px}
    .nlv-modal{padding:20px 18px!important}
    .pmodal{padding:22px 18px 20px}
    .pm-row{grid-template-columns:1fr}
    /* выдача кабинета в админке: поля в столбик */
    #admin-modal .nlv-modal>div:last-child>div[style*="flex"]{flex-direction:column;align-items:stretch}
    #admin-modal .nlv-modal>div:last-child input,
    #admin-modal .nlv-modal>div:last-child select,
    #admin-modal .nlv-modal>div:last-child .btn{width:100%;min-width:0}
  }

/* #27 (порт с redesign): блок «Баланс кошелька» — детализированный hero */
.bp-wallet-hero{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;
  margin-top:14px;padding:16px 18px;border:1px solid var(--ink-150);border-radius:var(--r-md);
  background:linear-gradient(160deg,var(--ink-50),var(--paper));box-shadow:inset 0 1px 0 rgba(255,255,255,.7)}
.bp-wallet-lab{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-400);font-weight:600}
.bp-wallet-bal{font-family:var(--font-mono);font-feature-settings:"tnum" 1;font-size:28px;font-weight:600;letter-spacing:-.02em;color:var(--ink-900);margin-top:4px;white-space:nowrap}
.bp-wallet-pay{display:flex;align-items:center;gap:9px;color:var(--ink-600)}
.bp-pay-ic{flex:0 0 auto;width:34px;height:34px;display:grid;place-items:center;border:1px solid var(--ink-200);border-radius:9px;background:var(--paper);color:var(--ink-500);box-shadow:var(--sh-xs)}
.bp-pay-txt{display:flex;flex-direction:column;font-size:13px;font-weight:600;color:var(--ink-800)}
.bp-pay-lab{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-400);font-weight:600}

/* ── #1 DS custom select (.dsel) — порт с redesign ── */
.dsel{position:relative;display:inline-block;width:100%;vertical-align:middle}
.dsel-tg{display:inline-flex;align-items:center;justify-content:space-between;gap:8px;width:100%;font:600 12.5px/1 var(--font-sans);color:var(--ink-900);background:var(--paper);border:1px solid var(--ink-200);border-radius:8px;padding:8px 11px;cursor:pointer;transition:border-color var(--dur-1) var(--ease-out),background var(--dur-1) var(--ease-out),box-shadow var(--dur-1) var(--ease-out)}
.dsel-tg:hover{background:var(--ink-50)}
.dsel.open .dsel-tg{border-color:var(--ink-300);box-shadow:0 0 0 3px rgba(20,23,26,.05)}
.dsel-val{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dsel-chev{flex:0 0 auto;color:var(--ink-400);transition:transform .26s cubic-bezier(.34,1.4,.5,1)}
.dsel.open .dsel-chev{transform:rotate(180deg)}
.dsel-menu{position:fixed;z-index:130;min-width:160px;background:var(--paper);border:1px solid var(--ink-150);border-radius:10px;box-shadow:var(--sh-lg),inset 0 1px 0 rgba(255,255,255,.7);padding:5px;
  opacity:0;visibility:hidden;transform:translateY(-7px) scale(.96);transform-origin:top center;pointer-events:none;
  transition:opacity .16s var(--ease-out),transform .26s cubic-bezier(.34,1.5,.52,1),visibility 0s linear .26s}
.dsel-menu.open{opacity:1;visibility:visible;transform:none;pointer-events:auto;transition:opacity .16s var(--ease-out),transform .28s cubic-bezier(.34,1.5,.52,1),visibility 0s}
.dsel-opt{appearance:none;-webkit-appearance:none;border:0;outline:0;background:transparent;width:100%;text-align:left;font-family:inherit;display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:13px;font-weight:500;color:var(--ink-700);border-radius:7px;padding:8px 10px;cursor:pointer;
  opacity:0;transform:translateY(5px);transition:opacity .2s var(--ease-out),transform .22s cubic-bezier(.34,1.4,.5,1),background var(--dur-1) var(--ease-out),color var(--dur-1) var(--ease-out)}
.dsel-menu.open .dsel-opt{opacity:1;transform:none;transition-delay:calc(var(--i,0)*34ms + 28ms),calc(var(--i,0)*34ms + 28ms),0s,0s}
.dsel-opt:hover{background:var(--ink-50);color:var(--ink-900)}
.dsel-opt.cur{color:var(--ink-900);font-weight:600}
.dsel-opt .dsel-ck{flex:0 0 auto;color:var(--accent-600);display:flex;opacity:0;transform:scale(.4);transition:opacity .15s var(--ease-out),transform .24s cubic-bezier(.34,1.7,.5,1)}
.dsel-opt.cur .dsel-ck{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.dsel-menu,.dsel-opt,.dsel-chev,.dsel-ck{transition:none!important}}

/* ── S2#7 + S2#2: единый шеврон + плавный дропдаун (отчётность: период / сравнение / скачать) ── */
.rv-chev{flex:0 0 auto;color:var(--ink-400);transition:transform .24s var(--ease-out)}
.rv-dd.open .rv-chev,.rv-ddbtn.open .rv-chev{transform:rotate(180deg)}
.rv-dd{position:relative;display:inline-block}
.rv-dd-tg{font-family:var(--font-mono);font-size:12.5px;font-weight:500;color:var(--ink-900);background:var(--paper);border:1px solid var(--ink-200);border-radius:8px;padding:8px 12px;cursor:pointer;display:inline-flex;gap:8px;align-items:center;justify-content:space-between;transition:border-color var(--dur-1) var(--ease-out),background var(--dur-1) var(--ease-out)}
.rv-dd-tg:hover{background:var(--ink-50)}
.rv-dd.open .rv-dd-tg{border-color:var(--ink-300);background:var(--ink-50)}
.rv-dd-lbl{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rv-dd-menu{position:absolute;top:calc(100% + 5px);left:0;z-index:60;background:var(--paper);border:1px solid var(--ink-150);border-radius:10px;box-shadow:var(--sh-md);padding:5px;overflow:auto;
  opacity:0;visibility:hidden;transform:translateY(-6px) scale(.985);transform-origin:top left;pointer-events:none;
  transition:opacity .15s var(--ease-out),transform .2s var(--ease-out),visibility 0s linear .2s}
.rv-dd.open .rv-dd-menu{opacity:1;visibility:visible;transform:none;pointer-events:auto;transition:opacity .15s var(--ease-out),transform .24s cubic-bezier(.34,1.4,.5,1),visibility 0s}
.rv-dd-menu.rv-dd-right{left:auto;right:0;transform-origin:top right}
/* #11: hover на пунктах дропдауна периода (фон ink-50, как в меню «Скачать»). Пункты — кнопки с inline background → !important перебивает inline. */
.rv-dd-menu button:hover{background:var(--ink-50)!important;color:var(--ink-900)!important}
/* JS-создаваемое меню «Скачать» (rv-dlmenu) — закрытие с анимацией через .closing */
.rv-dlmenu{animation:nlvDdIn .18s var(--ease-out) both;transform-origin:top right}
.rv-dlmenu.closing{animation:nlvDdOut .15s var(--ease-out) both}
@keyframes nlvDdIn{from{opacity:0;transform:translateY(-6px) scale(.985)}to{opacity:1;transform:none}}
@keyframes nlvDdOut{from{opacity:1;transform:none}to{opacity:0;transform:translateY(-6px) scale(.985)}}
@media (prefers-reduced-motion:reduce){.rv-chev,.rv-dd-menu,.rv-dlmenu{transition:none!important;animation:none!important}}

/* ── #28b DS-чекбоксы ── */
.bp-mode-row input[type="checkbox"], input.nlv-chk{
  appearance:none;-webkit-appearance:none;outline:none;flex:0 0 auto;width:18px;height:18px;border:1.5px solid var(--ink-300);border-radius:5px;
  background:var(--paper);cursor:pointer;position:relative;transition:background var(--dur-1) var(--ease-out),border-color var(--dur-1) var(--ease-out),box-shadow var(--dur-1) var(--ease-out)}
/* #B18 любой чекбокс в UI — убрать чёрную UA-обводку при клике (мышью), keyboard-фокус остаётся через :focus-visible ниже */
input[type="checkbox"]{outline:none}
input[type="checkbox"]:focus{outline:none}
input[type="checkbox"]:focus-visible{outline:0;box-shadow:0 0 0 3px var(--accent-100)}
.bp-mode-row input[type="checkbox"]:hover, input.nlv-chk:hover{border-color:var(--ink-400)}
.bp-mode-row input[type="checkbox"]:focus-visible, input.nlv-chk:focus-visible{outline:0;box-shadow:0 0 0 3px var(--accent-100)}
.bp-mode-row input[type="checkbox"]:checked, input.nlv-chk:checked{background:linear-gradient(180deg,var(--accent-500),var(--accent-600));border-color:var(--accent-600)}
.bp-mode-row input[type="checkbox"]:checked::after, input.nlv-chk:checked::after{
  content:"";position:absolute;left:5px;top:2px;width:4px;height:8px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg);
  animation:nlvChkPop .22s cubic-bezier(.34,1.7,.5,1)}
@keyframes nlvChkPop{from{opacity:0;transform:rotate(45deg) scale(.4)}to{opacity:1;transform:rotate(45deg) scale(1)}}

/* ── #9 попап ввода кода подтверждения email ── */
.nlv-code{display:flex;gap:8px;justify-content:center;margin:6px 0 4px}
.nlv-code input{width:44px;height:54px;text-align:center;font:600 22px/1 var(--font-mono);color:var(--ink-900);
  border:1.5px solid var(--ink-200);border-radius:11px;background:var(--paper);transition:border-color var(--dur-1) var(--ease-out),box-shadow var(--dur-1) var(--ease-out)}
.nlv-code input:focus{outline:0;border-color:var(--ink-300);box-shadow:0 0 0 3px rgba(20,23,26,.05)}
.nlv-code input.filled{border-color:var(--accent-500)}
.nlv-resend{background:none;border:0;color:var(--accent-700);font-weight:600;font-size:13px;cursor:pointer;padding:6px}
.nlv-resend[disabled]{color:var(--ink-400);cursor:default}
/* S1#17: блок «код не приходит» — спам-подсказка + 2 кнопки поддержки (Telegram / MAX) */
.nlv-support{margin-top:12px;padding-top:13px;border-top:1px solid var(--ink-100);text-align:center;animation:nlvFade .2s ease both}
.nlv-support-note{font-size:12.5px;line-height:1.5;color:var(--ink-500);margin-bottom:11px}
/* #7 (2026-06-25): ЕДИНЫЕ светлые компактные кнопки связи — иконка-бейдж слева + 2 строки
   (Telegram / @artempapst) + шеврон справа. Применяются ВЕЗДЕ вместо тёмных .nlv-msg-btn. */
.nlv-support-btns{display:flex;gap:9px;flex-wrap:wrap}
.nlv-sup-btn{flex:1 1 150px;min-width:150px;display:inline-flex;align-items:center;gap:10px;text-decoration:none;color:var(--ink-800);background:var(--paper);border:1px solid var(--ink-200);border-radius:11px;padding:9px 11px;cursor:pointer;box-shadow:0 1px 2px rgba(20,23,26,.04);transition:background .14s ease,border-color .14s ease,box-shadow .14s ease,transform .14s ease}
.nlv-sup-btn:hover{background:var(--ink-50);border-color:var(--ink-300);box-shadow:0 4px 12px rgba(20,23,26,.08);transform:translateY(-1px)}
.nlv-sup-btn:active{transform:translateY(1px)}
.nlv-sup-btn:focus-visible{outline:none;box-shadow:0 0 0 3px var(--accent-200)}
.nlv-sup-ic{flex:none;width:30px;height:30px;border-radius:9px;background:var(--ink-50);border:1px solid var(--ink-150);display:inline-flex;align-items:center;justify-content:center}
.nlv-sup-ic svg{display:block}
.nlv-sup-tx{min-width:0;display:flex;flex-direction:column;line-height:1.15}
.nlv-sup-tx b{font:700 13px/1.2 var(--font-sans);color:var(--ink-900);letter-spacing:-.01em}
.nlv-sup-tx span{font:500 11px/1.2 var(--font-mono);color:var(--ink-400);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}
.nlv-sup-go{flex:none;margin-left:auto;color:var(--ink-300);display:inline-flex}
.nlv-sup-go svg{display:block}
.nlv-sup-tg .nlv-sup-ic svg{color:#229ED9}
.nlv-sup-max .nlv-sup-ic svg{color:var(--accent-600)}
/* D7 (Claude Design 2026-06-22): детальные кнопки связи MAX/Telegram — тёмные карточки
   с иконкой-бейджем + 2-строчный лейбл + шеврон. Тариф «Индивидуальный», A3, A5. */
.nlv-msg-btns{display:flex;gap:12px;flex-wrap:wrap}
.nlv-msg-btn{flex:1;min-width:200px;text-decoration:none;position:relative;overflow:hidden;display:flex;align-items:center;gap:13px;border:1px solid var(--ink-900);border-radius:var(--r-md);padding:14px 16px;background:linear-gradient(180deg,var(--ink-700),var(--ink-900));box-shadow:inset 0 1px 0 rgba(255,255,255,.1),0 1px 2px rgba(20,23,26,.3),0 6px 16px rgba(20,23,26,.18);transition:transform .14s var(--ease-out),box-shadow .14s var(--ease-out)}
.nlv-msg-btn::before{content:'';position:absolute;left:0;right:0;top:0;height:46%;background:linear-gradient(180deg,rgba(255,255,255,.1),rgba(255,255,255,0));pointer-events:none}
.nlv-msg-btn>*{position:relative}
.nlv-msg-btn:hover{transform:translateY(-1px);box-shadow:inset 0 1px 0 rgba(255,255,255,.12),0 8px 22px rgba(20,23,26,.26)}
.nlv-msg-btn:active{transform:translateY(1px) scale(.995)}
.nlv-msg-btn:focus-visible{outline:none;box-shadow:inset 0 1px 0 rgba(255,255,255,.1),0 0 0 2px #fff,0 0 0 4px var(--accent-700)}
.nlv-msg-ic{flex:none;width:42px;height:42px;border-radius:11px;background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.13);display:inline-flex;align-items:center;justify-content:center}
.nlv-msg-tx{min-width:0}
.nlv-msg-tx b{display:block;font-size:15px;font-weight:700;color:#fff;letter-spacing:-.01em}
.nlv-msg-tx span{display:block;font-family:var(--font-mono);font-size:12.5px;color:rgba(255,255,255,.6);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nlv-msg-go{flex:none;margin-left:auto;color:rgba(255,255,255,.45)}
/* #18б: на экране сброса пароля кнопки связи — НАМНОГО компактнее и светлее
   (не тёмные крупные плашки), чтобы вся левая колонка влезала по высоте. Scoped к #auth. */
#auth .nlv-support .nlv-msg-btns{gap:8px}
#auth .nlv-support .nlv-msg-btn{flex:1 1 0;min-width:0;padding:8px 10px;gap:9px;border:1px solid var(--ink-200);border-radius:10px;
  background:var(--paper);box-shadow:0 1px 2px rgba(20,23,26,.04)}
#auth .nlv-support .nlv-msg-btn::before{display:none}
#auth .nlv-support .nlv-msg-btn:hover{transform:translateY(-1px);background:var(--ink-50);border-color:var(--ink-300);box-shadow:0 4px 12px rgba(20,23,26,.08)}
#auth .nlv-support .nlv-msg-btn:focus-visible{box-shadow:0 0 0 3px var(--accent-200)}
#auth .nlv-support .nlv-msg-ic{width:28px;height:28px;border-radius:8px;background:var(--ink-50);border:1px solid var(--ink-150)}
#auth .nlv-support .nlv-msg-ic svg{width:16px;height:16px}
#auth .nlv-support .nlv-msg-ic svg[fill="#fff"]{fill:var(--ink-700)}
#auth .nlv-support .nlv-msg-ic svg[stroke="#fff"]{stroke:var(--ink-700)}
#auth .nlv-support .nlv-msg-tx b{font-size:13px;color:var(--ink-900)}
#auth .nlv-support .nlv-msg-tx span{font-size:11px;color:var(--ink-400)}
#auth .nlv-support .nlv-msg-go{color:var(--ink-300)}
/* S1#30: «?»-тултип у опций поведения после лимита (эко / кошелёк) — hover/focus */
.nlv-qtip{position:relative;display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;border:1px solid var(--ink-200);color:var(--ink-400);font:700 10px/1 var(--font-sans);cursor:help;margin-left:5px;vertical-align:middle;flex:0 0 auto;outline:none}
.nlv-qtip:hover,.nlv-qtip:focus-visible{border-color:var(--accent-400,#46c08a);color:var(--accent-700)}
.nlv-qtip .nlv-qtip-box{position:absolute;bottom:calc(100% + 9px);left:50%;transform:translateX(-50%) translateY(4px);width:250px;max-width:74vw;background:var(--ink-900);color:#fff;border-radius:10px;padding:10px 12px;font:500 12px/1.55 var(--font-sans);text-align:left;box-shadow:var(--sh-lg);opacity:0;visibility:hidden;pointer-events:none;transition:opacity .16s var(--ease-out),transform .2s var(--ease-out),visibility 0s linear .2s;z-index:70}
.nlv-qtip .nlv-qtip-box b{color:#fff;font-weight:700}
.nlv-qtip:hover .nlv-qtip-box,.nlv-qtip:focus .nlv-qtip-box,.nlv-qtip:focus-within .nlv-qtip-box{opacity:1;visibility:visible;transform:translateX(-50%);transition:opacity .16s var(--ease-out),transform .2s var(--ease-out)}
.nlv-qtip .nlv-qtip-box::after{content:"";position:absolute;top:100%;left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:var(--ink-900)}
@media(max-width:560px){.nlv-qtip .nlv-qtip-box{left:auto;right:-6px;transform:translateY(4px)}.nlv-qtip:hover .nlv-qtip-box,.nlv-qtip:focus-within .nlv-qtip-box{transform:none}.nlv-qtip .nlv-qtip-box::after{left:auto;right:10px}}

/* ── Отчётность v2 (report-v2): кнопки/карточки/графики/адаптив ── */
#sec-reports .rv-sbtn{font-family:var(--font-sans);font-weight:600;font-size:13px;color:var(--ink-700);background:var(--paper);border:1px solid var(--ink-200);border-radius:9px;padding:8px 12px;display:inline-flex;gap:6px;align-items:center;cursor:pointer;transition:background .14s var(--ease-out)}
#sec-reports .rv-sbtn:hover{background:var(--ink-50)}
#sec-reports .rv-refresh.is-spinning svg{animation:nlvSpin .7s linear infinite}
#sec-reports .rv-nav{width:34px;height:34px;border:1px solid var(--ink-200);background:var(--paper);border-radius:8px;cursor:pointer;color:var(--ink-600);font-size:15px;display:grid;place-items:center;transition:background .14s}
#sec-reports .rv-nav:hover{background:var(--ink-50)}
#sec-reports .rv-nav:disabled{opacity:.4;cursor:default}
/* #1: ✕-закрытие попапов сравнения периодов (rv-x) — единый hover как у .nlv-x (rotate 90 + фон). Глобальный селектор: попапы вне #sec-reports. */
.rv-nav.rv-x{width:34px;height:34px;border:1px solid var(--ink-200);background:var(--paper);border-radius:8px;cursor:pointer;color:var(--ink-500);font-size:15px;display:grid;place-items:center;transition:background var(--dur-1) var(--ease-out),color var(--dur-1) var(--ease-out),transform .4s var(--ease-out)}
.rv-nav.rv-x:hover{background:var(--ink-50);color:var(--ink-900);transform:rotate(90deg)}
.rv-nav.rv-x:focus-visible{outline:none;box-shadow:0 0 0 3px var(--accent-200)}
/* #10a: молд-стиль для reports-primary (как .acct-btn, меньший размер) */
#sec-reports .rv-cta{position:relative;overflow:hidden;font-family:var(--font-sans);font-weight:600;font-size:13px;color:#fff;background:linear-gradient(180deg,var(--accent-500),var(--accent-700));border:1px solid var(--accent-700);border-radius:8px;padding:8px 16px;cursor:pointer;box-shadow:inset 0 1px 0 rgba(255,255,255,.26),0 1px 2px rgba(11,110,71,.4),0 5px 13px rgba(18,165,107,.24);transition:transform .14s,box-shadow .14s}
#sec-reports .rv-cta::before{content:'';position:absolute;left:0;right:0;top:0;height:46%;background:linear-gradient(180deg,rgba(255,255,255,.24),rgba(255,255,255,0));pointer-events:none}
#sec-reports .rv-cta>*{position:relative}
#sec-reports .rv-cta:hover{transform:translateY(-1px);box-shadow:inset 0 1px 0 rgba(255,255,255,.3),0 7px 18px rgba(18,165,107,.34)}
#sec-reports .rv-cta:active{transform:translateY(1px) scale(.99)}
#sec-reports .rv-ghost{font-family:var(--font-sans);font-weight:600;font-size:13px;color:var(--ink-600);background:transparent;border:1px solid var(--ink-200);border-radius:8px;padding:8px 14px;cursor:pointer}
#sec-reports .rv-ghost:hover{background:var(--ink-50)}
#sec-reports .rv-srcseg{font-family:var(--font-sans);font-weight:600;font-size:12.5px;border:0;border-radius:999px;padding:5px 13px;cursor:pointer;background:transparent}
  /* #31/#32: единый сегмент-контрол со скользящей плашкой. Один класс на все переключатели
     (Неделя/Месяц, Директ/Таблица) — одинаковый радиус, активная плашка плавно переезжает. */
  .nseg{position:relative;display:inline-flex;background:var(--ink-50);border:1px solid var(--ink-150);border-radius:9px;padding:3px;flex:0 0 auto}
  .nseg-thumb{position:absolute;top:3px;bottom:3px;left:0;width:0;background:var(--paper);border-radius:7px;
    box-shadow:var(--sh-sm),inset 0 1px 0 rgba(255,255,255,.8);z-index:0;
    transition:left .42s cubic-bezier(.34,1.2,.4,1),width .42s cubic-bezier(.34,1.2,.4,1)}
  .nseg-btn{position:relative;z-index:1;font-family:var(--font-sans);font-weight:600;font-size:13px;border:0;background:transparent;
    border-radius:7px;padding:6px 14px;cursor:pointer;color:var(--ink-500);white-space:nowrap;
    transition:color .2s var(--ease-out)}
  .nseg-btn.is-on{color:var(--ink-900)}
  .nseg-btn:focus-visible{outline:none;box-shadow:0 0 0 3px var(--accent-200)}
/* S2#20: фото-инструкция «Откуда взять ссылку» — hover + лайтбокс на весь экран с зумом */
.rs-guide-thumb{transition:transform .16s var(--ease-out),box-shadow .16s var(--ease-out),border-color .16s var(--ease-out)}
.rs-guide-cell:hover .rs-guide-thumb{transform:translateY(-2px);box-shadow:var(--sh-md);border-color:var(--ink-300)!important}
.nlv-lightbox{position:fixed;inset:0;z-index:10040;background:rgba(20,23,26,.9);display:grid;place-items:center;padding:32px;animation:nlvFade .16s ease both;cursor:zoom-out}
.nlv-lb-img{max-width:94vw;max-height:90vh;border-radius:8px;box-shadow:0 24px 70px rgba(0,0,0,.55);cursor:zoom-in;transition:transform .22s var(--ease-out),transform-origin .1s linear}
.nlv-lb-img.zoomed{transform:scale(2.1);cursor:zoom-out}
.nlv-lb-x{position:fixed;top:18px;right:20px;width:42px;height:42px;border-radius:11px;border:1px solid rgba(255,255,255,.25);background:rgba(255,255,255,.12);color:#fff;cursor:pointer;display:grid;place-items:center;transition:background .14s ease,transform .14s ease}
.nlv-lb-x:hover{background:rgba(255,255,255,.24);transform:rotate(90deg)}   /* #1: единый hover крестика */
@media(prefers-reduced-motion:reduce){.rs-guide-thumb,.nlv-lb-img{transition:none}}
/* S2#16: «Добавить комментарий» — выделенная кнопка (не шаблонный rv-sbtn) */
#sec-reports .rv-cmt-add{display:inline-flex;align-items:center;gap:7px;font:600 13px/1 var(--font-sans);color:var(--accent-700);background:var(--accent-50,#EFF9F3);border:1px solid var(--accent-200,#BFE6D2);border-radius:9px;padding:9px 14px;cursor:pointer;transition:background var(--dur-1) var(--ease-out),border-color var(--dur-1) var(--ease-out),color var(--dur-1) var(--ease-out)}
#sec-reports .rv-cmt-add:hover{background:var(--accent-100);border-color:var(--accent-400,#46c08a);color:var(--accent-700)}
#sec-reports .rv-cmt-add svg{flex:0 0 auto;color:var(--accent-600)}
#sec-reports .rv-link{font-family:var(--font-sans);font-size:12px;color:var(--ink-500);background:transparent;border:0;cursor:pointer;padding:2px 6px;border-radius:6px}
#sec-reports .rv-link:hover{background:var(--ink-50)}
#sec-reports .rv-link-d:hover{background:#FBE9E7;color:var(--danger-600)}
#sec-reports .rv-del{font-size:12px;color:var(--ink-400);background:transparent;border:0;cursor:pointer}
#sec-reports .rv-del:hover{color:var(--danger-600)}
#sec-reports .rv-kgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:12px}
#sec-reports .rv-kpi{position:relative;border:1px solid var(--ink-150);border-radius:12px;background:var(--paper);box-shadow:var(--sh-sm),inset 0 1px 0 rgba(255,255,255,.7);padding:15px 16px;min-width:0;transition:transform .14s var(--ease-out),box-shadow .14s var(--ease-out)}
#sec-reports .rv-kpi:hover{transform:translateY(-1px);box-shadow:var(--sh-md)}
#sec-reports .rv-adjbtn{position:absolute;top:12px;right:12px;font-family:var(--font-mono);font-size:9.5px;letter-spacing:.03em;text-transform:uppercase;color:var(--ink-400);background:var(--ink-50);border:1px solid var(--ink-150);border-radius:999px;padding:3px 8px;cursor:pointer;display:inline-flex;align-items:center;gap:3px}
#sec-reports .rv-adjbtn:hover{color:var(--accent-700);border-color:var(--accent-300)}
#sec-reports .rv-hit{cursor:default}
#sec-reports .rv-src-chip{display:inline-flex;align-items:center;font-family:var(--font-mono);font-size:11px;color:var(--ink-700);background:var(--ink-100);border:1px solid var(--ink-200);border-radius:999px;padding:3px 10px;white-space:nowrap}
@media (max-width:560px){
  #sec-reports .rv-kgrid{grid-template-columns:repeat(2,1fr)}
  #sec-reports .rv-cmp .rv-cmp-l{display:none}
  #sec-reports .rv-adjbtn-l{display:none}
  /* M/S1#40: тач-таргеты ≥44px на мобайле (вкладки входа + контролы Отчётности + клиентское сравнение в #cli-cmp-ov) */
  #au-tabs .tab{min-height:44px;display:flex;align-items:center;justify-content:center}
  #sec-reports .rv-nav,#cli-cmp-ov .rv-nav{width:44px;height:44px;font-size:17px}
  .rv-dd-tg{min-height:44px}
  #sec-reports .rv-sbtn,#sec-reports .rv-cmp{min-height:44px}
  #sec-reports .rv-cmp{min-width:44px;justify-content:center}
  .nseg-btn{min-height:44px}
}

/* ── Мультиагентный screener 2026-06-20: подтверждённые визуальные баги @375 ── */
@media (max-width:560px){
  /* P1 reports-dir-1: поповер «Что считать лидом» уезжал за левый край (right:0 + width:320) → бот-шит, гарантированно в вьюпорте */
  #sec-reports .rv-goalspop{position:fixed!important;left:12px!important;right:12px!important;top:auto!important;bottom:14px!important;width:auto!important;max-width:none!important;z-index:10001!important}
  /* P2 cabinet-1/billing-2: чип «Не подключено» обрезался в шапке карточки → переносим на свою строку */
  .intg-head{flex-wrap:wrap}
  .intg-head .ichip{margin-left:0;flex-basis:100%;justify-content:flex-start}
  /* P2 billing-1: чек оплаты обрезал значения → строки стопкой, значение во всю ширину без обрезки */
  .nlv-pay-row{flex-direction:column;align-items:flex-start;gap:3px}
  .nlv-pay-v{text-align:left;white-space:normal;overflow:visible;text-overflow:clip;max-width:100%}
  /* P3 billing-3: футер connect-modal — кнопка с margin-left:auto не растягивалась в column-reverse */
  .nlv-form .nlv-actions>*{margin-left:0!important;width:100%;box-sizing:border-box;justify-content:center}
  /* ── тач-таргеты ≥44px (подтверждено по экранам) ── */
  .nlv-x{width:44px;height:44px}                         /* ✕ всех модалок (admin/proposals/retention/upgrade/pay/connect) */
  .nlv-form .nlv-x{width:44px;height:44px}               /* ✕ form-модалок (settings/project) */
  .side-add{min-height:44px}                              /* «+ Новый» в шапке проектов */
  .bcta{min-height:44px}                                  /* «+ Новый проект» в пустом кабинете */
  #auth .au-eye{width:44px}                               /* глаз показа пароля */
  #auth a,#rs-resend{display:inline-flex;align-items:center;min-height:44px;padding:0 4px}  /* «Забыли пароль?» / «Назад ко входу» / «Отправить код повторно» */
  .nlv-inp{min-height:44px}                               /* инпуты форм (проект/настройки/подключение) */
  .qlink{min-height:44px}                                 /* «?как взять» помощь-линки */
  #sec-reports .rv-adjbtn{min-width:40px;min-height:40px;padding:0;justify-content:center}  /* «+» корректировки (огранич. место в углу KPI-карточки) */
  #sec-reports .rv-link,#sec-reports .rv-link-d{padding:11px 8px}  /* «Изменить»/«Удалить» коммента */
  #sec-reports .rv-cmt-add{min-height:44px}              /* «Добавить комментарий» */
  .pwd-ic{width:40px;height:44px}                         /* инлайн-иконки пароля (генер/копир/показать) */
  .pwd-ic.pwd-q{width:34px;height:34px}                   /* «?» подсказка (кружок — компромисс) */
  /* #24: на узких экранах иконки крупнее (40px) — увеличиваем padding-right поля, чтобы
     точки/плейсхолдер НЕ заходили под иконки. full=4 кнопки (40·3+34+gaps+7), minimal=1. */
  .pwd-wrap .pwd-inp{padding-right:64px!important}
  .pwd-wrap.pwd-wrap--full .pwd-inp{padding-right:178px!important}
  .q-rej{min-height:44px}                                 /* «Отклонить» в очереди */
}

/* ════════════════════════════════════════════════════════════════════════════
   Единый попап «Настройки» (#account-modal / .acct-*) — строго по макету Claude Design
   (design_handoff_settings_popup). Палитра ink + emerald, БЕЗ синего (вкл. :focus).
   Раскладка fluid (flex+flex-wrap+gap), без media-queries внутри попапа. Scoped — не
   пересекается с существующими set-*/bp-*. Добавлено в конец, ничего выше не трогает.
   ════════════════════════════════════════════════════════════════════════════ */
@keyframes acctFadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
@keyframes acctBarFill{from{width:0}to{width:var(--w)}}
@keyframes acctShimmer{0%{background-position:-460px 0}100%{background-position:460px 0}}

#account-modal .acct-modal{padding:0!important;max-height:min(90vh,900px);overflow:hidden;display:flex;flex-direction:column;border-radius:var(--r-xl)}
#account-modal *{box-sizing:border-box}
#account-modal .acct-mono{font-family:var(--font-mono);font-feature-settings:"tnum" 1}

/* Header */
.acct-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:24px 24px 18px 26px;border-bottom:1px solid var(--ink-100);flex:0 0 auto}
.acct-overline{font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-400);display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.acct-dot{width:3px;height:3px;border-radius:9px;background:var(--ink-200)}
.acct-h2{margin:7px 0 0;font-size:25px;font-weight:800;letter-spacing:-.02em;line-height:1.12;color:var(--ink-900)}
.acct-x{flex:none;width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;background:var(--paper);border:1px solid var(--ink-200);border-radius:var(--r-sm);color:var(--ink-600);cursor:pointer;box-shadow:0 1px 1px rgba(20,23,26,.03);transition:background var(--dur-1) var(--ease-out),color var(--dur-1) var(--ease-out),transform .4s var(--ease-out)}
.acct-x:hover{background:var(--ink-50);color:var(--ink-900);transform:rotate(90deg)}   /* #1: единый hover крестика (rotate 90 + фон) как у .nlv-x */
.acct-x:active{transform:rotate(90deg) scale(.94)}
.acct-x:focus-visible{outline:none;box-shadow:0 0 0 3px var(--accent-200)}

/* Баннер-причина */
.acct-reason{display:flex;align-items:flex-start;gap:12px;margin:14px 24px 0;padding:14px 16px;background:var(--warn-100);border:1px solid #ECD9B0;border-left:3px solid var(--warn-600);border-radius:var(--r-md)}
.acct-reason-ic{flex:none;width:30px;height:30px;border-radius:999px;background:#F2DFB6;display:inline-flex;align-items:center;justify-content:center}
.acct-reason-t{font-size:13.5px;font-weight:700;color:var(--warn-600);margin-bottom:2px}
.acct-reason-b{font-size:13px;line-height:1.5;color:var(--ink-700)}

/* Tabs */
/* #2/#6: единый скользящий индикатор (БЕЛАЯ плашка едет под активный таб — единый стиль со всеми табами) */
.acct-tabs{position:relative;display:flex;gap:0;margin:14px 24px 0;padding:3px;background:var(--ink-50);border:1px solid var(--ink-150);border-radius:10px;flex:0 0 auto}
.acct-thumb{position:absolute;top:3px;bottom:3px;left:0;width:0;background:var(--paper);border-radius:7px;box-shadow:var(--sh-sm),inset 0 1px 0 rgba(255,255,255,.8);z-index:0;opacity:0;transition:left .42s cubic-bezier(.34,1.2,.4,1),width .42s cubic-bezier(.34,1.2,.4,1),opacity .15s linear}
.acct-tab{position:relative;z-index:1;min-width:0;border:none;cursor:pointer;border-radius:7px;padding:9px 8px;font-family:var(--font-sans);font-size:13.5px;font-weight:600;color:var(--ink-500);background:transparent;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .2s var(--ease-out)}
.acct-tab:active{transform:scale(.98)}
.acct-tab:hover:not(.on){color:var(--ink-700)}
.acct-tab.on{font-weight:700;color:var(--ink-900)}
.acct-tab:focus-visible{outline:none;box-shadow:0 0 0 2px var(--accent-300)}
.acct-tabs-sep{height:1px;background:var(--ink-100);margin:14px 24px 0;flex:0 0 auto}
@media (max-width:560px){.acct-tab{padding:9px 5px;font-size:12px;letter-spacing:-.01em}}

/* Body / panes */
.acct-body{padding:22px 24px 26px;overflow-y:auto;flex:1 1 auto;scrollbar-width:thin;scrollbar-color:var(--ink-200) transparent}
.acct-body::-webkit-scrollbar{width:8px}
.acct-body::-webkit-scrollbar-thumb{background:var(--ink-200);border-radius:999px;border:2px solid transparent;background-clip:padding-box}
@media(max-width:560px){.acct-body::-webkit-scrollbar{display:none !important}.acct-body{scrollbar-width:none !important}}
.acct-pane{display:flex;flex-direction:column;animation:acctFadeIn var(--dur-2) var(--ease-out)}
.acct-pane.hidden{display:none}
.acct-shim{background:linear-gradient(90deg,var(--ink-100),var(--ink-50),var(--ink-100));background-size:460px 100%;animation:acctShimmer 1.3s linear infinite}
.acct-sec-l{font-family:var(--font-mono);font-size:11px;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-400)}

/* Таб Аккаунт */
.acct-prow{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;padding:13px 0;border-bottom:1px solid var(--ink-100)}
.acct-prow-k{font-size:14.5px;color:var(--ink-500)}
.acct-prow-v{font-size:14px;font-weight:600;color:var(--ink-900)}
.acct-rolepill{font-family:var(--font-mono);font-size:11.5px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-600);background:var(--ink-100);padding:4px 10px;border-radius:var(--r-pill)}

/* Билинг: общие */
.acct-tariffpill{font-size:12.5px;font-weight:700;color:var(--ink-700);background:var(--ink-100);padding:4px 11px;border-radius:var(--r-pill)}
.acct-track{height:8px;border-radius:9px;background:var(--ink-100);overflow:hidden}
.acct-fill{height:100%;border-radius:9px;transition:width var(--dur-3) var(--ease-out)}
.acct-hr{height:1px;background:var(--ink-100)}
.acct-badge{font-size:12px;font-weight:700;padding:4px 11px;border-radius:var(--r-pill);white-space:nowrap}

/* Карточка тарифа */
.acct-card{background:var(--paper);border:1px solid var(--ink-150);border-radius:var(--r-lg);padding:19px 20px;box-shadow:inset 0 1px 0 rgba(255,255,255,.7),var(--sh-xs)}

/* Кнопки */
/* #10a (Claude Design 2026-06-22): единая объёмная primary-кнопка DS — градиент 500→700,
   верхний блик (::before 46%), inset-низ, emerald-glow; фокус — бело-emerald ринг (НЕ синий). */
.acct-btn{position:relative;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--accent-700);cursor:pointer;border-radius:var(--r-sm);padding:11px 18px;font-family:var(--font-sans);font-size:14px;font-weight:600;color:#fff;background:linear-gradient(180deg,var(--accent-500),var(--accent-700));box-shadow:inset 0 1px 0 rgba(255,255,255,.28),inset 0 -1px 1px rgba(11,110,71,.5),0 1px 2px rgba(11,110,71,.4),0 6px 16px rgba(18,165,107,.26);transition:transform var(--dur-1) var(--ease-out),box-shadow var(--dur-1) var(--ease-out),background var(--dur-1) var(--ease-out),color var(--dur-1) var(--ease-out)}
.acct-btn::before{content:'';position:absolute;left:0;right:0;top:0;height:46%;background:linear-gradient(180deg,rgba(255,255,255,.26),rgba(255,255,255,0));pointer-events:none}
.acct-btn>*{position:relative}
.acct-btn:hover{box-shadow:inset 0 1px 0 rgba(255,255,255,.3),inset 0 -1px 1px rgba(11,110,71,.5),0 8px 22px rgba(18,165,107,.36),0 2px 6px rgba(11,110,71,.3);transform:translateY(-1px)}
.acct-btn:active{transform:translateY(1px) scale(.99);box-shadow:inset 0 2px 4px rgba(11,110,71,.5),0 1px 2px rgba(11,110,71,.3)}
.acct-btn:focus-visible{outline:none;box-shadow:inset 0 1px 0 rgba(255,255,255,.28),0 6px 16px rgba(18,165,107,.26),0 0 0 2px #fff,0 0 0 4px var(--accent-700)}
.acct-btn:disabled,.acct-btn[disabled]{background:linear-gradient(180deg,var(--ink-200),var(--ink-300));border-color:var(--ink-300);color:var(--ink-500);box-shadow:none;cursor:not-allowed;transform:none}
.acct-btn:disabled::before,.acct-btn[disabled]::before{display:none}
.acct-btn-danger{background:var(--paper);color:var(--danger-600);border:1px solid #E4B8B4;box-shadow:none}
.acct-btn-danger::before{display:none}
.acct-btn-danger:hover{background:var(--danger-100);border-color:var(--danger-600);box-shadow:none;transform:none}
.acct-btn-danger:active{transform:scale(.99);box-shadow:none}
.acct-btn-danger:focus-visible{box-shadow:0 0 0 2px #fff,0 0 0 4px var(--danger-600)}
.acct-btn-ink{background:linear-gradient(180deg,var(--ink-700),var(--ink-900));color:#fff;border:1px solid var(--ink-900);box-shadow:inset 0 1px 0 rgba(255,255,255,.1),0 1px 2px rgba(20,23,26,.3),0 6px 16px rgba(20,23,26,.18)}
.acct-btn-ink::before{background:linear-gradient(180deg,rgba(255,255,255,.12),rgba(255,255,255,0))}
.acct-btn-ink:hover{background:linear-gradient(180deg,var(--ink-700),var(--ink-900));box-shadow:inset 0 1px 0 rgba(255,255,255,.12),0 8px 22px rgba(20,23,26,.26);transform:translateY(-1px)}
.acct-btn-ink:active{transform:translateY(1px) scale(.99);box-shadow:inset 0 2px 4px rgba(0,0,0,.4)}

/* Другие тарифы (мини-карточки — НЕ в макете, подчинённо; требует дизайн-ревью) */
.acct-mini-tariff{display:flex;align-items:center;gap:10px;padding:11px 14px;background:var(--ink-50);border:1px solid var(--ink-150);border-radius:var(--r-md)}
.acct-mini-cur{border-color:var(--accent-300);background:var(--accent-50)}
.acct-mini-l{display:flex;align-items:center;gap:7px;flex:1 1 auto;min-width:0}
.acct-mini-name{font-size:14px;font-weight:700;color:var(--ink-900)}
.acct-mini-price{font-size:13px;color:var(--ink-700);white-space:nowrap}
.acct-mini-contact{border:1px solid var(--ink-200);background:var(--paper);color:var(--ink-700);font-size:12.5px;font-weight:600;border-radius:var(--r-sm);padding:7px 13px;cursor:pointer;transition:all var(--dur-1) var(--ease-out)}
.acct-mini-contact:hover{border-color:var(--accent-300);color:var(--accent-700)}
.acct-mini-contact:focus-visible{outline:none;box-shadow:0 0 0 2px var(--accent-300)}
.acct-contact-links{display:flex;align-items:center;gap:10px;margin-top:10px;flex-wrap:wrap}
.acct-contact-link{font-size:13px;font-weight:600;color:var(--accent-700);text-decoration:none;border-bottom:1px solid var(--accent-300)}
.acct-contact-link:hover{color:var(--accent-600)}
.acct-contact-link:focus-visible{outline:none;box-shadow:0 0 0 2px var(--accent-300);border-radius:3px}

/* Баланс кошелька */
.acct-wallet{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;background:var(--ink-50);border:1px solid var(--ink-150);border-radius:var(--r-md);padding:16px 18px}
.acct-wallet-lab{font-family:var(--font-mono);font-size:10px;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-400);margin-bottom:5px}
.acct-card-ic{width:38px;height:28px;border-radius:6px;border:1px solid var(--ink-200);display:inline-flex;align-items:center;justify-content:center;color:var(--ink-400)}
.acct-bal-note{display:flex;align-items:flex-start;gap:11px;padding:13px 15px;border-radius:var(--r-md);background:var(--warn-100);border:1px solid #ECD9B0;border-left:3px solid var(--warn-600)}
.acct-bal-note.danger{background:var(--danger-100);border-color:#F0D4D1;border-left-color:var(--danger-600)}
.acct-bal-note-ic{flex:none;width:28px;height:28px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:#F2DFB6;color:var(--warn-600)}
.acct-bal-note.danger .acct-bal-note-ic{background:#F3D4D1;color:var(--danger-600)}
.acct-bal-note-t{font-size:13.5px;font-weight:700;color:var(--warn-600);margin-bottom:2px}
.acct-bal-note.danger .acct-bal-note-t{color:var(--danger-600)}
.acct-bal-note-b{font-size:13px;line-height:1.45;color:var(--ink-600)}
.acct-preset{border:1px solid var(--ink-200);cursor:pointer;border-radius:var(--r-sm);padding:9px 15px;font-size:14px;font-weight:600;color:var(--ink-800);background:var(--paper);box-shadow:0 1px 1px rgba(20,23,26,.03);transition:all var(--dur-1) var(--ease-out)}
.acct-preset:hover{border-color:var(--accent-300)}
.acct-preset:active{transform:scale(.97)}
.acct-preset:focus-visible{outline:none;box-shadow:0 0 0 2px var(--accent-300)}
.acct-amt-field{flex:1;min-width:150px;display:flex;align-items:center;background:var(--paper);border:1px solid var(--ink-200);border-radius:var(--r-sm);padding:0 13px;transition:border-color var(--dur-1) var(--ease-out)}
.acct-amt-field:focus-within{border-color:var(--accent-500);box-shadow:0 0 0 3px var(--accent-50)}
.acct-amt-field input{flex:1;min-width:0;border:none;outline:none;background:transparent;font-family:var(--font-sans);font-size:14.5px;color:var(--ink-900);padding:11px 0;-moz-appearance:textfield}
.acct-amt-field input::-webkit-outer-spin-button,.acct-amt-field input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.acct-amt-cur{font-family:var(--font-mono);font-size:14px;color:var(--ink-400)}
.acct-amt-bad{border-color:var(--danger-600)!important;box-shadow:0 0 0 3px var(--danger-100)!important}
.acct-btn-pay{flex:none}
.acct-topup-msg{font-size:12.5px;min-height:1px;color:var(--ink-400)}
.acct-topup-msg.err{color:var(--danger-600)}
.acct-topup-msg.info{color:var(--ink-500)}

/* История оплат */
.acct-hist-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px solid var(--ink-100)}
.acct-hist-empty{display:flex;flex-direction:column;align-items:center;gap:7px;padding:26px 16px;background:var(--ink-50);border:1px dashed var(--ink-200);border-radius:var(--r-md);text-align:center}

/* Когда лимит исчерпан */
.acct-limit{background:var(--ink-50);border:1px solid var(--ink-150);border-radius:var(--r-lg);padding:18px 20px;display:flex;flex-direction:column;gap:14px;transition:background var(--dur-2) var(--ease-out),border-color var(--dur-2) var(--ease-out)}
.acct-limit.reached{background:var(--warn-100);border-color:#ECD9B0}
.acct-mode{flex:1;min-width:228px;background:var(--paper);border:1px solid var(--ink-150);border-radius:var(--r-md);padding:14px 15px;display:flex;flex-direction:column;gap:9px;box-shadow:inset 0 1px 0 rgba(255,255,255,.7),var(--sh-xs);transition:border-color var(--dur-2) var(--ease-out)}
.acct-mode.on{border-color:var(--accent-300)}
.acct-default-pill{align-self:flex-start;font-family:var(--font-mono);font-size:10px;letter-spacing:.05em;text-transform:uppercase;color:var(--accent-700);background:var(--accent-100);padding:2px 7px;border-radius:var(--r-pill)}
.acct-toggle{flex:none;width:42px;height:24px;border:none;cursor:pointer;border-radius:999px;background:var(--ink-200);position:relative;padding:0;transition:background var(--dur-2) var(--ease-out)}
.acct-toggle.on{background:var(--accent-500)}
.acct-toggle:focus-visible{outline:none;box-shadow:0 0 0 3px var(--accent-300)}
.acct-knob{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:999px;background:#fff;box-shadow:0 1px 2px rgba(20,23,26,.3);transition:left var(--dur-2) var(--ease-out)}
.acct-toggle.on .acct-knob{left:21px}
.acct-bothoff{display:flex;align-items:flex-start;gap:11px;padding:12px 15px;background:var(--warn-100);border:1px solid #ECD9B0;border-left:3px solid var(--warn-600);border-radius:var(--r-md)}

/* Дисклеймер автопродления */
.acct-disclaimer{display:flex;align-items:flex-start;gap:10px;padding:12px 15px;background:var(--ink-50);border:1px solid var(--ink-100);border-radius:var(--r-md)}
.acct-disclaimer-ic{flex:none;width:26px;height:26px;border-radius:999px;background:var(--ink-100);display:inline-flex;align-items:center;justify-content:center;margin-top:1px}

/* Поля пароля (Безопасность) — pwd-wrap обогащается enhancePwdField */
.acct-pwd-inp{width:100%;border:1px solid var(--ink-200);border-radius:var(--r-sm);background:var(--paper);font-family:var(--font-sans);font-size:14.5px;color:var(--ink-900);padding:11px 12px;outline:none;transition:border-color var(--dur-1) var(--ease-out)}
.acct-pwd-inp:focus,.acct-pane .pwd-wrap:focus-within{border-color:var(--accent-500)}
.acct-pane .pwd-wrap:focus-within{box-shadow:0 0 0 3px var(--accent-50);border-radius:var(--r-sm)}
.acct-pwd-msg{font-size:13px;color:var(--ink-400);min-height:1px}
/* C2: отступ сообщений-состояний форм ТОЛЬКО когда есть текст (фикс «впритык к следующему полю»; пустое не плодит зазор). */
.acct-pwd-msg:not(:empty),.acct-topup-msg:not(:empty){margin:4px 0 2px}
#auth .auth-err:not(:empty){margin:6px 0 2px}
.acct-pwd-msg.err:not(:empty){color:var(--danger-600)}
.acct-pwd-msg.err{color:var(--danger-600)}

/* «?»-поповеры (tooltip) — тёмная плашка, fade+scale, ink-900 */
.acct-q{position:relative;width:16px;height:16px;border-radius:999px;border:1px solid var(--ink-200);display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:var(--ink-400);cursor:help;transition:all var(--dur-1) var(--ease-out)}
.acct-q:hover{border-color:var(--ink-400);color:var(--ink-600)}
/* C5: светлый тултип (серый фон / чёрный текст), auto-ширина до 280px (длинный текст виден целиком, не узкий чёрный обрубок), высокий z-index чтобы не уезжал под соседей. */
.acct-q::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 9px);left:50%;width:max-content;max-width:min(280px,calc(100vw - 32px));transform:translateX(-50%) translateY(5px) scale(.96);transform-origin:bottom center;opacity:0;pointer-events:none;background:var(--paper);color:var(--ink-800);border:1px solid var(--ink-200);font-family:var(--font-sans);font-size:12px;line-height:1.45;font-weight:500;padding:9px 12px;border-radius:var(--r-sm);box-shadow:var(--sh-lg);transition:opacity var(--dur-2) var(--ease-out),transform var(--dur-2) var(--ease-out);z-index:1000;white-space:normal}
.acct-q:hover::after,.acct-q:focus-visible::after{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}
/* #25: при активном JS-позиционере (html.js-acct-tip) CSS-bubble отключаем — её рисует плавающий .acct-tip-float (fixed, escape clipping + viewport-flip), чтобы текст не срезался краем экрана/попапа. */
html.js-acct-tip .acct-q::after{display:none}
.acct-tip-float{position:fixed;z-index:10060;max-width:min(300px,calc(100vw - 16px));background:var(--paper);color:var(--ink-800);border:1px solid var(--ink-200);font-family:var(--font-sans);font-size:12px;line-height:1.45;font-weight:500;padding:9px 12px;border-radius:var(--r-sm);box-shadow:var(--sh-lg);pointer-events:none;white-space:normal;opacity:0;transform:translateY(4px) scale(.97);transform-origin:bottom center;transition:opacity var(--dur-2) var(--ease-out),transform var(--dur-2) var(--ease-out)}
.acct-tip-float.show{opacity:1;transform:translateY(0) scale(1)}
.acct-tip-float.below{transform-origin:top center}
@media(prefers-reduced-motion:reduce){.acct-tip-float{transition-duration:.001ms!important}}

/* prefers-reduced-motion внутри попапа — анимации ~0ms */
@media(prefers-reduced-motion:reduce){
  #account-modal *,#account-modal .acct-fill,#account-modal .acct-knob,#account-modal .acct-q::after{animation-duration:.001ms!important;transition-duration:.001ms!important}
}

/* Мобайл 375px: тач-таргеты ≥44px, без выхода за viewport. Раскладка уже fluid (flex-wrap). */
@media(max-width:560px){
  #account-modal .acct-modal{width:calc(100vw - 24px)}
  .acct-x{width:44px;height:44px}
  .acct-tab{min-height:44px}
  .acct-btn{min-height:44px}
  .acct-preset{min-height:44px}
  .acct-toggle{transform:scale(1.05)}
  .acct-amt-field input{min-height:44px}
  .acct-mini-contact{min-height:44px}
}

/* ── Виджет поддержки (floating) ── */
#nlv-help-widget{position:fixed;bottom:24px;right:24px;z-index:9000;display:flex;flex-direction:column;align-items:flex-end;gap:10px}
#nlv-help-widget.hidden{display:none}
#nlv-help-pop{width:284px;background:var(--paper);border:1px solid var(--ink-150);border-radius:16px;box-shadow:0 8px 32px rgba(20,23,26,.14),0 2px 8px rgba(20,23,26,.07);padding:16px 16px 14px;transform-origin:bottom right;animation:nlvHelpIn .22s cubic-bezier(.34,1.26,.5,1) both}
#nlv-help-pop.nlv-help-closing{animation:nlvHelpOut .15s ease both}
@keyframes nlvHelpIn{from{opacity:0;transform:scale(.88) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}
@keyframes nlvHelpOut{from{opacity:1;transform:scale(1) translateY(0)}to{opacity:0;transform:scale(.88) translateY(8px)}}
.nlv-help-hd{display:flex;align-items:flex-start;gap:11px;margin-bottom:13px}
.nlv-help-ico{flex:none;width:36px;height:36px;border-radius:10px;background:linear-gradient(145deg,var(--accent-400),var(--accent-700));display:grid;place-items:center;color:#fff}
/* Круглый flip-аватар партнёра (Хайдар) в шапке поддержки. Hover → 3D-переворот:
   фото → emerald-сторона с «N». Online-точка + glow-ring на hover. */
.nlv-help-ava{flex:none;width:46px;height:46px;position:relative;perspective:640px;cursor:pointer;margin-top:1px}
.nlv-help-ava-inner{position:relative;width:100%;height:100%;transition:transform .62s cubic-bezier(.4,.18,.2,1);transform-style:preserve-3d}
.nlv-help-ava:hover .nlv-help-ava-inner,.nlv-help-ava:focus-visible .nlv-help-ava-inner{transform:rotateY(180deg)}
.nlv-help-ava-face{position:absolute;inset:0;border-radius:50%;-webkit-backface-visibility:hidden;backface-visibility:hidden;overflow:hidden;display:grid;place-items:center;box-shadow:0 2px 9px rgba(20,23,26,.14),inset 0 0 0 2px rgba(255,255,255,.85)}
.nlv-help-ava-front{background:linear-gradient(150deg,var(--ink-200),var(--ink-300))}
.nlv-help-ava-front img{width:100%;height:100%;object-fit:cover;display:block}
/* пока фото нет (img onerror) — показываем инициал на градиенте */
.nlv-help-ava-front.is-ph::after{content:'Х';font:800 19px/1 var(--font-sans);color:var(--ink-500)}
/* Оборот — премиум-визитка: глубокий ink-градиент + фирменный знак Nelvo,
   тонкая внутр. обводка и зелёный отблеск снизу (не блёклый светлый круг). */
.nlv-help-ava-back{transform:rotateY(180deg);background:radial-gradient(125% 125% at 30% 16%,#2E343D 0%,#1A1E25 52%,#14171A 100%);box-shadow:0 3px 12px rgba(20,23,26,.24),inset 0 0 0 1px rgba(255,255,255,.16),inset 0 -11px 18px -8px rgba(25,195,125,.5)}
.nlv-help-ava-back svg{filter:drop-shadow(0 1px 2px rgba(0,0,0,.4))}
/* glow-ring при наведении — изумрудный отблеск вокруг */
.nlv-help-ava::before{content:'';position:absolute;inset:-4px;border-radius:50%;background:radial-gradient(circle,rgba(25,195,125,.55),transparent 68%);opacity:0;transition:opacity .35s;z-index:-1}
.nlv-help-ava:hover::before{opacity:.7}
/* online-индикатор «на связи» */
.nlv-help-ava-dot{position:absolute;right:1px;bottom:1px;width:11px;height:11px;border-radius:50%;background:var(--accent-500);box-shadow:0 0 0 2.5px var(--paper);z-index:2}
.nlv-help-ava-dot::after{content:'';position:absolute;inset:0;border-radius:50%;background:var(--accent-500);animation:nlvHelpPulse 1.9s ease-out infinite}
@keyframes nlvHelpPulse{0%{transform:scale(1);opacity:.55}70%,100%{transform:scale(2.4);opacity:0}}
@media (prefers-reduced-motion:reduce){.nlv-help-ava-inner{transition:none}.nlv-help-ava-dot::after{animation:none}}
.nlv-help-inf{min-width:0;flex:1 1 auto}
.nlv-help-inf b{display:block;font:700 13.5px/1.2 var(--font-sans);color:var(--ink-900)}
.nlv-help-inf span{font:500 11.5px/1.4 var(--font-sans);color:var(--ink-400);display:block;margin-top:2px}
.nlv-help-x{flex:none;width:26px;height:26px;border:0;background:none;border-radius:7px;color:var(--ink-400);cursor:pointer;display:grid;place-items:center;transition:background .12s,color .12s;margin-top:-2px;margin-right:-3px}
.nlv-help-x:hover{background:var(--ink-100);color:var(--ink-700)}
.nlv-help-note{font-size:11.5px;line-height:1.5;color:var(--ink-400);margin-top:11px;padding-top:10px;border-top:1px solid var(--ink-100)}
#nlv-help-btn{width:52px;height:52px;border-radius:999px;background:linear-gradient(145deg,var(--accent-500),var(--accent-700));border:0;cursor:pointer;color:#fff;display:grid;place-items:center;box-shadow:0 4px 18px rgba(16,140,90,.38),0 1px 4px rgba(16,140,90,.18);transition:transform .18s cubic-bezier(.34,1.26,.5,1),box-shadow .18s ease,background .2s ease}
#nlv-help-btn:hover{transform:scale(1.09);box-shadow:0 6px 26px rgba(16,140,90,.48),0 2px 8px rgba(16,140,90,.24)}
#nlv-help-btn:active{transform:scale(.95)}
#nlv-help-btn.is-open{background:linear-gradient(145deg,var(--ink-600),var(--ink-900));box-shadow:0 4px 16px rgba(20,23,26,.22)}
#nlv-help-pop .nlv-support-btns{flex-direction:column;gap:7px}
#nlv-help-pop .nlv-sup-btn{flex:none;min-width:0;width:100%;box-sizing:border-box}
@media(max-width:480px){#nlv-help-widget{bottom:16px;right:16px}#nlv-help-pop{width:calc(100vw - 32px)}}
