/* =====================================================================
   Salistica Design System
   ===================================================================== 

   Источник правды для нового UI. Уходим от theme/styles/core.css на этот
   файл по мере касания экранов.

   - Токены из docs/design/design-rules.md
   - Компоненты из docs/design/ui-kit.html
   - Специализированные блоки из standalone-HTML (Подписка и биллинг и т.п.)

   ВАЖНО: app-shell классы (.app/.topbar/.sidebar/.nav__*) живут только в
   референсных standalone-HTML. В нашем приложении используем СВОЙ layout
   (page_head.php / templates/layout.php) — эти классы здесь не нужны.
   ===================================================================== */

/* =====================================================================
   ТОКЕНЫ (полная копия из UI Kit / Settings / ClientFlow)
   ===================================================================== */
:root {
  --bg-app:#f6f7f9; --bg-card:#fff; --border:#e9ecf1; --border-strong:#e2e8f0;
  --divider:#f1f3f7; --hover:#f8fafc;
  --text:#0f172a; --text-muted:#64748b; --text-light:#94a3b8; --text-faint:#cbd5e1;
  --accent:#ea580c; --accent-soft:#fff5ee; --accent-line:#fed7aa;
  --info:#2563eb; --info-soft:#eff6ff; --info-line:#dbeafe;
  --success:#16a34a; --success-soft:#ecfdf5; --success-line:#bbf7d0;
  --warning:#d97706; --warning-soft:#fffbeb; --warning-line:#fde68a;
  --danger:#dc2626; --danger-soft:#fef2f2; --danger-line:#fecaca;
  --tip:#7c3aed; --tip-soft:#faf5ff; --tip-line:#e9d5ff;
  --radius-lg:16px; --radius:12px; --radius-sm:8px; --radius-xs:6px;
  --font:'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --side:232px;
  --shadow-sm:0 1px 2px rgba(15,23,42,.04);
  --shadow-md:0 4px 14px rgba(15,23,42,.08);
  --shadow-lg:0 18px 40px rgba(15,23,42,.18);
}
/* =====================================================================
   ВСЕ НИЖЕ — ВНУТРИ :is(.billing-page, .salary-page, .abonements-page) (CSS nesting).
   ===================================================================== */
/* Стили дизайн-системы НЕ глобальные. Все правила scoped через корневой
   :is(.billing-page, .salary-page, .abonements-page) класс (CSS nesting, поддерживается Chrome 112+ / Safari 16.5+ /
   Firefox 117+). Это безопасно даже если в проекте уже есть классы
   с теми же именами (.btn, .field, .badge, .banner) — наши стили
   применяются ТОЛЬКО к разметке с обёрткой <div class="billing-page">.
   ===================================================================== */
/* Базовые элементы внутри scope (по UI Kit) */
:is(.billing-page, .salary-page, .abonements-page) *{box-sizing:border-box}

/* Сбрасываем uppercase/letter-spacing от core.css (.btn, .badge и т.п.).
   В дизайне Salistica капс не используется — если где-то нужен, добавляем
   точечно с правилом ниже. */
:is(.billing-page, .salary-page, .abonements-page),
:is(.billing-page, .salary-page, .abonements-page) *{ text-transform: none; letter-spacing: normal; }

/* =====================================================================
   КОМПОНЕНТЫ ИЗ UI KIT
   ===================================================================== */

/* Buttons */
:is(.billing-page, .salary-page, .abonements-page) .btn{
  display:inline-flex; align-items:center; gap:8px;
  height:36px; padding: 0 14px;
  border-radius: 8px; border:1px solid var(--border-strong);
  background: var(--bg-card); color: var(--text);
  font:600 13px var(--font); cursor: pointer;
  transition: background .12s, border-color .12s, color .12s;
}
:is(.billing-page, .salary-page, .abonements-page) .btn:hover{ background: var(--hover); border-color: var(--text-faint); }
:is(.billing-page, .salary-page, .abonements-page) .btn--primary{ background: var(--accent); color:#fff; border-color: var(--accent); }
:is(.billing-page, .salary-page, .abonements-page) .btn--primary:hover{ background: #c2410c; border-color: #c2410c; }
:is(.billing-page, .salary-page, .abonements-page) .btn--ghost{ background: transparent; border-color: transparent; color: var(--text-muted); }
:is(.billing-page, .salary-page, .abonements-page) .btn--ghost:hover{ background: var(--hover); color: var(--text); }
:is(.billing-page, .salary-page, .abonements-page) .btn--danger-ghost{ background: transparent; border-color: transparent; color: var(--danger); }
:is(.billing-page, .salary-page, .abonements-page) .btn--danger-ghost:hover{ background: var(--danger-soft); }
:is(.billing-page, .salary-page, .abonements-page) .btn--sm{ height: 30px; padding: 0 10px; font-size: 12.5px; border-radius: 7px; gap: 6px; }
:is(.billing-page, .salary-page, .abonements-page) .btn--lg{ height: 44px; padding: 0 20px; font-size: 14.5px; border-radius: 9px; }
:is(.billing-page, .salary-page, .abonements-page) .btn--icon{ width: 36px; padding: 0; justify-content: center; }
:is(.billing-page, .salary-page, .abonements-page) .btn--icon.btn--sm{ width: 30px; }

/* Badges */
:is(.billing-page, .salary-page, .abonements-page) .badge{
  display:inline-flex; align-items:center; gap:5px;
  height: 22px; padding: 0 8px;
  border:1px solid var(--border); background: var(--bg-app);
  color: var(--text-muted); border-radius:999px;
  font:600 11.5px var(--font); white-space: nowrap; font-feature-settings: 'tnum' 1;
  text-transform: none; letter-spacing: 0;
}
:is(.billing-page, .salary-page, .abonements-page) .badge__dot{ width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
:is(.billing-page, .salary-page, .abonements-page) .badge--success{ background: var(--success-soft); color: var(--success); border-color: var(--success-line); }
:is(.billing-page, .salary-page, .abonements-page) .badge--info{ background: var(--info-soft); color: var(--info); border-color: var(--info-line); }
:is(.billing-page, .salary-page, .abonements-page) .badge--warning{ background: var(--warning-soft); color: var(--warning); border-color: var(--warning-line); }
:is(.billing-page, .salary-page, .abonements-page) .badge--danger{ background: var(--danger-soft); color: var(--danger); border-color: var(--danger-line); }
:is(.billing-page, .salary-page, .abonements-page) .badge--accent{ background: var(--accent-soft); color: var(--accent); border-color: var(--accent-line); }

/* Card */
:is(.billing-page, .salary-page, .abonements-page) .card{
  background: var(--bg-card); border:1px solid var(--border);
  border-radius: var(--radius); padding: 18px 20px;
}
:is(.billing-page, .salary-page, .abonements-page) .card__title{
  font:600 11.5px var(--font); color: var(--text-muted);

  margin: 0 0 14px;
}

/* Field */
:is(.billing-page, .salary-page, .abonements-page) .field{
  width: 100%; height: 38px; padding: 0 12px;
  background: #fff; border: 1px solid var(--border-strong);
  border-radius: var(--radius-xs); color: var(--text);
  font: 500 13.5px var(--font);
  transition: border-color .12s, box-shadow .12s;
}
:is(.billing-page, .salary-page, .abonements-page) .field::placeholder{ color: var(--text-light); }
:is(.billing-page, .salary-page, .abonements-page) .field:focus{ outline: none; border-color: var(--text); box-shadow: 0 0 0 3px rgba(15,23,42,.08); }

/* Toggle */
:is(.billing-page, .salary-page, .abonements-page) .toggle{
  display:inline-flex; align-items:center;
  width: 36px; height: 20px;
  background: var(--text-faint); border-radius: 99px;
  cursor: pointer; transition: background .14s;
  position: relative; flex:0 0 auto; border: 0; padding: 0;
}
:is(.billing-page, .salary-page, .abonements-page) .toggle__dot{
  position: absolute; top: 2px; left: 2px;
  width: 16px; height: 16px; background: #fff; border-radius: 50%;
  transition: transform .18s cubic-bezier(.4,.2,.2,1);
  box-shadow: 0 1px 2px rgba(15,23,42,.16);
}
:is(.billing-page, .salary-page, .abonements-page) .toggle.is-on{ background: var(--success); }
:is(.billing-page, .salary-page, .abonements-page) .toggle.is-on .toggle__dot{ transform: translateX(16px); }

/* Checkbox */
:is(.billing-page, .salary-page, .abonements-page) .checkbox-row{ display:inline-flex; align-items:center; gap: 10px; cursor: pointer; font:500 13.5px var(--font); user-select: none; }
:is(.billing-page, .salary-page, .abonements-page) .checkbox-row input{ position: absolute; opacity: 0; pointer-events: none; }
:is(.billing-page, .salary-page, .abonements-page) .checkbox-box{
  width: 18px; height: 18px;
  border: 1.5px solid var(--border-strong); border-radius: 5px;
  background: #fff; display: grid; place-items: center;
  flex: 0 0 auto;
}
:is(.billing-page, .salary-page, .abonements-page) .checkbox-row input:checked ~ .checkbox-box{ background: var(--text); border-color: var(--text); }
:is(.billing-page, .salary-page, .abonements-page) .checkbox-box svg{ width: 11px; height: 11px; color: #fff; opacity: 0; }
:is(.billing-page, .salary-page, .abonements-page) .checkbox-row input:checked ~ .checkbox-box svg{ opacity: 1; }

/* Banner */
:is(.billing-page, .salary-page, .abonements-page) .banner{
  display:flex; align-items:center; gap:14px;
  padding: 12px 18px; border-radius: var(--radius);
  background: var(--warning-soft); border: 1px solid var(--warning-line);
  margin-bottom: 22px;
}
:is(.billing-page, .salary-page, .abonements-page) .banner__icon{
  width: 32px; height: 32px; border-radius: 9px;
  background: var(--warning); color: #fff;
  display: grid; place-items: center; flex: 0 0 auto;
}
:is(.billing-page, .salary-page, .abonements-page) .banner__title{ font: 600 13.5px var(--font); margin: 0; }
:is(.billing-page, .salary-page, .abonements-page) .banner__desc{ font: 400 12.5px var(--font); color: var(--text-muted); margin: 2px 0 0; line-height: 1.5; }
:is(.billing-page, .salary-page, .abonements-page) .banner__actions{ margin-left: auto; display: flex; gap: 8px; flex: 0 0 auto; }

/* =====================================================================
   BILLING — главная структура
   ===================================================================== */
:is(.billing-page, .salary-page, .abonements-page) .billing-grid{
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 24px;
  align-items: start;
}
@media (max-width: 1100px){
  :is(.billing-page, .salary-page, .abonements-page) .billing-grid{ grid-template-columns: 1fr; }
}

/* KPI status strip */
:is(.billing-page, .salary-page, .abonements-page) .status-strip{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  margin-bottom: 24px;
}
:is(.billing-page, .salary-page, .abonements-page) .status-strip__item{
  padding: 16px 20px;
  border-right: 1px solid var(--divider);
}
:is(.billing-page, .salary-page, .abonements-page) .status-strip__item:last-child{ border-right: 0; }
:is(.billing-page, .salary-page, .abonements-page) .status-strip__label{
  font: 600 10.5px var(--font); color: var(--text-muted);

  margin: 0 0 6px;
}
:is(.billing-page, .salary-page, .abonements-page) .status-strip__value{
  font: 700 18px var(--font); color: var(--text);
  letter-spacing: -0.01em;
  font-feature-settings: 'tnum' 1;
  display: flex; align-items: baseline; gap: 6px;
}
:is(.billing-page, .salary-page, .abonements-page) .status-strip__value small{
  font: 500 12.5px var(--font); color: var(--text-muted);
  letter-spacing: 0;
}
:is(.billing-page, .salary-page, .abonements-page) .status-strip__hint{ font: 500 11.5px var(--font); color: var(--text-light); margin-top: 4px; font-feature-settings: 'tnum' 1; }

/* Modules — сгруппированные с подсказками */
:is(.billing-page, .salary-page, .abonements-page) .modules-section{ margin-bottom: 28px; }
:is(.billing-page, .salary-page, .abonements-page) .modules-section__head{
  display: flex; align-items: baseline; gap: 12px;
  margin-bottom: 14px;
}
:is(.billing-page, .salary-page, .abonements-page) .modules-section__head h2{
  margin: 0; font: 600 17px var(--font); letter-spacing: -0.005em;
}
:is(.billing-page, .salary-page, .abonements-page) .modules-section__count{
  font: 500 12.5px var(--font); color: var(--text-light);
}
:is(.billing-page, .salary-page, .abonements-page) .modules-section__filter{ margin-left: auto; }

:is(.billing-page, .salary-page, .abonements-page) .svc-category{
  font: 600 11px var(--font); color: var(--text-light);

  margin: 18px 4px 8px;
  display: flex; align-items: center; gap: 8px;
}
:is(.billing-page, .salary-page, .abonements-page) .svc-category:first-child{ margin-top: 0; }
:is(.billing-page, .salary-page, .abonements-page) .svc-category .count{
  font: 600 11px var(--font);
  background: var(--bg-app); color: var(--text-muted);
  padding: 1px 6px; border-radius: 999px;
  min-width: 18px; text-align: center;
}

:is(.billing-page, .salary-page, .abonements-page) .mod-grid{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
}
@media (max-width: 760px){ :is(.billing-page, .salary-page, .abonements-page) .mod-grid{ grid-template-columns: 1fr; } }

:is(.billing-page, .salary-page, .abonements-page) .mod-card{
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 14px 16px;
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-rows: auto 1fr auto;
  gap: 4px 12px;
  transition: border-color .14s, box-shadow .14s;
}
:is(.billing-page, .salary-page, .abonements-page) .mod-card:hover{ border-color: var(--text-faint); box-shadow: var(--shadow-sm); }
:is(.billing-page, .salary-page, .abonements-page) .mod-card.is-on{ border-color: var(--success-line); background: linear-gradient(180deg, var(--success-soft) 0%, var(--bg-card) 28%); }
:is(.billing-page, .salary-page, .abonements-page) .mod-card.is-included{ background: var(--accent-soft); border-color: var(--accent-line); }
:is(.billing-page, .salary-page, .abonements-page) .mod-card.is-required{ background: var(--bg-card); border-color: var(--border); }

:is(.billing-page, .salary-page, .abonements-page) .mod-card__name{
  font: 600 14px var(--font); color: var(--text);
  letter-spacing: -0.005em;
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  margin: 0;
}
:is(.billing-page, .salary-page, .abonements-page) .mod-card__toggle{ grid-row: 1; grid-column: 2; }
:is(.billing-page, .salary-page, .abonements-page) .mod-card__desc{
  grid-row: 2; grid-column: 1 / -1;
  font: 400 12.5px var(--font); color: var(--text-muted);
  line-height: 1.5; margin: 4px 0 0;
}
:is(.billing-page, .salary-page, .abonements-page) .mod-card__foot{
  grid-row: 3; grid-column: 1 / -1;
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 10px; margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid var(--divider);
}
:is(.billing-page, .salary-page, .abonements-page) .mod-card__price{
  font: 700 14px var(--font); color: var(--text);
  font-feature-settings: 'tnum' 1;
}
:is(.billing-page, .salary-page, .abonements-page) .mod-card__price small{ font: 500 12px var(--font); color: var(--text-muted); }
:is(.billing-page, .salary-page, .abonements-page) .mod-card__price--free{ color: var(--success); }
:is(.billing-page, .salary-page, .abonements-page) .mod-card__link{
  font: 600 12.5px var(--font); color: var(--accent);
  display: inline-flex; align-items: center; gap: 4px;
}
:is(.billing-page, .salary-page, .abonements-page) .mod-card__link:hover{ text-decoration: underline; }
:is(.billing-page, .salary-page, .abonements-page) .mod-card__lock{
  color: var(--text-light); font: 500 12px var(--font);
  display: inline-flex; align-items: center; gap: 5px;
}

/* SIDE — sticky summary */
:is(.billing-page, .salary-page, .abonements-page) .summary{
  position: sticky; top: 80px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
}
:is(.billing-page, .salary-page, .abonements-page) .summary__head{
  padding: 16px 20px;
  border-bottom: 1px solid var(--divider);
  display: flex; align-items: center; gap: 10px;
}
:is(.billing-page, .salary-page, .abonements-page) .summary__head-title{
  font: 600 14px var(--font); color: var(--text);
  margin: 0;
}
:is(.billing-page, .salary-page, .abonements-page) .summary__head .badge{ margin-left: auto; }
:is(.billing-page, .salary-page, .abonements-page) .summary__body{ padding: 18px 20px; }

/* Period radio (vertical) */
:is(.billing-page, .salary-page, .abonements-page) .period-radio{
  display: flex; flex-direction: column; gap: 6px;
  margin-bottom: 4px;
}
:is(.billing-page, .salary-page, .abonements-page) .period-radio__item{
  display: grid; grid-template-columns: 18px 1fr auto;
  gap: 10px; align-items: center;
  padding: 10px 12px;
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-sm);
  background: #fff;
  cursor: pointer;
  transition: border-color .14s, background .14s;
  position: relative;
}
:is(.billing-page, .salary-page, .abonements-page) .period-radio__item:hover{ border-color: var(--text-faint); background: var(--hover); }
:is(.billing-page, .salary-page, .abonements-page) .period-radio__item.is-on{
  border-color: var(--accent);
  background: var(--accent-soft);
  box-shadow: 0 0 0 1px var(--accent) inset;
}
:is(.billing-page, .salary-page, .abonements-page) .period-radio__radio{
  width: 16px; height: 16px; border-radius: 50%;
  border: 1.5px solid var(--border-strong);
  background: #fff;
  display: grid; place-items: center;
}
:is(.billing-page, .salary-page, .abonements-page) .period-radio__item.is-on .period-radio__radio{
  border-color: var(--accent);
}
:is(.billing-page, .salary-page, .abonements-page) .period-radio__item.is-on .period-radio__radio::after{
  content: ''; width: 8px; height: 8px; border-radius: 50%;
  background: var(--accent);
}
:is(.billing-page, .salary-page, .abonements-page) .period-radio__main{ min-width: 0; }
:is(.billing-page, .salary-page, .abonements-page) .period-radio__name{
  font: 600 13.5px var(--font); color: var(--text);
  display: flex; align-items: center; gap: 8px;
}
:is(.billing-page, .salary-page, .abonements-page) .period-radio__sub{
  font: 500 11.5px var(--font); color: var(--text-muted);
  margin-top: 1px; font-feature-settings: 'tnum' 1;
}
:is(.billing-page, .salary-page, .abonements-page) .period-radio__price{
  text-align: right;
  font: 700 14px var(--font); color: var(--text);
  font-feature-settings: 'tnum' 1;
}
:is(.billing-page, .salary-page, .abonements-page) .period-radio__save{
  font: 600 11px var(--font); color: var(--success);
  margin-top: 2px; font-feature-settings: 'tnum' 1;
}
:is(.billing-page, .salary-page, .abonements-page) .period-radio__badge{
  position: absolute; top: -8px; right: 12px;
  height: 18px; padding: 0 8px;
  background: var(--accent); color: #fff;
  border-radius: 999px;
  font: 700 10px var(--font);

  display: inline-flex; align-items: center;
}

/* Promo */
:is(.billing-page, .salary-page, .abonements-page) .promo-block{
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid var(--divider);
}
:is(.billing-page, .salary-page, .abonements-page) .promo-block__head{
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 10px;
}
:is(.billing-page, .salary-page, .abonements-page) .promo-block__title{
  font: 600 12.5px var(--font); color: var(--text);
}
:is(.billing-page, .salary-page, .abonements-page) .promo-block__hint{
  font: 500 11.5px var(--font); color: var(--text-light);
  margin-left: auto;
}
:is(.billing-page, .salary-page, .abonements-page) .promo-wrap{
  display: flex; gap: 6px;
}
:is(.billing-page, .salary-page, .abonements-page) .promo-wrap .field{ height: 36px; font-size: 12.5px; }

/* applied promo chips */
:is(.billing-page, .salary-page, .abonements-page) .promo-applied{
  display: flex; flex-direction: column; gap: 6px;
  margin-bottom: 10px;
}
:is(.billing-page, .salary-page, .abonements-page) .promo-chip{
  display: grid;
  grid-template-columns: 24px 1fr auto;
  gap: 8px; align-items: center;
  padding: 8px 10px;
  border: 1px solid var(--success-line);
  background: var(--success-soft);
  border-radius: var(--radius-xs);
}
:is(.billing-page, .salary-page, .abonements-page) .promo-chip--info    { border-color: var(--info-line);    background: var(--info-soft); }
:is(.billing-page, .salary-page, .abonements-page) .promo-chip--accent  { border-color: var(--accent-line);  background: var(--accent-soft); }
:is(.billing-page, .salary-page, .abonements-page) .promo-chip__icon{
  width: 24px; height: 24px; border-radius: 6px;
  background: #fff; color: var(--success);
  display: grid; place-items: center;
}
:is(.billing-page, .salary-page, .abonements-page) .promo-chip--info .promo-chip__icon  { color: var(--info); }
:is(.billing-page, .salary-page, .abonements-page) .promo-chip--accent .promo-chip__icon{ color: var(--accent); }
:is(.billing-page, .salary-page, .abonements-page) .promo-chip__main{ min-width: 0; }
:is(.billing-page, .salary-page, .abonements-page) .promo-chip__code{
  font: 700 12px ui-monospace, 'SF Mono', Menlo, monospace;
  color: var(--text);

  display: inline-flex; align-items: center; gap: 6px;
}
:is(.billing-page, .salary-page, .abonements-page) .promo-chip__bonus{
  font: 500 11.5px var(--font); color: var(--text-muted);
  margin-top: 2px;
}
:is(.billing-page, .salary-page, .abonements-page) .promo-chip__bonus b{ color: var(--success); font-weight: 600; }
:is(.billing-page, .salary-page, .abonements-page) .promo-chip--info .promo-chip__bonus b   { color: var(--info); }
:is(.billing-page, .salary-page, .abonements-page) .promo-chip--accent .promo-chip__bonus b { color: var(--accent); }
:is(.billing-page, .salary-page, .abonements-page) .promo-chip__close{
  width: 22px; height: 22px; border-radius: 50%;
  background: 0; border: 0; cursor: pointer;
  color: var(--text-light);
  display: grid; place-items: center;
}
:is(.billing-page, .salary-page, .abonements-page) .promo-chip__close:hover{ background: rgba(15,23,42,.08); color: var(--danger); }

:is(.billing-page, .salary-page, .abonements-page) .promo-status{
  font: 500 11.5px var(--font); color: var(--text-light);
  margin-top: 8px; line-height: 1.5;
}

/* Total */
:is(.billing-page, .salary-page, .abonements-page) .summary__total{
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid var(--divider);
  display: flex; flex-direction: column; gap: 8px;
}
:is(.billing-page, .salary-page, .abonements-page) .summary__row{
  display: flex; align-items: center; justify-content: space-between;
  font: 500 13px var(--font); color: var(--text-muted);
  font-feature-settings: 'tnum' 1;
}
:is(.billing-page, .salary-page, .abonements-page) .summary__row b{ color: var(--text); font-weight: 600; }
:is(.billing-page, .salary-page, .abonements-page) .summary__row--discount{ color: var(--success); font-weight: 600; }
:is(.billing-page, .salary-page, .abonements-page) .summary__grand{
  display: flex; align-items: baseline; justify-content: space-between;
  margin-top: 6px; padding-top: 14px;
  border-top: 1px solid var(--divider);
}
:is(.billing-page, .salary-page, .abonements-page) .summary__grand-label{
  font: 600 13px var(--font); color: var(--text);
}
:is(.billing-page, .salary-page, .abonements-page) .summary__grand-value{
  font: 700 28px var(--font); letter-spacing: -0.02em;
  color: var(--text); font-feature-settings: 'tnum' 1;
}
:is(.billing-page, .salary-page, .abonements-page) .summary__grand-value small{
  font: 500 13px var(--font); color: var(--text-muted);
  letter-spacing: 0; margin-left: 4px;
}

:is(.billing-page, .salary-page, .abonements-page) .summary__foot{
  border-top: 1px solid var(--divider);
  padding: 16px 20px;
  display: flex; flex-direction: column; gap: 12px;
  background: #fbfbfd;
}
:is(.billing-page, .salary-page, .abonements-page) .summary__pay{ width: 100%; justify-content: center; }
:is(.billing-page, .salary-page, .abonements-page) .summary__auto{
  display: flex; align-items: flex-start; gap: 10px;
  font: 500 12.5px var(--font); color: var(--text-muted);
  line-height: 1.5;
  cursor: pointer;
}
:is(.billing-page, .salary-page, .abonements-page) .summary__auto b{ display: block; font-weight: 600; color: var(--text); }

:is(.billing-page, .salary-page, .abonements-page) .summary__cancel{
  background: 0; border: 0; padding: 6px 0;
  color: var(--text-light); font: 500 12.5px var(--font);
  text-align: center; cursor: pointer;
  transition: color .12s;
}
:is(.billing-page, .salary-page, .abonements-page) .summary__cancel:hover{ color: var(--danger); }

/* Payment method (compact card) */
:is(.billing-page, .salary-page, .abonements-page) .pm-row{
  display: grid;
  grid-template-columns: 40px 1fr auto;
  gap: 14px; align-items: center;
  padding: 14px 18px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
}
:is(.billing-page, .salary-page, .abonements-page) .pm-row__icon{
  width: 40px; height: 28px;
  background: linear-gradient(135deg, #fbbf24, #ea580c);
  border-radius: 5px;
  display: grid; place-items: center;
  color: #fff;
  font: 800 9px var(--font);
}
:is(.billing-page, .salary-page, .abonements-page) .pm-row__main{ min-width: 0; }
:is(.billing-page, .salary-page, .abonements-page) .pm-row__num{ font: 600 14px var(--font); font-feature-settings: 'tnum' 1; }
:is(.billing-page, .salary-page, .abonements-page) .pm-row__meta{ font: 500 12px var(--font); color: var(--text-muted); margin-top: 2px; font-feature-settings: 'tnum' 1; }
:is(.billing-page, .salary-page, .abonements-page) .pm-row__actions{ display: flex; gap: 6px; }
:is(.billing-page, .salary-page, .abonements-page) .pm-row--empty{
  border-style: dashed; border-color: var(--border-strong);
  background: var(--hover);
  justify-content: center; text-align: center;
  display: flex;
  font: 500 13px var(--font); color: var(--text-muted);
  padding: 18px;
}

/* Table */
:is(.billing-page, .salary-page, .abonements-page) .tbl-card{
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--radius); overflow: hidden;
}
:is(.billing-page, .salary-page, .abonements-page) .tbl-card__bar{
  display: flex; align-items: center; gap: 10px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--divider);
}
:is(.billing-page, .salary-page, .abonements-page) .tbl-card__count{ font: 500 12.5px var(--font); color: var(--text-muted); }
:is(.billing-page, .salary-page, .abonements-page) .tbl{
  width: 100%; border-collapse: separate; border-spacing: 0;
  font: 500 13px var(--font);
}
:is(.billing-page, .salary-page, .abonements-page) .tbl thead th{
  text-align: left;
  font: 600 11px var(--font); color: var(--text-muted);

  padding: 10px 16px;
  border-bottom: 1px solid var(--border);
  background: #fff; white-space: nowrap;
}
:is(.billing-page, .salary-page, .abonements-page) .tbl tbody td{
  padding: 12px 16px;
  border-bottom: 1px solid var(--divider);
  vertical-align: middle; color: var(--text);
}
:is(.billing-page, .salary-page, .abonements-page) .tbl tbody tr:last-child td{ border-bottom: 0; }
:is(.billing-page, .salary-page, .abonements-page) .tbl tbody tr:hover td{ background: var(--hover); }
:is(.billing-page, .salary-page, .abonements-page) .tbl td.num{ text-align: right; font-feature-settings: 'tnum' 1; }
:is(.billing-page, .salary-page, .abonements-page) .tbl td.actions{ width: 1%; white-space: nowrap; text-align: right; }

/* Section header inside main col */
:is(.billing-page, .salary-page, .abonements-page) .section-h2{
  margin: 28px 0 14px;
  display: flex; align-items: baseline; gap: 10px;
}
:is(.billing-page, .salary-page, .abonements-page) .section-h2 h2{
  margin: 0; font: 600 17px var(--font); letter-spacing: -0.005em;
}
:is(.billing-page, .salary-page, .abonements-page) .section-h2__hint{ font: 500 12.5px var(--font); color: var(--text-muted); }
:is(.billing-page, .salary-page, .abonements-page) .section-h2__action{ margin-left: auto; }

/* Tabs */
:is(.billing-page, .salary-page, .abonements-page) .tabs{
  display: flex; flex-direction: row; align-items: center; border-bottom: 1px solid var(--border);
  gap: 24px;
  margin-bottom: 18px;
}
:is(.billing-page, .salary-page, .abonements-page) .tabs__item{
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 0 12px;
  font: 600 13.5px var(--font); color: var(--text-muted);
  border: 0; border-bottom: 2px solid transparent;
  background: 0; cursor: pointer;
  transition: color .12s, border-color .12s;
  margin-bottom: -1px;
}
:is(.billing-page, .salary-page, .abonements-page) .tabs__item:hover{ color: var(--text); }
:is(.billing-page, .salary-page, .abonements-page) .tabs__item.is-active{ color: var(--text); border-bottom-color: var(--accent); }
:is(.billing-page, .salary-page, .abonements-page) .tabs__item .count{
  font: 600 11px var(--font);
  background: var(--bg-app); color: var(--text-muted);
  padding: 1px 6px; border-radius: 999px;
  min-width: 18px; text-align: center;
  font-feature-settings: 'tnum' 1;
}
:is(.billing-page, .salary-page, .abonements-page) .tabs__item.is-active .count{ background: var(--accent-soft); color: var(--accent); }

/* Tab panels */
:is(.billing-page, .salary-page, .abonements-page) .tab-panel{ display: none; }
:is(.billing-page, .salary-page, .abonements-page) .tab-panel.is-active{ display: block; }

/* History KPI row */
:is(.billing-page, .salary-page, .abonements-page) .history-kpis{
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 0;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  margin-bottom: 18px;
}
:is(.billing-page, .salary-page, .abonements-page) .history-kpis__item{
  padding: 14px 18px;
  border-right: 1px solid var(--divider);
}
:is(.billing-page, .salary-page, .abonements-page) .history-kpis__item:last-child{ border-right: 0; }
:is(.billing-page, .salary-page, .abonements-page) .history-kpis__label{
  font: 600 10.5px var(--font); color: var(--text-muted);

  margin: 0 0 6px;
}
:is(.billing-page, .salary-page, .abonements-page) .history-kpis__value{
  font: 700 18px var(--font); color: var(--text);
  letter-spacing: -0.01em;
  font-feature-settings: 'tnum' 1;
}
:is(.billing-page, .salary-page, .abonements-page) .history-kpis__value small{ font: 500 12px var(--font); color: var(--text-muted); margin-left: 3px; }
:is(.billing-page, .salary-page, .abonements-page) .history-kpis__delta{
  font: 600 11px var(--font); margin-top: 4px;
  font-feature-settings: 'tnum' 1;
}
:is(.billing-page, .salary-page, .abonements-page) .history-kpis__delta--ok{ color: var(--success); }
:is(.billing-page, .salary-page, .abonements-page) .history-kpis__delta--warn{ color: var(--warning); }
:is(.billing-page, .salary-page, .abonements-page) .history-kpis__delta--mute{ color: var(--text-light); font-weight: 500; }

/* Filter row above table */
:is(.billing-page, .salary-page, .abonements-page) .filter-row{
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 12px; flex-wrap: wrap;
}
:is(.billing-page, .salary-page, .abonements-page) .filter-row__chips{
  display: inline-flex; background: var(--bg-app);
  padding: 3px; border-radius: 9px; gap: 2px;
}
:is(.billing-page, .salary-page, .abonements-page) .filter-row__chip{
  height: 30px; padding: 0 12px; border-radius: 6px;
  font: 600 12.5px var(--font); color: var(--text-muted);
  background: 0; border: 0; cursor: pointer;
  display: inline-flex; align-items: center; gap: 6px;
  font-feature-settings: 'tnum' 1;
}
:is(.billing-page, .salary-page, .abonements-page) .filter-row__chip:hover{ color: var(--text); }
:is(.billing-page, .salary-page, .abonements-page) .filter-row__chip.is-on{ background: #fff; color: var(--text); box-shadow: 0 1px 2px rgba(15,23,42,.06); }
:is(.billing-page, .salary-page, .abonements-page) .filter-row__chip .c{
  font: 600 11px var(--font);
  background: var(--bg-card); color: var(--text-muted);
  padding: 1px 6px; border-radius: 999px; min-width: 18px; text-align: center;
}
:is(.billing-page, .salary-page, .abonements-page) .filter-row__chip.is-on .c{ background: var(--bg-app); color: var(--text); }

/* Docs list */
:is(.billing-page, .salary-page, .abonements-page) .doc-row{
  display: grid;
  grid-template-columns: 44px 1fr auto auto auto;
  gap: 16px; align-items: center;
  padding: 14px 18px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  margin-bottom: 8px;
  transition: border-color .12s, box-shadow .12s;
}
:is(.billing-page, .salary-page, .abonements-page) .doc-row:hover{ border-color: var(--text-faint); box-shadow: var(--shadow-sm); }
:is(.billing-page, .salary-page, .abonements-page) .doc-row__icon{
  width: 44px; height: 44px; border-radius: 10px;
  background: var(--danger-soft); color: var(--danger);
  display: grid; place-items: center;
  font: 700 11px var(--font);
}
:is(.billing-page, .salary-page, .abonements-page) .doc-row__icon--xls{ background: var(--success-soft); color: var(--success); }
:is(.billing-page, .salary-page, .abonements-page) .doc-row__icon--zip{ background: var(--info-soft); color: var(--info); }
:is(.billing-page, .salary-page, .abonements-page) .doc-row__icon--xml{ background: var(--warning-soft); color: var(--warning); }
:is(.billing-page, .salary-page, .abonements-page) .doc-row__main{ min-width: 0; }
:is(.billing-page, .salary-page, .abonements-page) .doc-row__name{ font: 600 13.5px var(--font); color: var(--text); }
:is(.billing-page, .salary-page, .abonements-page) .doc-row__meta{ font: 500 12px var(--font); color: var(--text-light); margin-top: 2px; font-feature-settings: 'tnum' 1; }
:is(.billing-page, .salary-page, .abonements-page) .doc-row__date{
  font: 500 12.5px var(--font); color: var(--text-muted);
  white-space: nowrap; font-feature-settings: 'tnum' 1;
}
:is(.billing-page, .salary-page, .abonements-page) .doc-row__size{
  font: 500 12px var(--font); color: var(--text-light);
  white-space: nowrap; font-feature-settings: 'tnum' 1;
}
:is(.billing-page, .salary-page, .abonements-page) .doc-section-title{
  font: 600 11px var(--font); color: var(--text-light);

  margin: 22px 4px 10px;
  display: flex; align-items: center; gap: 8px;
}
:is(.billing-page, .salary-page, .abonements-page) .doc-section-title:first-child{ margin-top: 0; }
:is(.billing-page, .salary-page, .abonements-page) .doc-section-title .count{
  font: 600 11px var(--font);
  background: var(--bg-app); color: var(--text-muted);
  padding: 1px 6px; border-radius: 999px;
  min-width: 18px; text-align: center;
}


/* =====================================================================
   ДОПОЛНИТЕЛЬНЫЕ КОМПОНЕНТЫ ДИЗАЙН-СИСТЕМЫ (KPI / callout / page-state /
   form-row / text-helpers / field-modifiers / tbl-group)
   Добавлены 2026-05-21 при переделке /salary под дизайн-систему.
   ===================================================================== */

/* KPI cards (§9) */
:is(.billing-page, .salary-page, .abonements-page) .kpi-grid{ display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
:is(.billing-page, .salary-page, .abonements-page) .kpi{ background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius); padding: 16px 18px; }
:is(.billing-page, .salary-page, .abonements-page) .kpi__label{ font: 600 11px var(--font); color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 6px; }
:is(.billing-page, .salary-page, .abonements-page) .kpi__value{ font: 700 24px var(--font); color: var(--text); font-feature-settings: 'tnum' 1; }
@media (max-width: 1100px) { :is(.billing-page, .salary-page, .abonements-page) .kpi-grid{ grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { :is(.billing-page, .salary-page, .abonements-page) .kpi-grid{ grid-template-columns: 1fr; } :is(.billing-page, .salary-page, .abonements-page) .kpi__value{ font-size: 22px; } }

/* Callout (§1) — точная копия из docs/design/ui-kit.html */
:is(.billing-page, .salary-page, .abonements-page) .callout{
  display: grid; grid-template-columns: 28px minmax(0, 1fr) auto;
  gap: 14px; align-items: start;
  padding: 14px 16px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--tip-line);
  background: var(--tip-soft);
}
:is(.billing-page, .salary-page, .abonements-page) .callout--info     { border-color: var(--info-line);    background: var(--info-soft); }
:is(.billing-page, .salary-page, .abonements-page) .callout--success  { border-color: var(--success-line); background: var(--success-soft); }
:is(.billing-page, .salary-page, .abonements-page) .callout--warning  { border-color: var(--warning-line); background: var(--warning-soft); }
:is(.billing-page, .salary-page, .abonements-page) .callout--danger   { border-color: var(--danger-line);  background: var(--danger-soft); }
:is(.billing-page, .salary-page, .abonements-page) .callout--accent   { border-color: var(--accent-line);  background: var(--accent-soft); }
:is(.billing-page, .salary-page, .abonements-page) .callout__icon{
  width: 28px; height: 28px; border-radius: 8px;
  display: grid; place-items: center;
  background: rgba(124, 58, 237, .12); color: var(--tip);
  flex-shrink: 0;
}
:is(.billing-page, .salary-page, .abonements-page) .callout--info    .callout__icon { background: rgba(37, 99, 235, .12); color: var(--info); }
:is(.billing-page, .salary-page, .abonements-page) .callout--success .callout__icon { background: rgba(22, 163, 74, .14); color: var(--success); }
:is(.billing-page, .salary-page, .abonements-page) .callout--warning .callout__icon { background: rgba(217, 119, 6, .14); color: var(--warning); }
:is(.billing-page, .salary-page, .abonements-page) .callout--danger  .callout__icon { background: rgba(220, 38, 38, .14); color: var(--danger); }
:is(.billing-page, .salary-page, .abonements-page) .callout--accent  .callout__icon { background: rgba(234, 88, 12, .14); color: var(--accent); }
:is(.billing-page, .salary-page, .abonements-page) .callout__body{ font: 400 13px/1.55 var(--font); color: var(--text); margin: 0; }
:is(.billing-page, .salary-page, .abonements-page) .callout__body b,
:is(.billing-page, .salary-page, .abonements-page) .callout__body strong{ font-weight: 600; }
:is(.billing-page, .salary-page, .abonements-page) .callout__body em{ font-style: normal; background: #fff; padding: 1px 6px; border-radius: 4px; border: 1px solid rgba(15,23,42,.06); font-feature-settings: 'tnum' 1; font-weight: 600; }
:is(.billing-page, .salary-page, .abonements-page) .callout--inline{ border: 0; background: transparent; padding: 4px 0 14px; border-bottom: 1px dashed var(--border); border-radius: 0; grid-template-columns: 1fr; }

/* Page-state (§6.3) */
:is(.billing-page, .salary-page, .abonements-page) .page-state{ padding: 48px 24px; text-align: center; background: var(--bg-card); border: 1px dashed var(--border); border-radius: var(--radius); color: var(--text-muted); font: 500 13.5px var(--font); }
:is(.billing-page, .salary-page, .abonements-page) .page-state--error  { background: var(--danger-soft);  border-color: var(--danger-line);  color: var(--danger); }
:is(.billing-page, .salary-page, .abonements-page) .page-state--warning{ background: var(--warning-soft); border-color: var(--warning-line); color: var(--warning); }
:is(.billing-page, .salary-page, .abonements-page) .page-state--success{ background: var(--success-soft); border-color: var(--success-line); color: var(--success); }

/* Form-row (§7) — копия из ui-kit */
:is(.billing-page, .salary-page, .abonements-page) .form-row{
  display: grid; grid-template-columns: 220px 1fr; gap: 16px;
  padding: 16px 0; border-top: 1px solid var(--divider);
  align-items: flex-start;
}
:is(.billing-page, .salary-page, .abonements-page) .form-row:first-child{ border-top: 0; padding-top: 0; }
:is(.billing-page, .salary-page, .abonements-page) .form-row__label{ padding-top: 8px; }
:is(.billing-page, .salary-page, .abonements-page) .form-row__label-title{ font: 600 13.5px var(--font); color: var(--text); margin: 0 0 2px; }
:is(.billing-page, .salary-page, .abonements-page) .form-row__label-hint { font: 400 12.5px var(--font); color: var(--text-light); margin: 0; }
@media (max-width: 600px) {
  :is(.billing-page, .salary-page, .abonements-page) .form-row{ grid-template-columns: 1fr; gap: 6px; padding: 12px 0; }
  :is(.billing-page, .salary-page, .abonements-page) .form-row__label{ padding-top: 0; }
}

/* Text helpers */
:is(.billing-page, .salary-page, .abonements-page) .text-muted   { color: var(--text-muted); }
:is(.billing-page, .salary-page, .abonements-page) .text-light   { color: var(--text-light); }
:is(.billing-page, .salary-page, .abonements-page) .text-faint   { color: var(--text-faint); }
:is(.billing-page, .salary-page, .abonements-page) .text-accent  { color: var(--accent); }
:is(.billing-page, .salary-page, .abonements-page) .text-success { color: var(--success); }
:is(.billing-page, .salary-page, .abonements-page) .text-warning { color: var(--warning); }
:is(.billing-page, .salary-page, .abonements-page) .text-danger  { color: var(--danger); }

/* Field modifiers */
:is(.billing-page, .salary-page, .abonements-page) .field--sm  { height: 30px; padding: 4px 10px; font-size: 12.5px; border-radius: 7px; }
:is(.billing-page, .salary-page, .abonements-page) .field--num { text-align: right; font-feature-settings: 'tnum' 1; }

/* Table group-row */
:is(.billing-page, .salary-page, .abonements-page) .tbl__group{ background: var(--bg-app); font: 600 11px var(--font); color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.04em; padding: 8px 12px; }

/* Salary-локальные утилиты */
:is(.billing-page, .salary-page, .abonements-page) .sal-card-title{ font: 600 14px var(--font); color: var(--text); margin: 0 0 10px; }
:is(.billing-page, .salary-page, .abonements-page) .sal-card-actions{ display: flex; gap: 8px; justify-content: flex-end; margin-top: 16px; padding-top: 12px; border-top: 1px solid var(--divider); }
:is(.billing-page, .salary-page, .abonements-page) .sal-margin-top{ margin-top: 14px; }
:is(.billing-page, .salary-page, .abonements-page) .sal-stack{ display: flex; flex-direction: column; gap: 10px; }

/* Карточка в списке (правило/план) */
:is(.billing-page, .salary-page, .abonements-page) .sal-list-card{ background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius); padding: 14px 16px; display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; }
:is(.billing-page, .salary-page, .abonements-page) .sal-list-card__main{ flex: 1; min-width: 0; }
:is(.billing-page, .salary-page, .abonements-page) .sal-list-card__title{ font: 600 14px var(--font); color: var(--text); margin: 0 0 2px; }
:is(.billing-page, .salary-page, .abonements-page) .sal-list-card__meta{ font: 400 12.5px/1.5 var(--font); color: var(--text-muted); }
:is(.billing-page, .salary-page, .abonements-page) .sal-list-card__flags{ font: 400 11.5px var(--font); color: var(--text-light); margin-top: 4px; }
:is(.billing-page, .salary-page, .abonements-page) .sal-list-card__actions{ display: flex; gap: 6px; flex-shrink: 0; }

/* Поле rate (тип + значение) */
:is(.billing-page, .salary-page, .abonements-page) .sal-rate{ display: grid; grid-template-columns: 120px 1fr; gap: 10px; }

/* .sal-step-card удалён — была выдумка. Используй обычную .card. */

/* Перебиваем легаси-hover из core.css (.card:hover transform+shadow).
   В новой дизайн-системе у блочных карточек ховера нет. */
:is(.billing-page, .salary-page, .abonements-page) .card:hover{ box-shadow: none; transform: none; }
:is(.billing-page, .salary-page, .abonements-page) .sal-list-card:hover{ box-shadow: none; transform: none; }

/* Salary — строка налога (тип + название + % + удалить) */
:is(.billing-page, .salary-page, .abonements-page) .sal-tax-row{ display: grid; grid-template-columns: 1fr 1.5fr 110px 32px; gap: 6px; align-items: center; }
@media (max-width: 600px){ :is(.billing-page, .salary-page, .abonements-page) .sal-tax-row{ grid-template-columns: 1fr 100px 32px; } :is(.billing-page, .salary-page, .abonements-page) .sal-tax-row > input[data-taxf="name"], :is(.billing-page, .salary-page, .abonements-page) .sal-tax-row > input[data-tx-name]{ grid-column: 1 / -1; } }

/* Salary — два равных поля с подписями (Гарант: день/месяц и т.п.) */
:is(.billing-page, .salary-page, .abonements-page) .sal-twin{ display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
:is(.billing-page, .salary-page, .abonements-page) .sal-twin__cell{ display: flex; flex-direction: column; gap: 4px; }
:is(.billing-page, .salary-page, .abonements-page) .sal-twin__cap{ font: 500 12px var(--font); color: var(--text-muted); }

/* Salary — поле с % суффиксом */
:is(.billing-page, .salary-page, .abonements-page) .sal-pct{ position: relative; }
:is(.billing-page, .salary-page, .abonements-page) .sal-pct > .field{ padding-right: 26px; width: 100%; }
:is(.billing-page, .salary-page, .abonements-page) .sal-pct__suffix{ position: absolute; right: 10px; top: 50%; transform: translateY(-50%); color: var(--text-muted); font: 500 12.5px var(--font); pointer-events: none; }

/* Salary — строка условия в редакторе бонус-плана (метрика + сравнение + порог + удалить) */
:is(.billing-page, .salary-page, .abonements-page) .sal-cond-row{ display: grid; grid-template-columns: 1fr 80px 140px 32px; gap: 6px; align-items: center; }
@media (max-width: 600px){
  :is(.billing-page, .salary-page, .abonements-page) .sal-cond-row{ grid-template-columns: 1fr 80px 32px; }
  :is(.billing-page, .salary-page, .abonements-page) .sal-cond-row > input[type="number"]{ grid-column: 1 / -1; }
}

/* Salary — чекбокс в form-row */
:is(.billing-page, .salary-page, .abonements-page) .sal-check{ display: inline-flex; align-items: center; gap: 8px; cursor: pointer; font: 500 13.5px var(--font); color: var(--text); padding-top: 8px; }
:is(.billing-page, .salary-page, .abonements-page) .sal-check input[type="checkbox"]{ width: 16px; height: 16px; accent-color: var(--accent); }

/* Salary — чип бонус-плана в строке мастера */
:is(.billing-page, .salary-page, .abonements-page) .sal-plan-chip{ display: inline-flex; align-items: center; gap: 6px; padding: 4px 8px 4px 10px; background: var(--accent-soft); border: 1px solid var(--accent-line); border-radius: 999px; font: 500 12px var(--font); color: var(--accent); margin: 2px 4px 2px 0; }
:is(.billing-page, .salary-page, .abonements-page) .sal-plan-chip__del{ background: transparent; border: 0; cursor: pointer; color: var(--accent); font-size: 14px; line-height: 1; padding: 0 2px; }
:is(.billing-page, .salary-page, .abonements-page) .sal-plan-chip__del:hover{ color: var(--danger); }

/* ─────────────────────────────────────────────────────────────────────────
   Reports — транспонированная таблица (мастера — колонки, метрики — строки)
   ────────────────────────────────────────────────────────────────────────── */
.report-viewer .data-table.data-table--transposed { table-layout: auto; }
.report-viewer .data-table.data-table--transposed th,
.report-viewer .data-table.data-table--transposed td { white-space: nowrap; overflow: visible; text-overflow: unset; width: auto; }
.report-viewer .data-table.data-table--transposed th:first-child {
    position: sticky; left: 0; z-index: 3;
    background: #f8f9fa;
    min-width: 140px; max-width: 220px;
    white-space: normal; word-break: break-word;
    overflow: visible; text-overflow: unset;
}
.report-viewer .data-table.data-table--transposed td:first-child {
    position: sticky; left: 0; z-index: 2;
    background: #fff;
    min-width: 140px; max-width: 220px;
    white-space: normal; word-break: break-word;
    overflow: visible; text-overflow: unset;
}
.report-viewer .data-table.data-table--transposed tr:hover td:first-child { background: #fafbfc; }
.report-viewer .data-table.data-table--transposed .table-subheader-row td {
    background: #f8fafc;
    font-size: 0.6875rem; font-weight: 700; color: #64748b;
    text-transform: uppercase; letter-spacing: 0.06em;
    padding-top: 0.875rem; border-top: 1px solid #e5e7eb;
}
.report-viewer .data-table.data-table--transposed .table-subheader-row:hover td,
.report-viewer .data-table.data-table--transposed .table-subheader-row td:first-child,
.report-viewer .data-table.data-table--transposed .table-subheader-row:hover td:first-child { background: #f8fafc; }

/* Цветовая индикация коэффициента (milena_upsell) */
.report-viewer .ratio-high { color: #166534; font-weight: 700; }
.report-viewer .ratio-mid  { color: #16a34a; }
.report-viewer .ratio-low  { color: #94a3b8; }

/* =====================================================================
   WIZARD — «Быстрая настройка» на /salary.
   Перенесено 1:1 из docs-референса «Визард · Правила расчёта ЗП».
   Все цвета — через токены; никаких hex/inline-стилей.
   ===================================================================== */
:is(.billing-page, .salary-page, .abonements-page) .wiz-shell{ max-width: 920px; margin: 0 auto; padding: 0 0 100px; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-h1{ font: 700 24px var(--font); letter-spacing: -0.015em; margin: 0 0 6px; color: var(--text); }
:is(.billing-page, .salary-page, .abonements-page) .wiz-sub{ font: 500 14px var(--font); color: var(--text-muted); margin: 0 0 24px; line-height: 1.55; }

/* Stepper */
:is(.billing-page, .salary-page, .abonements-page) .wiz-stepper{ display: grid; grid-template-columns: repeat(var(--wiz-steps, 3), 1fr); gap: 8px; margin-bottom: 28px; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-stepper__item{ display: flex; align-items: center; gap: 12px; padding: 12px 14px; background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius); position: relative; cursor: pointer; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-stepper__item.is-active{ border-color: var(--accent); box-shadow: 0 0 0 2px var(--accent-soft); }
:is(.billing-page, .salary-page, .abonements-page) .wiz-stepper__item.is-done{ border-color: var(--success-line); background: var(--success-soft); }
:is(.billing-page, .salary-page, .abonements-page) .wiz-stepper__num{ width: 28px; height: 28px; border-radius: 50%; background: var(--bg-app); color: var(--text-muted); display: grid; place-items: center; font: 700 13px var(--font); border: 1.5px solid var(--border-strong); flex: 0 0 auto; font-feature-settings: 'tnum' 1; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-stepper__item.is-active .wiz-stepper__num{ background: var(--accent); color: var(--bg-card); border-color: var(--accent); }
:is(.billing-page, .salary-page, .abonements-page) .wiz-stepper__item.is-done .wiz-stepper__num{ background: var(--success); color: var(--bg-card); border-color: var(--success); }
:is(.billing-page, .salary-page, .abonements-page) .wiz-stepper__label{ font: 600 12.5px var(--font); color: var(--text); line-height: 1.3; min-width: 0; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-stepper__label small{ display: block; font: 500 11.5px var(--font); color: var(--text-muted); margin-top: 1px; }
@media (max-width: 720px){
  :is(.billing-page, .salary-page, .abonements-page) .wiz-stepper{ grid-template-columns: 1fr; gap: 6px; margin-bottom: 22px; }
  :is(.billing-page, .salary-page, .abonements-page) .wiz-stepper__item:not(.is-active){ padding: 10px 12px; }
  :is(.billing-page, .salary-page, .abonements-page) .wiz-stepper__item:not(.is-active) .wiz-stepper__label small{ display: none; }
}

/* Step container & card */
:is(.billing-page, .salary-page, .abonements-page) .wiz-step{ display: none; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-step.is-active{ display: block; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-step-card{ background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 28px 32px; margin-bottom: 18px; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-step-card__kicker{ display: inline-flex; align-items: center; gap: 6px; font: 700 11px var(--font); letter-spacing: 0.07em; text-transform: uppercase; color: var(--accent); background: var(--accent-soft); border: 1px solid var(--accent-line); padding: 4px 9px; border-radius: 999px; margin-bottom: 14px; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-step-card__title{ font: 700 22px var(--font); letter-spacing: -0.01em; margin: 0 0 8px; color: var(--text); }
:is(.billing-page, .salary-page, .abonements-page) .wiz-step-card__desc{ font: 500 14px var(--font); color: var(--text-muted); margin: 0 0 22px; line-height: 1.6; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-step-card__desc b{ color: var(--text); font-weight: 600; }
@media (max-width: 720px){
  :is(.billing-page, .salary-page, .abonements-page) .wiz-step-card{ padding: 22px 18px; border-radius: var(--radius); }
  :is(.billing-page, .salary-page, .abonements-page) .wiz-step-card__title{ font-size: 19px; }
}

/* Tip callout (отличается от .callout — есть title) */
:is(.billing-page, .salary-page, .abonements-page) .wiz-tip{ display: grid; grid-template-columns: 28px 1fr; gap: 12px; padding: 14px 16px; background: var(--tip-soft); border: 1px solid var(--tip-line); border-radius: var(--radius-sm); margin-top: 18px; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-tip__icon{ width: 28px; height: 28px; border-radius: 8px; background: rgba(124, 58, 237, 0.14); color: var(--tip); display: grid; place-items: center; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-tip__title{ font: 600 13px var(--font); color: var(--tip); margin: 1px 0 4px; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-tip__body{ font: 400 13px var(--font); color: var(--text); line-height: 1.5; margin: 0; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-tip__body b{ font-weight: 600; }

/* Field label + hint */
:is(.billing-page, .salary-page, .abonements-page) .wiz-field-label{ display: block; font: 600 13px var(--font); color: var(--text); margin-bottom: 6px; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-field-hint{ font: 400 12.5px var(--font); color: var(--text-light); margin: 6px 0 0; line-height: 1.5; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-field-hint--accent{ color: var(--accent); font-weight: 500; }

/* Form row + columns */
:is(.billing-page, .salary-page, .abonements-page) .wiz-form-row{ margin-bottom: 18px; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-form-row:last-child{ margin-bottom: 0; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-form-row--cols{ display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media (max-width: 540px){ :is(.billing-page, .salary-page, .abonements-page) .wiz-form-row--cols{ grid-template-columns: 1fr; } }

/* Choice cards (rich radio) */
:is(.billing-page, .salary-page, .abonements-page) .wiz-choices{ display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
@media (max-width: 540px){ :is(.billing-page, .salary-page, .abonements-page) .wiz-choices{ grid-template-columns: 1fr; } }
:is(.billing-page, .salary-page, .abonements-page) .wiz-choice{ display: flex; flex-direction: column; padding: 18px 18px 16px; background: var(--bg-card); border: 1.5px solid var(--border-strong); border-radius: var(--radius); cursor: pointer; transition: border-color .14s, background .14s, box-shadow .14s; text-align: left; position: relative; font-family: inherit; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-choice:hover{ border-color: var(--text-faint); }
:is(.billing-page, .salary-page, .abonements-page) .wiz-choice.is-on{ border-color: var(--accent); background: var(--accent-soft); box-shadow: inset 0 0 0 1px var(--accent); }
:is(.billing-page, .salary-page, .abonements-page) .wiz-choice__radio{ position: absolute; top: 16px; right: 16px; width: 18px; height: 18px; border-radius: 50%; border: 1.5px solid var(--border-strong); background: var(--bg-card); display: grid; place-items: center; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-choice.is-on .wiz-choice__radio{ border-color: var(--accent); }
:is(.billing-page, .salary-page, .abonements-page) .wiz-choice.is-on .wiz-choice__radio::after{ content: ''; width: 9px; height: 9px; border-radius: 50%; background: var(--accent); }
:is(.billing-page, .salary-page, .abonements-page) .wiz-choice__name{ font: 700 15px var(--font); margin: 0 0 6px; padding-right: 28px; letter-spacing: -0.005em; color: var(--text); }
:is(.billing-page, .salary-page, .abonements-page) .wiz-choice__desc{ font: 400 13px var(--font); color: var(--text-muted); margin: 0; line-height: 1.5; }

/* Ladder (ступени) */
:is(.billing-page, .salary-page, .abonements-page) .wiz-ladder{ display: flex; flex-direction: column; gap: 10px; margin-top: 18px; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-lad{ background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-lad__head{ display: grid; grid-template-columns: 1fr auto auto; gap: 12px; align-items: center; padding: 14px 16px; background: var(--bg-app); border-bottom: 1px solid var(--divider); cursor: pointer; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-lad__head-title{ font: 700 14px var(--font); display: flex; align-items: center; gap: 10px; color: var(--text); }
:is(.billing-page, .salary-page, .abonements-page) .wiz-lad__head-num{ width: 26px; height: 26px; border-radius: 50%; background: var(--accent); color: var(--bg-card); display: grid; place-items: center; font: 700 12px var(--font); font-feature-settings: 'tnum' 1; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-lad__head-range{ font: 500 12.5px var(--font); color: var(--text-muted); font-feature-settings: 'tnum' 1; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-lad__head-range b{ color: var(--text); font-weight: 600; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-lad__remove{ width: 28px; height: 28px; border-radius: 7px; background: transparent; border: 0; color: var(--text-light); cursor: pointer; display: grid; place-items: center; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-lad__remove:hover{ background: var(--danger-soft); color: var(--danger); }
:is(.billing-page, .salary-page, .abonements-page) .wiz-lad__remove:disabled{ opacity: 0.3; cursor: not-allowed; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-lad__body{ padding: 18px 16px; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-lad__body.is-collapsed{ display: none; }

/* Range row inside ladder */
:is(.billing-page, .salary-page, .abonements-page) .wiz-range-row{ display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 16px; padding-bottom: 16px; border-bottom: 1px solid var(--divider); }
@media (max-width: 540px){ :is(.billing-page, .salary-page, .abonements-page) .wiz-range-row{ grid-template-columns: 1fr; } }

/* Add-step button */
:is(.billing-page, .salary-page, .abonements-page) .wiz-add-step{ width: 100%; height: 44px; border-radius: var(--radius); border: 1.5px dashed var(--border-strong); background: transparent; color: var(--text-muted); cursor: pointer; font: 600 13px var(--font); display: inline-flex; align-items: center; justify-content: center; gap: 6px; margin-top: 8px; transition: border-color .12s, color .12s, background .12s; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-add-step:hover{ border-color: var(--accent); color: var(--accent); background: var(--accent-soft); }

/* Advanced (тонкие настройки) */
:is(.billing-page, .salary-page, .abonements-page) .wiz-advanced{ margin-top: 14px; padding-top: 14px; border-top: 1px solid var(--divider); }
:is(.billing-page, .salary-page, .abonements-page) .wiz-advanced__toggle{ display: inline-flex; align-items: center; gap: 6px; background: transparent; border: 0; padding: 0; cursor: pointer; font: 600 13px var(--font); color: var(--accent); }
:is(.billing-page, .salary-page, .abonements-page) .wiz-advanced__toggle svg{ transition: transform .15s; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-advanced__toggle.is-open svg{ transform: rotate(90deg); }
:is(.billing-page, .salary-page, .abonements-page) .wiz-advanced__body{ display: none; padding-top: 12px; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-advanced__body.is-open{ display: block; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-advanced__add{ background: transparent; border: 0; padding: 4px 0; cursor: pointer; font: 600 12.5px var(--font); color: var(--accent); }
:is(.billing-page, .salary-page, .abonements-page) .wiz-advanced__add:hover{ text-decoration: underline; }

/* Adv block + inline forms */
:is(.billing-page, .salary-page, .abonements-page) .wiz-adv-block{ margin-top: 10px; padding-top: 10px; border-top: 1px dashed var(--divider); }
:is(.billing-page, .salary-page, .abonements-page) .wiz-adv-block:first-of-type{ border-top: 0; padding-top: 4px; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-adv-block__title{ font: 700 11.5px var(--font); color: var(--text); margin: 0 0 8px; text-transform: uppercase; letter-spacing: 0.06em; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-adv-block__desc{ font: 500 12px var(--font); color: var(--text-muted); margin: 0 0 10px; line-height: 1.5; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-adv-list{ display: flex; flex-direction: column; gap: 6px; margin-bottom: 8px; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-adv-form{ display: grid; align-items: center; gap: 8px; padding: 10px 12px; background: var(--bg-app); border: 1px solid var(--border); border-radius: var(--radius-xs); }
:is(.billing-page, .salary-page, .abonements-page) .wiz-adv-form--tax{ grid-template-columns: 200px 1fr 90px 32px; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-adv-form--cat{ grid-template-columns: 1fr 90px 32px; }
@media (max-width: 720px){
  :is(.billing-page, .salary-page, .abonements-page) .wiz-adv-form--tax,
  :is(.billing-page, .salary-page, .abonements-page) .wiz-adv-form--cat{ grid-template-columns: 1fr 90px 32px; }
  :is(.billing-page, .salary-page, .abonements-page) .wiz-adv-form--tax > :first-child{ grid-column: 1 / -1; }
}
:is(.billing-page, .salary-page, .abonements-page) .wiz-adv-form .field{ height: 32px; padding: 0 10px; font-size: 13px; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-adv-form__pct{ display: flex; align-items: center; gap: 4px; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-adv-form__pct .field{ flex: 1; text-align: right; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-adv-form__pct span{ font: 600 13px var(--font); color: var(--text-muted); }
:is(.billing-page, .salary-page, .abonements-page) .wiz-adv-form__remove{ width: 32px; height: 32px; border-radius: 7px; background: transparent; border: 0; color: var(--text-light); display: grid; place-items: center; cursor: pointer; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-adv-form__remove:hover{ background: var(--danger-soft); color: var(--danger); }

/* Check grid + custom checkbox */
:is(.billing-page, .salary-page, .abonements-page) .wiz-check-grid{ display: grid; grid-template-columns: 1fr 1fr; gap: 8px 14px; }
@media (max-width: 540px){ :is(.billing-page, .salary-page, .abonements-page) .wiz-check-grid{ grid-template-columns: 1fr; } }
:is(.billing-page, .salary-page, .abonements-page) .wiz-check-row{ display: flex; align-items: center; gap: 10px; padding: 8px 0; cursor: pointer; font: 500 13.5px var(--font); color: var(--text); user-select: none; position: relative; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-check-row input{ position: absolute; opacity: 0; pointer-events: none; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-check-row__box{ width: 18px; height: 18px; border: 1.5px solid var(--border-strong); border-radius: 5px; background: var(--bg-card); display: grid; place-items: center; flex: 0 0 auto; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-check-row input:checked ~ .wiz-check-row__box{ background: var(--text); border-color: var(--text); }
:is(.billing-page, .salary-page, .abonements-page) .wiz-check-row__box svg{ width: 11px; height: 11px; color: var(--bg-card); opacity: 0; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-check-row input:checked ~ .wiz-check-row__box svg{ opacity: 1; }

/* Sticky action bar */
:is(.billing-page, .salary-page, .abonements-page) .wiz-actionbar{ position: fixed; bottom: 0; left: 0; right: 0; z-index: 30; background: rgba(255, 255, 255, 0.95); backdrop-filter: blur(8px); border-top: 1px solid var(--border); padding: 14px 24px; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-actionbar__wrap{ max-width: 920px; margin: 0 auto; display: flex; align-items: center; gap: 12px; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-actionbar__info{ flex: 1; font: 500 13px var(--font); color: var(--text-muted); }
:is(.billing-page, .salary-page, .abonements-page) .wiz-actionbar__info b{ color: var(--text); font-weight: 600; }
@media (max-width: 540px){
  :is(.billing-page, .salary-page, .abonements-page) .wiz-actionbar{ padding: 10px 14px; }
  :is(.billing-page, .salary-page, .abonements-page) .wiz-actionbar__info{ display: none; }
}

/* Summary card on last step */
:is(.billing-page, .salary-page, .abonements-page) .wiz-summary{ background: linear-gradient(180deg, var(--success-soft) 0%, var(--bg-card) 60%); border: 1px solid var(--success-line); border-radius: var(--radius); padding: 16px 18px; margin-top: 18px; display: grid; grid-template-columns: 28px 1fr; gap: 12px; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-summary__icon{ width: 28px; height: 28px; border-radius: 8px; background: var(--success); color: var(--bg-card); display: grid; place-items: center; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-summary__title{ font: 700 13.5px var(--font); color: var(--success); margin: 1px 0 6px; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-summary__list{ list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 4px; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-summary__list li{ font: 500 13px var(--font); color: var(--text); display: flex; gap: 8px; }
:is(.billing-page, .salary-page, .abonements-page) .wiz-summary__list li::before{ content: '•'; color: var(--success); flex: 0 0 6px; }

/* Inline badge inside choice title */
:is(.billing-page, .salary-page, .abonements-page) .wiz-badge{ display: inline-flex; align-items: center; height: 18px; padding: 0 7px; background: var(--info-soft); color: var(--info); border: 1px solid var(--info-line); border-radius: 999px; font: 600 10.5px var(--font); letter-spacing: 0.04em; text-transform: uppercase; vertical-align: middle; margin-left: 6px; }

/* Large button modifier (для actionbar) */
:is(.billing-page, .salary-page, .abonements-page) .btn--lg{ height: 44px; padding: 0 20px; font-size: 14px; border-radius: 9px; }

/* =====================================================================
   DASHBOARD — состояние первой синхронизации (skeleton-гейт).
   Перенесено из docs-референса «Дашборд · первая синхронизация».
   Scope #syncingState — стили не утекают на остальной дашборд.
   ===================================================================== */
#syncingState .dsync-banner{
  background: linear-gradient(135deg, var(--tip-soft) 0%, var(--info-soft) 100%);
  border: 1px solid var(--tip-line);
  border-radius: var(--radius);
  padding: 18px 22px;
  display: grid; grid-template-columns: 44px 1fr;
  gap: 16px; align-items: center;
  margin-bottom: 22px;
}
#syncingState .dsync-banner__icon{
  width: 44px; height: 44px; border-radius: 12px;
  background: var(--tip); color: #fff;
  display: grid; place-items: center;
  position: relative;
}
#syncingState .dsync-banner__icon::after{
  content: ''; position: absolute; inset: -4px;
  border: 2px solid var(--tip);
  border-top-color: transparent;
  border-radius: 50%;
  animation: dsync-spin 1.1s linear infinite;
  opacity: .6;
}
@keyframes dsync-spin{ to{ transform: rotate(360deg); } }
#syncingState .dsync-banner__title{ font: 700 15px var(--font); color: var(--text); margin: 0 0 4px; }
#syncingState .dsync-banner__desc{ font: 500 13px var(--font); color: var(--text-muted); margin: 0; line-height: 1.5; }
#syncingState .dsync-banner__desc b{ color: var(--tip); font-weight: 700; }
#syncingState .dsync-banner__bar{
  margin-top: 10px;
  height: 4px; border-radius: 999px;
  background: rgba(124, 58, 237, .18);
  overflow: hidden;
}
#syncingState .dsync-banner__bar > i{
  display: block; height: 100%; border-radius: 999px;
  background: linear-gradient(90deg, var(--tip), var(--info));
  width: 0;
  animation: dsync-bar 14s ease-out forwards;
}
@keyframes dsync-bar{
  0%{ width: 4%; } 20%{ width: 22%; } 50%{ width: 48%; }
  80%{ width: 72%; } 100%{ width: 88%; }
}

/* Skeleton shimmer */
@keyframes dsync-shimmer{
  0%{ background-position: -240px 0; }
  100%{ background-position: calc(240px + 100%) 0; }
}
@keyframes dsync-shimmer-v{
  0%{ background-position: 0 -240px; }
  100%{ background-position: 0 calc(240px + 100%); }
}
#syncingState .dsync-skel{
  display: block;
  background: #eef1f5;
  background-image: linear-gradient(90deg, #eef1f5 0%, #f7f9fc 40%, #eef1f5 80%);
  background-size: 240px 100%;
  background-repeat: no-repeat;
  border-radius: 6px;
  animation: dsync-shimmer 1.5s linear infinite;
}
#syncingState .dsync-skel--text { height: 10px; border-radius: 4px; }
#syncingState .dsync-skel--label{ height: 11px; border-radius: 4px; }
#syncingState .dsync-skel--title{ height: 28px; border-radius: 6px; }
#syncingState .dsync-skel--row  { height: 14px; border-radius: 4px; }

/* Ширины skeleton-полос — модификаторы (вместо inline style=width) */
#syncingState .dsync-w-20{ width: 20%; }
#syncingState .dsync-w-22{ width: 22%; }
#syncingState .dsync-w-25{ width: 25%; }
#syncingState .dsync-w-28{ width: 28%; }
#syncingState .dsync-w-30{ width: 30%; }
#syncingState .dsync-w-32{ width: 32%; }
#syncingState .dsync-w-35{ width: 35%; }
#syncingState .dsync-w-38{ width: 38%; }
#syncingState .dsync-w-40{ width: 40%; }
#syncingState .dsync-w-50{ width: 50%; }
#syncingState .dsync-w-55{ width: 55%; }
#syncingState .dsync-w-58{ width: 58%; }
#syncingState .dsync-w-60{ width: 60%; }
#syncingState .dsync-w-65{ width: 65%; }

/* KPI grid 3×2 */
#syncingState .dsync-kpi-grid{
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 14px; margin-bottom: 18px;
}
@media (max-width: 980px){ #syncingState .dsync-kpi-grid{ grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px){ #syncingState .dsync-kpi-grid{ grid-template-columns: 1fr; } }

#syncingState .dsync-card{
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 22px 24px;
  position: relative;
}
#syncingState .dsync-card__head{ display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
#syncingState .dsync-card__value{ margin-bottom: 8px; }
#syncingState .dsync-card__sub  { margin-bottom: 18px; }
#syncingState .dsync-card__divider{ height: 1px; background: var(--divider); margin: 0 -24px 14px; }
#syncingState .dsync-card__row  { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; }
#syncingState .dsync-card__row:last-child{ margin-bottom: 0; }
#syncingState .dsync-card__hint{ position: absolute; top: 22px; right: 22px; font: 600 10.5px var(--font); color: var(--text-light); letter-spacing: .06em; text-transform: uppercase; }

/* Chart skeleton */
#syncingState .dsync-chart{ background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius); padding: 22px 24px; margin-top: 18px; }
#syncingState .dsync-chart__head{ display: flex; justify-content: space-between; align-items: center; margin-bottom: 22px; }
#syncingState .dsync-chart__head-left{ display: flex; align-items: center; gap: 18px; }
#syncingState .dsync-chart__body{ height: 230px; position: relative; }
#syncingState .dsync-chart__line{ position: absolute; left: 0; right: 0; height: 1px; background: var(--divider); }
#syncingState .dsync-chart__line:nth-child(1){ top: 0; }
#syncingState .dsync-chart__line:nth-child(2){ top: 25%; }
#syncingState .dsync-chart__line:nth-child(3){ top: 50%; }
#syncingState .dsync-chart__line:nth-child(4){ top: 75%; }
#syncingState .dsync-chart__line:nth-child(5){ bottom: 0; }
#syncingState .dsync-chart__bars{ position: absolute; inset: 0; display: flex; align-items: flex-end; gap: 18px; padding-bottom: 4px; }
#syncingState .dsync-chart__bar{
  flex: 1;
  background: #eef1f5;
  background-image: linear-gradient(180deg, #eef1f5 0%, #f7f9fc 40%, #eef1f5 80%);
  background-size: 100% 240px;
  background-repeat: no-repeat;
  border-radius: 6px 6px 2px 2px;
  animation: dsync-shimmer-v 1.6s linear infinite;
}
#syncingState .dsync-chart__bar--38{ height: 38%; }
#syncingState .dsync-chart__bar--22{ height: 22%; }
#syncingState .dsync-chart__bar--54{ height: 54%; }
#syncingState .dsync-chart__bar--76{ height: 76%; }
#syncingState .dsync-chart__bar--92{ height: 92%; }
#syncingState .dsync-chart__bar--64{ height: 64%; }
#syncingState .dsync-chart__bar--44{ height: 44%; }
#syncingState .dsync-chart__bar--28{ height: 28%; }

/* AI tip — нижняя плашка «что мы загружаем» */
#syncingState .dsync-tip{
  margin-top: 22px;
  background: var(--info-soft);
  border: 1px solid var(--info-line);
  border-radius: var(--radius);
  padding: 14px 18px;
  display: grid; grid-template-columns: 28px 1fr; gap: 12px;
}
#syncingState .dsync-tip__icon{
  width: 28px; height: 28px; border-radius: 8px;
  background: var(--info); color: #fff;
  display: grid; place-items: center;
}
#syncingState .dsync-tip__title{ font: 700 13px var(--font); color: var(--info); margin: 1px 0 4px; }
#syncingState .dsync-tip__body { font: 400 13px var(--font); color: var(--text); line-height: 1.5; margin: 0; }
#syncingState .dsync-tip__body b{ font-weight: 600; }
