/* 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{font:inherit}
  ::selection{background:var(--accent-100)}

  /* Кнопки — 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)}

  /* Шапка */
  header#topbar{display:flex;align-items:center;gap:14px;padding:12px 20px;
    background:var(--paper);border-bottom:1px solid var(--ink-150);position:sticky;top:0;z-index:10}
  .brand{display:flex;align-items:center}
  .brand img{height:30px;display:block}
  #header-title{font-weight:600;color:var(--ink-600);padding-left:14px;margin-left:2px;
    border-left:1px solid var(--ink-150)}
  #header-actions{display:flex;gap:8px;margin-left:auto;align-items:center}
  .user-chip{font-size:11.5px;color:var(--ink-500);font-family:var(--font-mono);letter-spacing:.02em;
    background:var(--ink-50);border:1px solid var(--ink-150);border-radius:999px;padding:5px 11px}

  /* Метеринг-индикатор расхода AI-кредитов (кликабелен → апгрейд) */
  .usage-meter{display:inline-flex;align-items:center;gap:8px;cursor:pointer;border:1px solid var(--ink-150);
    background:var(--ink-50);border-radius:999px;padding:4px 6px 4px 11px;font-family:var(--font-mono);
    font-size:11.5px;color:var(--ink-600);letter-spacing:.02em;transition:border-color .15s,background .15s}
  .usage-meter:hover{border-color:var(--ink-300);background:var(--paper)}
  .usage-meter .um-bar{width:56px;height:6px;border-radius:999px;background:var(--ink-150);overflow:hidden;flex:0 0 auto}
  .usage-meter .um-fill{height:100%;width:0;border-radius:999px;background:var(--good-500);transition:width .35s,background .25s}
  .usage-meter.warn .um-fill{background:var(--warn-600)} .usage-meter.warn{color:var(--warn-600)}
  .usage-meter.over .um-fill{background:var(--danger-600)} .usage-meter.over{color:var(--danger-600);border-color:var(--danger-600)}
  .usage-meter .um-cta{font-family:var(--font-sans,inherit);font-weight:700;font-size:11px;color:var(--paper);
    background:var(--ink-900);border-radius:999px;padding:3px 9px;white-space:nowrap}
  .usage-meter.over .um-cta{background:var(--danger-600)}
  /* Страница «Тариф и оплата» */
  #billing-page{position:fixed;inset:0;background:var(--paper,#fff);z-index:60;overflow-y:auto}
  .bp-wrap{max-width:760px;margin:0 auto;padding:24px 20px 64px;display:flex;flex-direction:column;gap:16px}
  .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}
  .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)}
  /* 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)}
  .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}
  .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-900);box-shadow:0 0 0 3px rgba(20,23,26,.08)}
  .ad-mini-btn{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}
  .ad-mini-btn:hover{background:var(--ink-50)}
  /* разворот клиента — мини фин-отчёт */
  .ad-det{grid-column:1/-1;padding:14px 4px 6px;border-top:1px dashed var(--ink-200);margin-top:4px}
  .ad-det-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
  .ad-mc{border:1px solid var(--ink-150);background:var(--ink-50);border-radius:var(--r-sm);padding:10px 11px}
  .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-det-note{font-size:11.5px;color:var(--ink-400);margin-top:8px}
  /* 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;gap:8px;flex-wrap:wrap;margin-top:8px}
  .set-pwd input{flex:1;min-width:150px;padding:9px 11px;border:1px solid var(--ink-200);border-radius:var(--r-sm);font-size:13px}
  .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-900);box-shadow:0 0 0 3px rgba(20,23,26,.08)}
  .ca-msg{font-size:13px;min-height:18px;margin:2px 0 12px}
  .ca-acts{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
  .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}
  .wl-logo{width:28px;height:28px;border-radius:8px;display:grid;place-items:center}
  .wl-bn{font-weight:700;font-size:14px;color:var(--ink-900);min-width:0;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-cap{font-size:11.5px;color:var(--ink-400);margin-top:10px}
  @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-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)}
  .tour-skip:hover{background:var(--ink-50);color:var(--ink-900)}
  .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)}
  .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) ── */
  .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-bottom:14px;padding:12px 14px;background:var(--ink-50);border-radius:var(--r-md)}
  .pr-detail.hidden{display:none}
  .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}
  .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}
  .pr-ok:hover{background:linear-gradient(180deg,var(--accent-600),var(--accent-700))}
  .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}
  .pr-defer:hover,.pr-rej:hover{background:var(--ink-50)}
  .pr-rej{margin-left:auto;color:var(--danger-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}
  }

  /* Раскладка */
  .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:11px;padding:9px 12px 9px 11px;border-radius:var(--r-md);cursor:pointer;
    border:1px solid transparent;position:relative;overflow:hidden;
    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 = чистая белая карта + изумрудная левая грань + мягкая тень (не плоский зелёный фон) */
  .proj.active{background:var(--paper);border-color:var(--ink-150);
    box-shadow:var(--sh-sm),inset 0 1px 0 rgba(255,255,255,.7)}
  .proj.active::before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:3px;border-radius:0 3px 3px 0;
    background:linear-gradient(180deg,var(--accent-500),var(--accent-700))}
  .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)}
  .proj.active .ptile{background:linear-gradient(157deg,var(--accent-500),var(--accent-700));
    box-shadow:inset 0 1px 0 rgba(255,255,255,.22),0 2px 8px rgba(11,110,71,.32)}
  .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}
  .proj .pdot{flex:none;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)}
  .proj .pgear{flex:none;width:26px;height:26px;display:none;place-items:center;border:0;background:transparent;
    color:var(--ink-400);border-radius:7px;cursor:pointer;transition:background var(--dur-1) var(--ease-out),color var(--dur-1) var(--ease-out)}
  .proj:hover .pgear,.proj.active .pgear{display:grid}
  .proj:hover .pdot,.proj.active .pdot{display:none}
  .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%)}
  .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}
  @media(max-width:640px){ .bento{grid-template-columns:1fr} }

  /* ===== Экран входа — импульс клавиши: волны-keycap + синхрон CTA ===== */
  #auth{position:fixed;inset:0;z-index:50;overflow:hidden;display:grid;place-items:center;
    background:radial-gradient(85% 75% at 50% 46%, #0c1117 0%, #070b0f 55%, #05070a 100%)}
  .ks-haze{position:absolute;left:50%;top:50%;width:52vw;height:52vw;transform:translate(-50%,-50%);border-radius:50%;
    background:radial-gradient(circle,rgba(18,165,107,.16),transparent 62%);filter:blur(54px);pointer-events:none}
  .ks-core{position:absolute;left:50%;top:50%;width:128px;height:128px;transform:translate(-50%,-50%);border-radius:30px;
    background:radial-gradient(circle,rgba(43,208,143,.5),rgba(18,165,107,.14) 55%,transparent 72%);filter:blur(14px);
    will-change:opacity;animation:ksCore 9s ease-in-out infinite;pointer-events:none}
  /* Только opacity (без scale): blur-слой не перерастеризуется на кадр — иначе мерцание. */
  @keyframes ksCore{0%,100%{opacity:.5}48%{opacity:.95}}
  /* Волны: маленькая базовая текстура (760px) + рост transform:scale — GPU масштабирует готовый
     слой, без re-raster гигантского кольца. border-color НЕ анимируем (это paint каждый кадр на
     огромном элементе = главная причина мерцания). Композит-only: transform + opacity. */
  .ks-wave{position:absolute;left:50%;top:50%;width:760px;height:760px;border-radius:24%;
    border:1.6px solid rgba(43,208,143,.5);pointer-events:none;will-change:transform,opacity;backface-visibility:hidden;
    transform:translate(-50%,-50%) scale(.1);animation:ksWave 9s cubic-bezier(.33,0,.15,1) infinite}
  .ks-wave.w2{animation-delay:2.25s}.ks-wave.w3{animation-delay:4.5s}.ks-wave.w4{animation-delay:6.75s}
  @keyframes ksWave{
    0%{transform:translate(-50%,-50%) scale(.1);opacity:0}
    10%{opacity:.55}
    100%{transform:translate(-50%,-50%) scale(6);opacity:0}}
  .ks-vig{position:absolute;inset:0;pointer-events:none;background:radial-gradient(64% 64% at 50% 47%,transparent,rgba(5,7,10,.82))}
  .auth-center{position:relative;z-index:1;width:404px;max-width:calc(100vw - 36px);
    display:flex;flex-direction:column;align-items:center}
  .auth-brand{display:flex;align-items:center;margin-bottom:20px}
  .auth-brand img{height:22px;display:block}
  .auth-card{width:100%;background:var(--paper);border:1px solid var(--ink-150);border-radius:var(--r-xl);
    padding:28px 28px 24px;box-shadow:0 44px 100px -34px rgba(0,0,0,.88),inset 0 1px 0 rgba(255,255,255,.7)}
  /* кнопка «Войти» пульсирует в такт импульсу — фон связан с действием */
  #au-submit{animation:ksCta 9s ease-in-out infinite}
  @keyframes ksCta{0%,40%,100%{box-shadow:inset 0 1px 0 rgba(255,255,255,.16),0 3px 0 #0c0e10,0 5px 12px rgba(20,23,26,.26)}
    50%{box-shadow:inset 0 1px 0 rgba(255,255,255,.16),0 3px 0 #0c0e10,0 5px 12px rgba(20,23,26,.26),0 0 0 4px rgba(18,165,107,.16),0 10px 36px -6px rgba(18,165,107,.55)}}
  @media (prefers-reduced-motion:reduce){
    .ks-wave,.ks-core,#au-submit{animation:none!important}
    .ks-core{opacity:.8}
  }
  .auth-card h2{font-weight:800;letter-spacing:-.02em;font-size:23px;margin:0 0 5px}
  .auth-card .sub{color:var(--ink-400);font-size:13.5px;margin:0 0 18px;line-height:1.5}
  /* Сегмент Вход/Регистрация — СВЕТЛЫЙ, со скользящей пилюлей (iOS-style) */
  .tabs{position:relative;display:flex;gap:3px;margin-bottom:18px;background:var(--ink-100);border-radius:11px;padding:4px}
  /* белая пилюля едет под активный таб через transform — только композитор, без рывка */
  .tabs::before{content:"";position:absolute;top:4px;left:4px;z-index:0;
    width:calc((100% - 11px)/2);height:calc(100% - 8px);border-radius:8px;
    background:var(--paper);box-shadow:var(--sh-sm),inset 0 1px 0 rgba(255,255,255,.85);
    transform:translateX(0);transition:transform var(--dur-2) var(--ease-out)}
  .tabs.reg::before{transform:translateX(calc(100% + 3px))}
  .tab{position:relative;z-index:1;flex:1;padding:9px;text-align:center;border-radius:8px;
    color:var(--ink-500);font-weight:600;font-size:14px;cursor:pointer;transition:color var(--dur-2) var(--ease-out)}
  .tab:hover:not(.active){color:var(--ink-700)}
  .tab.active{color:var(--ink-900)}
  @media (prefers-reduced-motion:reduce){.tabs::before{transition:none}}
  .fld-label{font-size:12px;font-weight:600;color:var(--ink-600);display:block;margin:12px 0 5px;letter-spacing:.01em}
  .auth-card input{width:100%;padding:11px 13px;margin:0 0 2px;border:1px solid var(--ink-200);
    border-radius:var(--r-sm);background:var(--paper);color:var(--ink-900);transition:border-color var(--dur-1) var(--ease-out)}
  .auth-card .btn{width:100%;margin-top:16px;padding:13px}
  .auth-err{color:var(--danger-600);font-size:13px;min-height:18px;margin-top:6px}
  .hidden{display:none!important}

  /* Модалки — единый паттерн: затемнение + клик-вне + крестик (Esc тоже) */
  .nlv-overlay{position:fixed;inset:0;background:rgba(20,23,26,.45);z-index:60;display:grid;place-items:center;padding:20px}
  .nlv-modal{position:relative;background:var(--paper);border:1px solid var(--ink-150);border-radius:var(--r-lg);
    box-shadow:var(--sh-lg),inset 0 1px 0 rgba(255,255,255,.7);max-height:88vh;overflow:auto}
  .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)}
  .nlv-x:hover{background:var(--ink-50);color:var(--ink-900)}
  .nlv-x:focus-visible{outline:2px solid var(--ink-900);outline-offset:2px}

  /* ===== Модал результата оплаты (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)}
  .nlv-pay-v{font-family:var(--font-mono);font-size:13px;color:var(--ink-900);white-space:nowrap;font-feature-settings:'tnum' 1}
  .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}

  input:focus,select:focus{outline:2px solid var(--ink-900);outline-offset:1px;border-color:transparent}

  /* ===== Единый 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:2px solid var(--ink-900);outline-offset:2px}
  @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-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)}
    header#topbar{gap:8px;padding:10px 14px;flex-wrap:wrap}
    #header-title{display:none}
    .auth-center{width:100%}
    .auth-card{padding:24px 22px 20px}
  }
  /* ── Mobile 375: внутренние экраны после логина без оверфлоу ── */
  @media (max-width:430px){
    /* топбар: бренд + меню в один аккуратный ряд, кнопки переносятся */
    header#topbar{gap:6px;padding:9px 12px}
    #topbar .brand img{height:20px}
    #header-actions{margin-left:0}
    /* индикатор расхода не должен распирать ряд */
    .usage-meter{max-width:100%;overflow:hidden}
    .usage-meter #usage-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
    /* рабочая область: меньше боковых полей, ничего не вылезает */
    .layout>main{padding:16px 14px!important}
    /* страница «Тариф и оплата»: шапка тарифа в столбик, цена слева */
    .bp-wrap{padding:18px 14px 56px}
    .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}
  }
