*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

:root {
  --primary: #6C63FF;
  --primary-light: #EEF0FF;
  --primary-dark: #5A52D5;
  --green: #22C55E;
  --green-light: #DCFCE7;
  --yellow: #F59E0B;
  --yellow-light: #FEF3C7;
  --yellow-dark: #92400E;
  --red: #EF4444;
  --red-light: #FEE2E2;
  --gray-50: #F9FAFB;
  --gray-100: #F3F4F6;
  --gray-200: #E5E7EB;
  --gray-400: #9CA3AF;
  --gray-600: #4B5563;
  --gray-800: #1F2937;
  --radius: 12px;
  --shadow: 0 1px 3px rgba(0,0,0,.08), 0 4px 16px rgba(0,0,0,.06);
  --shadow-lg: 0 4px 24px rgba(108,99,255,.15);
  /* Emil Kowalski easing curves */
  --ease-out: cubic-bezier(0.23, 1, 0.32, 1);
  --ease-in-out: cubic-bezier(0.77, 0, 0.175, 1);
  --ease-out-fast: cubic-bezier(0.33, 1, 0.68, 1);
}

body {
  font-family: 'Inter', sans-serif;
  background: var(--gray-50);
  color: var(--gray-800);
  min-height: 100vh;
}

/* HEADER */
.header {
  background: white;
  border-bottom: 1px solid var(--gray-200);
  padding: 16px 0;
  position: sticky;
  top: 0;
  z-index: 100;
  box-shadow: 0 1px 4px rgba(0,0,0,.06);
}

.header .container {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.cabinet-select {
  margin-left: auto;
  padding: 10px 36px 10px 16px;
  background: white;
  color: var(--gray-800);
  border: 2px solid var(--gray-200);
  border-radius: 10px;
  font-family: inherit;
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
  transition: border-color 150ms var(--ease-out), box-shadow 150ms var(--ease-out), transform 150ms var(--ease-out);
  max-width: 240px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236C63FF' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  appearance: none;
  -webkit-appearance: none;
}
@media (hover: hover) and (pointer: fine) {
  .cabinet-select:hover { border-color: var(--primary); box-shadow: 0 2px 8px rgba(108,99,255,.12); }
}
.cabinet-select:active { transform: scale(0.98); }
.cabinet-select:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px var(--primary-light); }

.btn-settings {
  margin-left: 0;
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  background: var(--gray-100);
  color: var(--gray-600);
  border: 1.5px solid var(--gray-200);
  border-radius: 8px;
  font-family: inherit;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: transform 150ms var(--ease-out), box-shadow 150ms var(--ease-out), background 150ms var(--ease-out), color 150ms var(--ease-out), border-color 150ms var(--ease-out);
}
@media (hover: hover) and (pointer: fine) {
  .btn-settings:hover { background: var(--primary-light); color: var(--primary); border-color: var(--primary); transform: translateY(-1px); box-shadow: 0 4px 12px rgba(108,99,255,.12); }
}
.btn-settings:active { transform: scale(0.97); box-shadow: none; }
/* Logout — иконка-only кнопка, без текста, тот же стиль что btn-settings.
   На hover красноватый акцент чтобы намекнуть на «выход». */
.btn-settings.btn-logout { padding: 8px 10px; }
@media (hover: hover) and (pointer: fine) {
  .btn-settings.btn-logout:hover {
    background: #fef2f2;
    color: #dc2626;
    border-color: #fecaca;
    box-shadow: 0 4px 12px rgba(220,38,38,.12);
  }
}

/* PAGE NAV */
.page-nav { background: white; border-bottom: 1px solid var(--gray-200); }
.page-nav .container { display: flex; gap: 4px; padding: 0 32px; }
.nav-btn {
  padding: 14px 20px; background: none; border: none;
  border-bottom: 3px solid transparent; font-family: inherit;
  font-size: 14px; font-weight: 600; color: var(--gray-600);
  cursor: pointer;
  /* transition + :active живут в design-tokens.css (.nav-btn) — там единый
     transform 90ms для всей шапки. Здесь дубликат не держим. */
  white-space: nowrap;
}
@media (hover: hover) and (pointer: fine) {
  .nav-btn:hover { color: var(--primary); }
}
.nav-btn.active { color: var(--primary); border-bottom-color: var(--primary); }

/* COSTS PAGE */
.costs-page { padding: 24px 0; }
.costs-header { display: flex; justify-content: space-between; align-items: flex-start; gap: 16px; margin-bottom: 20px; flex-wrap: wrap; }
.costs-title { font-size: 22px; font-weight: 700; margin-bottom: 4px; }
.costs-subtitle { font-size: 13px; color: var(--gray-600); }
.costs-actions { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.costs-search { margin-bottom: 14px; }
.costs-search .form-input {
  width: 100%; max-width: 400px; height: 40px; padding: 0 14px;
  border: 1.5px solid var(--gray-200); border-radius: 10px;
  font-size: 14px; outline: none; transition: border .2s;
}
.costs-search .form-input:focus { border-color: var(--primary); }
.costs-add-form {
  display: flex; gap: 8px; align-items: center; padding: 16px;
  background: var(--primary-light); border-radius: var(--radius); margin-bottom: 16px;
}
.costs-add-form .form-input { max-width: 200px; }
.costs-table-wrap { overflow-x: auto; }
.costs-table {
  width: 100%; border-collapse: separate; border-spacing: 0; font-size: 14px;
  background: white; border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.costs-table th {
  text-align: center; padding: 10px 12px; font-weight: 700; font-size: 13px;
  color: var(--gray-700); vertical-align: bottom;
  background: var(--gray-50); border-bottom: 2px solid var(--gray-200);
  white-space: normal; word-break: keep-all;
}
/* Sticky-шапка для таблицы ежедневных отчётов. Используем тот же подход,
   что в .supply-table-scroll: ОБЁРТКА — собственный scroll-context
   (overflow:auto + max-height). Sticky thead тогда железно крепится к верху
   обёртки независимо от родительских стилей, расширений браузера и нюансов
   table layout. Высота обёртки = viewport - сайтовая шапка - заголовок
   страницы и карточки сверху (~260px суммарно). */
.daily-page .costs-table-wrap {
  overflow: auto;
  max-height: calc(100vh - var(--header-h, 75px) - 260px);
  background: white;
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}
#dailyArticlesTable thead th {
  position: sticky; top: 0; z-index: 5;
  background: var(--gray-50);
}
.sort-arrow {
  display: inline-block; font-size: 10px; line-height: 1;
  color: var(--gray-400); margin-top: 2px;
}
.costs-table td {
  padding: 10px 12px; border-bottom: 1px solid var(--gray-100);
  vertical-align: middle; white-space: nowrap; text-align: center;
}
.sticky-col {
  position: sticky !important;
  z-index: 2;
}
.sticky-col-0 { left: 0; width: 40px; min-width: 40px; max-width: 40px; }
.sticky-col-1 { left: 40px; min-width: 130px; text-align: left; }
.sticky-col-2 { left: 170px; min-width: 180px; font-size: 13px; font-weight: 500; color: var(--gray-600); text-align: left; }
th.sticky-col { z-index: 3; background: var(--gray-50) !important; }
td.sticky-col { background: white !important; }
tr:hover td.sticky-col { background: var(--gray-50) !important; }
tr.missing-cost-row td.sticky-col { background: #fff0f0 !important; }
.sticky-col-2::after {
  content: '';
  position: absolute;
  top: 0; right: -4px;
  width: 4px; height: 100%;
  box-shadow: 2px 0 4px rgba(0,0,0,0.06);
}
.costs-table tbody tr:hover { background: var(--gray-50); }
.costs-table tbody tr:last-child td { border-bottom: none; }

/* Unit economics button & modal */
.td-analytics { width: 40px; text-align: center; padding: 0 4px !important; }
.unit-econ-btn {
  background: none; border: 1px solid var(--gray-200); border-radius: 6px;
  cursor: pointer; font-size: 16px; color: var(--gray-500); padding: 5px 8px;
  vertical-align: middle; line-height: 1;
  transition: transform 160ms var(--ease-out), background 150ms var(--ease-out), color 150ms var(--ease-out), border-color 150ms var(--ease-out);
}
@media (hover: hover) and (pointer: fine) {
  .unit-econ-btn:hover { background: var(--primary); color: white; border-color: var(--primary); }
}
.unit-econ-btn:active { transform: scale(0.93); }
.unit-econ-overlay {
  position: fixed; top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,0.4); z-index: 1000;
  display: flex; align-items: center; justify-content: center;
}
.unit-econ-panel {
  background: white; border-radius: 12px; padding: 28px 32px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.18); max-width: 480px; width: 90%;
}
.unit-econ-header {
  display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px;
}
.unit-econ-header h3 { margin: 0; font-size: 18px; }
.unit-econ-close {
  background: none; border: none; font-size: 24px; cursor: pointer;
  color: var(--gray-400); line-height: 1; padding: 0 4px;
}
.unit-econ-close:hover { color: var(--gray-800); }
.unit-econ-article { margin-bottom: 16px; }
.unit-econ-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.unit-econ-table td, .unit-econ-table th { padding: 6px 8px; border-bottom: 1px solid var(--gray-100); white-space: nowrap; }
.unit-econ-table td:nth-child(2) { text-align: right; font-weight: 500; }
.unit-econ-table td:nth-child(3) { text-align: right; color: var(--gray-400); font-size: 13px; padding-left: 8px; }
.unit-econ-table tbody tr:last-child td { border-bottom: none; }
.unit-econ-highlight td { background: var(--gray-50); border-bottom: 2px solid var(--gray-200); }
.unit-econ-separator td { border-bottom: none; padding: 0; height: 0; }
.unit-econ-separator + tr td { border-top: 2px solid var(--gray-200); }

/* Merged unit econ table */
.unit-econ-merged th { font-size: 11px; font-weight: 700; color: var(--gray-400); text-transform: uppercase; letter-spacing: 0.6px; border-bottom: 2px solid var(--gray-200); padding: 5px 8px; }
.unit-econ-merged td:first-child { font-size: 14px; }
.unit-econ-merged td:nth-child(2),
.unit-econ-merged td:nth-child(4) { text-align: right; font-weight: 600; font-size: 14px; padding-left: 16px; }
.unit-econ-merged td.ue-pct { text-align: right; color: var(--gray-400); font-size: 13px; padding-left: 8px; }
.unit-econ-merged td:nth-child(4) { border-left: 1.5px solid var(--gray-200); }

/* Analytics top row */
.analytics-top-row { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 12px; flex-wrap: wrap; }
.analytics-article-header { display: flex; flex-direction: column; gap: 4px; }
.analytics-article-header h2 { font-size: 20px; font-weight: 700; }

/* Analytics hero: photo + unit econ side by side */
.analytics-hero { display: grid; grid-template-columns: 180px auto; gap: 12px; margin-bottom: 12px; align-items: start; }
.analytics-hero-photo { display: flex; align-items: flex-start; }
.analytics-article-photo { width: 180px; height: 240px; object-fit: cover; border-radius: 10px; border: 1px solid var(--gray-200); }
.analytics-hero-econ { min-width: 0; max-width: 820px; }
@media (max-width: 768px) {
  .analytics-hero { grid-template-columns: 1fr; }
  .analytics-hero-photo { justify-content: center; }
  .analytics-article-photo { width: 120px; height: 160px; }
}
.ue-input {
  width: 88px; padding: 3px 6px; border: 1px solid var(--gray-200); border-radius: 5px;
  font-size: 13px; text-align: right; font-weight: 600; background: var(--gray-50);
  transition: border-color 150ms var(--ease-out), box-shadow 150ms var(--ease-out), background 150ms var(--ease-out);
}
.ue-input:focus { outline: none; border-color: var(--primary); background: white; box-shadow: 0 0 0 3px var(--primary-light); }
.cost-cell { cursor: pointer; min-width: 100px; }
.cost-cell:hover { color: var(--primary); }
.cost-cell input {
  border: none; background: none; font: inherit; width: 100px;
  outline: none; border-bottom: 2px solid var(--primary); padding: 0;
}
.btn-delete {
  background: none; border: none; cursor: pointer; font-size: 16px;
  color: var(--gray-400); padding: 4px 8px; border-radius: 4px;
  transition: transform 160ms var(--ease-out), color 150ms var(--ease-out), background 150ms var(--ease-out);
}
.btn-delete:hover { color: var(--red); background: var(--red-light); }
.btn-delete:active { transform: scale(0.93); }
.costs-empty {
  text-align: center; color: var(--gray-400); padding: 60px 20px;
  font-size: 14px;
}

/* TOAST */
.toast-container { position: fixed; bottom: 20px; right: 20px; z-index: 2000; display: flex; flex-direction: column; gap: 8px; }
.toast {
  padding: 10px 16px; border-radius: 8px; font-size: 13px; font-weight: 600;
  color: white; min-width: 200px;
  box-shadow: 0 4px 12px rgba(0,0,0,.15);
  opacity: 1; transform: translateY(0);
  transition: opacity 250ms var(--ease-out), transform 250ms var(--ease-out);
}
@supports (animation-name: toastIn) {
  .toast { animation: toastIn 250ms var(--ease-out); }
}
.toast-success { background: var(--green); }
.toast-error { background: var(--red); }
.toast-warn { background: var(--warn); color: white; }
.toast-info { background: var(--primary); }
@keyframes toastIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }

/* REPORTS */
.reports-page { padding: 24px 0; }
.reports-header-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  justify-content: flex-end;
}
.reports-header-actions .sync-hint { flex-basis: 100%; margin: 0; }
.report-period-badge {
  display: inline-block; padding: 4px 12px;
  background: var(--primary-light); color: var(--primary);
  border-radius: 20px; font-size: 13px; font-weight: 600;
}
.reports-nocost-badge {
  display: inline-block; padding: 2px 8px; margin-left: 8px;
  background: var(--warn-bg); color: var(--warn);
  border-radius: 12px; font-size: 11px; font-weight: 600;
  white-space: nowrap;
}
/* WB разделил неделю на несколько отчётов и они ещё не объединены пересчётом. */
.reports-split-badge {
  display: inline-block; padding: 2px 8px; margin-left: 8px;
  background: color-mix(in srgb, var(--neg) 14%, transparent);
  color: var(--neg);
  border-radius: 12px; font-size: 11px; font-weight: 600;
  white-space: nowrap; cursor: help;
}
.cost-add-inline {
  background: var(--warn-bg); color: var(--warn);
  border: 1px dashed var(--warn); border-radius: 6px;
  padding: 2px 8px; font-size: 11px; font-weight: 600;
  cursor: pointer; white-space: nowrap;
  font-family: inherit;
  transition: transform 120ms var(--ease-out), background 120ms var(--ease-out);
}
@media (hover: hover) and (pointer: fine) {
  .cost-add-inline:hover {
    background: var(--warn); color: white;
    border-style: solid;
  }
}
.cost-add-inline:active { transform: scale(0.96); }
.btn-back {
  background: none; border: none; color: var(--primary);
  font-family: inherit; font-size: 14px; font-weight: 600;
  cursor: pointer; padding: 0 0 16px; display: block;
}
.btn-back:hover { text-decoration: underline; }
.report-detail-header { display: flex; align-items: center; gap: 16px; margin-bottom: 24px; flex-wrap: wrap; }
.report-detail-header h2 { font-size: 22px; font-weight: 700; }
.detail-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 16px; }
@media (max-width: 768px) { .detail-cards { grid-template-columns: 1fr; } }
.detail-card {
  background: white; border-radius: var(--radius);
  box-shadow: var(--shadow); padding: 16px;
  transition: box-shadow 200ms var(--ease-out);
}
@media (hover: hover) and (pointer: fine) {
  .detail-card:hover { box-shadow: 0 2px 8px rgba(0,0,0,.1), 0 8px 24px rgba(0,0,0,.08); }
}
.detail-card-title { font-size: 15px; font-weight: 700; margin-bottom: 10px; color: var(--gray-800); }
.detail-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.detail-table td { padding: 7px 10px; border-bottom: 1px solid var(--gray-100); }
.detail-table td:last-child { text-align: right; font-weight: 500; }
.detail-table tr:last-child td { border-bottom: none; }
.detail-separator td { padding: 4px 0; border: none; }
.detail-bold td { font-weight: 700; }

/* Analytics period detail table — larger, tighter */
.detail-card-period { max-width: 580px; }
.detail-card-period .detail-table { font-size: 15px; }
.detail-card-period .detail-table td { padding: 9px 4px; }
.detail-card-period .detail-table td:last-child { font-weight: 600; }
.detail-card-period .detail-bold td { font-size: 16px; font-weight: 700; }
.detail-card-period .row-total td { font-size: 16px; }
.detail-green td:last-child { color: var(--green); }
/* Detail subgroups */
.detail-subgroup {
  background: var(--gray-50);
  border-radius: 8px;
  padding: 8px 10px;
  margin-bottom: 8px;
}
.detail-subgroup-label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--gray-400);
  padding-bottom: 6px;
}
.detail-subgroup-result {
  background: var(--gray-100);
  border: 1px solid var(--gray-200);
}

/* Detail table row styles */
.dt-row-minus td { color: #b91c1c; }
.dt-row-expense td { color: #b91c1c; font-weight: 600; }
.dt-row-tax td { color: #92400e; }
.dt-row-accent td { color: #15803d; font-weight: 700; }
.dt-row-total td { font-weight: 700; }

/* Legacy row classes (analytics detail) */
.row-negative td { background: var(--red-light); }
.row-warning td { background: var(--yellow-light); }
.row-positive td { background: var(--green-light); }
.row-accent td { background: var(--primary-light); }
.row-total td { font-weight: 700; border-top: 2px solid var(--gray-200); }
.text-red { color: var(--red) !important; }
.text-green { color: var(--green) !important; }
.text-muted { color: var(--gray-400); }

.timeline-scroll {
  overflow-x: auto;
  overflow-y: hidden;
  border: 1px solid var(--gray-200);
  border-radius: 10px;
  background: #fff;
  scroll-behavior: auto;
  padding-bottom: 6px;
  scrollbar-width: thin;
  scrollbar-color: rgba(0,0,0,.22) transparent;
}
.timeline-scroll::-webkit-scrollbar { height: 8px; }
.timeline-scroll::-webkit-scrollbar-track { background: transparent; }
.timeline-scroll::-webkit-scrollbar-thumb {
  background: rgba(0,0,0,.22);
  border-radius: 4px;
}
.timeline-scroll::-webkit-scrollbar-thumb:hover { background: rgba(0,0,0,.38); }
.timeline-table {
  border-collapse: separate;
  border-spacing: 0;
  font-size: 13px;
  width: max-content;
  table-layout: fixed;
}
.timeline-table col { width: 38px; }
.timeline-table col.tl-col-metric { width: 190px; }

.timeline-table th,
.timeline-table td {
  padding: 7px 6px;
  text-align: center;
  white-space: nowrap;
  border-bottom: 1px solid var(--gray-100);
  font-variant-numeric: tabular-nums;
}

.timeline-table thead .tl-month {
  background: var(--gray-50);
  font-weight: 600;
  color: var(--gray-600);
  font-size: 11px;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  padding: 6px 4px;
  border-bottom: 1px solid var(--gray-200);
}
.timeline-table thead .tl-day {
  background: var(--gray-50);
  font-weight: 600;
  color: var(--gray-600);
  font-size: 12px;
  padding: 5px 4px;
  border-bottom: 1px solid var(--gray-200);
}
.timeline-table thead .tl-day.tl-today {
  background: var(--primary-light);
  color: var(--primary);
  font-weight: 700;
}

.timeline-table .tl-day-sep,
.timeline-table .tl-month-sep { border-left: 1px solid var(--gray-200); }
.timeline-table tbody td.tl-day-sep { border-left: 1px solid var(--gray-100); }

.timeline-metric-col {
  text-align: left !important;
  background: #fff;
  position: sticky;
  left: 0;
  z-index: 2;
  font-weight: 600;
  padding: 7px 14px 7px 14px !important;
  box-shadow: 4px 0 6px -4px rgba(0, 0, 0, 0.08);
  color: var(--gray-800);
}
.timeline-table thead .timeline-metric-col {
  z-index: 3;
  background: var(--gray-50);
  font-size: 12px;
  color: var(--gray-600);
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

.timeline-table tbody tr { transition: background 160ms var(--ease-out, cubic-bezier(0.23,1,0.32,1)); }
@media (hover: hover) and (pointer: fine) {
  .timeline-table tbody tr:hover td:not(.timeline-metric-col),
  .timeline-table tbody tr:hover .timeline-metric-col { background: #FAFAFD; }
  .timeline-table tbody tr:hover .timeline-metric-col { box-shadow: 4px 0 6px -4px rgba(0, 0, 0, 0.08); }
}

.timeline-table .tl-num { color: var(--gray-800); }
.timeline-table .tl-muted { color: var(--gray-400); opacity: 0.6; }
.timeline-table .tl-subtle { color: var(--gray-400); }
.timeline-table .tl-disc { color: var(--primary); font-weight: 600; }
.timeline-table .tl-stock-zero { color: var(--red); font-weight: 700; }

.timeline-table tbody td.tl-today { background: var(--primary-light); font-weight: 600; color: var(--gray-800); }
.timeline-table tbody td.tl-today.tl-disc { color: var(--primary); }

.timeline-table .tl-ads-on { color: var(--green) !important; font-weight: 700; font-size: 14px; }

.timeline-hint {
  font-size: 12px;
  color: var(--gray-400);
  margin-top: 10px;
  line-height: 1.7;
  display: flex;
  flex-wrap: wrap;
  gap: 4px 16px;
}
.timeline-hint .tl-ads-on { color: var(--green); font-weight: 700; margin-right: 4px; }

@media (max-width: 640px) {
  .timeline-table col { width: 32px; }
  .timeline-table col.tl-col-metric { width: 140px; }
  .timeline-metric-col { padding: 7px 10px !important; font-size: 12px; }
}
.sortable-th:hover { background: rgba(99, 102, 241, 0.08); }
.detail-profit td { font-size: 16px; }
.detail-articles { margin-top: 8px; }
.detail-articles-title { font-size: 17px; font-weight: 700; margin-bottom: 16px; }
.reports-arrow { color: var(--gray-400); font-size: 18px; }
.sync-hint { font-size: 12px; color: var(--gray-400); margin-top: 4px; }

/* Missing costs */
.missing-costs-block {
  background: var(--red-light);
  border: 1.5px solid var(--red);
  border-radius: var(--radius);
  padding: 16px 20px;
  margin-bottom: 20px;
}
.missing-costs-header {
  display: flex; align-items: flex-start; gap: 12px; flex-wrap: wrap;
}
.missing-costs-icon { font-size: 24px; flex-shrink: 0; }
.missing-costs-title { font-size: 15px; font-weight: 700; color: var(--red); margin-bottom: 4px; }
.missing-costs-sub { font-size: 13px; color: var(--gray-600); }
.missing-costs-header .btn-primary { margin-left: auto; flex-shrink: 0; }
.missing-row { background: #fff5f5; }
.missing-cost-row { background: #fff5f5; }
.totals-row { background: #f9fafb; font-weight: 700; border-top: 2px solid var(--gray-300, #d1d5db); }
.totals-row td { font-weight: 700 !important; }
.totals-row td.sticky-col { background: #f9fafb !important; }
tr.totals-row:hover td.sticky-col { background: #f3f4f6 !important; }
.btn-add-cost {
  padding: 4px 10px; border-radius: 6px;
  background: var(--primary-light); color: var(--primary);
  border: 1px solid var(--primary); font-family: inherit;
  font-size: 12px; font-weight: 600; cursor: pointer;
  transition: transform 160ms var(--ease-out), background 150ms var(--ease-out), color 150ms var(--ease-out);
}
.btn-add-cost:hover { background: var(--primary); color: white; }
.btn-add-cost:active { transform: scale(0.95); }

.sync-banner {
  background: var(--purple-50, #f3f0ff);
  border: 1px solid var(--purple-200, #c4b5fd);
  border-radius: 12px;
  padding: 16px 20px;
  margin-bottom: 16px;
}
.sync-banner-head {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
}
.sync-banner-title {
  flex: 1;
  display: flex;
  align-items: baseline;
  gap: 8px;
  min-width: 0;
}
.sync-banner-title #syncBannerText {
  font-size: 14px;
  color: var(--purple-700, #6d28d9);
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.sync-banner-elapsed {
  font-size: 12px;
  color: var(--purple-600, #7c3aed);
  opacity: .75;
  font-variant-numeric: tabular-nums;
}
.sync-banner-percent {
  font-size: 14px;
  color: var(--purple-700, #6d28d9);
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}
.sync-banner-spinner {
  width: 20px; height: 20px;
  border: 3px solid var(--purple-200, #c4b5fd);
  border-top-color: var(--purple-600, #7c3aed);
  border-radius: 50%;
  animation: spin .8s linear infinite;
  flex-shrink: 0;
}
@keyframes spin { to { transform: rotate(360deg); } }

.sync-progress {
  height: 8px;
  background: var(--purple-100, #ede9fe);
  border-radius: 999px;
  overflow: hidden;
  margin-bottom: 12px;
}
.sync-progress-bar {
  height: 100%;
  background: linear-gradient(90deg, var(--purple-500, #8b5cf6), var(--purple-600, #7c3aed));
  border-radius: 999px;
  transition: width .6s ease;
  position: relative;
  overflow: hidden;
}
.sync-progress-bar::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.35), transparent);
  animation: syncShimmer 1.8s linear infinite;
}
@keyframes syncShimmer {
  0% { transform: translateX(-100%); }
  100% { transform: translateX(100%); }
}

.sync-stages {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
}
.sync-stage {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--purple-600, #7c3aed);
  opacity: .55;
  transition: opacity .3s;
}
.sync-stage small {
  opacity: .8;
  font-variant-numeric: tabular-nums;
}
.sync-stage-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: currentColor;
  opacity: .4;
}
.sync-stage.active {
  opacity: 1;
  font-weight: 600;
}
.sync-stage.active .sync-stage-dot {
  opacity: 1;
  animation: syncDotPulse 1.2s ease-in-out infinite;
}
@keyframes syncDotPulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.4); }
}
.sync-stage.done {
  opacity: .85;
}
.sync-stage.done .sync-stage-dot {
  opacity: 1;
  background: var(--green-500, #10b981);
}
.costs-table tbody tr { cursor: pointer; }

/* MODAL */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.4);
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}

.modal {
  background: white;
  border-radius: var(--radius);
  width: 100%;
  max-width: 480px;
  box-shadow: 0 8px 40px rgba(0,0,0,.2);
  animation: modalIn 200ms var(--ease-out);
  /* Длинный контент (настройки кабинета + блок расширения) уходил за viewport.
     Делаем модалку flex-колонкой с ограничением по высоте, body скроллится. */
  display: flex;
  flex-direction: column;
  max-height: calc(100vh - 40px);
}

@keyframes modalIn {
  from { opacity: 0; transform: scale(0.96); }
  to   { opacity: 1; transform: scale(1); }
}

.modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 24px 0;
}

.modal-title {
  font-size: 17px;
  font-weight: 700;
  color: var(--gray-800);
}

.modal-close {
  background: none;
  border: none;
  font-size: 18px;
  color: var(--gray-400);
  cursor: pointer;
  padding: 4px 8px;
  border-radius: 6px;
  line-height: 1;
}
@media (hover: hover) and (pointer: fine) {
  .modal-close:hover { background: var(--gray-100); color: var(--gray-800); }
}
.modal-close:active { transform: scale(0.93); }

.modal-body { padding: 20px 24px; overflow-y: auto; flex: 1; min-height: 0; }

.modal-footer {
  display: flex;
  gap: 10px;
  justify-content: flex-end;
  padding: 0 24px 20px;
}

.btn-primary {
  padding: 10px 20px;
  background: var(--primary);
  color: white;
  border: none;
  border-radius: 8px;
  font-family: inherit;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: transform 150ms var(--ease-out), box-shadow 150ms var(--ease-out), background 150ms var(--ease-out);
}
@media (hover: hover) and (pointer: fine) {
  .btn-primary:hover { background: var(--primary-dark); transform: translateY(-1px); box-shadow: 0 4px 12px rgba(108,99,255,.25); }
}
.btn-primary:active { transform: scale(0.97); box-shadow: none; }
.btn-primary:disabled { opacity: .5; cursor: wait; }

.btn-secondary {
  padding: 10px 20px;
  background: white;
  color: var(--gray-600);
  border: 1.5px solid var(--gray-200);
  border-radius: 8px;
  font-family: inherit;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: transform 150ms var(--ease-out), box-shadow 150ms var(--ease-out), border-color 150ms var(--ease-out), color 150ms var(--ease-out);
}
@media (hover: hover) and (pointer: fine) {
  .btn-secondary:hover { border-color: var(--red); color: var(--red); transform: translateY(-1px); box-shadow: 0 4px 12px rgba(239,68,68,.15); }
}
.btn-secondary:active { transform: scale(0.97); box-shadow: none; }

.modal-wide { max-width: 560px; }

/* CABINET LIST */
.cabinet-list { display: flex; flex-direction: column; gap: 8px; margin-bottom: 16px; }

.cabinet-card {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 14px; border-radius: 10px;
  background: var(--gray-50); border: 1.5px solid var(--gray-200);
  transition: border-color 150ms var(--ease-out), background 150ms var(--ease-out);
  cursor: pointer;
}
@media (hover: hover) and (pointer: fine) {
  .cabinet-card:hover { border-color: var(--primary); }
}
.cabinet-card.active { border-color: var(--primary); background: var(--primary-light); }

.cabinet-card-name { font-weight: 600; font-size: 14px; flex: 1; }
.cabinet-card-meta { font-size: 11px; color: var(--gray-400); }
.cabinet-card-actions { display: flex; gap: 6px; }
.cabinet-card-actions button {
  background: none; border: none; cursor: pointer; font-size: 12px; color: var(--gray-400);
  padding: 4px; border-radius: 4px;
}
.cabinet-card-actions button:hover { background: var(--gray-100); color: var(--gray-800); }
.cabinet-card-actions .btn-del:hover { color: var(--red); }

.cabinet-form {
  border-top: 1px solid var(--gray-200); padding-top: 16px;
}
.cabinet-form-title { font-size: 13px; font-weight: 700; color: var(--gray-600); margin-bottom: 10px; }

.logo {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  user-select: none;
  transition: opacity .15s;
}
.logo:hover { opacity: .8; }
.logo:focus-visible { outline: 2px solid var(--primary); outline-offset: 4px; border-radius: 4px; }

/* ─── Главный дашборд ─────────────────────────────────────────────────────── */
.dash-page { padding-top: 20px; }
.dash-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 24px;
  gap: 16px;
  flex-wrap: wrap;
}
.dash-title {
  font-size: 28px;
  font-weight: 700;
  margin: 0;
  color: var(--ink-1, #111827);
}
.dash-controls { display: flex; gap: 10px; }
.dash-content { display: flex; flex-direction: column; gap: 24px; }
.dash-loading, .dash-error {
  padding: 60px 20px;
  text-align: center;
  color: var(--gray-500);
  background: #fff;
  border-radius: 12px;
  border: 1px dashed var(--gray-200);
}
.dash-error { color: var(--red, #dc2626); }

/* Сегментированный фильтр периода (Сегодня / Вчера / 7 дней / Месяц / Свой).
   Стиль OneScreen-like: контейнер с лёгкой обводкой, активная кнопка тёмная,
   остальные прозрачные. Чёрно-белая палитра — не конкурирует с акцент-цветом. */
.dash-period-tabs {
  display: inline-flex;
  align-items: center;
  background: var(--bg-2, #f3f4f6);
  border: 1px solid var(--line, var(--gray-200));
  border-radius: 10px;
  padding: 3px;
  gap: 2px;
}
.dash-period-tab {
  appearance: none;
  background: transparent;
  border: 0;
  color: var(--ink-2, #4b5563);
  font-family: inherit;
  font-size: 13px;
  font-weight: 600;
  padding: 7px 14px;
  border-radius: 7px;
  cursor: pointer;
  transition:
    background 160ms var(--ease, cubic-bezier(0.23, 1, 0.32, 1)),
    color 160ms var(--ease, cubic-bezier(0.23, 1, 0.32, 1)),
    transform 90ms var(--ease, cubic-bezier(0.23, 1, 0.32, 1));
  white-space: nowrap;
}
.dash-period-tab:hover:not(.is-active):not(:disabled) {
  color: var(--ink, var(--ink-1, #111827));
  background: rgba(0,0,0,0.04);
}
.dash-period-tab:active:not(:disabled) { transform: scale(0.97); }
.dash-period-tab.is-active {
  background: var(--ink, var(--ink-1, #111827));
  color: #fff;
  box-shadow: 0 1px 2px rgba(0,0,0,0.10);
}
.dash-period-tab:disabled {
  color: var(--ink-4, #9ca3af);
  cursor: not-allowed;
  opacity: 0.55;
}
.dash-period-tab:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px var(--action, var(--primary));
}
/* Двухстрочный таб «Свой» когда активен: над — слово «Свой», под — выбранный диапазон.
   Высота кнопки чуть больше остальных, центрируем содержимое флексом. */
.dash-period-tab-custom {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  line-height: 1.15;
  padding-top: 5px;
  padding-bottom: 5px;
}
.dash-period-tab-main {
  font-size: 13px;
  font-weight: 600;
}
.dash-period-tab-sub {
  font-size: 10px;
  font-weight: 500;
  opacity: 0.78;
  margin-top: 1px;
  font-variant-numeric: tabular-nums;
}

/* Inline-календарь с range-selection для таба «Свой». Модалка по центру экрана
   с backdrop. Слева — два месяца с навигацией по году, справа — пресеты быстрых
   диапазонов и поля «Начало / Конец периода» + кнопки «Сбросить / Сохранить». */
.dash-cal-overlay {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(15, 23, 42, 0.40);
  opacity: 0;
  transition: opacity 160ms var(--ease, cubic-bezier(0.23, 1, 0.32, 1));
}
.dash-cal-overlay.is-visible { opacity: 1; }
.dash-cal-overlay[hidden] { display: none; }

.dash-cal-modal {
  width: min(720px, calc(100vw - 32px));
  max-height: min(540px, calc(100vh - 48px));
  background: var(--surface, #fff);
  border: 1px solid var(--line, var(--gray-200));
  border-radius: 16px;
  box-shadow: 0 24px 64px rgba(15, 23, 42, 0.22), 0 4px 12px rgba(15, 23, 42, 0.08);
  overflow: hidden;
  transform: translateY(8px) scale(0.985);
  transition: transform 180ms var(--ease, cubic-bezier(0.23, 1, 0.32, 1));
}
.dash-cal-overlay.is-visible .dash-cal-modal {
  transform: translateY(0) scale(1);
}

.dash-cal-body {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(0, 1fr);
  /* grid-template-rows 1fr — растянуть строку на всю доступную высоту, иначе
     внутренние grid-children .dash-cal-col-controls с rows:1fr auto не получат
     явной высоты и actions «исчезнут» при превышении контента. */
  grid-template-rows: 1fr;
  height: 100%;
  max-height: 540px;
}

/* ─── Левая колонка: год + два месяца ──────────────────────────── */
.dash-cal-col-calendar {
  display: flex;
  flex-direction: column;
  border-right: 1px solid var(--line, var(--gray-200));
  min-height: 0;
}
.dash-cal-yearbar {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--line, var(--gray-200));
  background: var(--bg-2, #f1f5f9);
}
.dash-cal-year {
  font-family: var(--font-display, inherit);
  font-size: 16px;
  font-weight: 600;
  color: var(--ink, var(--ink-1, #0f172a));
  min-width: 56px;
  text-align: center;
  font-variant-numeric: tabular-nums;
}
.dash-cal-nav {
  appearance: none;
  background: transparent;
  border: 1px solid transparent;
  border-radius: 8px;
  width: 30px;
  height: 30px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--ink-2, #334155);
  font-size: 13px;
  transition:
    background 120ms var(--ease, cubic-bezier(0.23, 1, 0.32, 1)),
    color 120ms var(--ease, cubic-bezier(0.23, 1, 0.32, 1)),
    transform 90ms var(--ease, cubic-bezier(0.23, 1, 0.32, 1));
}
.dash-cal-nav:hover {
  background: var(--surface, #fff);
  color: var(--ink, #0f172a);
}
.dash-cal-nav:active { transform: scale(0.92); }
.dash-cal-nav:focus-visible {
  outline: none;
  border-color: var(--action, #4f46e5);
  box-shadow: 0 0 0 3px var(--action-bg, rgba(79, 70, 229, 0.12));
}

.dash-cal-months {
  flex: 1 1 auto;
  overflow-y: auto;
  padding: 16px 18px 18px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.dash-cal-month-title {
  font-family: var(--font-display, inherit);
  font-size: 14px;
  font-weight: 600;
  color: var(--ink, var(--ink-1, #0f172a));
  margin: 0 0 8px;
  letter-spacing: 0.01em;
}
.dash-cal-weekdays {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 2px;
  margin-bottom: 4px;
}
.dash-cal-weekday {
  font-size: 10px;
  font-weight: 600;
  text-align: center;
  color: var(--ink-3, #64748b);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 4px 0;
}
.dash-cal-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 2px;
}

/* День: квадратная кнопка, текст по центру. Hover — мягкий фон.
   Range — голубой фон, границы — фиолетовая обводка на крайних. */
.dash-cal-day {
  appearance: none;
  background: transparent;
  border: 1px solid transparent;
  border-radius: 8px;
  font: inherit;
  font-size: 13px;
  font-variant-numeric: tabular-nums;
  color: var(--ink, var(--ink-1, #0f172a));
  height: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition:
    background 100ms var(--ease, cubic-bezier(0.23, 1, 0.32, 1)),
    color 100ms var(--ease, cubic-bezier(0.23, 1, 0.32, 1)),
    border-color 100ms var(--ease, cubic-bezier(0.23, 1, 0.32, 1));
}
.dash-cal-day:hover:not(:disabled) {
  background: var(--bg-2, #f1f5f9);
}
.dash-cal-day-weekend { color: #dc2626; }
.dash-cal-day-other-month { color: var(--ink-4, #94a3b8); }
.dash-cal-day-other-month.dash-cal-day-weekend { color: rgba(220, 38, 38, 0.45); }

.dash-cal-day-today {
  border-color: var(--ink-3, #64748b);
}

/* Внутри range — светло-голубой/фиолетовый фон. */
.dash-cal-day-in-range,
.dash-cal-day-in-range-preview {
  background: var(--action-bg, rgba(79, 70, 229, 0.10));
  border-radius: 0;
}
.dash-cal-day-in-range-preview { opacity: 0.65; }

/* Стартовая и конечная даты — фиолетовая обводка + скруглённый угол с нужной стороны. */
.dash-cal-day-start,
.dash-cal-day-end,
.dash-cal-day-single,
.dash-cal-day-end-preview {
  background: var(--action-bg, rgba(79, 70, 229, 0.10));
  border-color: var(--action, #4f46e5);
  color: var(--ink, var(--ink-1, #0f172a));
  font-weight: 600;
}
.dash-cal-day-start { border-radius: 8px 0 0 8px; }
.dash-cal-day-end   { border-radius: 0 8px 8px 0; }
.dash-cal-day-single,
.dash-cal-day-end-preview { border-radius: 8px; }
.dash-cal-day-end-preview { border-style: dashed; }

/* ─── Правая колонка: пресеты, поля, кнопки ────────────────────── */
.dash-cal-col-controls {
  /* Grid 1fr auto: верхняя часть (пресеты + поля) скроллится при низком
     viewport'е, нижняя (Сбросить / Сохранить) всегда видна снизу. */
  display: grid;
  grid-template-rows: 1fr auto;
  padding: 16px 18px 18px;
  background: var(--paper, #fff);
  min-height: 0;
  overflow: hidden;
}
.dash-cal-col-controls-top {
  display: flex;
  flex-direction: column;
  gap: 16px;
  overflow-y: auto;
  padding-bottom: 12px;
}
.dash-cal-presets {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.dash-cal-preset {
  appearance: none;
  background: transparent;
  border: 1px solid var(--line, var(--gray-200));
  border-radius: 8px;
  font: inherit;
  font-size: 13px;
  font-weight: 500;
  color: var(--ink-2, #334155);
  padding: 9px 12px;
  text-align: left;
  cursor: pointer;
  transition:
    background 120ms var(--ease, cubic-bezier(0.23, 1, 0.32, 1)),
    border-color 120ms var(--ease, cubic-bezier(0.23, 1, 0.32, 1)),
    color 120ms var(--ease, cubic-bezier(0.23, 1, 0.32, 1)),
    transform 90ms var(--ease, cubic-bezier(0.23, 1, 0.32, 1));
}
.dash-cal-preset:hover {
  background: var(--bg-2, #f1f5f9);
  border-color: var(--line-2, #94a3b8);
  color: var(--ink, #0f172a);
}
.dash-cal-preset:active { transform: scale(0.98); }
.dash-cal-preset:focus-visible {
  outline: none;
  border-color: var(--action, #4f46e5);
  box-shadow: 0 0 0 3px var(--action-bg, rgba(79, 70, 229, 0.12));
}

.dash-cal-fields {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 4px;
}
.dash-cal-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.dash-cal-field-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--ink-3, #64748b);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.dash-cal-field-value {
  font-family: var(--font-mono, var(--font-ui, inherit));
  font-size: 14px;
  font-weight: 500;
  color: var(--ink, var(--ink-1, #0f172a));
  padding: 9px 12px;
  border: 1px solid var(--line, var(--gray-200));
  border-radius: 8px;
  background: var(--surface, #fff);
  font-variant-numeric: tabular-nums;
  min-height: 18px;
}
.dash-cal-field-placeholder {
  color: var(--ink-4, #94a3b8);
  font-weight: 400;
  font-family: var(--font-ui, inherit);
}

.dash-cal-actions {
  display: flex;
  gap: 8px;
  padding-top: 12px;
  border-top: 1px solid var(--line, var(--gray-200));
}
.dash-cal-btn {
  appearance: none;
  font: inherit;
  font-size: 13px;
  font-weight: 600;
  padding: 10px 14px;
  border-radius: 8px;
  cursor: pointer;
  flex: 1 1 auto;
  transition:
    background 120ms var(--ease, cubic-bezier(0.23, 1, 0.32, 1)),
    color 120ms var(--ease, cubic-bezier(0.23, 1, 0.32, 1)),
    border-color 120ms var(--ease, cubic-bezier(0.23, 1, 0.32, 1)),
    transform 90ms var(--ease, cubic-bezier(0.23, 1, 0.32, 1)),
    opacity 120ms var(--ease, cubic-bezier(0.23, 1, 0.32, 1));
}
.dash-cal-btn:active:not(:disabled) { transform: scale(0.97); }
.dash-cal-btn-ghost {
  background: transparent;
  border: 1px solid var(--line, var(--gray-200));
  color: var(--ink-2, #4b5563);
}
.dash-cal-btn-ghost:hover {
  background: var(--bg-2, #f1f5f9);
  border-color: var(--line-2, #94a3b8);
}
.dash-cal-btn-primary {
  background: var(--action, #4f46e5);
  border: 1px solid var(--action, #4f46e5);
  color: var(--ink-inverse, #fff);
}
.dash-cal-btn-primary:hover:not(:disabled) {
  filter: brightness(1.05);
}
.dash-cal-btn-primary:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

/* Адаптив: на узких экранах модалка занимает почти весь экран,
   контролы переезжают под календарь. */
@media (max-width: 720px) {
  .dash-cal-modal {
    width: calc(100vw - 16px);
    max-height: calc(100vh - 16px);
  }
  .dash-cal-body {
    grid-template-columns: 1fr;
    max-height: calc(100vh - 16px);
  }
  .dash-cal-col-calendar {
    border-right: none;
    border-bottom: 1px solid var(--line, var(--gray-200));
  }
  .dash-cal-presets {
    flex-direction: row;
    flex-wrap: wrap;
  }
  .dash-cal-preset { flex: 1 1 calc(50% - 6px); }
}

@media (prefers-reduced-motion: reduce) {
  .dash-cal-overlay,
  .dash-cal-modal,
  .dash-cal-day,
  .dash-cal-btn,
  .dash-cal-preset,
  .dash-cal-nav {
    transition-duration: 0.01ms;
  }
}

/* ─── KPI-карточки крупного формата ─────────────────────────────── */
/* 3 карточки в ряд (Заказы / Маржа / Остатки). Главное число 36px, дельта
   справа сверху, под цифрой — подпись + ещё одна метрика (средний чек / ROI). */
.dash-kpis-big {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
@media (max-width: 1400px) { .dash-kpis-big { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 700px)  { .dash-kpis-big { grid-template-columns: 1fr; } }

.dash-card-big {
  background: #fff;
  border: 1px solid var(--line, var(--gray-200));
  border-radius: 14px;
  padding: 20px 22px 18px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.dash-big-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.dash-card-title {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--gray-500, var(--ink-3));
  font-weight: 600;
}
.dash-big-main {
  font-size: 36px;
  font-weight: 700;
  line-height: 1.05;
  color: var(--ink-1, #111827);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
}
.dash-big-negative { color: #dc2626; }
.dash-big-main-row {
  display: flex;
  align-items: baseline;
  gap: 14px;
  flex-wrap: wrap;
}
.dash-big-main-secondary {
  font-size: 18px;
  font-weight: 500;
  color: var(--gray-500, var(--ink-3));
  font-variant-numeric: tabular-nums;
}
.dash-big-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}
.dash-big-sub {
  font-size: 14px;
  color: var(--gray-600, var(--ink-2, #4b5563));
  font-variant-numeric: tabular-nums;
}
.dash-big-foot {
  margin-top: 4px;
  padding-top: 10px;
  border-top: 1px dashed var(--gray-200, var(--line));
  font-size: 12px;
  color: var(--ink-2, var(--gray-600, #4b5563));
}
.dash-big-foot b { color: var(--ink-1, #111827); font-weight: 700; }
.dash-big-foot-sep { margin: 0 6px; color: var(--gray-300, var(--ink-4)); }
.dash-big-foot-dim { color: var(--gray-500, var(--ink-3)); }

/* Кнопка-полоса «Развернуть детализацию» — заменяет карточку Продаж. */
.dash-bd-toggle {
  appearance: none;
  width: 100%;
  background: #fff;
  border: 1px solid var(--line, var(--gray-200));
  border-radius: 12px;
  padding: 14px 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  cursor: pointer;
  font-family: inherit;
  text-align: left;
  transition:
    border-color 160ms var(--ease, cubic-bezier(0.23, 1, 0.32, 1)),
    background 160ms var(--ease, cubic-bezier(0.23, 1, 0.32, 1)),
    box-shadow 160ms var(--ease, cubic-bezier(0.23, 1, 0.32, 1)),
    transform 90ms var(--ease, cubic-bezier(0.23, 1, 0.32, 1));
}
.dash-bd-toggle:hover {
  border-color: var(--ink-3, var(--gray-400));
  background: rgba(0,0,0,0.015);
}
.dash-bd-toggle:active { transform: scale(0.997); }
.dash-bd-toggle-open {
  border-color: var(--ink-2, var(--gray-500));
  background: rgba(0,0,0,0.02);
}
.dash-bd-toggle:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px var(--action, var(--primary));
}
.dash-bd-toggle-label {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  font-weight: 600;
  color: var(--ink-1, #111827);
}
.dash-bd-toggle-icon {
  display: inline-flex;
  width: 22px;
  height: 22px;
  align-items: center;
  justify-content: center;
  border-radius: 6px;
  background: var(--bg-2, #f3f4f6);
  color: var(--ink-2, var(--gray-600));
  font-size: 10px;
}
.dash-bd-toggle-meta {
  display: inline-flex;
  align-items: baseline;
  gap: 10px;
  font-size: 13px;
  color: var(--ink-2, var(--gray-600, #4b5563));
  font-variant-numeric: tabular-nums;
}
.dash-bd-toggle-meta b {
  color: var(--ink-1, #111827);
  font-weight: 700;
}

.dash-delta {
  font-size: 13px;
  font-weight: 600;
  white-space: nowrap;
}
.dash-delta-up    { color: #16a34a; }
.dash-delta-down  { color: #dc2626; }
.dash-delta-zero  { color: var(--gray-400); }

/* ─── Детализация продаж и удержаний ──────────────────────────────
   3-секционный layout: слева — вертикальный список строк, справа —
   waterfall сверху и горизонтальные доли удержаний снизу. */
.dash-breakdown {
  background: #fff;
  border: 1px solid var(--line, var(--gray-200));
  border-radius: 14px;
  padding: 18px 22px 22px;
}

/* Шапка: имя кабинета + бейдж WB + момент обновления. */
.dash-bd-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px;
  flex-wrap: wrap;
}
.dash-bd-head-left {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.dash-bd-head-title {
  font-size: 16px;
  font-weight: 600;
  color: var(--ink-1, #111827);
}
.dash-bd-head-badge {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--ink-2, var(--gray-600));
  background: var(--bg-2, #f3f4f6);
  border: 1px solid var(--line, var(--gray-200));
  padding: 3px 8px;
  border-radius: 6px;
}
.dash-bd-head-right {
  font-size: 12px;
  color: var(--gray-500, var(--ink-3));
  cursor: help;
}

/* Двухколоночная сетка. На узких — стек. */
.dash-bd-layout {
  display: grid;
  grid-template-columns: minmax(280px, 4fr) minmax(360px, 6fr);
  gap: 22px;
  align-items: start;
}
@media (max-width: 1024px) { .dash-bd-layout { grid-template-columns: 1fr; } }

/* ─── Левый столбец: вертикальный список ─────────────────────────── */
.dash-bd-list {
  background: var(--bg-2, #f9fafb);
  border: 1px solid var(--line, var(--gray-200));
  border-radius: 12px;
  padding: 14px 16px 16px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.dash-bd-list-total {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--line, var(--gray-200));
}
.dash-bd-list-total-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
}
.dash-bd-list-total-label {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--gray-500, var(--ink-3));
  font-weight: 600;
}
.dash-bd-list-total-val {
  font-size: 28px;
  font-weight: 700;
  color: var(--ink-1, #111827);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
}
.dash-bd-list-total-val.dash-bd-list-neg { color: #dc2626; }
.dash-bd-list-total-meta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.dash-bd-list-total-hint {
  font-size: 11px;
  color: var(--gray-500, var(--ink-3));
}
.dash-bd-list-rows {
  display: flex;
  flex-direction: column;
}
.dash-bd-list-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  padding: 8px 0;
  border-bottom: 1px dashed var(--gray-200, var(--line));
  font-size: 13px;
}
.dash-bd-list-row:last-child { border-bottom: 0; }
.dash-bd-list-row-na { color: var(--gray-400, var(--ink-4)); cursor: help; }
.dash-bd-list-label {
  color: var(--ink-2, var(--gray-700, #374151));
}
.dash-bd-list-val {
  font-weight: 600;
  color: var(--ink-1, #111827);
  font-variant-numeric: tabular-nums;
}
.dash-bd-list-val .dash-bd-list-neg { color: #dc2626; }
.dash-bd-list-val .dash-bd-na { color: var(--gray-400, var(--ink-4)); font-weight: 400; }
.dash-bd-list-footer {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  margin-top: 4px;
  padding-top: 10px;
  border-top: 1px solid var(--line, var(--gray-200));
}
.dash-bd-list-footer .dash-bd-list-total-val { font-size: 22px; }

/* ─── Правый столбец: водопад + бары ─────────────────────────────── */
.dash-bd-col-right {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.dash-bd-block-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--ink-1, #111827);
  margin-bottom: 10px;
}
.dash-bd-waterfall {
  background: #fff;
  border: 1px solid var(--line, var(--gray-200));
  border-radius: 12px;
  padding: 14px 16px;
}
/* SVG-водопад. Габариты задаются viewBox в JS (460x220); CSS только ограничивает
   ширину контейнера, чтобы график не растягивался и шрифты в SVG не масштабировались. */
.dash-wf-svg {
  width: 100%;
  max-width: 620px;          /* совпадает с viewBox width, чтобы шрифты не масштабировались */
  height: auto;
  display: block;
  margin: 0 auto;
  font-family: inherit;
}
/* Столбики: тёмно-синий для положительных (Продажи, положительный Итог),
   красный для отрицательных (все удержания и отрицательный Итог). */
.dash-wf-bar-pos { fill: var(--ink-1, #1e293b); }
.dash-wf-bar-neg { fill: #dc2626; }
.dash-wf-bar {
  transition: opacity 150ms var(--ease, cubic-bezier(0.23, 1, 0.32, 1));
}
.dash-wf-bar:hover { opacity: 0.85; }
/* Тонкая baseline по нулю — отделяет положительные значения от отрицательных,
   делает «куда уходит линия» прозрачным. */
.dash-wf-baseline {
  stroke: var(--line, #e5e7eb);
  stroke-width: 1;
}
/* Пунктирные соединители между верхами соседних столбиков — читатель видит
   уровень накопленного итога без чтения цифр. */
.dash-wf-link {
  stroke: var(--ink-3, #94a3b8);
  stroke-width: 1;
  stroke-dasharray: 3 3;
  opacity: 0.55;
}
/* Значение внутри столбика — белым жирным. Рисуем только для столбиков ≥35px высотой. */
.dash-wf-bar-val-in {
  font-size: 10px;
  fill: #fff;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  pointer-events: none;
}
/* Значение над столбиком — крупнее и темнее для читаемости. Всегда сверху. */
.dash-wf-bar-val-out {
  font-size: 12px;
  fill: var(--ink-1, #1e293b);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  pointer-events: none;
}
/* Подписи категорий под столбиками — medium тёмно-серый, читается без напряжения. */
.dash-wf-bar-label {
  font-size: 12px;
  fill: var(--ink-2, #475569);
  font-weight: 500;
}

/* Горизонтальные progress-bars долей удержаний. */
.dash-bd-shares {
  background: #fff;
  border: 1px solid var(--line, var(--gray-200));
  border-radius: 12px;
  padding: 14px 16px 16px;
}
.dash-bd-share-row {
  margin-bottom: 10px;
}
.dash-bd-share-row:last-child { margin-bottom: 0; }
.dash-bd-share-na { opacity: 0.5; }
.dash-bd-share-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 4px;
  font-size: 12px;
}
.dash-bd-share-label { color: var(--ink-2, var(--gray-700, #374151)); }
.dash-bd-share-val {
  font-weight: 700;
  color: var(--ink-1, #111827);
  font-variant-numeric: tabular-nums;
}
.dash-bd-share-track {
  width: 100%;
  height: 6px;
  background: var(--bg-2, #f3f4f6);
  border-radius: 3px;
  overflow: hidden;
}
.dash-bd-share-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--ink-1, #1e293b) 0%, var(--ink-2, #475569) 100%);
  border-radius: 3px;
  transition: width 280ms var(--ease, cubic-bezier(0.23, 1, 0.32, 1));
}
.dash-bd-empty-msg {
  font-size: 12px;
  color: var(--gray-500, var(--ink-3));
  padding: 8px 0;
}

/* Дельта-чип в % (используется в шапке Общего итога). */
.dash-delta-pct {
  font-size: 11px;
  font-weight: 600;
  padding: 2px 6px;
  border-radius: 4px;
  background: rgba(0,0,0,0.03);
  font-variant-numeric: tabular-nums;
}
.dash-delta-pct.dash-delta-up    { color: #16a34a; background: rgba(22,163,74,0.10); }
.dash-delta-pct.dash-delta-down  { color: #dc2626; background: rgba(220,38,38,0.10); }
.dash-delta-pct.dash-delta-zero  { color: var(--gray-400, var(--ink-4)); }

.dash-cabinets {
  background: #fff;
  border: 1px solid var(--gray-200);
  border-radius: 14px;
  padding: 18px 22px 22px;
}
.dash-table-scroll { overflow-x: auto; margin: 0 -22px; padding: 0 22px; }
.dash-section-hint-light {
  font-size: 12px;
  font-weight: 400;
  color: var(--gray-500);
  margin-left: 8px;
  text-transform: none;
  letter-spacing: 0;
}
.dash-cab-name {
  /* НЕЛЬЗЯ display: flex на <td> — ломает table-layout, ячейка перестаёт
     подчиняться height/vertical-align, граница строки рендерится по другой
     высоте чем у соседних td. Используем inline-вёрстку: аватарка
     inline-flex + spacer-gap, baseline-выравнивание через CSS ниже. */
  min-width: 180px;
  white-space: nowrap;
}
.dash-cab-name > .dash-cab-avatar { margin-right: 10px; }
.dash-cab-name > * { vertical-align: middle; }
.dash-cab-avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 7px;
  background: var(--primary);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  flex-shrink: 0;
  letter-spacing: 0.5px;
}
.dash-cab-avatar-sum {
  background: var(--ink-1, #111827);
  font-size: 14px;
}
.dash-row-totals { background: var(--gray-50, #f9fafb); }
.dash-row-totals td {
  font-weight: 700;
  border-top: 2px solid var(--gray-200);
  /* Высоту строки матчим с обычными: там под значением есть .dash-cell-delta
     (11px + 2px margin = ~15px). Без этого Итого визуально ниже остальных,
     создавая ощущение «съехавших линий». */
  padding-top: 14px;
  padding-bottom: 18px;
}
.dash-cabinets-hint {
  margin-top: 12px;
  font-size: 12px;
  color: var(--gray-500);
  padding-top: 12px;
  border-top: 1px dashed var(--gray-200);
}
.dash-section-title {
  font-size: 16px;
  font-weight: 600;
  margin-bottom: 14px;
  color: var(--ink-1, #111827);
}
.dash-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
}
.dash-table th, .dash-table td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--gray-200);
  text-align: left;
  /* Без vertical-align: middle ячейки с дельтой растягивают строку, а
     ячейка с одним лишь текстом (Кабинет) центрируется по baseline сверху —
     визуально получается «съехавшая» нижняя граница. */
  vertical-align: middle;
  /* Фиксированная min-height на всех ячейках — единая высота строки
     независимо от того есть в ячейке дельта или нет. Иначе .dash-cab-name
     (только текст) короче .dash-num (значение + .dash-cell-delta) и
     граница строки рендерится на разной высоте у двух соседей. */
  height: 56px;
}
.dash-table th {
  font-weight: 600;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--gray-500);
  background: var(--gray-50, #f9fafb);
}
.dash-table tbody tr:last-child td { border-bottom: none; }
.dash-table tbody tr:hover { background: var(--gray-50, #f9fafb); }
.dash-row-active { background: rgba(124, 58, 237, 0.06); }
.dash-row-active td { font-weight: 600; }
.dash-num { text-align: right; white-space: nowrap; }
.dash-cab-name { font-weight: 500; }
.dash-cell-delta { font-size: 11px; font-weight: 400; margin-top: 2px; }

.logo-icon { font-size: 24px; }

.logo-text {
  font-size: 22px;
  font-weight: 700;
  color: var(--primary);
  letter-spacing: -0.5px;
}

.header-sub {
  font-size: 13px;
  color: var(--gray-400);
  border-left: 1px solid var(--gray-200);
  padding-left: 16px;
}

/* LAYOUT */
/* Контейнер растёт вместе с экраном до 2800px. Раньше упирался в 1600px —
   на 4K (3840px) и даже на 27" 2.5K оставались огромные пустые поля по бокам.
   Сейчас на FullHD (1920px) полезной ширины ~1844 вместо 1536, на 2K (2560px)
   ~2484, на 4K ~2752. Padding через clamp() — 16-48px плавно по 2vw. */
.container {
  width: 100%;
  max-width: 2800px;
  margin: 0 auto;
  padding: 0 clamp(16px, 2vw, 48px);
}

/* Страницы с формами / компактными таблицами (Калькулятор, Себестоимость,
   Аналитика артикула, Сравнение кабинетов, Мастер-отчёт, План продаж)
   плохо переносят ширину 2500+px — текст и инпуты разъезжаются, числа в
   коротких таблицах уезжают далеко от подписей. Ограничиваем их до 1800px.
   Шапка и table-heavy страницы (Матрица, Стоки, Недельные отчёты, Daily,
   Потребность по складам) используют все 2800px — таблицы получают
   больше колонок без скролла. */
.container.container-narrow,
.costs-page,
.analytics-page,
.master-page,
.compare-page,
.sp-page {
  max-width: 1800px;
  margin-left: auto;
  margin-right: auto;
}
/* Калькулятор v2 — корень не имеет класса .calc2-page, поэтому ограничение
   ширины живёт прямо на .c2 (см. calc2.css). Здесь ничего не делаем. */

.main-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  padding-top: 28px;
  padding-bottom: 48px;
}

@media (min-width: 900px) {
  .main-layout {
    grid-template-columns: 1fr 480px;
    align-items: start;
  }
}

/* FORM */
.form-section {
  background: white;
  border-radius: var(--radius);
  padding: 28px;
  box-shadow: var(--shadow);
  display: flex;
  flex-direction: column;
  gap: 4px;
  transition: box-shadow 200ms var(--ease-out);
}
@media (hover: hover) and (pointer: fine) {
  .form-section:hover { box-shadow: 0 2px 8px rgba(0,0,0,.1), 0 8px 24px rgba(0,0,0,.08); }
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 10px 0;
  border-bottom: 1px solid var(--gray-100);
}

.form-group:last-child {
  border-bottom: none;
}

.form-label {
  font-size: 13px;
  font-weight: 600;
  color: var(--gray-600);
  display: flex;
  align-items: center;
  gap: 6px;
}

.form-input,
.form-select {
  width: 100%;
  height: 40px;
  padding: 0 12px;
  border: 1.5px solid var(--gray-200);
  border-radius: 8px;
  font-size: 15px;
  font-family: inherit;
  color: var(--gray-800);
  background: white;
  transition: border-color 150ms var(--ease-out), box-shadow 150ms var(--ease-out);
  outline: none;
  appearance: none;
  -webkit-appearance: none;
}

.form-select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%239CA3AF' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 36px;
  cursor: pointer;
}

.form-input:focus,
.form-select:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px var(--primary-light);
}

.form-hint {
  font-size: 12px;
  color: var(--gray-400);
}

.api-tag {
  display: inline-block;
  padding: 1px 7px;
  background: var(--primary-light);
  color: var(--primary);
  font-size: 10px;
  font-weight: 700;
  border-radius: 10px;
  text-transform: uppercase;
  letter-spacing: .3px;
}

/* TOGGLE */
.toggle-group {
  display: inline-flex;
  background: var(--gray-100);
  border-radius: 8px;
  padding: 3px;
  gap: 2px;
}

.toggle-btn {
  padding: 7px 18px;
  border: none;
  border-radius: 6px;
  font-family: inherit;
  font-size: 14px;
  font-weight: 600;
  color: var(--gray-600);
  background: transparent;
  cursor: pointer;
  transition: transform 160ms var(--ease-out), background 150ms var(--ease-out), color 150ms var(--ease-out), box-shadow 150ms var(--ease-out);
}
.toggle-btn:active { transform: scale(0.97); }

.toggle-btn.active {
  background: white;
  color: var(--primary);
  box-shadow: 0 1px 4px rgba(0,0,0,.1);
}

/* Switch toggle */
.switch {
  position: relative; display: inline-block;
  width: 36px; height: 20px; flex-shrink: 0;
}
.switch input { opacity: 0; width: 0; height: 0; }
.switch-slider {
  position: absolute; inset: 0; cursor: pointer;
  background: var(--gray-200); border-radius: 20px;
  transition: background 200ms var(--ease-out);
}
.switch-slider::before {
  content: ''; position: absolute;
  left: 2px; top: 2px; width: 16px; height: 16px;
  background: white; border-radius: 50%;
  transition: transform 200ms var(--ease-out);
}
.switch input:checked + .switch-slider { background: var(--primary); }
.switch input:checked + .switch-slider::before { transform: translateX(16px); }

/* FORM ROW 3 COLUMNS */
.form-row-3 {
  display: grid;
  grid-template-columns: 1fr 1fr auto;
  gap: 16px;
  align-items: start;
  padding: 12px 0;
  border-bottom: 1px solid var(--gray-200);
}
.form-row-3 .form-group { margin: 0; }
.form-row-3 .form-select { font-size: 13px; }

/* INPUT WITH RESULT INSIDE */
.input-with-result {
  position: relative;
}
.input-with-result .form-input {
  width: 100%;
  padding-right: 100px;
  -moz-appearance: textfield;
}
.input-with-result .form-input::-webkit-inner-spin-button,
.input-with-result .form-input::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
.input-result {
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 15px;
  font-weight: 700;
  color: var(--primary);
  white-space: nowrap;
  pointer-events: none;
  border-left: 1px solid var(--gray-200);
  padding-left: 12px;
  transition: opacity 150ms var(--ease-out);
}
.input-result.blink {
  opacity: 0.3;
}

/* AUTOCOMPLETE */
.autocomplete-wrap { position: relative; }
.autocomplete-dropdown {
  display: none;
  position: absolute;
  top: 100%;
  left: 0; right: 0;
  max-height: 200px;
  overflow-y: auto;
  background: white;
  border: 1.5px solid var(--gray-200);
  border-top: none;
  border-radius: 0 0 8px 8px;
  box-shadow: 0 4px 12px rgba(0,0,0,.1);
  z-index: 50;
}
.autocomplete-dropdown.open { display: block; }
.autocomplete-item {
  padding: 8px 12px;
  font-size: 13px;
  cursor: pointer;
  transition: background .1s;
}
.autocomplete-item:hover, .autocomplete-item.highlighted { background: var(--primary-light); }

/* PRODUCT PHOTO */
.nm-row {
  display: flex;
  gap: 12px;
  align-items: flex-start;
}
.nm-photo {
  width: 64px;
  height: 85px;
  object-fit: cover;
  border-radius: 8px;
  flex-shrink: 0;
  background: var(--gray-100);
}
.nm-details {
  flex: 1;
  min-width: 0;
}

/* COST PRICE BUTTONS */
.btn-sm {
  display: inline-block;
  padding: 4px 10px;
  font-size: 12px;
  font-weight: 600;
  font-family: inherit;
  color: var(--primary);
  background: var(--primary-light);
  border: 1px solid transparent;
  border-radius: 6px;
  cursor: pointer;
  text-decoration: none;
  transition: transform 150ms var(--ease-out), box-shadow 150ms var(--ease-out), background 150ms var(--ease-out), color 150ms var(--ease-out);
}
@media (hover: hover) and (pointer: fine) {
  .btn-sm:hover { background: var(--primary); color: white; transform: translateY(-1px); box-shadow: 0 2px 8px rgba(108,99,255,.2); }
}
.btn-sm:active { transform: scale(0.95); box-shadow: none; }
.btn-sm-upload { position: relative; }

/* TOOLTIP */
.tooltip-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--gray-200);
  color: var(--gray-600);
  font-size: 10px;
  font-weight: 700;
  cursor: pointer;
  position: relative;
  flex-shrink: 0;
}

.tooltip {
  position: fixed;
  background: var(--gray-800);
  color: white;
  font-size: 12px;
  padding: 8px 12px;
  border-radius: 8px;
  max-width: 240px;
  z-index: 9999;
  pointer-events: none;
  line-height: 1.4;
  box-shadow: 0 4px 12px rgba(0,0,0,.2);
}

/* RESULTS */
.results-section {
  position: sticky;
  top: 80px;
}

.results-card {
  background: white;
  border-radius: var(--radius);
  padding: 24px;
  box-shadow: var(--shadow);
  transition: box-shadow 200ms var(--ease-out);
}
@media (hover: hover) and (pointer: fine) {
  .results-card:hover { box-shadow: 0 2px 8px rgba(0,0,0,.1), 0 8px 24px rgba(0,0,0,.08); }
}

.results-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 16px;
}

.results-title {
  font-size: 16px;
  font-weight: 700;
  color: var(--gray-800);
  margin-bottom: 0;
}

/* STATUS BADGE */
.status-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 10px;
  border-radius: 20px;
  font-weight: 600;
  font-size: 12px;
  white-space: nowrap;
  transition: background 200ms var(--ease-out), color 200ms var(--ease-out);
}

.status-neutral { background: var(--gray-100); color: var(--gray-600); }
.status-green   { background: var(--green-light); color: #15803D; }
.status-red     { background: var(--red-light); color: #B91C1C; }
.status-yellow  { background: var(--yellow-light); color: #92400E; }

.status-badge span:first-child { font-size: 12px; }

/* RESULT ROWS */
.result-rows {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-bottom: 20px;
}

/* RESULT SUBGROUPS */
.result-subgroup {
  background: var(--gray-100);
  border-radius: 8px;
  padding: 10px 12px;
  margin-bottom: 8px;
  border: 1px solid var(--gray-200);
}
.result-subgroup-total {
  background: none;
  padding: 4px 0 0;
  margin-bottom: 0;
}

.result-group-label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--gray-400);
  padding-bottom: 6px;
}

.result-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 6px 0;
  font-size: 13px;
  border-bottom: 1px solid rgba(0,0,0,.05);
}
.result-row:last-child {
  border-bottom: none;
}

.result-row-accent {
  font-weight: 600;
  font-size: 13.5px;
  color: var(--gray-800);
  background: white;
  margin: 4px -8px 0;
  padding: 7px 8px;
  border-radius: 6px;
  border-bottom: none;
}

.result-row.total {
  border-bottom: none;
  border-top: 2px solid var(--gray-200);
  padding-top: 10px;
  margin-top: 2px;
  font-weight: 700;
  font-size: 14px;
}

.result-label { color: var(--gray-600); }
.result-value { font-weight: 600; color: var(--gray-800); }

.result-detail {
  font-size: 11px;
  color: var(--gray-400);
  padding: 0 0 6px;
  line-height: 1.4;
  word-break: break-word;
}

/* HIGHLIGHT CARDS */
.result-highlights {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.highlight-card {
  background: var(--gray-50);
  border-radius: 10px;
  padding: 14px;
  text-align: center;
  transition: background 200ms var(--ease-out);
}

.highlight-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--gray-400);
  text-transform: uppercase;
  letter-spacing: .5px;
  margin-bottom: 6px;
}

.highlight-value {
  font-size: 20px;
  font-weight: 700;
  color: var(--gray-800);
  transition: color 200ms var(--ease-out);
}

.highlight-sub {
  font-size: 11px;
  color: var(--gray-400);
  margin-top: 2px;
}

/* COLOR STATES */
.color-green  { color: var(--green) !important; }
.color-yellow { color: var(--yellow) !important; }
.color-red    { color: var(--red) !important; }

/* ANIMATION */
@keyframes pulse {
  0%   { transform: scale(1); }
  50%  { transform: scale(1.03); }
  100% { transform: scale(1); }
}

.animate-update {
  animation: pulse 200ms var(--ease-out);
}

/* SETTINGS BLOCK */
.settings-block {
  background: var(--primary-light);
  border-radius: 10px;
  padding: 14px 16px;
  margin-bottom: 4px;
}

.settings-title {
  font-size: 12px;
  font-weight: 700;
  color: var(--primary);
  text-transform: uppercase;
  letter-spacing: .5px;
  margin-bottom: 10px;
}

.settings-row {
  display: flex;
  gap: 12px;
}

.settings-field {
  flex: 1;
}

.form-input-sm {
  padding: 8px 10px;
  font-size: 14px;
}

/* ARTICLE INPUT */
.article-row {
  display: flex;
  gap: 8px;
}

.article-row .form-input {
  flex: 1;
}

.btn-load {
  padding: 10px 16px;
  background: var(--primary);
  color: white;
  border: none;
  border-radius: 8px;
  font-family: inherit;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  transition: transform 150ms var(--ease-out), box-shadow 150ms var(--ease-out), background 150ms var(--ease-out), opacity 150ms var(--ease-out);
  flex-shrink: 0;
}
@media (hover: hover) and (pointer: fine) {
  .btn-load:hover { background: var(--primary-dark); transform: translateY(-1px); box-shadow: 0 4px 12px rgba(108,99,255,.25); }
}
.btn-load:active { transform: scale(0.97); box-shadow: none; }
.btn-load:disabled { opacity: 0.5; cursor: wait; }

.nm-info {
  padding: 10px 12px;
  background: var(--primary-light);
  border-radius: 8px;
  font-size: 13px;
  color: var(--primary-dark);
  line-height: 1.5;
}

.nm-info .nm-name    { font-weight: 700; font-size: 14px; }
.nm-info .nm-vendor  { font-size: 12px; color: var(--gray-600); margin-top: 2px; }
.nm-info .nm-subject { font-size: 12px; color: var(--gray-400); margin-top: 2px; }
.nm-info .nm-filled  { color: var(--green); font-size: 12px; margin-top: 6px; }
.nm-info .nm-warn    { color: var(--yellow); font-size: 12px; margin-top: 4px; }
.nm-info .nm-error   { color: var(--red); }

.field-autofilled {
  border-color: var(--primary) !important;
  background: var(--primary-light) !important;
}

/* ANALYTICS */
.analytics-page { padding: 24px 0; }
.articles-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 12px;
  margin-bottom: 24px;
}
.article-card {
  background: white;
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 16px;
  cursor: pointer;
  transition: transform 200ms var(--ease-out), border-color 150ms var(--ease-out), box-shadow 200ms var(--ease-out);
  border: 2px solid transparent;
}
@media (hover: hover) and (pointer: fine) {
  .article-card:hover {
    border-color: var(--primary);
    box-shadow: var(--shadow-lg);
    transform: translateY(-2px);
  }
}
.article-card:active { transform: scale(0.98); }
.article-card-id {
  font-size: 16px;
  font-weight: 700;
  color: var(--primary);
  margin-bottom: 4px;
}
.article-card-art {
  font-size: 13px;
  color: var(--gray-600);
  margin-bottom: 8px;
}
.article-card-cost {
  font-size: 13px;
  font-weight: 600;
  color: var(--gray-800);
}
.article-card-nodata {
  font-size: 11px;
  color: var(--gray-400);
  margin-top: 6px;
  font-style: italic;
}
.analytics-search-wrap { margin-bottom: 16px; }
.analytics-period-filter {
  display: flex; align-items: center; gap: 8px;
  flex-wrap: wrap; position: relative;
}
.period-label { font-size: 13px; color: var(--gray-600); font-weight: 600; }
.date-range-picker {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 14px; background: white; border: 1.5px solid var(--gray-200);
  border-radius: 8px; cursor: pointer; font-size: 14px; font-weight: 500;
  color: var(--gray-800); transition: border-color 0.15s var(--ease-out), box-shadow 0.15s var(--ease-out); position: relative;
}
@media (hover: hover) and (pointer: fine) {
  .date-range-picker:hover { border-color: var(--primary); }
}
.date-range-picker:active { transform: scale(0.98); }
.date-range-clear { color: var(--gray-400); cursor: pointer; font-size: 12px; }
.date-range-clear:hover { color: var(--red); }
.calendar-dropdown {
  position: absolute; top: 100%; left: 0; z-index: 200; background: white;
  border-radius: var(--radius); box-shadow: 0 8px 32px rgba(0,0,0,.15);
  padding: 16px; width: 280px; margin-top: 8px;
}
.calendar-presets {
  display: flex; flex-wrap: wrap; gap: 4px;
  padding-bottom: 12px; margin-bottom: 12px;
  border-bottom: 1px solid var(--gray-100);
}
.cal-preset {
  background: var(--gray-50); border: 1px solid var(--gray-200);
  border-radius: 6px; padding: 4px 10px; font-size: 12px;
  color: var(--gray-700); cursor: pointer;
  transition: background 100ms var(--ease-out), color 100ms var(--ease-out), border-color 100ms var(--ease-out);
}
.cal-preset:hover {
  background: var(--primary-light); color: var(--primary); border-color: var(--primary);
}
.cal-preset:active { transform: scale(0.97); }
.calendar-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 12px; font-weight: 600;
}
.cal-nav {
  background: none; border: none; font-size: 20px; cursor: pointer;
  color: var(--gray-600); padding: 4px 8px; border-radius: 6px;
}
.cal-nav:hover { background: var(--gray-100); }
.cal-nav:active { transform: scale(0.93); }
.calendar-weekdays {
  display: grid; grid-template-columns: repeat(7, 1fr);
  gap: 2px; margin-bottom: 4px;
}
.calendar-weekdays span {
  text-align: center; font-size: 11px; font-weight: 600;
  color: var(--gray-400); padding: 4px 0;
}
.calendar-days { display: grid; grid-template-columns: repeat(7, 1fr); gap: 2px; }
.cal-day {
  text-align: center; padding: 6px 4px; border-radius: 6px;
  font-size: 13px; cursor: pointer; transition: background 100ms var(--ease-out), color 100ms var(--ease-out);
}
.cal-day:hover { background: var(--primary-light); color: var(--primary); }
.cal-day-empty { cursor: default; }
.cal-day-empty:hover { background: none; }
.cal-day-start, .cal-day-end {
  background: var(--primary) !important; color: white !important; font-weight: 700;
}
.cal-day-range { background: var(--primary-light); color: var(--primary); }
.calendar-footer {
  margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--gray-100);
  display: flex; align-items: center; justify-content: space-between; gap: 8px;
}
#calSelectionHint { font-size: 12px; color: var(--gray-600); }

/* MASTER REPORT */
.master-page { padding: 24px 0; }
.master-filters {
  display: flex; align-items: center; gap: 20px;
  flex-wrap: wrap; margin-bottom: 24px;
  padding: 16px 20px; background: white;
  border-radius: var(--radius); box-shadow: var(--shadow);
}
.master-filter-item {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  position: relative;
}
.master-kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 12px; margin-bottom: 8px;
}
.master-kpi-card {
  background: white; border-radius: var(--radius);
  box-shadow: var(--shadow); padding: 16px 20px;
  transition: box-shadow 200ms var(--ease-out);
}
@media (hover: hover) and (pointer: fine) {
  .master-kpi-card:hover { box-shadow: 0 2px 8px rgba(0,0,0,.1), 0 8px 24px rgba(0,0,0,.08); }
}
.master-kpi-label {
  font-size: 12px; color: var(--gray-600);
  font-weight: 600; margin-bottom: 8px;
  text-transform: uppercase; letter-spacing: .4px;
}
.master-kpi-value {
  font-size: 20px; font-weight: 700; color: var(--gray-800);
}
@media (max-width: 768px) {
  .master-kpi-grid { grid-template-columns: repeat(2, 1fr); }
  .master-filters { flex-direction: column; align-items: flex-start; }
}

/* MOBILE */
@media (max-width: 899px) {
  .form-section { padding: 20px 16px; }
  .results-section { position: static; }
  .results-card { padding: 20px 16px; }
  .form-row-3 { grid-template-columns: 1fr; gap: 8px; }
}

/* TABLE ROW TRANSITIONS */
/* Убрана с .matrix-table: в матрице ~100+ строк × до 60 колонок, анимация hover
   на каждой строке даёт постоянный репейнт при движении мышкой — на Windows ощутимо
   подтормаживает курсор при редактировании ячеек. */
.costs-table:not(.matrix-table) tbody tr {
  transition: background 100ms var(--ease-out);
}

/* REDUCED MOTION */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

/* Матрица заказов по дням */
#matrixWrap {
  max-height: calc(100vh - 180px);
  overflow: auto;
}
.matrix-table td { padding: 6px 8px; font-size: 13px; }
.matrix-table th { font-size: 12px; }
.matrix-table thead th {
  position: sticky;
  top: 0;
  background: #fff;
  z-index: 5;
  box-shadow: inset 0 -1px 0 var(--gray-200);
}
/* При большом кабинете (500+ артикулов) таблица становится огромной и браузер
   на Windows при фокусе инпута долго считает accessibility tree всех строк —
   клавиатурные события задерживаются на секунды. content-visibility: auto
   говорит браузеру не рендерить строки, которые вне видимой области —
   реальная работа ведётся только для видимых ~30 строк, остальное пропускается.
   contain-intrinsic-size резервирует примерную высоту, чтобы скроллбар и
   прогноз позиций работали корректно. */
.matrix-table tbody tr {
  content-visibility: auto;
  contain-intrinsic-size: auto 32px;
}
.matrix-cell-up   { background: var(--green-light); }
.matrix-cell-down { background: var(--red-light); }
.matrix-cell-eq   { background: var(--gray-100); }

/* Sticky-колонки матрицы — приклеиваем первые 3 (Артикул WB / Предмет /
   Арт. поставщика). При горизонтальном скролле остаются на месте, чтобы
   юзер не терял контекст пока листает дни вправо. Z-index послойно:
   thead pin (8) > thead обычный (5) > tbody pin (4) > обычные ячейки (auto). */
.matrix-table .matrix-pin-1,
.matrix-table .matrix-pin-2,
.matrix-table .matrix-pin-3 {
  position: sticky;
  background: #fff;
  z-index: 4;
}
.matrix-table thead th.matrix-pin-1,
.matrix-table thead th.matrix-pin-2,
.matrix-table thead th.matrix-pin-3 {
  z-index: 8;
  background: #fff;
}
.matrix-table .matrix-pin-1 { left: 0;     min-width: 110px; }
.matrix-table .matrix-pin-2 { left: 110px; min-width: 130px; }
.matrix-table .matrix-pin-3 { left: 240px; min-width: 220px; }
/* Граница «приклеенной» области — мягкая правая тень на 3-й колонке.
   pointer-events:none — чтоб не перехватывала клики по соседним ячейкам. */
.matrix-table .matrix-pin-3::after {
  content: '';
  position: absolute;
  top: 0; right: -6px;
  width: 6px; height: 100%;
  box-shadow: 4px 0 6px rgba(0, 0, 0, 0.06);
  pointer-events: none;
}
/* Фоны pin-ячеек должны совпадать с background строки, иначе под ними
   видно прокручивающийся контент. */
.matrix-line-row td.matrix-pin-1,
.matrix-line-row td.matrix-pin-2,
.matrix-line-row td.matrix-pin-3 { background: var(--gray-50); }
.matrix-row-clearance td.matrix-pin-1,
.matrix-row-clearance td.matrix-pin-2,
.matrix-row-clearance td.matrix-pin-3 { background: #fff; }
.matrix-total-row td.matrix-pin-1,
.matrix-total-row td.matrix-pin-2 { background: var(--primary-light); }
.matrix-total-row td.matrix-pin-3 { background: #fff; }
/* Текст лейбла секции (д-36, ж-160) — sticky внутри colspan-ячейки, чтобы
   при горизонтальном скролле название группы оставалось видимым у левого
   края, а не уезжало с прокруткой. */
.matrix-line-row .matrix-line-sticky {
  position: sticky;
  left: 12px;
  display: inline-block;
}
.matrix-line-row td { background: var(--gray-50); }
.matrix-total-row td {
  border-top: 2px solid var(--primary);
  font-weight: 700;
  font-size: 14px;
}
.matrix-group-cell,
.matrix-season-cell,
.matrix-manager-cell {
  cursor: pointer;
  min-width: 120px;
}
/* Инпут инлайн-редактирования в матрице. Живёт внутри ячейки td, занимает её
   полностью — чтобы при скролле таблицы не уезжал в сторону. */
.matrix-inline-edit {
  display: block;
  width: 100%;
  padding: 4px 6px;
  font-size: 13px;
  font-family: inherit;
  color: var(--gray-800);
  background: #fff;
  border: 1px solid var(--primary);
  border-radius: 3px;
  outline: none;
  box-sizing: border-box;
  box-shadow: 0 0 0 2px rgba(108, 99, 255, 0.18);
  contain: layout paint;
}
td.matrix-cell-editing { padding: 2px 4px; }
.matrix-group-cell:hover,
.matrix-season-cell:hover,
.matrix-manager-cell:hover { background: var(--gray-50); }

/* Мультиселект групп */
.multi-select { position: relative; display: inline-block; }
.multi-select-btn {
  cursor: pointer;
  min-width: 180px;
  text-align: left;
  background: #fff;
}
.multi-select-panel {
  position: absolute;
  top: 100%;
  left: 0;
  margin-top: 4px;
  background: #fff;
  border: 1px solid var(--gray-200);
  border-radius: 6px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.08);
  padding: 6px 0;
  max-height: 280px;
  overflow-y: auto;
  min-width: 220px;
  z-index: 50;
}
.multi-select-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  cursor: pointer;
  font-size: 13px;
}
.multi-select-row:hover { background: var(--gray-50); }
.multi-select-row input { margin: 0; }

/* Бейдж статуса артикула */
.matrix-status-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 10px;
  font-size: 12px;
  font-weight: 600;
  border: 1px solid transparent;
  cursor: pointer;
  line-height: 1.4;
}
.matrix-status-active {
  background: var(--green-light);
  color: #15803D;
}
.matrix-status-clearance {
  background: var(--red-light);
  color: #B91C1C;
}
.matrix-status-badge:hover { filter: brightness(0.96); }

/* Bulk-кнопка в заголовке линейки */
.matrix-bulk-status {
  margin-left: 10px;
  padding: 2px 8px;
  font-size: 11px;
  border: 1px solid var(--gray-300);
  border-radius: 4px;
  background: #fff;
  cursor: pointer;
  color: var(--gray-700);
}
.matrix-bulk-status:hover { background: var(--gray-50); }

/* Артикул со статусом «слив» — неяркая подсветка строки */
.matrix-row-clearance td { opacity: 0.85; }

/* Сводный отчёт по продавцу (помесячный P&L). По стилю похож на матрицу
   но с собственным sticky первого столбца и под-ячейкой «прошлый год».
   Помещаем рядом с матрицей чтобы не дублировать переменные цвета. */
.ss-table {
  font-size: 13px;
  width: max-content;
  min-width: 100%;
}
.ss-table thead th {
  position: sticky;
  top: 0;
  background: #fff;
  z-index: 5;
  white-space: nowrap;
  font-size: 12px;
  font-weight: 600;
  padding: 8px 10px;
  box-shadow: inset 0 -1px 0 var(--gray-200);
}
.ss-table tbody tr:hover { background: var(--gray-50); }
.ss-table .ss-num {
  text-align: right;
  font-variant-numeric: tabular-nums;
  min-width: 100px;
  padding: 6px 10px;
}
.ss-table .ss-month,
.ss-table .ss-month-head {
  text-align: left;
  font-weight: 600;
  min-width: 90px;
  padding: 6px 12px;
}
.ss-table .ss-month { background: #fff; }
.ss-table .ss-month-head {
  background: #fff;
  z-index: 7;  /* above thead.z-index 5 + body sticky */
}
/* Sticky 1-я колонка (Месяц). Отдельные правила для ss-table т.к. matrix-pin-1
   завязан на .matrix-table. Корзина z-index'ов: thead-pin > tbody-pin > thead > tbody. */
.ss-table .matrix-pin-1 {
  position: sticky;
  left: 0;
  z-index: 4;
  background: #fff;
}
.ss-table thead th.matrix-pin-1 { z-index: 8; }
.ss-table .ss-total-row td {
  border-top: 2px solid var(--primary);
  background: var(--primary-light);
  font-weight: 700;
}
.ss-table .ss-total-row td.matrix-pin-1 { background: var(--primary-light); }
.ss-cell-main {
  font-weight: 500;
  line-height: 1.2;
}
.ss-cell-bold { font-weight: 700; }
.ss-cell-neg { color: var(--neg, #dc2626); }
.ss-cell-prev {
  font-size: 11px;
  color: var(--gray-500, #94a3b8);
  margin-top: 2px;
  font-weight: 400;
}
.ss-cell-prev-empty { color: var(--gray-400); }
.ss-delta-up   { color: var(--pos, #16a34a); font-weight: 600; }
.ss-delta-down { color: var(--neg, #dc2626); font-weight: 600; }
.ss-delta-zero { color: var(--gray-500); }
.ss-table-wrap { overflow-x: auto; max-height: calc(100vh - 220px); overflow-y: auto; }
/* Drill-down ячейка: «Прочие удерж.» — клик открывает модалку с
   разбивкой. Лёгкий hover-индикатор и cursor:pointer. */
.ss-table .ss-cell-drill { cursor: pointer; transition: background 100ms ease; }
.ss-table .ss-cell-drill:hover { background: var(--gray-100); }
.ss-table .ss-cell-drill .ss-cell-main::after {
  content: ' ⓘ';
  font-size: 10px;
  color: var(--gray-400);
  font-weight: 400;
}
/* Поповер «Прочие удержания» — компактный, появляется рядом с ячейкой.
   position:fixed + js-вычисленные left/top. Без overlay/backdrop —
   закрывается кликом по странице. */
.ss-pop {
  position: fixed;
  z-index: 1000;
  background: #fff;
  border: 1px solid var(--gray-200);
  border-radius: 10px;
  box-shadow: 0 12px 32px rgba(0,0,0,0.16);
  font-size: 13px;
  overflow: hidden;
  animation: ssPopIn 140ms ease-out;
}
@keyframes ssPopIn {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}
.ss-pop-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 14px;
  background: var(--gray-50);
  border-bottom: 1px solid var(--gray-200);
}
.ss-pop-title { font-weight: 600; font-size: 13px; color: var(--gray-800); }
.ss-pop-close {
  background: transparent;
  border: 0;
  font-size: 18px;
  line-height: 1;
  color: var(--gray-500);
  cursor: pointer;
  padding: 2px 6px;
  border-radius: 4px;
}
.ss-pop-close:hover { background: var(--gray-100); color: var(--gray-800); }
.ss-pop-body { padding: 8px; }
.ss-pop-table { width: 100%; border-collapse: collapse; }
.ss-pop-table th {
  text-align: left;
  font-weight: 600;
  font-size: 11px;
  color: var(--gray-500);
  padding: 6px 8px;
  border-bottom: 1px solid var(--gray-200);
  text-transform: uppercase;
  letter-spacing: 0.02em;
}
.ss-pop-table td {
  padding: 6px 8px;
  border-bottom: 1px solid var(--gray-100);
}
.ss-pop-table tr:last-child td { border-bottom: none; }
.ss-pop-rows { text-align: right; color: var(--gray-500); font-variant-numeric: tabular-nums; width: 60px; }
.ss-pop-sum  { text-align: right; font-weight: 600; font-variant-numeric: tabular-nums; }
.ss-pop-pct  { text-align: right; color: var(--gray-500); font-variant-numeric: tabular-nums; width: 60px; }
.ss-pop-cat  { color: var(--gray-800); }
.ss-pop-total td {
  border-top: 2px solid var(--primary);
  background: var(--primary-light);
  font-weight: 700;
}

/* Нижняя строка-итог в таблице ежедневных отчётов. Просто акцентная рамка
   сверху и подложка — не липнет к низу, иначе перекрывает последнюю строку
   данных при прокрутке. Закреплена только верхняя шапка thead. */
.daily-total-row td {
  border-top: 2px solid var(--primary);
  background: var(--primary-light);
  font-size: 14px;
}
.matrix-total-row td:first-child,
.matrix-total-row td:nth-child(2) { background: var(--primary-light); }
.matrix-legend { font-size: 12px; color: var(--gray-600); display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.matrix-legend .sw { display: inline-block; width: 14px; height: 14px; border-radius: 3px; margin-right: 4px; vertical-align: middle; }
.matrix-legend .sw-up   { background: var(--green-light); }
.matrix-legend .sw-down { background: var(--red-light); }
.matrix-legend .sw-eq   { background: var(--gray-100); }

/* MATRIX — forecast: переключатель окна velocity + подсветка колонок */
.matrix-vw-wrap {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 4px 8px;
  border: 1.5px solid var(--gray-200);
  border-radius: 10px;
  background: white;
}
.matrix-vw-caption {
  font-size: 12px;
  color: var(--gray-500);
  font-weight: 600;
}
.matrix-vw-group {
  display: inline-flex;
  border: 1px solid var(--gray-200);
  border-radius: 8px;
  overflow: hidden;
}
.matrix-vw-btn {
  padding: 6px 10px;
  background: white;
  border: none;
  cursor: pointer;
  font-family: inherit;
  font-size: 13px;
  font-weight: 600;
  color: var(--gray-700);
  transition: background 120ms var(--ease-out), color 120ms var(--ease-out);
}
.matrix-vw-btn + .matrix-vw-btn { border-left: 1px solid var(--gray-200); }
@media (hover: hover) and (pointer: fine) {
  .matrix-vw-btn:hover { background: var(--primary-light); color: var(--primary-dark); }
}
.matrix-vw-btn[aria-pressed="true"] {
  background: var(--primary);
  color: white;
}
.matrix-vw-settings {
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: white;
  color: var(--gray-600);
  border: 1px solid var(--gray-200);
  border-radius: 8px;
  cursor: pointer;
  transition: color 120ms var(--ease-out), background 120ms var(--ease-out), border-color 120ms var(--ease-out);
}
@media (hover: hover) and (pointer: fine) {
  .matrix-vw-settings:hover { color: var(--primary); border-color: var(--primary); background: var(--primary-light); }
}
.matrix-forecast-danger { background: var(--red-light); color: var(--red); font-weight: 600; }
.matrix-forecast-warn   { background: var(--yellow-light); color: var(--yellow-dark); font-weight: 600; }

/* SYNC BAR (global header) */
#syncBarSlot { margin-left: auto; }
.sync-bar { position: relative; }
#syncBarSlot + .cabinet-select { margin-left: 0; }
.sync-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  background: white;
  color: var(--gray-800);
  border: 1.5px solid var(--gray-200);
  border-radius: 10px;
  font-family: inherit;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  transition: border-color 150ms var(--ease-out), background 150ms var(--ease-out), transform 150ms var(--ease-out), box-shadow 150ms var(--ease-out);
}
@media (hover: hover) and (pointer: fine) {
  .sync-btn:hover { border-color: var(--primary); background: var(--primary-light); }
}
.sync-btn:active { transform: scale(0.97); }
.sync-btn .sync-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 14px;
  height: 14px;
  color: var(--primary);
  transition: color 150ms var(--ease-out);
}
.sync-btn-running {
  border-color: var(--primary);
  background: var(--primary-light);
  color: var(--primary-dark);
  cursor: default;
}
.sync-btn-running:hover { transform: none; }
.sync-btn-running .sync-icon {
  color: var(--primary-dark);
  animation: sync-icon-spin 1.1s linear infinite;
}

@keyframes sync-icon-spin {
  from { transform: rotate(0deg); }
  to   { transform: rotate(-360deg); }
}

/* Вспышка после завершения. Pulse + смена фона. */
@keyframes sync-btn-flash-success {
  0%   { background: var(--green-light); border-color: var(--green); box-shadow: 0 0 0 0 rgba(34,197,94,.45); }
  40%  { background: var(--green-light); border-color: var(--green); box-shadow: 0 0 0 10px rgba(34,197,94,0); }
  100% { background: white; border-color: var(--gray-200); box-shadow: 0 0 0 0 rgba(34,197,94,0); }
}
@keyframes sync-btn-flash-error {
  0%   { background: var(--red-light); border-color: var(--red); box-shadow: 0 0 0 0 rgba(239,68,68,.45); }
  40%  { background: var(--red-light); border-color: var(--red); box-shadow: 0 0 0 10px rgba(239,68,68,0); }
  100% { background: white; border-color: var(--gray-200); box-shadow: 0 0 0 0 rgba(239,68,68,0); }
}
.sync-btn-flash-success { animation: sync-btn-flash-success 1.8s ease-out; }
.sync-btn-flash-success .sync-icon { color: var(--green); }
.sync-btn-flash-error { animation: sync-btn-flash-error 1.8s ease-out; }
.sync-btn-flash-error .sync-icon { color: var(--red); }

@media (prefers-reduced-motion: reduce) {
  .sync-btn-running .sync-icon { animation: none; }
  .sync-btn-flash-success,
  .sync-btn-flash-error { animation: none; }
}

.sync-popup {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  width: 280px;
  background: white;
  border: 1px solid var(--gray-200);
  border-radius: 12px;
  box-shadow: 0 8px 24px rgba(0,0,0,.12);
  padding: 14px;
  z-index: 200;
  animation: sync-popup-in 160ms var(--ease-out);
}
@keyframes sync-popup-in {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}
.sync-popup-title { font-size: 13px; font-weight: 700; color: var(--gray-800); }
.sync-popup-hint { font-size: 11px; color: var(--gray-500); margin-top: 8px; line-height: 1.4; }

/* ─── Sales plan ──────────────────────────────────────────────────────────── */

.sp-page { padding-top: 20px; }

.sp-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin: 16px 0 20px;
}
.sp-card {
  min-width: 140px;
  padding: 10px 14px;
  background: white;
  border: 1px solid var(--gray-200);
  border-radius: 10px;
}
.sp-card-label { font-size: 11px; color: var(--gray-600); text-transform: uppercase; letter-spacing: .03em; }
.sp-card-val   { font-size: 20px; font-weight: 700; color: var(--gray-800); margin-top: 2px; line-height: 1.2; }
.sp-card-unit  { font-size: 12px; font-weight: 500; color: var(--gray-600); margin-left: 3px; }
.sp-card-sub   { font-size: 11px; color: var(--gray-600); margin-top: 4px; }

.sp-card-counts .sp-card-counts-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 6px;
}

.sp-filters {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  margin: 6px 0 14px;
}
.sp-status-tabs {
  display: inline-flex;
  background: var(--gray-100);
  padding: 3px;
  border-radius: 8px;
  gap: 2px;
}
.sp-tab {
  border: none;
  background: transparent;
  color: var(--gray-600);
  font-size: 12px;
  font-weight: 500;
  padding: 5px 12px;
  border-radius: 6px;
  cursor: pointer;
  transition: background 120ms var(--ease-out), color 120ms var(--ease-out);
}
.sp-tab:hover { color: var(--gray-800); }
.sp-tab.active {
  background: white;
  color: var(--gray-800);
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.06);
}
.sp-filter-counter {
  margin-left: auto;
  font-size: 12px;
  color: var(--gray-600);
}

.sp-hint {
  font-size: 12px;
  color: var(--gray-600);
  margin-top: 12px;
  line-height: 1.5;
}

.sp-table td, .sp-table th { vertical-align: middle; }
.sp-table th:nth-child(n+2), .sp-table td:nth-child(n+2) { text-align: right; }
.sp-table th:last-child, .sp-table td:last-child { text-align: left; }

.sp-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 10px;
  font-size: 11px;
  font-weight: 600;
}
.sp-status-ahead   { background: var(--green-light);  color: var(--green); }
.sp-status-ontrack { background: var(--gray-100);     color: var(--gray-600); }
.sp-status-behind  { background: var(--red-light);    color: var(--red); }
.sp-status-soldout { background: var(--yellow-light); color: var(--yellow-dark); }

/* ─── Cost price modal ─────────────────────────────────────────────────────── */
.cost-modal {
  position: fixed; inset: 0; z-index: 1000;
  display: flex; align-items: center; justify-content: center;
}
.cost-modal-backdrop {
  position: absolute; inset: 0;
  background: rgba(17, 24, 39, 0.45);
}
.cost-modal-box {
  position: relative;
  width: 480px; max-width: 92vw;
  background: var(--white, #fff);
  border-radius: 12px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.25);
  overflow: hidden;
}
.cost-modal-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid var(--gray-100);
}
.cost-modal-header h3 { margin: 0; font-size: 16px; }
.cost-modal-close {
  background: transparent; border: none;
  font-size: 24px; line-height: 1; cursor: pointer;
  color: var(--gray-500); padding: 4px 8px; border-radius: 6px;
}
.cost-modal-close:hover { background: var(--gray-100); color: var(--gray-800); }
.cost-modal-body {
  padding: 16px 20px;
  display: flex; flex-direction: column; gap: 14px;
}
.cost-modal-label {
  display: flex; flex-direction: column; gap: 6px;
  font-size: 13px; color: var(--gray-700);
}
.cost-modal-label > span { font-weight: 500; }
.cost-modal-hint { font-size: 11px; color: var(--gray-500); }
.cost-modal-nm-wrap { position: relative; }
.cost-modal-dropdown {
  position: absolute; top: calc(100% + 2px); left: 0; right: 0;
  max-height: 220px; overflow-y: auto;
  background: #fff;
  border: 1px solid var(--gray-200);
  border-radius: 6px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.08);
  z-index: 10;
}
.cost-modal-dropdown-item {
  padding: 8px 12px;
  cursor: pointer;
  border-bottom: 1px solid var(--gray-50, #f5f5f5);
  font-size: 13px;
}
.cost-modal-dropdown-item:hover,
.cost-modal-dropdown-item.active {
  background: var(--gray-50, #f5f5f5);
}
.cost-modal-dropdown-item b { color: var(--primary); }
.cost-modal-dropdown-item small {
  display: block;
  color: var(--gray-500);
  font-size: 11px;
  margin-top: 2px;
}
.cost-modal-footer {
  display: flex; justify-content: flex-end; gap: 8px;
  padding: 14px 20px;
  border-top: 1px solid var(--gray-100);
}
.cost-record-delete {
  background: transparent; border: none; cursor: pointer;
  font-size: 14px; color: var(--gray-400);
  padding: 2px 6px; border-radius: 4px;
}
.cost-record-delete:hover { color: var(--red); background: var(--red-light); }

.cost-col-photo { width: 56px; padding: 4px 8px !important; }
.cost-row-photo {
  width: 40px; height: 40px;
  object-fit: cover; border-radius: 6px;
  background: var(--gray-100);
  display: block;
}
.cost-nm-link {
  color: var(--primary);
  font-weight: 600;
  text-decoration: none;
}
.cost-nm-link:hover { text-decoration: underline; }
.cost-nm-sub {
  color: var(--gray-500);
  font-size: 11px;
  margin-top: 2px;
  max-width: 220px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.cost-row-actions { white-space: nowrap; }
.cost-row-btn {
  background: transparent; border: 1px solid var(--gray-200);
  cursor: pointer;
  font-size: 13px;
  color: var(--gray-500);
  padding: 4px 8px;
  border-radius: 6px;
  margin-right: 4px;
  transition: all 120ms var(--ease-out);
}
.cost-row-btn:last-child { margin-right: 0; }
.cost-row-edit:hover { color: var(--primary); border-color: var(--primary); background: #ede9fe; }
.cost-row-del:hover  { color: var(--red);     border-color: var(--red);     background: var(--red-light); }

.cost-barcode-badge {
  display: inline-block;
  padding: 2px 8px;
  background: var(--gray-100);
  color: var(--gray-600);
  border-radius: 4px;
  font-size: 12px;
  font-family: ui-monospace, monospace;
}
.cost-barcode-all {
  color: var(--gray-500);
  font-style: italic;
  font-size: 12px;
}
.cost-edit-cell { cursor: pointer; position: relative; }
.cost-edit-cell:hover { background: var(--gray-50); }
.cost-price-missing { color: var(--red); font-weight: 600; }
tr.missing-cost-row .cost-edit-cell:hover { background: #ffe4e4; }
.cost-edit-cell:hover::after {
  content: '✎';
  position: absolute;
  right: 4px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--gray-400);
  font-size: 11px;
}
.cost-inline-input {
  width: 100%;
  min-width: 120px;
  padding: 4px 6px;
  border: 1px solid var(--blue);
  border-radius: 4px;
  font-size: 13px;
  background: white;
  outline: none;
}

/* === Motion layer ========================================================= */
/* Универсальные классы для feedback анимаций. Подключаются через ui-fx.js.   */

/* Reduced motion — accessibility: сводим все transition/animation к нулю */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* Press-эффект: на .btn-primary/.btn-secondary/.nav-btn scale уже задан
   в своих блоках выше по файлу. Тут ускоряем transition на press-состояние
   и добавляем scale для .cost-row-btn, которому его не хватало. */
.btn-primary:active,
.btn-secondary:active,
.nav-btn:active {
  transition-duration: 80ms;
}
.cost-row-btn:active {
  transform: scale(0.97);
  transition-duration: 80ms;
}

/* Зелёная галочка в углу после успешного сохранения */
.ui-saved-flash {
  position: relative;
}
.ui-saved-flash::after {
  content: '✓';
  position: absolute;
  top: -6px;
  right: -6px;
  width: 16px;
  height: 16px;
  background: var(--green, #22c55e);
  color: #fff;
  border-radius: 50%;
  font-size: 11px;
  line-height: 16px;
  text-align: center;
  font-weight: 700;
  pointer-events: none;
  animation: uiSavedFlash 1500ms var(--ease-out) forwards;
  z-index: 5;
}
@keyframes uiSavedFlash {
  0%   { opacity: 0; transform: scale(0.6); }
  15%  { opacity: 1; transform: scale(1.12); }
  28%  { transform: scale(1); }
  85%  { opacity: 1; }
  100% { opacity: 0; transform: scale(0.9); }
}

/* Шейк поля при ошибке валидации */
.ui-error-shake {
  animation: uiErrShake 220ms var(--ease-out);
  border-color: var(--red, #ef4444) !important;
}
@keyframes uiErrShake {
  0%, 100% { transform: translateX(0); }
  20%      { transform: translateX(-4px); }
  40%      { transform: translateX(4px); }
  60%      { transform: translateX(-3px); }
  80%      { transform: translateX(2px); }
}

/* Fade-in блока при смене фильтра/периода */
.ui-fade-in {
  animation: uiFadeIn 180ms var(--ease-out);
}
@keyframes uiFadeIn {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ─── TABLET ADAPTIVE (≤1024px) ───────────────────────────────────────────
 * Поддержка планшетов: iPad portrait 768px, landscape 1024px.
 * Полноценный мобильный вид (<768px) сделаем при общем редизайне.
 */

/* Широкие таблицы, которые рендерятся без обёртки — скроллятся внутри */
#spWrap,
.analytics-hero-econ {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

/* На узких ноутбуках padding уменьшается естественно через clamp() в
   .container, дополнительно ужимать не нужно — оставлено как fallback на
   случай старых браузеров без clamp(). */
@media (max-width: 1024px) {
  .container { padding: 0 20px; }
}

/* Шапка (two-tier): на узких окнах ужимаем cabinet-select. */
@media (max-width: 1599px) {
  .header-tier-1 .container { gap: 10px; }
  .cabinet-select { max-width: 200px; }
}

/* Tier-2 в two-tier шапке уже имеет свой overflow-x: auto на .tier-2-tabs
   (см. design-tokens.css). Двойной overflow здесь не нужен.
   На узких ноутбуках (≤1279) шапке tier-1 не хватает ширины под укрупнённые
   domain-tab — возвращаем их к компактному размеру. Это «progressive enhancement
   наоборот»: на 4K/2K крупно, на маленьких — как было до укрупнения. */
@media (max-width: 1279px) {
  .nav-btn { flex-shrink: 0; white-space: nowrap; }
  .costs-table-wrap,
  .timeline-scroll { -webkit-overflow-scrolling: touch; }
  .domain-tab { font-size: 13px; padding: 8px 14px; }
  .logo-text { font-size: 20px; }
  .logo-icon { width: 32px; height: 32px; border-radius: 9px; }
}

/* ─── Stocks (остатки по складам) ───────────────────────────────────────── */
.stocks-page { padding-top: 16px; }

/* Summary-блок над таблицей Остатков: общая сумма + плитки per склад. */
.stocks-sum {
  display: flex;
  gap: 12px;
  margin-bottom: 12px;
  padding: 12px 16px;
  background: #fff;
  border: 1px solid var(--gray-200);
  border-radius: 12px;
  align-items: stretch;
}
.stocks-sum-grand {
  flex: 0 0 auto;
  padding: 8px 16px 8px 0;
  border-right: 1px solid var(--gray-200);
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.stocks-sum-grand-label {
  font-size: 12px;
  color: var(--gray-500);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.stocks-sum-grand-val {
  font-size: 22px;
  font-weight: 700;
  line-height: 1.1;
  margin-top: 4px;
  color: var(--ink-1, #111827);
}
.stocks-sum-tiles {
  flex: 1 1 auto;
  display: flex;
  gap: 6px;
  overflow-x: auto;
  align-items: stretch;
  padding-bottom: 2px;
}
.stocks-sum-tile {
  flex: 0 0 auto;
  min-width: 96px;
  padding: 6px 10px;
  border-radius: 8px;
  background: var(--gray-50, #f9fafb);
  text-align: right;
}
.stocks-sum-wh {
  font-size: 11px;
  color: var(--gray-500);
  text-align: left;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
  max-width: 140px;
}
.stocks-sum-val {
  font-size: 15px;
  font-weight: 600;
  margin-top: 2px;
  color: var(--ink-1, #111827);
}

.stocks-table-scroll {
  overflow: auto;
  max-height: calc(100vh - 220px);
  border: 1px solid var(--gray-200);
  border-radius: 12px;
  background: #fff;
}
.stocks-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: 13px;
}
.stocks-table thead th {
  position: sticky;
  top: 0;
  background: var(--gray-50);
  border-bottom: 1px solid var(--gray-200);
  font-weight: 600;
  text-align: right;
  padding: 10px 8px;
  z-index: 2;
  white-space: nowrap;
  color: var(--gray-700);
}
.stocks-table th.stocks-arrow,
.stocks-table th.stocks-nm,
.stocks-table th.stocks-art { text-align: left; }
.stocks-table td {
  padding: 8px;
  border-bottom: 1px solid var(--gray-100);
  text-align: right;
  white-space: nowrap;
}
.stocks-table td.stocks-nm,
.stocks-table td.stocks-art,
.stocks-table td.stocks-size-label,
.stocks-table td.stocks-arrow { text-align: left; }

/* Закреплённые слева колонки (стрелка + Артикул WB + Арт. поставщика) — при
   горизонтальном скролле остаются на месте, склады уезжают вправо.
   Фон ставим на tr и наследуем в sticky-td через `background: inherit`,
   чтобы hover/open подсветки работали без отдельных правил. Ширины фиксированы
   (max-width = width), иначе sticky `left` начнёт расходиться с реальностью. */
.stocks-arrow { width: 36px; min-width: 36px; max-width: 36px; color: var(--gray-400); }
.stocks-nm    { width: 130px; min-width: 130px; max-width: 130px; }
.stocks-art   { width: 250px; min-width: 250px; max-width: 250px; color: var(--gray-700);
                overflow: hidden; text-overflow: ellipsis; }
.stocks-nm a { color: var(--primary); text-decoration: none; font-weight: 600; }
.stocks-nm a:hover { text-decoration: underline; }
.stocks-wh-col { min-width: 90px; }
.stocks-total { font-weight: 600; min-width: 80px; }

.stocks-table thead th.stocks-arrow,
.stocks-table thead th.stocks-nm,
.stocks-table thead th.stocks-art {
  position: sticky;
  z-index: 3; /* перекрывает и body sticky-left, и body */
}
.stocks-table tbody td.stocks-arrow,
.stocks-table tbody td.stocks-nm,
.stocks-table tbody td.stocks-art {
  position: sticky;
  z-index: 1;
  background: inherit;
}
.stocks-table .stocks-arrow { left: 0; }
.stocks-table .stocks-nm    { left: 36px; }
.stocks-table .stocks-art   { left: 166px; }

/* В строках размера: первая ячейка пустая (под стрелкой), вторая — colspan=2
   c размером и баркодом (под Артикулом WB и Арт. поставщика). Тоже sticky. */
.stocks-table tbody tr.stocks-row-size td:first-child {
  position: sticky;
  left: 0;
  z-index: 1;
  background: inherit;
}
.stocks-table tbody td.stocks-size-label {
  position: sticky;
  left: 36px;
  z-index: 1;
  background: inherit;
}

/* Фон — на tr, чтобы наследовался sticky-cells через background:inherit. */
.stocks-table tbody tr.stocks-row-article { background: #fff; }
.stocks-row-article.stocks-clickable { cursor: pointer; }
.stocks-table tbody tr.stocks-row-article.stocks-clickable:hover { background: var(--gray-50); }
.stocks-table tbody tr.stocks-row-article.stocks-open,
.stocks-table tbody tr.stocks-row-article.stocks-open:hover { background: var(--primary-light); }

.stocks-table tbody tr.stocks-row-size { background: #fafafb; }
.stocks-table tbody tr.stocks-row-size td { color: var(--gray-700); }
.stocks-size { font-weight: 600; margin-right: 8px; }
.stocks-barcode { color: var(--gray-500); font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 12px; }

.stocks-cell { font-variant-numeric: tabular-nums; }
.stocks-cell-pos { color: var(--gray-900); font-weight: 500; }
.stocks-zero { color: var(--gray-300); }

/* Планшет portrait и уже: главный layout схлопывается в одну колонку
   (это уже покрыто @media min-width:900px для .main-layout, тут косметика). */
@media (max-width: 899px) {
  .header .container { padding: 0 16px; }
  .page-nav .container { padding: 0 16px; }
  /* Шапка tier-1 на узких viewports: даём элементам перенестись на вторую
     строку. Без wrap логo+cabinet+3 domain-tabs+3 actions суммарно ~960px
     не влезают в viewport 768-899px → горизонтальный скролл всей страницы.
     `row-gap` отделяет первую и вторую строку шапки. */
  .header-tier-1 .container {
    flex-wrap: wrap;
    row-gap: 8px;
  }
  /* domain-tabs занимают свою строку целиком, чтобы actions остались справа
     рядом с лого/кабинетом. На совсем узких (<600) tier-2 даёт привычный
     overflow-x scroll, поэтому здесь только tier-1 трогаем. */
  .domain-tabs {
    order: 99;
    width: 100%;
    margin-left: 0;
    overflow-x: auto;
    scrollbar-width: none;
  }
  .domain-tabs::-webkit-scrollbar { display: none; }
}

/* YEARLY PLAN — годовой план продаж с месячным разрезом */
.yp-page { padding: 24px 0; }
.yp-table-wrap {
  background: white;
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow-x: auto;
  margin-top: 16px;
}
.yp-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.yp-table thead th {
  background: var(--bg-2);
  padding: 12px 14px;
  text-align: left;
  font-weight: 600;
  color: var(--gray-600);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.3px;
  border-bottom: 2px solid var(--line-2);
  white-space: nowrap;
}
.yp-table tbody td {
  padding: 12px 14px;
  border-bottom: 1px solid var(--bg-2);
  white-space: nowrap;
}
.yp-table tbody tr:hover { background: var(--bg-2); }
.yp-month-cell { font-weight: 600; color: var(--ink); }
.yp-current-month { background: color-mix(in srgb, var(--primary) 4%, transparent); }
.yp-current-month .yp-month-cell { color: var(--primary); }
.yp-plan-cell { font-weight: 600; }
.yp-growth-cell {
  cursor: pointer;
  user-select: none;
  position: relative;
  transition: background 120ms var(--ease-out);
}
.yp-growth-cell:hover { background: var(--bg-2); }
.yp-growth-cell.yp-override {
  background: color-mix(in srgb, var(--warn) 8%, transparent);
  color: var(--warn);
  font-weight: 600;
}
.yp-pos { color: var(--green); font-weight: 600; }
.yp-neg { color: var(--red); font-weight: 600; }
.yp-total-row {
  background: var(--bg-2);
  border-top: 2px solid var(--line-2);
  font-weight: 700;
}
.yp-total-row td { padding-top: 14px; padding-bottom: 14px; }
.yp-metric-toggle {
  display: inline-flex;
  background: var(--bg-2);
  border-radius: 8px;
  padding: 2px;
}
.yp-metric-btn {
  border: none;
  background: transparent;
  padding: 6px 14px;
  font-family: inherit;
  font-size: 13px;
  font-weight: 600;
  color: var(--gray-600);
  cursor: pointer;
  border-radius: 6px;
  transition: background 120ms var(--ease-out), color 120ms var(--ease-out);
}
.yp-metric-btn.active {
  background: white;
  color: var(--primary);
  box-shadow: 0 1px 3px rgba(0,0,0,0.08);
}
.yp-view-btn {
  border: 1.5px solid var(--bg-2);
  background: white;
  padding: 8px 16px;
  font-family: inherit;
  font-size: 13px;
  font-weight: 600;
  color: var(--gray-600);
  cursor: pointer;
  border-radius: 8px;
  transition: border-color 120ms var(--ease-out), color 120ms var(--ease-out), background 120ms var(--ease-out);
}
.yp-view-btn:hover { border-color: var(--primary); color: var(--primary); }
.yp-view-btn.active {
  border-color: var(--primary);
  background: var(--primary-light);
  color: var(--primary);
}
.yp-sortable { cursor: pointer; user-select: none; }
.yp-sortable:hover { color: var(--primary); }
.yp-cell-toggle {
  display: flex; flex-wrap: wrap; gap: 6px; align-items: center;
  padding: 8px 12px;
  background: var(--bg-2);
  border-bottom: 1px solid var(--line-2);
}
.yp-cell-btn {
  border: 1px solid transparent;
  background: transparent;
  padding: 4px 10px;
  font-family: inherit;
  font-size: 12px;
  font-weight: 600;
  color: var(--gray-600);
  cursor: pointer;
  border-radius: 6px;
  transition: background 120ms var(--ease-out), color 120ms var(--ease-out);
}
.yp-cell-btn:hover { background: white; color: var(--primary); }
.yp-cell-btn.active {
  background: white;
  color: var(--primary);
  border-color: var(--primary);
}
.yp-pivot-table { font-size: 12px; min-width: 1100px; }
.yp-pivot-table th, .yp-pivot-table td { padding: 8px 10px; text-align: right; }
.yp-pivot-table th:nth-child(1), .yp-pivot-table th:nth-child(2),
.yp-pivot-table td:nth-child(1), .yp-pivot-table td:nth-child(2) { text-align: left; }
.yp-sticky-col {
  position: sticky; left: 0; z-index: 1;
  background: white;
}
.yp-pivot-table thead .yp-sticky-col { background: var(--bg-2); z-index: 2; }
.yp-pivot-table tbody tr:hover .yp-sticky-col { background: var(--bg-2); }
.yp-pivot-table tfoot .yp-sticky-col { background: var(--bg-2); }
.yp-current-month-th { background: color-mix(in srgb, var(--primary) 12%, var(--bg-2)) !important; color: var(--primary); }
.yp-future-th { color: var(--gray-400); font-weight: 500; }
.yp-cmp { display: flex; flex-direction: column; gap: 1px; line-height: 1.2; font-size: 11px; }
.yp-cmp-prev { color: var(--gray-400); font-size: 10px; }
.yp-cmp-plan { color: var(--primary); font-size: 10px; font-weight: 500; }
.yp-cmp-actual { font-size: 12px; font-weight: 600; }
.yp-cmp-empty { color: var(--gray-400); font-weight: 400; }
/* compare-режим: 3 sub-колонки под общей шапкой месяца */
.yp-pivot-cmp { min-width: 2400px; }
.yp-pivot-cmp .yp-month-group {
  text-align: center;
  border-left: 1px solid var(--line-2);
  border-right: 1px solid var(--line-2);
  background: var(--bg-2);
  padding: 8px 6px;
  font-weight: 700;
  letter-spacing: 0.4px;
}
.yp-pivot-cmp .yp-sub-th {
  padding: 6px 6px;
  font-size: 10px;
  font-weight: 600;
  text-transform: none;
  letter-spacing: 0;
  color: var(--gray-600);
  background: var(--bg-2);
}
.yp-pivot-cmp .yp-sub-cell {
  padding: 6px 6px;
  font-size: 11px;
  border-left: 1px dashed transparent;
  border-right: 1px dashed transparent;
}
/* Левая граница каждой группы из 3-х: prev-колонка получает border слева */
.yp-pivot-cmp tbody td.yp-sub-cell:nth-of-type(3n+3),
.yp-pivot-cmp thead .yp-sub-th:nth-of-type(3n+1),
.yp-pivot-cmp tfoot td.yp-sub-cell:nth-of-type(3n+1) {
  border-left: 1px solid var(--bg-2);
}
.yp-cmp-plan-col { color: var(--primary); }

/* ADVERTS — read-only дашборд кампаний */
.adv-page { padding: 24px 0; }
.adv-balance {
  background: var(--bg-2);
  padding: 8px 16px;
  border-radius: 8px;
  font-size: 13px;
  min-width: 140px;
}
.adv-bal-line { display: flex; justify-content: space-between; gap: 12px; align-items: baseline; }
.adv-bal-label { color: var(--gray-600); font-size: 11px; }
.adv-bal-value { font-weight: 700; color: var(--ink); }
.adv-bal-sub { font-size: 10px; color: var(--gray-400); margin-top: 2px; }
.adv-bal-sub-line { margin-top: 1px; }
.adv-bal-sub-label { color: var(--gray-500); font-size: 10px; }
.adv-bal-sub-value { font-size: 11px; color: var(--gray-700); font-weight: 500; }
.adv-filters {
  display: flex; gap: 12px; align-items: center; flex-wrap: wrap;
  margin: 16px 0;
}
.adv-status-tabs { display: flex; gap: 4px; background: var(--bg-2); padding: 2px; border-radius: 8px; }
.adv-tab {
  border: none; background: transparent;
  padding: 6px 12px;
  font-family: inherit; font-size: 12px; font-weight: 600;
  color: var(--gray-600); cursor: pointer;
  border-radius: 6px;
  transition: background 120ms var(--ease-out), color 120ms var(--ease-out);
}
.adv-tab:hover { color: var(--primary); }
.adv-tab.active { background: var(--surface); color: var(--primary); box-shadow: 0 1px 3px rgba(0,0,0,.08); }
.adv-table-wrap {
  background: var(--surface);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow-x: auto;
  padding: 8px;
}
.adv-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.adv-table thead th {
  background: var(--bg-2);
  padding: 10px 14px;
  text-align: left;
  font-weight: 600;
  color: var(--gray-600);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.3px;
  white-space: nowrap;
}
.adv-table tbody td {
  padding: 10px 14px;
  border-bottom: 1px solid var(--bg-2);
  white-space: nowrap;
}
.adv-table tbody tr:hover { background: var(--bg-2); }
.adv-sortable { cursor: pointer; user-select: none; }
.adv-sortable:hover { color: var(--primary); }
.adv-status {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 12px;
  font-size: 11px;
  font-weight: 600;
  white-space: nowrap;
}
.adv-status-green { background: var(--green-light); color: var(--green); }
.adv-status-red   { background: var(--red-light);   color: var(--red); }
.adv-status-warn  { background: var(--warn-bg);     color: var(--warn); }
.adv-status-gray  { background: var(--bg-2);        color: var(--gray-600); }
/* Бейдж типа ставок: ручная (per-фраза) vs единая (на кампанию). */
.adv-bid-pill {
  display: inline-block;
  padding: 1px 7px;
  margin-left: 4px;
  border-radius: 10px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.02em;
  vertical-align: middle;
}
.adv-bid-manual  { background: var(--bg-2);     color: var(--gray-600); }
.adv-bid-unified { background: var(--warn-bg);  color: var(--warn); }

/* Token input с eye-кнопкой для показа/скрытия. Wrap позиционирует кнопку
   absolute внутри, поле получает паддинг справа чтобы текст не залезал. */
.token-input-wrap { position: relative; }
.token-input-wrap .form-input { padding-right: 38px; }
.token-eye {
  position: absolute;
  right: 4px;
  top: 50%;
  transform: translateY(-50%);
  background: transparent;
  border: none;
  padding: 6px 8px;
  cursor: pointer;
  font-size: 16px;
  line-height: 1;
  border-radius: 6px;
  opacity: 0.6;
  transition: opacity 150ms ease, background 150ms ease;
}
.token-eye:hover { opacity: 1; background: var(--bg-2); }
.token-eye:active { transform: translateY(-50%) scale(0.94); }

/* Inline success state в модалке пополнения. Зелёный круг рисуется stroke-
   dashoffset, галочка вписывается следом — всё за ~600ms. */
.adv-dep-success {
  padding: 32px 24px 24px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}
.adv-dep-success-check {
  color: var(--green, #16a34a);
  margin-bottom: 4px;
  filter: drop-shadow(0 4px 12px color-mix(in srgb, var(--green, #16a34a) 30%, transparent));
}
.adv-dep-success-circle {
  stroke-dasharray: 151;
  stroke-dashoffset: 151;
  animation: advDepCircle 480ms cubic-bezier(0.65, 0, 0.45, 1) forwards;
  transform-origin: center;
  transform: rotate(-90deg);
}
.adv-dep-success-tick {
  stroke-dasharray: 50;
  stroke-dashoffset: 50;
  animation: advDepTick 320ms cubic-bezier(0.65, 0, 0.45, 1) 320ms forwards;
}
@keyframes advDepCircle {
  to { stroke-dashoffset: 0; }
}
@keyframes advDepTick {
  to { stroke-dashoffset: 0; }
}
.adv-dep-success-title {
  font-size: 18px;
  font-weight: 600;
  color: var(--ink, #111);
  opacity: 0;
  animation: advDepFadeUp 320ms ease-out 480ms forwards;
}
.adv-dep-success-sum {
  font-size: 28px;
  font-weight: 700;
  color: var(--green, #16a34a);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.02em;
  opacity: 0;
  animation: advDepFadeUp 360ms ease-out 580ms forwards;
}
.adv-dep-success-sub {
  font-size: 12px;
  color: var(--gray-500);
  opacity: 0;
  animation: advDepFadeUp 320ms ease-out 700ms forwards;
}
@keyframes advDepFadeUp {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}
.adv-article-cell { display: flex; gap: 8px; align-items: center; }
.adv-thumb {
  width: 36px; height: 48px;
  object-fit: cover; border-radius: 4px;
  background: var(--bg-2);
  flex-shrink: 0;
}
.adv-article-text { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.adv-article-art {
  font-size: 12px; font-weight: 600; color: var(--ink);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  max-width: 220px;
}
.adv-article-nm { font-size: 11px; color: var(--gray-400); }
.adv-multi-badge {
  display: inline-block;
  margin-left: 6px;
  padding: 1px 6px;
  background: var(--primary-light);
  color: var(--primary);
  border-radius: 8px;
  font-size: 10px;
  font-weight: 600;
}

/* Этап 2: actions + CPM-edit
   ─────────────────────────────────────────────────────────────────── */
.adv-actions-cell { width: 1%; white-space: nowrap; text-align: center; }
/* Колонка чекбокса массового выделения — узкая, по центру. */
.adv-col-cb { width: 1%; padding-left: 14px; padding-right: 6px; text-align: center; }
.adv-col-cb .pm-cb-label { margin: 0; }
/* Список ID кампаний в bulk-модалке пополнения. Мелкий приглушённый
   моно-текст; при большом числе кампаний — скролл вместо распирания модалки. */
.adv-bulk-dep-list {
  font-family: var(--font-mono, ui-monospace, monospace);
  font-size: 12px;
  line-height: 1.6;
  color: var(--ink-3, var(--gray-500, #64748b));
  background: var(--bg-2, var(--gray-50, #f8fafc));
  border: 1px solid var(--line, var(--gray-200, #e2e8f0));
  border-radius: var(--r-sm, 8px);
  padding: 8px 10px;
  margin-bottom: 4px;
  max-height: 96px;
  overflow-y: auto;
  word-break: break-word;
}
/* Колонка «Остаток» в списке кампаний. Имя `adv-list-budget-cell` чтобы
   не пересекаться с `.adv-budget-cell` из карточки кампании (там
   inline-flex для бюджет-бара). */
.adv-list-budget-cell {
  text-align: right;
  white-space: nowrap;
  vertical-align: middle;
  font-variant-numeric: tabular-nums;
  font-weight: 600;
}
.adv-budget-pending {
  color: var(--gray-300);
  font-size: 12px;
  letter-spacing: 0.2em;
  font-weight: 400;
}
.adv-budget-empty {
  color: var(--neg, #dc2626);
  font-weight: 600;
}
/* Селектор периода для финансов в шапке списка кампаний (7/30/90д). */
.adv-finance-period {
  display: inline-flex;
  border: 1px solid var(--gray-200);
  border-radius: 6px;
  overflow: hidden;
  background: #fff;
  height: 36px;
}
.adv-fin-btn {
  border: 0;
  background: transparent;
  padding: 0 12px;
  font-size: 12px;
  font-weight: 600;
  color: var(--gray-600);
  cursor: pointer;
  transition: background 120ms, color 120ms;
}
@media (hover: hover) {
  .adv-fin-btn:hover { background: var(--gray-50); }
}
.adv-fin-btn.active {
  background: var(--primary, #6366f1);
  color: #fff;
}
/* Числовые ячейки финансов кампаний — 4 отдельных колонки. */
.adv-num-cell {
  text-align: right;
  vertical-align: middle;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}
.adv-fin-drr {
  font-size: 11px;
  font-weight: 700;
  padding: 1px 6px;
  border-radius: 3px;
  display: inline-block;
}
.adv-fin-drr-good { background: var(--pos-bg, #dcfce7); color: var(--pos, #16a34a); }
.adv-fin-drr-mid  { background: var(--gray-100, #f1f5f9); color: var(--gray-700, #475569); }
.adv-fin-drr-bad  { background: var(--neg-bg, #fee2e2); color: var(--neg, #dc2626); }
/* Popover выбора custom-диапазона дат для финансов кампаний. Появляется
   под кнопкой «Свой» в селекторе периода. */
.adv-fin-picker {
  background: #fff;
  border: 1px solid var(--gray-200);
  border-radius: 10px;
  box-shadow: 0 12px 32px rgba(0,0,0,0.16);
  padding: 14px;
  min-width: 320px;
  font-size: 13px;
}
.adv-fin-picker-row {
  display: flex; gap: 12px; align-items: center;
  margin-bottom: 10px;
}
.adv-fin-picker-row label {
  display: flex; align-items: center; gap: 6px;
  font-size: 12px; color: var(--gray-600);
}
.adv-fin-picker-row input[type="date"] {
  font-size: 13px;
  padding: 4px 8px;
  border: 1px solid var(--gray-200);
  border-radius: 6px;
}
.adv-fin-picker-presets {
  display: flex; flex-wrap: wrap; gap: 6px;
  margin-bottom: 12px;
}
.adv-fin-picker-presets button {
  background: var(--gray-50);
  border: 1px solid var(--gray-200);
  border-radius: 5px;
  padding: 4px 10px;
  font-size: 12px;
  color: var(--gray-700);
  cursor: pointer;
  transition: background 100ms;
}
@media (hover: hover) {
  .adv-fin-picker-presets button:hover {
    background: var(--primary-light, #e0e7ff);
    color: var(--primary, #6366f1);
    border-color: var(--primary, #6366f1);
  }
}
.adv-fin-picker-actions {
  display: flex; justify-content: flex-end; gap: 8px;
  border-top: 1px solid var(--gray-100);
  padding-top: 10px;
}
.adv-fin-picker-actions button {
  font-size: 13px;
  padding: 6px 14px;
}
/* Предупреждение под таблицей когда все финансы = 0 (синк отстал). */
.adv-fin-warning {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-top: 12px;
  padding: 10px 14px;
  background: var(--warn-bg, #fef3c7);
  border: 1px solid var(--warn, #f59e0b);
  border-radius: 8px;
  font-size: 12px;
  color: var(--gray-800);
  line-height: 1.4;
}
.adv-fin-warning-icon {
  font-size: 16px;
  flex-shrink: 0;
  color: var(--warn, #f59e0b);
}
/* «обновлено N сек назад» рядом с кнопкой ↻ Обновить в карточке кампании. */
.adv-words-fresh {
  font-size: 11px;
  color: var(--gray-500);
  font-variant-numeric: tabular-nums;
}
.adv-words-fresh-stale { color: var(--gray-400); }
.adv-words-refresh-btn {
  height: 32px;
  padding: 0 12px;
  font-size: 12px;
}
.adv-act-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 28px; height: 28px;
  background: var(--bg-2); color: var(--gray-700);
  border: 1px solid transparent;
  border-radius: 6px;
  font-size: 13px; line-height: 1;
  cursor: pointer;
  transition: transform 120ms cubic-bezier(.23,1,.32,1), background 120ms ease;
}
.adv-act-btn:active { transform: scale(0.94); }
.adv-act-btn:disabled { opacity: 0.5; cursor: not-allowed; }
@media (hover: hover) {
  .adv-act-btn:hover { background: var(--primary-light); color: var(--primary); }
  .adv-act-pause:hover { background: var(--warn-bg); color: var(--warn); }
  .adv-act-resume:hover { background: var(--green-light); color: var(--green); }
}

.adv-cpm-btn {
  background: transparent;
  border: none;
  padding: 2px 0;
  color: inherit;
  font: inherit;
  cursor: pointer;
  border-bottom: 1px dashed var(--gray-400);
  transition: color 120ms ease, border-color 120ms ease;
}
@media (hover: hover) {
  .adv-cpm-btn:hover { color: var(--primary); border-bottom-color: var(--primary); }
}

.adv-cpm-meta {
  display: flex; gap: 10px; align-items: center;
  padding: 8px 10px;
  background: var(--bg-2);
  border-radius: 8px;
}
.adv-cpm-row { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.adv-cpm-arrow { color: var(--gray-400); font-size: 14px; }
.adv-cpm-preview { font-weight: 700; color: var(--primary); min-width: 80px; }
.adv-cpm-prev-note { font-size: 11px; color: var(--gray-500); }
.adv-cpm-input { height: 32px; padding: 0 8px; }

/* Этап 3a: deposit
   ─────────────────────────────────────────────────────────────────── */
.adv-actions-group { display: inline-flex; gap: 4px; }
.adv-act-deposit { font-weight: 700; }
@media (hover: hover) {
  .adv-act-deposit:hover { background: var(--green-light); color: var(--green); }
}

.adv-dep-sources { display: flex; flex-direction: column; gap: 6px; }
.adv-dep-source {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px;
  background: var(--bg-2);
  border: 1px solid transparent;
  border-radius: 8px;
  cursor: pointer;
  transition: border-color 120ms ease, background 120ms ease;
}
.adv-dep-source:has(input:checked) {
  border-color: var(--primary);
  background: var(--primary-light);
}
.adv-dep-source.is-disabled {
  opacity: 0.45;
  cursor: not-allowed;
}
.adv-dep-source-label { flex: 1; font-weight: 500; }
.adv-dep-source-amount {
  font-variant-numeric: tabular-nums;
  color: var(--gray-600);
  font-size: 12px;
}
.adv-dep-source:has(input:checked) .adv-dep-source-amount { color: var(--primary); }
.adv-dep-empty {
  padding: 10px 12px;
  background: var(--warn-bg);
  color: var(--warn);
  border-radius: 8px;
  font-size: 12px;
  line-height: 1.4;
}

/* Этап 3a п.2: detail view + табы фраз
   ─────────────────────────────────────────────────────────────────── */
.adv-id-btn {
  background: transparent; border: none; padding: 2px 0;
  color: var(--primary); font: inherit; font-weight: 700;
  cursor: pointer;
}
@media (hover: hover) {
  .adv-id-btn:hover { text-decoration: underline; }
}
.adv-row-clickable { cursor: pointer; display: block; }
@media (hover: hover) {
  .adv-row-clickable:hover .adv-article-art { color: var(--primary); }
}

/* Detail-view: entrance-анимация при открытии карточки кампании.
   data-mounted ставится в JS через rAF после display:'' — даёт браузеру
   один кадр чтобы зафиксировать start-state, и transition отрабатывает плавно. */
#advDetailView {
  transform-origin: 50% 0;
  opacity: 0;
  transform: translateY(8px) scale(0.992);
  transition: opacity 220ms var(--ease-out), transform 220ms var(--ease-out);
  will-change: opacity, transform;
}
#advDetailView[data-mounted] {
  opacity: 1;
  transform: translateY(0) scale(1);
}

.adv-detail-header {
  display: flex; align-items: center; gap: 16px;
  padding: 14px 16px;
  background: var(--surface);
  border: 1px solid var(--gray-100);
  border-radius: 12px;
  margin-bottom: 12px;
  box-shadow: 0 1px 2px rgba(0,0,0,.02);
}
.adv-detail-back {
  height: 32px; padding: 0 12px;
  font-size: 13px;
  transition: transform 140ms var(--ease-out), background 150ms var(--ease-out), color 150ms var(--ease-out);
}
.adv-detail-back:active { transform: translateX(-2px); }
.adv-detail-meta { display: flex; align-items: center; gap: 12px; min-width: 0; flex: 1; }
/* Кнопки управления (Пополнить / Старт / Пауза) в шапке карточки кампании.
   Полноценные крупные с цветовой семантикой — отличаются от мелких icon-only
   в списке. Цвет сразу, не только на hover; чёткий ховер с подъёмом и
   затемнением. */
.adv-detail-actions {
  display: flex;
  gap: 10px;
  flex-shrink: 0;
  margin-left: auto;
}
.adv-detail-actions .adv-act-btn {
  width: auto;
  height: 44px;
  padding: 0 18px;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.01em;
  border-radius: 10px;
  border: 1px solid transparent;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.06);
  transition: transform 120ms ease, box-shadow 150ms ease, background 150ms ease, filter 150ms ease;
}
.adv-detail-actions .adv-act-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.10);
  filter: brightness(1.05);
}
.adv-detail-actions .adv-act-btn:active {
  transform: translateY(0);
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.06);
}
/* ▶ Старт — насыщенный зелёный, белый текст, очевидное «запустить». */
.adv-detail-actions .adv-act-resume {
  background: var(--green, #16a34a);
  color: #fff;
}
.adv-detail-actions .adv-act-resume:hover { background: var(--green, #16a34a); color: #fff; }
/* ⏸ Пауза — оранжевый warning, тоже белый текст. */
.adv-detail-actions .adv-act-pause {
  background: var(--warn, #f59e0b);
  color: #fff;
}
.adv-detail-actions .adv-act-pause:hover { background: var(--warn, #f59e0b); color: #fff; }
/* ₽ Пополнить — outlined серо-синий: важная но не действие первого порядка. */
.adv-detail-actions .adv-act-deposit {
  background: #fff;
  color: var(--ink, #0f172a);
  border-color: var(--gray-300, #cbd5e1);
}
.adv-detail-actions .adv-act-deposit:hover {
  background: var(--gray-50, #f8fafc);
  color: var(--primary, #6366f1);
  border-color: var(--primary, #6366f1);
}
.adv-detail-meta .adv-thumb {
  width: 40px; height: 40px;
  border-radius: 8px;
  border: 1px solid var(--gray-100);
}
.adv-detail-title {
  font-size: 15px; font-weight: 700; color: var(--ink);
  letter-spacing: -0.01em;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  max-width: 480px;
}
.adv-detail-sub {
  font-size: 12px; color: var(--gray-600); margin-top: 2px;
  display: flex; align-items: center; gap: 6px;
  font-variant-numeric: tabular-nums;
}

.adv-detail-tabs {
  display: flex; gap: 4px;
  border-bottom: 1px solid var(--gray-100);
  margin-bottom: 16px;
}
.adv-detail-tabs .adv-tab {
  position: relative;
  background: transparent;
  border: none;
  border-bottom: 2px solid transparent;
  padding: 10px 16px;
  font-size: 13px; font-weight: 500;
  color: var(--gray-600);
  cursor: pointer;
  transition: color 150ms var(--ease-out), border-color 150ms var(--ease-out);
}
@media (hover: hover) {
  .adv-detail-tabs .adv-tab:hover { color: var(--primary); }
}
.adv-detail-tabs .adv-tab.active {
  color: var(--primary);
  border-bottom-color: var(--primary);
  /* Гасим pill-фон/тень от глобального `.adv-tab.active` (статус-фильтры в шапке) —
     в detail-табах underline-стиль, не pill. */
  background: transparent;
  box-shadow: none;
}

/* Body content fade при смене таба — анимация проигрывается на каждом
   innerHTML-ребилде, потому что узлы новые. */
.adv-detail-body { min-height: 200px; }
.adv-detail-body > * {
  animation: advTabFadeIn 180ms var(--ease-out) both;
}
@keyframes advTabFadeIn {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}

.adv-detail-empty {
  padding: 32px 20px;
  text-align: center;
  color: var(--gray-500);
  background: var(--bg-2);
  border-radius: 8px;
  font-size: 13px;
  line-height: 1.5;
}

/* Toolbar — метрики-карточки слева, hint справа.
   .adv-detail-stats — flex-row с тонким divider, главные числа — крупные tnum. */
.adv-detail-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px; flex-wrap: wrap;
  padding: 4px 0 14px;
}
.adv-detail-stats {
  display: flex; align-items: stretch;
  gap: 0;
  background: var(--surface);
  border: 1px solid var(--gray-100);
  border-radius: 10px;
  padding: 4px;
  flex-wrap: wrap;
}
.adv-detail-stats > * {
  display: inline-flex; align-items: center;
  padding: 6px 14px;
  font-size: 13px;
  white-space: nowrap;
  position: relative;
}
.adv-detail-stats > * + *::before {
  content: '';
  position: absolute;
  left: 0; top: 25%; bottom: 25%;
  width: 1px;
  background: var(--gray-100);
}
.adv-detail-count { color: var(--gray-600); }
.adv-detail-count b {
  color: var(--ink);
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  margin: 0 3px;
}
.adv-detail-period { color: var(--gray-600); gap: 6px; }
.adv-detail-period b {
  color: var(--ink);
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}
.adv-detail-hint {
  font-size: 12px;
  color: var(--gray-500);
  padding: 4px 10px;
  border-radius: 6px;
  background: var(--bg-2);
}

.adv-act-minus { color: var(--red); }
@media (hover: hover) {
  .adv-act-minus:hover { background: var(--red-light); color: var(--red); }
}
/* Унифицированный press-feedback: чуть мягче и явнее в transition list. */
.adv-act-btn { transition: transform 140ms var(--ease-out), background 140ms var(--ease-out), color 140ms var(--ease-out), border-color 140ms var(--ease-out); }
.adv-act-btn:active { transform: scale(0.92); }

.adv-exc-add { display: flex; gap: 8px; align-items: center; }
.adv-exc-list {
  list-style: none; padding: 0; margin: 0;
  display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 8px;
}
.adv-exc-item {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 12px;
  background: var(--bg-2);
  border: 1px solid transparent;
  border-radius: 8px;
  font-size: 13px;
  gap: 8px;
  transition: border-color 150ms var(--ease-out), background 150ms var(--ease-out);
}
@media (hover: hover) {
  .adv-exc-item:hover {
    border-color: var(--gray-200);
    background: var(--surface);
  }
}
.adv-exc-text {
  flex: 1; min-width: 0;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.adv-exc-remove {
  background: transparent; border: none; cursor: pointer;
  width: 22px; height: 22px;
  border-radius: 4px;
  color: var(--gray-500); font-size: 12px;
  transition: background 140ms var(--ease-out), color 140ms var(--ease-out), transform 140ms var(--ease-out);
}
@media (hover: hover) {
  .adv-exc-remove:hover { background: var(--red-light); color: var(--red); }
}
.adv-exc-remove:active { transform: scale(0.92); }
.adv-exc-remove:disabled { opacity: 0.5; cursor: not-allowed; }

/* Stats columns в keywords-таблице */
.adv-keywords-table .adv-num,
.adv-keywords-table th.adv-num { text-align: right; font-variant-numeric: tabular-nums; }
.adv-keywords-table tbody td.adv-num {
  font-size: 15px;
  font-weight: 600;
  color: var(--ink);
}

/* Hover-эффекты на строках кластеров: подсветка фона + усиление колонки действия.
   transform на <tr> рендерится непредсказуемо, поэтому используем box-shadow inset. */
.adv-keywords-table tbody tr {
  transition: background 150ms var(--ease-out), box-shadow 150ms var(--ease-out);
}
@media (hover: hover) {
  .adv-keywords-table tbody tr:hover {
    background: var(--bg-2);
    box-shadow: inset 0 0 0 1px var(--gray-100);
  }
  .adv-keywords-table tbody tr:hover .adv-act-minus {
    background: var(--red-light);
    color: var(--red);
  }
}

.adv-wasted-pill {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 1px 8px;
  background: var(--red-light);
  color: var(--red);
  border-radius: 999px;
  font-size: 11px;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  /* Один subtle pulse при появлении — обращает внимание, дальше не отвлекает. */
  animation: advWastedPulse 1400ms var(--ease-out) 200ms 1 both;
}
@keyframes advWastedPulse {
  0%   { box-shadow: 0 0 0 0 color-mix(in srgb, var(--red) 35%, transparent); }
  60%  { box-shadow: 0 0 0 6px color-mix(in srgb, var(--red) 0%, transparent); }
  100% { box-shadow: 0 0 0 0 transparent; }
}
.adv-wasted-tag {
  display: inline-block;
  margin-left: 6px;
  padding: 0 6px;
  background: var(--red-light);
  color: var(--red);
  border-radius: 4px;
  font-size: 10px;
  font-weight: 600;
  vertical-align: middle;
  letter-spacing: 0.02em;
}

/* Wasted-row: фон + тонкая красная граница слева через inset shadow.
   Граница рисуется на td, не на tr — у tr `border-left` не отрисовывается
   при `border-collapse: collapse`. */
.adv-row-wasted { background: color-mix(in srgb, var(--red-light) 40%, transparent); }
.adv-row-wasted td:first-child {
  box-shadow: inset 3px 0 0 var(--red);
}
@media (hover: hover) {
  .adv-keywords-table tbody tr.adv-row-wasted:hover {
    background: color-mix(in srgb, var(--red-light) 60%, transparent);
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--red) 25%, transparent);
  }
  .adv-keywords-table tbody tr.adv-row-wasted:hover td:first-child {
    box-shadow: inset 3px 0 0 var(--red), inset 0 0 0 1px color-mix(in srgb, var(--red) 25%, transparent);
  }
}

/* ────────────────────────────────────────────────────────────────────
   Detail v2: stat-cards + period selector + redesigned keyword rows.
   ──────────────────────────────────────────────────────────────────── */

/* Шапка карточки — крупная миниатюра + dot-разделители + большой заголовок. */
.adv-thumb.adv-thumb-lg {
  width: 56px; height: 56px;
  border-radius: 12px;
  flex-shrink: 0;
  object-fit: cover;
  border: 1px solid var(--gray-100);
}
.adv-detail-meta-text { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.adv-detail-meta .adv-detail-title {
  font-size: 22px; font-weight: 700; letter-spacing: -0.01em;
  line-height: 1.15;
  color: var(--ink);
}
.adv-detail-sub {
  display: inline-flex; align-items: center; flex-wrap: wrap;
  gap: 8px;
  font-size: 13px; color: var(--gray-600);
}
.adv-detail-id {
  font-weight: 600;
  color: var(--gray-700);
  font-variant-numeric: tabular-nums;
}
.adv-detail-dot { color: var(--gray-300); }

/* Stat-row: 4 равные плитки с отступом, period-row под ним. */
.adv-stat-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin: 4px 0 14px;
}
.adv-stat-card {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 16px;
  background: var(--surface);
  border: 1px solid var(--gray-100);
  border-radius: 14px;
  min-width: 0;
  transition: border-color 200ms var(--ease-out), transform 200ms var(--ease-out), box-shadow 200ms var(--ease-out);
}
@media (hover: hover) {
  .adv-stat-card:hover {
    border-color: var(--gray-200);
    box-shadow: 0 1px 3px rgba(0,0,0,0.04);
  }
}
.adv-stat-card-warn {
  border-color: color-mix(in srgb, var(--red) 22%, var(--gray-100));
  background: color-mix(in srgb, var(--red-light) 30%, var(--surface));
}
.adv-stat-icon {
  width: 40px; height: 40px;
  border-radius: 10px;
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.adv-stat-icon-clusters { background: color-mix(in srgb, var(--primary) 12%, transparent); color: var(--primary); }
.adv-stat-icon-spend    { background: color-mix(in srgb, var(--accent, var(--primary)) 12%, transparent); color: var(--gray-700); }
.adv-stat-icon-wasted   { background: color-mix(in srgb, var(--red) 14%, transparent); color: var(--red); }
.adv-stat-icon-ctr      { background: color-mix(in srgb, var(--green, #16a34a) 14%, transparent); color: var(--green, #16a34a); }
.adv-stat-body { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.adv-stat-label {
  font-size: 12px;
  color: var(--gray-500);
  letter-spacing: 0.01em;
}
.adv-stat-value {
  font-size: 22px; font-weight: 700; letter-spacing: -0.01em;
  color: var(--ink);
  line-height: 1.1;
}
.adv-stat-value-tnum { font-variant-numeric: tabular-nums; }
.adv-stat-value-warn { color: var(--red); }
.adv-stat-sub {
  font-size: 11px;
  color: var(--gray-500);
  font-variant-numeric: tabular-nums;
}

/* Период-селектор: pill-группа слева + custom-инпуты справа. */
.adv-period-row {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  padding: 0 0 14px;
}
.adv-period-pick {
  display: inline-flex; align-items: center;
  background: var(--bg-2);
  padding: 3px;
  border-radius: 999px;
  border: 1px solid var(--gray-100);
}
.adv-period-btn {
  appearance: none;
  background: transparent;
  border: none; cursor: pointer;
  padding: 6px 14px;
  border-radius: 999px;
  font-size: 13px; font-weight: 500;
  color: var(--gray-600);
  transition: background 150ms var(--ease-out), color 150ms var(--ease-out), transform 120ms var(--ease-out);
}
@media (hover: hover) {
  .adv-period-btn:hover { color: var(--ink); }
}
.adv-period-btn:active { transform: scale(0.96); }
.adv-period-btn.active {
  background: var(--surface);
  color: var(--ink);
  font-weight: 600;
  box-shadow: 0 1px 2px rgba(0,0,0,0.06);
}
.adv-period-current {
  font-size: 12px; color: var(--gray-500);
  font-variant-numeric: tabular-nums;
}
.adv-period-custom {
  display: inline-flex; align-items: center; gap: 6px;
  animation: advTabFadeIn 180ms var(--ease-out) both;
}
.adv-period-input {
  height: 30px;
  padding: 0 8px;
  font-size: 12px;
  border-radius: 8px;
  border: 1px solid var(--gray-200);
  background: var(--surface);
  color: var(--ink);
  font-variant-numeric: tabular-nums;
}
.adv-period-dash { color: var(--gray-400); font-size: 13px; }
.btn-primary.adv-period-apply {
  height: 30px;
  padding: 0 12px;
  font-size: 12px;
  border-radius: 8px;
}

/* Keyword-row: убираем дефолтную акцент-полоску wasted у td:first-child,
   ставим её на КАЖДУЮ строку (зелёную/красную) — по мокапу. */
.adv-kw-row td { vertical-align: middle; }
.adv-row-ok td:first-child {
  box-shadow: inset 3px 0 0 var(--green, #16a34a);
}
.adv-kw-phrase {
  font-weight: 500;
  color: var(--ink);
  padding-left: 14px !important;
}
.adv-kw-phrase-text { vertical-align: middle; }

.adv-kw-actions { text-align: right; padding-right: 4px !important; }

/* Action-pill — компактные кнопки в колонке Действия. */
.adv-act-pill {
  appearance: none;
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  height: 30px;
  padding: 0 14px;
  border-radius: 8px;
  font-size: 12px; font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  transition: background 140ms var(--ease-out), color 140ms var(--ease-out), border-color 140ms var(--ease-out), transform 120ms var(--ease-out);
}
.adv-act-pill:active { transform: scale(0.96); }
.adv-act-pill:disabled { opacity: 0.55; cursor: not-allowed; }

.adv-act-pill-boost {
  background: transparent;
  color: var(--green, #16a34a);
  border: 1px solid color-mix(in srgb, var(--green, #16a34a) 35%, transparent);
}
@media (hover: hover) {
  .adv-act-pill-boost:not(:disabled):hover {
    background: color-mix(in srgb, var(--green, #16a34a) 10%, transparent);
    border-color: var(--green, #16a34a);
  }
}

.adv-act-pill-minus {
  background: var(--red);
  color: #fff;
  border: 1px solid var(--red);
}
@media (hover: hover) {
  .adv-act-pill-minus:hover {
    background: color-mix(in srgb, var(--red) 88%, #000);
    border-color: color-mix(in srgb, var(--red) 88%, #000);
  }
}

/* ────────────────────────────────────────────────────────────────────
   Dashboard: 4 KPI-плитки + period-селектор над табами.
   Плитка: Label + delta-pill справа сверху, крупное значение, footer-stats.
   ──────────────────────────────────────────────────────────────────── */
.adv-dashboard {
  display: flex; flex-direction: column;
  gap: 12px;
  margin: 4px 0 18px;
}
.adv-dashboard-head {
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px; flex-wrap: wrap;
}
.adv-dashboard-title {
  font-size: 20px; font-weight: 700; letter-spacing: -0.01em;
  color: var(--ink);
}
.adv-dashboard-period {
  display: inline-flex; align-items: center; gap: 12px; flex-wrap: wrap;
}
.adv-detail-bidtype {
  font-size: 12px;
  color: var(--gray-600);
  padding: 1px 8px;
  background: var(--bg-2);
  border: 1px solid var(--gray-100);
  border-radius: 999px;
  font-weight: 500;
}
.adv-dashboard-spinner {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-left: 10px;
  padding: 3px 10px 3px 8px;
  font-size: 11px;
  font-weight: 600;
  color: var(--action, #6366f1);
  letter-spacing: 0.02em;
  background: color-mix(in srgb, var(--action, #6366f1) 12%, transparent);
  border-radius: 999px;
  vertical-align: middle;
  text-transform: uppercase;
}
.adv-dashboard-spinner::before {
  content: '';
  width: 10px; height: 10px;
  border: 1.5px solid currentColor;
  border-top-color: transparent;
  border-radius: 50%;
  animation: advSpinnerRotate 700ms linear infinite;
}
@keyframes advSpinnerRotate {
  to { transform: rotate(360deg); }
}
/* Диммим тайлы при рефетче — юзер видит старые данные, но понимает что грузится. */
.adv-kpi-row-refreshing .adv-kpi-tile,
.adv-budget-refreshing .adv-budget-val,
.adv-budget-refreshing .adv-budget-period {
  opacity: 0.4;
  transition: opacity 200ms var(--ease-out);
}

/* KPI-row: 4 плитки одинаковой ширины */
.adv-kpi-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.adv-kpi-tile {
  background: var(--surface);
  border: 1px solid var(--gray-100);
  border-radius: 14px;
  padding: 16px;
  display: flex; flex-direction: column;
  gap: 10px;
  min-width: 0;
  transition: border-color 200ms var(--ease-out), box-shadow 200ms var(--ease-out), transform 200ms var(--ease-out);
}
@media (hover: hover) {
  .adv-kpi-tile:hover {
    border-color: var(--gray-200);
    box-shadow: 0 1px 3px rgba(0,0,0,0.04);
  }
}
.adv-kpi-tile-skel { opacity: 0.55; }
.adv-kpi-head {
  display: flex; align-items: center; justify-content: space-between;
  gap: 8px;
}
.adv-kpi-label {
  font-size: 13px;
  color: var(--gray-600);
  font-weight: 500;
}
.adv-kpi-value {
  font-size: 26px;
  font-weight: 700;
  letter-spacing: -0.015em;
  font-variant-numeric: tabular-nums;
  color: var(--ink);
  line-height: 1.05;
}
.adv-kpi-foot {
  display: flex; align-items: center; gap: 8px;
  padding-top: 10px;
  border-top: 1px solid var(--gray-100);
  font-size: 12px;
  flex-wrap: wrap;
  min-height: 28px;
}
.adv-kpi-foot-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px 12px;
  border-top: 1px solid var(--gray-100);
  padding-top: 10px;
}
.adv-kpi-foot-2 > div {
  display: inline-flex; align-items: center; gap: 6px;
  flex-wrap: wrap;
  min-width: 0;
}
.adv-kpi-foot-key {
  color: var(--gray-500);
  font-weight: 500;
}
.adv-kpi-foot-val {
  color: var(--ink);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}

/* Delta-индикаторы. up=зелёный, down=красный, zero=серый.
   Иконка ▲▼ + знак + процент. */
.adv-kpi-delta {
  display: inline-flex; align-items: center; gap: 3px;
  font-size: 11px;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
  letter-spacing: 0.01em;
}
.adv-kpi-delta-up   { color: var(--green, #16a34a); }
.adv-kpi-delta-down { color: var(--red); }
.adv-kpi-delta-zero { color: var(--gray-400); }

/* Адаптив: на узких экранах KPI-row 2×2 */
@media (max-width: 1100px) {
  .adv-kpi-row { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 600px) {
  .adv-kpi-row { grid-template-columns: 1fr; }
  .adv-kpi-foot-2 { grid-template-columns: 1fr; }
}

/* Адаптив: на узких экранах stat-row 2×2, period-row в столбец. */
@media (max-width: 880px) {
  .adv-stat-row { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .adv-period-row { flex-direction: column; align-items: stretch; }
  .adv-period-pick { align-self: flex-start; }
}

/* ────────────────────────────────────────────────────────────────────
   Budget bar — компактная плашка под шапкой карточки.
   Остаток + потрачено + кнопки обновить и пополнить.
   ──────────────────────────────────────────────────────────────────── */
.adv-budget-bar {
  display: flex; align-items: center; gap: 16px;
  padding: 12px 16px;
  margin: 4px 0 14px;
  background: var(--surface);
  border: 1px solid var(--gray-100);
  border-radius: 12px;
  flex-wrap: wrap;
}

/* Защита от переплаты — компактная плашка над budget-bar.
   Тоггл, min-input, кнопка журнала и hint. */
.adv-protection-bar {
  margin: 4px 0 10px;
}
.adv-protection-loading,
.adv-protection-fail {
  padding: 8px 12px;
  background: var(--surface);
  border: 1px solid var(--gray-100);
  border-radius: 10px;
  font-size: 12px;
  color: var(--ink-3);
}
.adv-protection-fail { color: var(--red); }
.adv-protection-row {
  display: flex; align-items: center; gap: 14px;
  padding: 10px 14px;
  background: var(--surface);
  border: 1px solid var(--gray-100);
  border-radius: 10px;
  flex-wrap: wrap;
}
.adv-protection-toggle {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 13px; font-weight: 600; color: var(--ink);
  cursor: pointer; user-select: none;
}
.adv-protection-toggle input { width: 16px; height: 16px; cursor: pointer; }
.adv-protection-min {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 12px;
}
.adv-protection-label { color: var(--gray-500); text-transform: uppercase; letter-spacing: 0.04em; font-weight: 500; }
.adv-protection-min input {
  width: 90px; padding: 4px 8px;
  border: 1px solid var(--gray-200); border-radius: 6px;
  font-size: 13px; font-family: inherit;
  background: var(--bg); color: var(--ink);
}
.adv-protection-min input:focus { outline: none; border-color: var(--accent); }
.adv-protection-suffix { color: var(--gray-500); }
.adv-protection-log {
  font-size: 12px; padding: 4px 10px;
}
.adv-protection-hint {
  margin-left: auto;
  font-size: 11px; color: var(--ink-3);
}
.adv-protection-hint.adv-protection-ok { color: var(--green, #2a8); }
.adv-protection-hint.adv-protection-err { color: var(--red); }

/* ===== Автопополнение бюджета — симметрично protection bar ===== */
.adv-auto-dep-bar {
  margin: 0 0 10px;
}
.adv-auto-dep-loading,
.adv-auto-dep-fail {
  padding: 8px 12px;
  background: var(--surface);
  border: 1px solid var(--gray-100);
  border-radius: 10px;
  font-size: 12px;
  color: var(--ink-3);
}
.adv-auto-dep-fail { color: var(--red); }

.adv-auto-dep-row {
  display: flex; align-items: center; gap: 14px;
  padding: 10px 14px;
  background: var(--surface);
  border: 1px solid var(--gray-100);
  border-radius: 10px;
  flex-wrap: wrap;
}
.adv-auto-dep-toggle {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 13px; font-weight: 600; color: var(--ink);
  cursor: pointer; user-select: none;
}
.adv-auto-dep-toggle input { width: 16px; height: 16px; cursor: pointer; }

.adv-auto-dep-fields {
  display: inline-flex; align-items: center; gap: 10px;
  flex-wrap: wrap;
}
.adv-auto-dep-field {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 12px;
}
.adv-auto-dep-label {
  color: var(--gray-500);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: 500;
}
.adv-auto-dep-field input {
  width: 92px; padding: 4px 8px;
  border: 1px solid var(--gray-200); border-radius: 6px;
  font-size: 13px; font-family: inherit;
  background: var(--bg); color: var(--ink);
  font-variant-numeric: tabular-nums;
  transition: border-color 120ms cubic-bezier(0.23,1,0.32,1),
              opacity 120ms cubic-bezier(0.23,1,0.32,1);
}
.adv-auto-dep-field input:focus { outline: none; border-color: var(--accent); }
.adv-auto-dep-field input:disabled {
  opacity: 0.45; cursor: not-allowed;
  background: var(--gray-100);
}
.adv-auto-dep-suffix { color: var(--gray-500); }

.adv-auto-dep-log { font-size: 12px; padding: 4px 10px; }

.adv-auto-dep-status {
  margin-left: auto;
  font-size: 11px; color: var(--ink-3);
  font-variant-numeric: tabular-nums;
}
.adv-auto-dep-status b { color: var(--ink); font-weight: 600; }
.adv-auto-dep-status.adv-auto-dep-ok  { color: var(--green, #2a8); }
.adv-auto-dep-status.adv-auto-dep-err { color: var(--red); }

.adv-auto-dep-hint {
  margin: 6px 14px 0;
  font-size: 11px; color: var(--ink-3);
  line-height: 1.5;
}

/* ===== Бэйдж в строке списка кампаний ===== */
.adv-auto-dep-on {
  display: inline-flex; align-items: center; justify-content: center;
  width: 18px; height: 18px;
  margin-left: 4px;
  font-size: 11px;
  border-radius: 999px;
  background: var(--pos-bg, var(--green, #2a8));
  color: var(--pos, #fff);
  line-height: 1;
  cursor: help;
  user-select: none;
}

/* ===== Журнал — модалка ===== */
.adv-auto-dep-log-table {
  width: 100%;
  font-size: 12px;
  font-variant-numeric: tabular-nums;
}
.adv-auto-dep-log-table th.num,
.adv-auto-dep-log-table td.num { text-align: right; white-space: nowrap; }
.adv-auto-dep-log-table td.mono { font-family: var(--font-mono, ui-monospace, monospace); color: var(--ink-3); }
.adv-auto-dep-arrow,
.adv-auto-dep-sep {
  color: var(--ink-3);
  margin: 0 4px;
}
.adv-auto-dep-err { color: var(--red); font-size: 11px; max-width: 260px; }

/* ===== Chip'ы статусов ===== */
.adv-auto-dep-chip {
  display: inline-flex; align-items: center;
  padding: 2px 8px;
  font-size: 11px; font-weight: 600;
  border-radius: 999px;
  border: 1px solid transparent;
  white-space: nowrap;
}
.adv-auto-dep-chip-success {
  background: var(--pos-bg, #DCFCE7);
  color:      var(--pos,    #15803D);
  border-color: var(--pos-bg, #DCFCE7);
}
.adv-auto-dep-chip-skip {
  background: var(--warn-bg, #FEF3C7);
  color:      var(--warn,    #B45309);
  border-color: var(--warn-bg, #FEF3C7);
}
.adv-auto-dep-chip-fail {
  background: var(--neg-bg, #FEE2E2);
  color:      var(--neg,    #B91C1C);
  border-color: var(--neg-bg, #FEE2E2);
}

/* ===== Empty state ===== */
.adv-auto-dep-empty {
  padding: 40px 20px;
  text-align: center;
  color: var(--ink-3);
}
.adv-auto-dep-empty-icon {
  font-size: 32px;
  opacity: 0.6;
  margin-bottom: 12px;
}
.adv-auto-dep-empty-title {
  font-size: 14px; font-weight: 600; color: var(--ink);
  margin-bottom: 4px;
}
.adv-auto-dep-empty-sub {
  font-size: 12px;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .adv-auto-dep-field input { transition-duration: 0.01ms; }
}

.adv-budget-cell {
  display: inline-flex; align-items: center; gap: 8px;
  flex-wrap: wrap;
  min-width: 0;
}
.adv-budget-label {
  font-size: 12px;
  color: var(--gray-500);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: 500;
}
.adv-budget-val {
  font-size: 18px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--ink);
}
.adv-budget-skel { font-size: 18px; color: var(--gray-300); }
.adv-budget-fail { font-size: 13px; color: var(--red); }
.adv-budget-period {
  font-size: 11px;
  color: var(--gray-500);
  font-variant-numeric: tabular-nums;
  margin-left: 4px;
}
.adv-budget-divider {
  width: 1px; height: 24px;
  background: var(--gray-200);
}
.adv-budget-refresh {
  background: transparent;
  border: 1px solid var(--gray-200);
  color: var(--gray-500);
  width: 26px; height: 26px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 13px;
  transition: background 140ms var(--ease-out), color 140ms var(--ease-out), transform 140ms var(--ease-out), border-color 140ms var(--ease-out);
}
@media (hover: hover) {
  .adv-budget-refresh:not(:disabled):hover {
    background: var(--bg-2);
    color: var(--ink);
    border-color: var(--gray-300);
  }
}
.adv-budget-refresh:active { transform: rotate(180deg); }
.adv-budget-refresh:disabled { opacity: 0.5; cursor: wait; }
.adv-budget-actions {
  margin-left: auto;
  display: inline-flex; gap: 8px;
}
.btn-secondary.adv-budget-deposit {
  height: 32px; padding: 0 14px;
  font-size: 13px; font-weight: 600;
  border-radius: 8px;
}

/* ──── Минус-фразы: переиспользуем .adv-keywords-table + поправки ───── */
.adv-exc-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px; flex-wrap: wrap;
  margin-bottom: 14px;
}
.adv-exc-summary {
  display: inline-flex; align-items: center; gap: 18px;
  font-size: 13px; color: var(--gray-600);
  flex-wrap: wrap;
}
.adv-exc-summary b {
  color: var(--ink); font-weight: 700;
  font-variant-numeric: tabular-nums;
}
.adv-exc-saved {
  padding: 3px 10px;
  background: color-mix(in srgb, var(--red-light) 70%, transparent);
  color: color-mix(in srgb, var(--red) 92%, var(--ink));
  border-radius: 999px;
  font-size: 12px;
}
.adv-exc-add {
  display: inline-flex; align-items: center; gap: 8px;
}
.adv-exc-add .form-input {
  width: 280px; height: 34px;
  padding: 0 12px;
  font-size: 13px;
  border-radius: 8px;
}
.adv-exc-add .btn-primary {
  height: 34px;
  padding: 0 14px;
  font-size: 13px;
  border-radius: 8px;
}
/* Строка минус-фразы — нейтральный accent-bar (серый, не зелёный/красный) */
.adv-row-excluded td:first-child {
  box-shadow: inset 3px 0 0 var(--gray-300);
}
.adv-exc-no-hist {
  display: inline-block;
  margin-left: 8px;
  padding: 0 6px;
  background: var(--bg-2);
  color: var(--gray-500);
  border-radius: 4px;
  font-size: 10px;
  font-weight: 500;
  vertical-align: middle;
}
/* Кнопка «Убрать» из минус-фраз — оранжевая outline (не red как «В минус») */
.adv-act-pill-restore {
  background: transparent;
  color: var(--gray-700);
  border: 1px solid var(--gray-300);
}
@media (hover: hover) {
  .adv-act-pill-restore:not(:disabled):hover {
    background: var(--bg-2);
    color: var(--ink);
    border-color: var(--gray-400);
  }
}

@media (max-width: 880px) {
  .adv-budget-bar { gap: 10px; padding: 10px 12px; }
  .adv-budget-actions { margin-left: 0; width: 100%; }
  .adv-budget-divider { display: none; }
  .adv-exc-toolbar { flex-direction: column; align-items: stretch; }
  .adv-exc-add .form-input { width: 100%; flex: 1; }
}

/* ──── Сжимаем колонку «Запросы» — длинные фразы обрезаются ellipsis,
   короткие не растягивают столбец на пол-таблицы. ───── */
.adv-keywords-table {
  table-layout: auto;
  width: 100%;
}
.adv-keywords-host {
  padding: 0 16px;
}

/* ──── Блок «Единая ставка» — для unified-кампаний, над таблицей фраз.
   Карточка со списком товаров: товар слева, редактор ставки справа. ───── */
.adv-unified-cost {
  margin: 0 16px 16px;
  padding: 14px 16px;
  border: 1px solid var(--line);
  border-radius: var(--r-lg, 16px);
  background: var(--paper);
}
.adv-unified-cost-title {
  font-size: 14px;
  font-weight: 700;
  color: var(--ink);
  letter-spacing: -0.01em;
}
.adv-unified-cost-hint {
  margin-top: 3px;
  font-size: 12px;
  line-height: 1.45;
  color: var(--ink-3);
}

/* Строка товара. Разделители — между строками (не у первой/последней). */
.adv-unified-cost-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  padding: 12px 0;
  border-top: 1px solid var(--line);
  margin-top: 12px;
}
.adv-unified-cost-row:last-child { padding-bottom: 0; }

.adv-unified-cost-prod {
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
  flex: 1 1 240px;
}
.adv-unified-cost-name {
  font-size: 13px;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.35;
}
.adv-unified-cost-nm {
  font-size: 11px;
  color: var(--ink-4);
  font-variant-numeric: tabular-nums;
}

.adv-unified-cost-edit {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}
.adv-unified-cost-input.form-input {
  width: 90px;
  text-align: right;
  font-variant-numeric: tabular-nums;
  font-weight: 600;
}
.adv-unified-cost-cur {
  font-size: 13px;
  color: var(--ink-3);
  margin-left: -2px;
}
.adv-unified-cost-save.btn-primary {
  padding: 8px 14px;
  font-size: 13px;
  white-space: nowrap;
}

/* Состояния: загрузка / ошибка (нет сессии и т.п.). */
.adv-unified-cost-loading {
  font-size: 13px;
  color: var(--ink-3);
}
.adv-unified-cost-err {
  border-color: var(--warn);
  background: var(--warn-bg);
  color: var(--warn);
  font-size: 13px;
  line-height: 1.45;
  font-weight: 500;
}

.adv-keywords-table td.adv-kw-phrase {
  max-width: 420px;
  width: 420px;
  font-size: 15px;
  font-weight: 600;
}
.adv-kw-phrase-text {
  display: inline-block;
  max-width: calc(100% - 60px);  /* оставляем место для тега «слива» */
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  vertical-align: middle;
}

/* ──── Чекбокс-колонка для bulk-выделения кластеров ───── */
.adv-keywords-table .adv-kw-check-col {
  width: 36px;
  padding-left: 14px !important;
  padding-right: 0 !important;
  text-align: center;
}
.adv-kw-check, .adv-kw-check-all {
  width: 16px;
  height: 16px;
  cursor: pointer;
  accent-color: var(--accent, #16a34a);
}
.adv-kw-row.is-selected td {
  background: rgba(22, 163, 74, 0.05);
}
.adv-kw-row.is-selected td:first-child {
  box-shadow: inset 3px 0 0 var(--accent, #16a34a);
}

/* ──── Bulk-action bar над таблицей ───── */
.adv-bulk-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 0 0 10px;
  padding: 10px 14px;
  border: 1px solid var(--gray-200);
  border-radius: 12px;
  background: var(--bg-1, #fff);
  font-size: 13px;
  color: var(--gray-600);
  transition: border-color 160ms cubic-bezier(0.23, 1, 0.32, 1),
              background 160ms cubic-bezier(0.23, 1, 0.32, 1);
}
.adv-bulk-bar.is-active {
  border-color: var(--accent, #16a34a);
  background: rgba(22, 163, 74, 0.04);
  color: var(--ink);
}
.adv-bulk-bar .adv-bulk-info b {
  color: var(--ink);
  font-weight: 700;
  font-size: 14px;
  margin: 0 2px;
}
.adv-bulk-bar .adv-bulk-hint { color: var(--gray-500); }
.adv-bulk-bar .adv-bulk-actions {
  display: flex;
  gap: 8px;
  flex-shrink: 0;
}

/* ──── Колонка «Ставка» — chip как в WB UI: белая пилюля с accent-баром снизу ───── */
.adv-bid-cell { padding-right: 12px !important; }
.adv-bid-chip {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  min-width: 96px;
  padding: 9px 14px 12px;
  background: #fff;
  border: 1px solid var(--gray-200);
  border-radius: 12px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--ink);
  font-size: 16px;
  letter-spacing: -0.01em;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
  cursor: pointer;
  transition: transform 160ms cubic-bezier(0.23, 1, 0.32, 1),
              box-shadow 160ms cubic-bezier(0.23, 1, 0.32, 1),
              border-color 160ms cubic-bezier(0.23, 1, 0.32, 1);
}
.adv-bid-chip:hover:not(:disabled) {
  border-color: var(--accent-300, #86efac);
  box-shadow: 0 2px 6px rgba(15, 23, 42, 0.07);
}
.adv-bid-chip:active:not(:disabled) { transform: scale(0.97); }
/* button-element variant: убираем дефолтные кнопочные стили */
button.adv-bid-chip {
  font-family: inherit;
  -webkit-tap-highlight-color: transparent;
}
button.adv-bid-chip:disabled {
  cursor: not-allowed;
  opacity: 0.7;
}
/* Fallback (общая ставка) — accent-бар чуть бледнее */
.adv-bid-chip.is-fallback::after {
  background: linear-gradient(90deg, #86efac, #bbf7d0);
}

/* Рекомендуемая ставка из расширения Chrome (preset-bids → top12_bid).
   Цветовая индикация: green = ставка ≥ рекомендуемой, yellow = в зоне между
   min и реком, red = ниже минимума. */
.adv-rec-chip {
  display: inline-block;
  min-width: 80px;
  padding: 4px 10px;
  border-radius: 8px;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  font-size: 13px;
  background: #f1f5f9;
  color: var(--ink, #0f172a);
  border: 1px solid #e2e8f0;
}
.adv-rec-chip.adv-rec-ok  { background: #ecfdf5; color: #065f46; border-color: #a7f3d0; }
.adv-rec-chip.adv-rec-mid { background: #fffbeb; color: #92400e; border-color: #fde68a; }
.adv-rec-chip.adv-rec-low { background: #fef2f2; color: #991b1b; border-color: #fecaca; }

/* Три зоны рекомендаций (Топ 1-2 / 3-10 / 11-34) — компактный столбик
   с цветовой подсветкой попадания и встроенной ↑ кнопкой применить. */
.adv-rec-zones {
  display: flex;
  flex-direction: column;
  gap: 3px;
  font-size: 11px;
  font-variant-numeric: tabular-nums;
}
.adv-rec-zone {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  min-width: 130px;
  padding: 2px 8px;
  border: 1px solid #e2e8f0;
  border-radius: 5px;
  background: #f1f5f9;
  color: var(--ink-2, #475569);
  font-weight: 600;
}
.adv-rec-zone .adv-rec-label {
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  opacity: 0.72;
}
.adv-rec-zone .adv-rec-price { font-weight: 600; }
.adv-rec-zone.adv-rec-empty .adv-rec-price { opacity: 0.5; }
.adv-rec-zone.adv-rec-ok  { background: #ecfdf5; color: #065f46; border-color: #a7f3d0; }
.adv-rec-zone.adv-rec-mid { background: #fffbeb; color: #92400e; border-color: #fde68a; }
.adv-rec-zone.adv-rec-low { background: #fef2f2; color: #991b1b; border-color: #fecaca; }
.adv-rec-zone .adv-rec-apply {
  width: 16px; height: 16px;
  margin-left: 2px;
  font-size: 10px;
  border-width: 1px;
}
.adv-rec-none { color: var(--ink-3, #94a3b8); font-size: 13px; }
/* Кнопка «↑» — применить рекомендуемую ставку в один клик. Маленькая,
   только когда ставка фразы < рекомендуемой. Цвет — мягкий зелёный, чтоб
   не пугать (это всё-таки повышение цены). */
.adv-rec-apply {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px; height: 22px;
  margin-left: 4px;
  padding: 0;
  border: 1px solid #a7f3d0;
  background: #ecfdf5;
  color: #065f46;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  vertical-align: middle;
  transition: background 120ms, transform 120ms;
}
.adv-rec-apply:hover:not(:disabled) { background: #d1fae5; transform: translateY(-1px); }
.adv-rec-apply:active { transform: scale(0.92); }
.adv-rec-apply:disabled { opacity: 0.5; cursor: wait; }

/* ──── Popover редактирования ставки ───── */
.adv-bid-popover {
  position: absolute;
  z-index: 1000;
  min-width: 280px;
  background: #fff;
  border: 1px solid var(--gray-200);
  border-radius: 12px;
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.12);
  padding: 14px;
  font-size: 13px;
  color: var(--ink);
  animation: advBidPopIn 160ms cubic-bezier(0.23, 1, 0.32, 1) both;
}
@keyframes advBidPopIn {
  from { opacity: 0; transform: translateY(-4px) scale(0.97); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
.adv-bid-popover-head {
  margin-bottom: 10px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--gray-100, #f1f5f9);
}
.adv-bid-popover-phrase {
  font-weight: 700;
  font-size: 14px;
  margin-bottom: 4px;
  word-break: break-word;
}
.adv-bid-popover-cur {
  font-size: 12px;
  color: var(--gray-500);
}
.adv-bid-popover-cur b { color: var(--ink); font-weight: 700; }
.adv-bid-popover-row {
  display: flex;
  gap: 8px;
  margin-bottom: 8px;
}
.adv-bid-popover-input {
  flex: 1;
  padding: 8px 10px;
  border: 1px solid var(--gray-200);
  border-radius: 8px;
  font-size: 14px;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  outline: none;
  transition: border-color 160ms cubic-bezier(0.23, 1, 0.32, 1);
}
.adv-bid-popover-input:focus { border-color: var(--accent, #16a34a); }
.adv-bid-popover-save {
  padding: 8px 14px;
  background: var(--accent, #16a34a);
  color: #fff;
  border: none;
  border-radius: 8px;
  font-weight: 600;
  font-size: 13px;
  cursor: pointer;
  transition: background 160ms cubic-bezier(0.23, 1, 0.32, 1), transform 160ms cubic-bezier(0.23, 1, 0.32, 1);
}
.adv-bid-popover-save:hover { background: #15803d; }
.adv-bid-popover-save:active { transform: scale(0.97); }
.adv-bid-popover-save:disabled { opacity: 0.5; cursor: not-allowed; }
.adv-bid-popover-actions {
  display: flex;
  justify-content: space-between;
  gap: 8px;
}
.adv-bid-popover-reset, .adv-bid-popover-cancel {
  padding: 6px 10px;
  background: transparent;
  border: 1px solid var(--gray-200);
  border-radius: 6px;
  font-size: 12px;
  color: var(--gray-600);
  cursor: pointer;
  transition: background 160ms cubic-bezier(0.23, 1, 0.32, 1);
}
.adv-bid-popover-reset:hover { background: var(--gray-100, #f1f5f9); color: #dc2626; border-color: #fca5a5; }
.adv-bid-popover-cancel:hover { background: var(--gray-100, #f1f5f9); }

/* ──── Поисковая строка «Посмотреть выдачу WB» ───── */
.adv-feed-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0 0 10px;
  padding: 10px 14px;
  border: 1px solid var(--gray-200);
  border-radius: 12px;
  background: var(--bg-1, #fff);
}
.adv-feed-bar-label {
  font-size: 13px;
  color: var(--gray-600);
  font-weight: 500;
  white-space: nowrap;
}
.adv-feed-bar-input {
  flex: 1;
  padding: 8px 12px;
  border: 1px solid var(--gray-200);
  border-radius: 8px;
  font-size: 14px;
  font-weight: 500;
  outline: none;
  transition: border-color 160ms cubic-bezier(0.23, 1, 0.32, 1);
}
.adv-feed-bar-input:focus { border-color: var(--accent, #16a34a); }
.adv-feed-bar-btn {
  padding: 8px 18px;
  background: var(--accent, #16a34a);
  color: #fff;
  border: none;
  border-radius: 8px;
  font-weight: 600;
  font-size: 13px;
  cursor: pointer;
  transition: background 160ms cubic-bezier(0.23, 1, 0.32, 1), transform 160ms cubic-bezier(0.23, 1, 0.32, 1);
}
.adv-feed-bar-btn:hover { background: #15803d; }
.adv-feed-bar-btn:active { transform: scale(0.97); }

/* ──── Модалка «Выдача WB» ───── */
.adv-feed-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, 0.5);
  backdrop-filter: blur(4px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1100;
  padding: 24px;
  animation: advFeedFadeIn 200ms cubic-bezier(0.23, 1, 0.32, 1);
}
@keyframes advFeedFadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}
.adv-feed-modal {
  background: var(--bg-1, #fff);
  border-radius: 16px;
  width: 100%;
  max-width: 1200px;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  box-shadow: 0 20px 60px rgba(15, 23, 42, 0.2);
  animation: advFeedScaleIn 220ms cubic-bezier(0.23, 1, 0.32, 1);
}
@keyframes advFeedScaleIn {
  from { transform: scale(0.96) translateY(8px); }
  to { transform: scale(1) translateY(0); }
}
.adv-feed-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid var(--gray-200);
  flex-shrink: 0;
}
.adv-feed-title {
  font-size: 13px;
  color: var(--gray-500);
  font-weight: 500;
  margin-bottom: 2px;
}
.adv-feed-query {
  font-size: 18px;
  font-weight: 700;
  color: var(--ink);
}
.adv-feed-close {
  background: transparent;
  border: none;
  font-size: 26px;
  line-height: 1;
  color: var(--gray-500);
  cursor: pointer;
  padding: 0 6px;
  transition: color 160ms cubic-bezier(0.23, 1, 0.32, 1);
}
.adv-feed-close:hover { color: var(--ink); }
.adv-feed-body {
  overflow-y: auto;
  padding: 16px 20px 20px;
  flex: 1;
}
.adv-feed-loading, .adv-feed-empty, .adv-feed-error {
  padding: 40px 20px;
  text-align: center;
  color: var(--gray-500);
  font-size: 14px;
}
.adv-feed-error { color: #dc2626; }
.adv-feed-summary {
  display: flex;
  gap: 16px;
  margin-bottom: 14px;
  font-size: 13px;
  color: var(--gray-600);
}
.adv-feed-stat b { color: var(--ink); font-weight: 700; font-size: 14px; }
.adv-feed-stat-warn { color: #d97706; }

.adv-feed-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
  gap: 12px;
}
.adv-feed-card {
  position: relative;
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid var(--gray-200);
  border-radius: 10px;
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  transition: transform 160ms cubic-bezier(0.23, 1, 0.32, 1),
              box-shadow 160ms cubic-bezier(0.23, 1, 0.32, 1),
              border-color 160ms cubic-bezier(0.23, 1, 0.32, 1);
}
.adv-feed-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 18px rgba(15, 23, 42, 0.08);
  border-color: var(--gray-300, #cbd5e1);
}
.adv-feed-card.is-ours {
  border-color: var(--accent, #16a34a);
  border-width: 2px;
  background: rgba(22, 163, 74, 0.04);
}
.adv-feed-card.is-ad {
  border-color: #fbbf24;
}
.adv-feed-card.is-ours.is-ad {
  border-color: var(--accent, #16a34a);
  box-shadow: 0 0 0 1px #fbbf24;
}
.adv-feed-pos {
  position: absolute;
  top: 6px;
  left: 6px;
  z-index: 2;
  background: rgba(15, 23, 42, 0.75);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  padding: 3px 7px;
  border-radius: 6px;
  font-variant-numeric: tabular-nums;
}
.adv-feed-photo {
  position: relative;
  aspect-ratio: 3/4;
  background: var(--gray-100, #f1f5f9);
  overflow: hidden;
}
.adv-feed-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.adv-feed-badge {
  position: absolute;
  bottom: 6px;
  font-size: 10px;
  font-weight: 700;
  padding: 3px 7px;
  border-radius: 6px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.adv-feed-badge-ad {
  right: 6px;
  background: #fbbf24;
  color: #78350f;
}
.adv-feed-badge-ours {
  left: 6px;
  background: var(--accent, #16a34a);
  color: #fff;
}
.adv-feed-meta {
  padding: 8px 10px 10px;
  display: flex;
  flex-direction: column;
  gap: 3px;
  font-size: 12px;
}
.adv-feed-brand {
  color: var(--gray-500);
  font-size: 11px;
  text-transform: uppercase;
  font-weight: 600;
  letter-spacing: 0.02em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.adv-feed-name {
  color: var(--ink);
  font-weight: 500;
  font-size: 12px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  line-height: 1.3;
  min-height: 31px;
}
.adv-feed-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 4px;
  gap: 6px;
}
.adv-feed-price {
  font-weight: 700;
  font-size: 14px;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
}
.adv-feed-rating {
  font-size: 11px;
  color: var(--gray-600);
  white-space: nowrap;
}
.adv-feed-reviews { color: var(--gray-400); }
/* Accent-бар снизу: занимает 50% ширины пилюли по умолчанию.
   Цвет — насыщенно-зелёный для персональной ставки. */
.adv-bid-chip::after {
  content: '';
  position: absolute;
  left: 8px;
  right: 50%;
  bottom: 4px;
  height: 4px;
  border-radius: 2px;
  background: linear-gradient(90deg, #16a34a, #22c55e);
}
.adv-bid-none { color: var(--gray-300); font-weight: 500; }

/* ──── Кнопки действий рядом: «Усилить» + «В минус» ───── */
.adv-kw-actions { white-space: nowrap; }
.adv-kw-actions .adv-act-pill { margin-left: 6px; }
.adv-kw-actions .adv-act-pill:first-child { margin-left: 0; }
/* Дефолтная «В минус» — мягкий outline. На wasted-row (или при .strong) — заливная red. */
.adv-act-pill-minus {
  background: transparent;
  color: var(--red);
  border: 1px solid color-mix(in srgb, var(--red) 35%, transparent);
}
@media (hover: hover) {
  .adv-act-pill-minus:hover {
    background: color-mix(in srgb, var(--red) 10%, transparent);
    border-color: var(--red);
  }
}
.adv-act-pill-minus.adv-act-pill-minus-strong,
.adv-row-wasted .adv-act-pill-minus {
  background: var(--red);
  color: #fff;
  border-color: var(--red);
}
@media (hover: hover) {
  .adv-act-pill-minus.adv-act-pill-minus-strong:hover,
  .adv-row-wasted .adv-act-pill-minus:hover {
    background: color-mix(in srgb, var(--red) 88%, #000);
    border-color: color-mix(in srgb, var(--red) 88%, #000);
  }
}

/* ============================================================
   Аналитика конкурентов — подвкладка карточки кампании
   ============================================================ */
.adv-comp { display: flex; flex-direction: column; gap: 14px; }
.adv-comp-chips {
  display: flex; flex-wrap: wrap; gap: 6px;
  padding: 12px 14px;
  background: var(--gray-50);
  border: 1px solid var(--gray-100);
  border-radius: 10px;
}
.adv-comp-chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 10px;
  background: white;
  border: 1px solid var(--gray-200);
  border-radius: 6px;
  font-size: 12.5px; color: var(--gray-700); font-weight: 500;
  cursor: pointer;
  transition: border-color 120ms, color 120ms;
}
@media (hover: hover) {
  .adv-comp-chip:hover { border-color: var(--primary); color: var(--primary); }
}
.adv-comp-chip.active {
  background: var(--primary-light);
  border-color: var(--primary);
  color: var(--primary);
  font-weight: 600;
}
.adv-comp-chip-pos {
  background: var(--gray-100);
  color: var(--gray-700);
  border-radius: 4px;
  padding: 1px 6px;
  font-size: 11px; font-weight: 700;
  font-family: var(--font-mono);
}
.adv-comp-chip.active .adv-comp-chip-pos {
  background: var(--primary); color: white;
}
.adv-comp-chip-pos-none { color: var(--gray-400); }

.adv-comp-head {
  display: flex; align-items: center; gap: 16px;
  padding: 14px 16px;
  background: white;
  border: 1px solid var(--gray-100);
  border-radius: 10px;
}
.adv-comp-head-info { flex: 1; min-width: 0; }
.adv-comp-phrase {
  font-size: 16px; font-weight: 600; color: var(--gray-900);
  margin-bottom: 6px;
}
.adv-comp-meta { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; font-size: 12px; }
.adv-comp-meta-sub { color: var(--gray-500); }
.adv-comp-pos-badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 8px;
  border-radius: 4px;
  font-size: 12px; font-weight: 600;
}
.adv-comp-pos-badge.pos-top  { background: var(--green-light); color: var(--green); }
.adv-comp-pos-badge.pos-mid  { background: var(--gray-100);    color: var(--gray-700); }
.adv-comp-pos-badge.pos-low  { background: var(--warn-bg);     color: var(--warn); }
.adv-comp-pos-badge.pos-far  { background: var(--red-light);   color: var(--red); }
.adv-comp-pos-badge.pos-none { background: var(--gray-100);    color: var(--gray-500); font-style: italic; }

.adv-comp-content { display: flex; flex-direction: column; gap: 14px; }
.adv-comp-table-host { background: white; border-radius: 10px; }
.adv-comp-empty {
  padding: 30px 20px;
  text-align: center;
  color: var(--gray-500);
  font-size: 13px;
  background: white;
  border: 1px dashed var(--gray-200);
  border-radius: 10px;
}

/* ── Шапка «Моя позиция» — 3 карточки в строку ──────────────── */
.adv-comp-summary {
  display: grid;
  grid-template-columns: 1.2fr 1fr 1fr;
  gap: 12px;
  background: white;
  border: 1px solid var(--gray-100);
  border-radius: 10px;
  padding: 14px 16px;
}
.adv-comp-summary-card { display: flex; flex-direction: column; gap: 8px; min-width: 0; }
.adv-comp-summary-card + .adv-comp-summary-card { padding-left: 16px; border-left: 1px solid var(--gray-100); }
.adv-comp-summary-h {
  font-size: 10px;
  letter-spacing: 0.12em;
  color: var(--gray-500);
  text-transform: uppercase;
  font-weight: 600;
}
.adv-comp-summary-q {
  display: flex; align-items: center; gap: 8px;
  background: var(--gray-50);
  border: 1px solid var(--gray-100);
  border-radius: 8px;
  padding: 8px 12px;
  font-size: 14px; font-weight: 600;
  color: var(--gray-900);
}
.adv-comp-summary-q svg { color: var(--gray-500); flex-shrink: 0; }
.adv-comp-summary-meta {
  font-size: 12px; color: var(--gray-500);
  display: flex; align-items: center; gap: 6px; flex-wrap: wrap;
}
.adv-comp-summary-meta .sep { color: var(--gray-400); }

.adv-comp-summary-pos-row { display: flex; align-items: center; gap: 14px; }
.adv-comp-pos-circle {
  width: 56px; height: 56px;
  border-radius: 50%;
  border: 2px solid var(--gray-200);
  background: var(--gray-50);
  color: var(--gray-700);
  display: grid; place-items: center;
  font-family: var(--font-mono);
  font-weight: 700; font-size: 22px;
  flex-shrink: 0;
}
.adv-comp-pos-circle.pos-top  { background: var(--green-light); border-color: var(--green); color: var(--green); }
.adv-comp-pos-circle.pos-mid  { background: var(--gray-100);    border-color: var(--gray-300); color: var(--gray-700); }
.adv-comp-pos-circle.pos-low  { background: var(--warn-bg);     border-color: var(--warn); color: var(--warn); }
.adv-comp-pos-circle.pos-far  { background: var(--red-light);   border-color: var(--red); color: var(--red); }
.adv-comp-pos-circle.pos-none { background: var(--gray-100);    border-color: var(--gray-200); color: var(--gray-400); font-size: 18px; }

.adv-comp-pos-info { min-width: 0; }
.adv-comp-pos-lbl {
  font-size: 11px;
  letter-spacing: 0.05em;
  color: var(--gray-500);
  font-weight: 600;
  text-transform: uppercase;
}
.adv-comp-pos-meta { font-size: 12.5px; color: var(--gray-700); margin-top: 2px; }
.adv-comp-pos-bid { font-size: 12px; color: var(--gray-500); margin-top: 3px; }
.adv-comp-pos-bid b { color: var(--gray-900); font-family: var(--font-mono); }
.adv-comp-pos-bid-mine { color: var(--primary); font-weight: 600; }
.adv-comp-pos-bid-win  { color: var(--green); }
.adv-comp-pos-bid-over { color: var(--red); }
.adv-comp-pos-bid-auto {
  display: inline-block;
  font-size: 10px;
  font-weight: 600;
  line-height: 1;
  padding: 2px 6px;
  margin-left: 4px;
  border-radius: 4px;
  background: var(--primary-light);
  color: var(--primary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  vertical-align: middle;
}
.adv-comp-pos-hint {
  font-size: 11.5px;
  color: var(--green);
  background: var(--green-light);
  padding: 4px 8px;
  border-radius: 4px;
  margin-top: 4px;
  line-height: 1.35;
}
.adv-comp-pos-hint-warn { color: var(--red); background: var(--red-light); }
.adv-comp-pos-best { color: var(--green); font-weight: 700; }

.adv-comp-summary-dyn-row { display: flex; align-items: center; gap: 12px; }
.adv-comp-summary-dyn-stat { font-size: 11px; color: var(--gray-500); }
.adv-comp-summary-dyn-lbl { letter-spacing: 0.04em; }
.adv-comp-summary-dyn-val { font-size: 16px; font-weight: 700; color: var(--gray-900); margin-top: 2px; }

.adv-comp-spark { color: var(--primary); }
.adv-comp-spark.spark-up   { color: var(--green); }
.adv-comp-spark.spark-down { color: var(--red); }
.adv-comp-spark.spark-flat { color: var(--gray-500); }
.adv-comp-spark-empty {
  display: grid; place-items: center;
  font-size: 11px; color: var(--gray-400);
  font-style: italic;
}

.adv-comp-actions-row { display: flex; justify-content: flex-end; padding: 8px 0; }

/* ── SERP двухколоночный layout (sidebar + table) ──────────── */
.adv-comp-serp {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 12px;
  background: white;
  border: 1px solid var(--gray-100);
  border-radius: 10px;
  overflow: hidden;
}
@media (max-width: 1100px) { .adv-comp-serp { grid-template-columns: 1fr; } }

.adv-comp-side {
  background: var(--gray-50);
  border-right: 1px solid var(--gray-100);
  padding: 14px 16px;
}
@media (max-width: 1100px) {
  .adv-comp-side { border-right: 0; border-bottom: 1px solid var(--gray-100); }
}
.adv-comp-side h4 {
  font-size: 10px;
  letter-spacing: 0.12em;
  color: var(--gray-500);
  font-weight: 600;
  text-transform: uppercase;
  margin-bottom: 8px;
  margin-top: 18px;
}
.adv-comp-side h4:first-child { margin-top: 0; }
.adv-comp-side-stat {
  background: white;
  border: 1px solid var(--gray-100);
  border-radius: 8px;
  padding: 8px 10px;
  margin-bottom: 6px;
}
.adv-comp-side-stat-l { font-size: 11px; color: var(--gray-500); }
.adv-comp-side-stat-v { font-size: 16px; font-weight: 700; color: var(--gray-900); margin-top: 2px; }
.adv-comp-side-stat-mine {
  border-color: var(--green);
  background: var(--green-light);
}
.adv-comp-side-stat-mine .adv-comp-side-stat-v { color: var(--green); }

.adv-comp-legend { display: flex; flex-direction: column; gap: 6px; }
.adv-comp-legend-row { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--gray-700); }
.adv-comp-legend-sw { width: 14px; height: 14px; border-radius: 3px; border: 1px solid var(--gray-200); }
.legend-ad   { background: var(--primary-light); }
.legend-mine { background: var(--green); border-color: var(--green); }
.legend-top  { background: var(--green-light); border-color: var(--green); }
.legend-org  { background: var(--gray-50); }

.adv-comp-side-actions { display: flex; flex-direction: column; gap: 6px; }
.adv-comp-side-act {
  width: 100%;
  text-align: left;
  font-size: 12.5px;
  padding: 7px 10px;
}

/* ── SERP main: фильтр-полоска + таблица ────────────────────── */
.adv-comp-serp-main { padding: 0; min-width: 0; }
.adv-comp-filter-row {
  display: flex; align-items: center; gap: 14px;
  padding: 12px 14px;
  border-bottom: 1px solid var(--gray-100);
}
.adv-comp-filter-row h4 {
  font-size: 14px; font-weight: 700; color: var(--gray-900); margin: 0;
  flex: 1; min-width: 0;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.adv-comp-filter-seg {
  display: flex; gap: 2px;
  background: var(--gray-50);
  border: 1px solid var(--gray-100);
  border-radius: 8px;
  padding: 3px;
}
.adv-comp-filter-seg button {
  padding: 5px 12px;
  border: 0; background: transparent;
  font-size: 12px; color: var(--gray-500); font-weight: 500;
  border-radius: 5px;
  cursor: pointer;
}
.adv-comp-filter-seg button.on {
  background: white; color: var(--gray-900); font-weight: 600;
  box-shadow: 0 1px 2px rgba(15,23,42,0.06);
}

/* ── Заголовок над карточками топ-конкурентов ──────────────── */
.adv-comp-cards-head {
  font-size: 14px; font-weight: 700; color: var(--gray-900);
  margin: 18px 0 10px;
}

/* ── Автобиддер: bar в шапке + журнал ──────────────────────── */
.adv-ab-bar {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 14px;
  border-radius: 8px;
  font-size: 13px;
  margin-bottom: 8px;
  border: 1px solid var(--gray-200);
}
.adv-ab-bar-active { background: var(--primary-light); border-color: var(--primary); }
.adv-ab-bar-win    { background: var(--green-light);   border-color: var(--green); }
.adv-ab-bar-warn   { background: var(--warn-bg);       border-color: var(--warn); }
.adv-ab-bar-fail   { background: var(--gray-100);      border-color: var(--gray-200); }

.adv-ab-bar-icon {
  width: 28px; height: 28px;
  border-radius: 50%;
  background: white;
  display: grid; place-items: center;
  font-size: 14px; font-weight: 700;
  flex-shrink: 0;
}
.adv-ab-bar-active .adv-ab-bar-icon { color: var(--primary); }
.adv-ab-bar-win    .adv-ab-bar-icon { color: var(--green); }
.adv-ab-bar-warn   .adv-ab-bar-icon { color: var(--warn); }
.adv-ab-bar-fail   .adv-ab-bar-icon { color: var(--gray-500); }

.adv-ab-bar-info { flex: 1; min-width: 0; }
.adv-ab-bar-title { font-weight: 600; color: var(--gray-900); margin-bottom: 2px; }
.adv-ab-bar-title b { font-family: var(--font-mono); }
.adv-ab-bar-meta {
  font-size: 11.5px; color: var(--gray-600);
  display: flex; align-items: center; gap: 6px; flex-wrap: wrap;
}
.adv-ab-bar-meta .sep { color: var(--gray-400); }
.adv-ab-bar-meta b { color: var(--gray-900); font-family: var(--font-mono); }
.adv-ab-bar-actions {
  display: flex; align-items: center; gap: 4px;
  flex-shrink: 0;
}

.btn-link {
  background: none; border: 0;
  color: var(--primary);
  font-size: 12px; font-weight: 600;
  cursor: pointer;
  padding: 4px 8px;
  text-decoration: underline;
}
.btn-link:hover { color: var(--primary-dark); }

.adv-ab-log {
  margin: 4px 0 12px;
  background: white;
  border: 1px solid var(--gray-100);
  border-radius: 8px;
  overflow: hidden;
}
.adv-ab-log summary {
  padding: 8px 14px;
  cursor: pointer;
  font-size: 12px; color: var(--gray-700);
  user-select: none;
}
.adv-ab-log[open] summary { border-bottom: 1px solid var(--gray-100); }
.adv-ab-log-table {
  width: 100%; border-collapse: collapse; font-size: 12px;
}
.adv-ab-log-table th {
  padding: 6px 10px;
  font-size: 10px;
  letter-spacing: 0.1em;
  color: var(--gray-500);
  text-transform: uppercase;
  font-weight: 600;
  border-bottom: 1px solid var(--gray-100);
  text-align: left;
}
.adv-ab-log-table td {
  padding: 5px 10px;
  border-bottom: 1px solid var(--gray-100);
  vertical-align: top;
  color: var(--gray-700);
}
.adv-ab-log-table tr:last-child td { border-bottom: none; }
.adv-ab-log-note { color: var(--gray-500); font-size: 11.5px; }

.adv-ab-action {
  display: inline-block;
  padding: 1px 6px;
  border-radius: 3px;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  background: var(--gray-100);
  color: var(--gray-700);
}
.adv-ab-action-init   { background: var(--primary-light); color: var(--primary); }
.adv-ab-action-lower  { background: var(--green-light);   color: var(--green); }
.adv-ab-action-raise  { background: var(--warn-bg);       color: var(--warn); }
.adv-ab-action-finish { background: var(--green);         color: white; }
.adv-ab-action-wb_error,
.adv-ab-action-skip   { background: var(--red-light);     color: var(--red); }
.adv-ab-action-monitor_warn       { background: var(--warn-bg);     color: var(--warn); }
.adv-ab-action-monitor_reactivate { background: var(--primary);     color: white; }
.adv-ab-action-hold_ok      { background: var(--green-light); color: var(--green); }
.adv-ab-action-hold_set,
.adv-ab-action-hold_restore { background: var(--primary-light); color: var(--primary); }
.adv-ab-action-reconfigure  { background: var(--gray-100); color: var(--gray-700); }
.adv-ab-action-expand_target,
.adv-ab-action-expand_to_partial {
  background: var(--warn-bg);
  color: var(--warn);
  font-weight: 700;
}

/* Бейдж в шапке job когда цель авто-расширена. */
.adv-ab-expanded-badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 2px 8px;
  margin-left: 6px;
  font-size: 11px; font-weight: 700;
  background: var(--warn-bg);
  color: var(--warn);
  border-radius: 4px;
  letter-spacing: 0.02em;
}

/* ── Side-action кнопки автобиддера (sidebar) ─────────────── */
.adv-comp-side-act-go    { color: var(--primary); border-color: var(--primary-light); background: var(--primary-light); }
.adv-comp-side-act-stop  { color: var(--red);     border-color: var(--red-light);     background: var(--red-light); }

/* ── Toggle Обзор / Детали по фразе ─────────────────────────── */
.adv-comp-mode-row {
  display: flex; align-items: center; gap: 12px;
  margin-bottom: 12px;
}
.adv-comp-poll-hint {
  margin-left: auto;
  font-size: 11.5px;
  color: var(--gray-500);
  font-style: italic;
}
.adv-comp-mode-seg {
  display: flex; gap: 2px;
  background: var(--gray-50);
  border: 1px solid var(--gray-100);
  border-radius: 8px;
  padding: 3px;
}
.adv-comp-mode-seg button {
  padding: 7px 14px;
  border: 0; background: transparent;
  font-size: 13px; color: var(--gray-500); font-weight: 500;
  border-radius: 6px;
  cursor: pointer;
}
.adv-comp-mode-seg button.on {
  background: white; color: var(--gray-900); font-weight: 600;
  box-shadow: 0 1px 2px rgba(15,23,42,0.06);
}

/* ── Overview таблица всех фраз ─────────────────────────────── */
.adv-ovr-toolbar {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 14px;
  background: white;
  border: 1px solid var(--gray-100);
  border-bottom: 0;
  border-radius: 10px 10px 0 0;
  flex-wrap: wrap;
}
.adv-ovr-toolbar-title { font-size: 13px; color: var(--gray-700); }
.adv-ovr-toolbar-title b { color: var(--gray-900); font-family: var(--font-mono); }
.adv-ovr-toolbar-actions {
  margin-left: auto;
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
}

.adv-ovr-table-wrap {
  background: white;
  border: 1px solid var(--gray-100);
  border-radius: 0 0 10px 10px;
  overflow-x: auto;
}
.adv-ovr-table {
  width: 100%; border-collapse: collapse; font-size: 13px;
}
.adv-ovr-table thead th {
  padding: 10px 12px;
  background: var(--gray-50);
  font-size: 10px;
  letter-spacing: 0.12em;
  color: var(--gray-500);
  text-transform: uppercase;
  font-weight: 600;
  border-bottom: 1px solid var(--gray-100);
  text-align: left;
  white-space: nowrap;
}
.adv-ovr-table tbody td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--gray-100);
  vertical-align: middle;
}
.adv-ovr-table tbody tr:last-child td { border-bottom: none; }
.adv-ovr-table tbody tr:hover { background: var(--gray-50); }

.adv-ovr-row-top { background: color-mix(in srgb, var(--green-light) 30%, transparent); }
.adv-ovr-row-top:hover { background: color-mix(in srgb, var(--green-light) 50%, transparent) !important; }

.adv-ovr-col-check { width: 30px; }
.adv-ovr-col-phrase { font-weight: 500; color: var(--gray-900); min-width: 200px; }
.adv-ovr-col-pos { width: 90px; }
.adv-ovr-col-delta { width: 50px; text-align: center; }
.adv-ovr-col-best { width: 80px; text-align: center; font-family: var(--font-mono); color: var(--green); font-weight: 600; }
.adv-ovr-col-bid,
.adv-ovr-col-rec { width: 100px; text-align: right; font-family: var(--font-mono); }
.adv-ovr-col-ab { width: 130px; }
.adv-ovr-col-act { width: 90px; text-align: right; }

.adv-ovr-pos {
  display: inline-grid; place-items: center;
  min-width: 32px; height: 24px;
  padding: 0 8px;
  border-radius: 4px;
  font-family: var(--font-mono);
  font-weight: 700; font-size: 13px;
  background: var(--gray-100); color: var(--gray-700);
}
.adv-ovr-pos.pos-top  { background: var(--green-light); color: var(--green); }
.adv-ovr-pos.pos-mid  { background: var(--gray-100);    color: var(--gray-700); }
.adv-ovr-pos.pos-low  { background: var(--warn-bg);     color: var(--warn); }
.adv-ovr-pos.pos-far  { background: var(--red-light);   color: var(--red); }
.adv-ovr-pos.pos-none { background: var(--gray-100);    color: var(--gray-400); font-style: italic; }
.adv-ovr-total { font-size: 11px; color: var(--gray-400); margin-left: 4px; }

.adv-ovr-delta-up   { color: var(--green); font-weight: 700; font-family: var(--font-mono); }
.adv-ovr-delta-down { color: var(--red);   font-weight: 700; font-family: var(--font-mono); }
.adv-ovr-delta-zero { color: var(--gray-400); }

.adv-ovr-empty { color: var(--gray-400); }
.adv-ovr-ab {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 11.5px;
  font-weight: 600;
}
.adv-ovr-ab-active { background: var(--primary-light); color: var(--primary); }
.adv-ovr-ab-win    { background: var(--green-light);   color: var(--green); }

/* ── Модалка автобиддера (3 стратегии + диапазоны) ─────────── */
body.adv-ab-modal-open { overflow: hidden; }
.adv-ab-modal-backdrop {
  position: fixed; inset: 0;
  background: rgba(15,23,42,0.45);
  display: grid; place-items: center;
  z-index: 1000;
  animation: advAbFadeIn 150ms var(--ease-out);
}
@keyframes advAbFadeIn { from { opacity: 0; } to { opacity: 1; } }
.adv-ab-modal {
  background: white;
  border-radius: 12px;
  width: 100%;
  max-width: 520px;
  max-height: calc(100vh - 40px);
  display: flex; flex-direction: column;
  box-shadow: 0 20px 50px rgba(15,23,42,0.25);
}
.adv-ab-modal-head {
  display: flex; align-items: center;
  padding: 16px 20px;
  border-bottom: 1px solid var(--gray-100);
}
.adv-ab-modal-head h3 { font-size: 16px; font-weight: 700; color: var(--gray-900); flex: 1; }
.adv-ab-modal-close {
  background: none; border: 0;
  font-size: 24px; line-height: 1;
  color: var(--gray-400); cursor: pointer;
  padding: 0 8px;
}
.adv-ab-modal-close:hover { color: var(--gray-700); }

.adv-ab-modal-body {
  padding: 16px 20px;
  overflow-y: auto;
}
.adv-ab-field { margin-bottom: 18px; }
.adv-ab-field-lbl {
  font-size: 11px;
  letter-spacing: 0.1em;
  color: var(--gray-500);
  text-transform: uppercase;
  font-weight: 600;
  margin-bottom: 8px;
}
.adv-ab-field-hint {
  font-size: 11.5px;
  color: var(--gray-500);
  margin-top: 6px;
  line-height: 1.4;
}

.adv-ab-strategies { display: flex; flex-direction: column; gap: 6px; }
.adv-ab-strategy {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 10px 12px;
  border: 1px solid var(--gray-200);
  border-radius: 8px;
  cursor: pointer;
  transition: border-color 120ms, background 120ms;
}
.adv-ab-strategy:hover { border-color: var(--gray-400); }
.adv-ab-strategy-active {
  background: var(--primary-light);
  border-color: var(--primary);
}
.adv-ab-strategy input[type="radio"] { margin-top: 3px; flex-shrink: 0; }
.adv-ab-strategy-info { display: flex; flex-direction: column; gap: 2px; }
.adv-ab-strategy-info b { font-size: 13px; color: var(--gray-900); }
.adv-ab-strategy-info span { font-size: 11.5px; color: var(--gray-600); line-height: 1.35; }

.adv-ab-range {
  display: flex; align-items: center; gap: 10px;
  font-size: 13px; color: var(--gray-600);
}
.adv-ab-range input[type="number"] {
  width: 90px;
  padding: 7px 10px;
  border: 1px solid var(--gray-200);
  border-radius: 6px;
  font-family: var(--font-mono);
  font-weight: 600; font-size: 13px;
  color: var(--gray-900);
}
.adv-ab-range input[type="number"]:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px var(--primary-light);
}

.adv-ab-modal-foot {
  display: flex; gap: 10px; justify-content: flex-end;
  padding: 12px 20px;
  border-top: 1px solid var(--gray-100);
}

/* ─── AI-агент ───────────────────────────────────────────────────────────── */
.ai-page { padding: 0 24px 24px; }
.ai-tabs { border-bottom: 1px solid var(--gray-100); padding-bottom: 0; }
.ai-tab-btn {
  background: transparent; border: 0; border-bottom: 2px solid transparent;
  padding: 8px 14px; font-size: 13px; color: var(--gray-600); cursor: pointer;
  font-weight: 500;
}
.ai-tab-btn:hover { color: var(--gray-900); }
.ai-tab-btn.active { color: var(--primary); border-bottom-color: var(--primary); }

.ai-flag {
  display: inline-block; padding: 2px 8px; border-radius: 10px;
  font-size: 11px; font-weight: 600;
}
.ai-flag-red   { background: var(--red-light, #fee); color: var(--red, #c00); }
.ai-flag-amber { background: #fff3cd; color: #856404; }

/* Модал детального аудита */
.ai-modal-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,0.5);
  display: flex; align-items: center; justify-content: center;
  z-index: 1000; padding: 24px;
}
.ai-modal {
  background: var(--bg, #fff); border-radius: 12px;
  max-width: 1100px; width: 100%; max-height: 90vh;
  display: flex; flex-direction: column;
  box-shadow: 0 20px 50px rgba(0,0,0,0.3);
}
.ai-modal-header {
  display: flex; justify-content: space-between; align-items: center;
  padding: 16px 24px; border-bottom: 1px solid var(--gray-100);
}
.ai-modal-header h3 { margin: 0; font-size: 16px; font-weight: 600; }
.ai-modal-close {
  background: transparent; border: 0; font-size: 28px; cursor: pointer;
  color: var(--gray-500); line-height: 1;
}
.ai-modal-close:hover { color: var(--gray-900); }
.ai-modal-body {
  padding: 20px 24px; overflow-y: auto; flex: 1;
}
.ai-modal-footer {
  padding: 16px 24px; border-top: 1px solid var(--gray-100);
  display: flex; justify-content: flex-end; gap: 10px;
}

.ai-notes {
  background: #f4f9ff; border-left: 3px solid var(--primary);
  padding: 12px 14px; border-radius: 6px; margin-bottom: 16px;
  font-size: 13px; line-height: 1.5;
}
.ai-diff-block { margin-bottom: 20px; }
.ai-diff-block h4 {
  margin: 0 0 8px; font-size: 13px; font-weight: 600; color: var(--gray-700);
}
.ai-diff { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.ai-diff-col {
  background: var(--gray-50, #fafafa); border-radius: 8px; padding: 12px;
  font-size: 13px;
}
.ai-diff-col b { display: block; margin-bottom: 6px; font-size: 11px; color: var(--gray-500); text-transform: uppercase; letter-spacing: 0.5px; }
.ai-diff-text { white-space: pre-wrap; word-break: break-word; line-height: 1.5; }
.ai-diff-new { color: var(--primary); }

.ai-chars { display: flex; flex-direction: column; gap: 6px; }
.ai-char-row {
  display: grid; grid-template-columns: 200px 1fr 1fr; gap: 12px;
  align-items: center; padding: 8px 12px;
  background: var(--gray-50, #fafafa); border-radius: 6px;
  font-size: 12px;
}
.ai-char-name { font-weight: 600; color: var(--gray-700); }
.ai-char-old { color: var(--gray-500); font-family: var(--font-mono, monospace); }
.ai-char-new { font-family: var(--font-mono, monospace); }

.ai-edit-field {
  width: 100%; box-sizing: border-box;
  border: 1px solid var(--primary); border-radius: 8px;
  padding: 10px 12px; font-size: 13px; line-height: 1.5;
  font-family: inherit; color: var(--gray-900);
  background: #fff; resize: vertical;
}
.ai-edit-field:focus { outline: none; box-shadow: 0 0 0 3px var(--primary-light); }
.ai-save-btn { background: var(--gray-100); color: var(--gray-800); }
.ai-save-btn:hover { background: var(--gray-200); }

/* Таблица аудитов: фиксируем ширины, заметку обрезаем в одну строку. */
.ai-audits-table { table-layout: fixed; width: 100%; }
.ai-audits-table th, .ai-audits-table td { overflow: hidden; text-overflow: ellipsis; }
.ai-cell-art  { white-space: nowrap; max-width: 220px; overflow: hidden; text-overflow: ellipsis; }
.ai-cell-note { white-space: nowrap; max-width: 480px; overflow: hidden; text-overflow: ellipsis; color: var(--gray-600); }
.ai-cell-date { white-space: nowrap; width: 130px; color: var(--gray-500); font-size: 12px; }
.ai-cell-err  { white-space: nowrap; width: 70px; }
.ai-audits-table th:last-child, .ai-audits-table td:last-child { width: 100px; text-align: right; }

/* Ключевые фразы в карточке аудита */
.ai-kw-row { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; margin-bottom: 8px; }
.ai-kw-label { font-size: 12px; color: var(--gray-500); margin-right: 4px; }
.ai-kw {
  display: inline-block; padding: 3px 10px; border-radius: 12px;
  font-size: 12px; font-weight: 500;
  cursor: pointer; user-select: none;
  transition: filter 100ms ease-out, box-shadow 100ms ease-out;
}
.ai-kw:hover { filter: brightness(0.96); }
.ai-kw:active { filter: brightness(0.92); }
.ai-kw-active {
  /* Активный чип — выделен рамкой и тенью, ассоциируется с подсветкой в тексте. */
  box-shadow: 0 0 0 2px var(--primary), 0 1px 4px rgba(0,0,0,0.08);
}
.ai-kw-old { background: var(--gray-100); color: var(--gray-600); }
.ai-kw-new { background: #e6f7ed; color: #1a7f43; }
/* SEO-фразы из реальных WB-поисков: акцентный синий — это главный таргет. */
.ai-kw-seo { background: #e0eaff; color: #1d4ed8; font-weight: 600; }

/* Подсветка совпадений ключевой фразы в тексте. Жёлтый «маркер» — стандарт. */
.ai-modal mark.ai-kw-hl {
  background: #fff3a0;
  color: inherit;
  padding: 1px 2px;
  border-radius: 2px;
  box-shadow: 0 0 0 1px #f0c419 inset;
}

/* Цветные бейджи счётчика символов. */
.ai-len-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 10px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.02em;
  font-variant-numeric: tabular-nums;
  background: var(--gray-100);
  color: var(--gray-600);
  vertical-align: middle;
  margin-left: 4px;
}
.ai-len-badge.ai-len-old { background: var(--gray-100); color: var(--gray-600); }
.ai-len-badge.ai-len-ok { background: #e6f7ed; color: #1a7f43; }
.ai-len-badge.ai-len-low { background: #fff4d6; color: #8a6310; }
.ai-len-badge.ai-len-bad { background: #fdecec; color: #c0392b; }
.ai-len-badge.ai-len-over { background: #c0392b; color: white; }

/* Дельта-индикатор: «+150 до цели», «✓ в цели», «−25 перебор». */
.ai-len-delta {
  display: inline-block;
  margin-left: 6px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.02em;
}
.ai-len-delta.ai-len-ok { color: #1a7f43; }
.ai-len-delta.ai-len-low { color: #8a6310; }
.ai-len-delta.ai-len-bad { color: #c0392b; }
.ai-len-delta.ai-len-over { color: #c0392b; }

/* Прогресс-бар длины описания: визуально показывает положение
   относительно цели 1800-2000. Риска на 90% (1800) обозначает старт
   зелёной зоны, край шкалы — 2000 симв. */
.ai-len-bar {
  position: relative;
  height: 6px;
  background: var(--gray-100);
  border-radius: 3px;
  margin: 4px 0 10px 0;
  overflow: visible;
}
.ai-len-bar-fill {
  height: 100%;
  border-radius: 3px;
  background: var(--gray-400);
  transition: width 120ms ease-out, background 120ms ease-out;
}
.ai-len-bar-fill[data-state="ok"]   { background: #1a7f43; }
.ai-len-bar-fill[data-state="low"]  { background: #c47f17; }
.ai-len-bar-fill[data-state="bad"]  { background: #c0392b; }
.ai-len-bar-fill[data-state="over"] { background: #c0392b; }
/* Риска на 90% (1800/2000) — старт зелёной зоны. */
.ai-len-bar-target {
  position: absolute;
  left: 90%;
  top: -2px;
  bottom: -2px;
  width: 2px;
  background: var(--gray-500);
  pointer-events: none;
}

/* Mirror-вид нового описания: read-only превью с подсветкой ключей,
   подменяет textarea при клике на чип или toggle-кнопку. */
.ai-edit-wrap { position: relative; display: flex; flex-direction: column; gap: 6px; }
.ai-edit-mirror {
  min-height: 240px;
  max-height: 400px;
  overflow-y: auto;
  /* Тот же визуал что у диффа: лёгкая граница, паддинг как у textarea. */
}
.ai-mirror-toggle {
  align-self: flex-start;
  padding: 4px 10px;
  border: 1px solid var(--gray-200);
  background: var(--gray-100);
  color: var(--gray-700);
  border-radius: 6px;
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  transition: background 100ms ease-out, border-color 100ms ease-out;
}
.ai-mirror-toggle:hover { background: white; border-color: var(--primary); color: var(--primary); }
.ai-mirror-toggle-active { background: var(--primary-light); border-color: var(--primary); color: var(--primary); }

/* Редактируемые характеристики в аудите */
.ai-char-row { grid-template-columns: 200px 1fr 1fr 28px; }
.ai-charc-input {
  width: 100%; box-sizing: border-box;
  border: 1px solid var(--primary); border-radius: 6px;
  padding: 5px 8px; font-size: 12px; font-family: var(--font-mono, monospace);
  color: var(--gray-900); background: #fff;
}
.ai-charc-input:focus { outline: none; box-shadow: 0 0 0 2px var(--primary-light); }
.ai-charc-remove {
  background: transparent; border: 0; color: var(--gray-400);
  font-size: 18px; cursor: pointer; line-height: 1;
}
.ai-charc-remove:hover { color: var(--red, #c00); }

/* Ревью характеристик: статус-иконка + цвет строки */
.ai-char-row { grid-template-columns: 28px 190px 1fr 1fr 28px; align-items: center; }
.ai-char-status { font-size: 15px; font-weight: 700; text-align: center; }
.ai-st-ok      .ai-char-status { color: #1a7f43; }
.ai-st-fill    .ai-char-status { color: #c47f17; }
.ai-st-improve .ai-char-status { color: #c47f17; }
.ai-st-skip    .ai-char-status { color: var(--gray-300); }
.ai-st-fill, .ai-st-improve { background: #fff9ec; }
.ai-st-ok { background: transparent; }

.ai-kw-missing { background: #fdecec; color: #c0392b; text-decoration: line-through; }
/* Слова есть, но врозь — WB не ранжирует как полную фразу. Жёлтое предупреждение. */
.ai-kw-scattered { background: #fff4d6; color: #8a6310; }
/* Счётчик «N×» в чипе — сколько раз фраза подряд встречается в новом тексте. */
.ai-kw-count {
  display: inline-block;
  margin-left: 4px;
  padding: 1px 5px;
  border-radius: 8px;
  background: rgba(0,0,0,0.08);
  font-size: 10px;
  font-weight: 600;
  vertical-align: middle;
}

/* Переписать описание по пожеланию */
.ai-rewrite-row { display: flex; gap: 8px; margin-top: 10px; }
.ai-rewrite-row .form-input { flex: 1; height: 38px; font-size: 13px; }
.ai-rewrite-btn { white-space: nowrap; background: var(--gray-100); color: var(--gray-800); }
.ai-rewrite-btn:hover { background: var(--primary); color: #fff; }

/* Горящие карточки (трафик есть, CR слабая) — выделяем строку и флаг */
.ai-flag-hot { background: #ffe9d6; color: #c2410c; font-weight: 600; }
.ai-row-hot td { background: #fff7ed; }

/* ─── Контент-ферма (вкладка ai-content) ───────────────────────────────── */
.aic-tab-btn {
  background: transparent; border: 0; border-bottom: 2px solid transparent;
  padding: 8px 14px; font-size: 13px; color: var(--gray-600); cursor: pointer;
  font-weight: 500;
}
.aic-tab-btn:hover { color: var(--gray-900); }
.aic-tab-btn.active { color: var(--primary); border-bottom-color: var(--primary); }

.aic-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 16px;
}
.aic-card {
  background: #fff; border: 1px solid var(--gray-100); border-radius: 10px;
  overflow: hidden; transition: box-shadow .15s, transform .15s;
}
.aic-card:hover { box-shadow: 0 6px 18px rgba(0,0,0,0.08); transform: translateY(-2px); }
.aic-media-wrap {
  aspect-ratio: 3 / 4; background: var(--gray-50, #fafafa);
  display: flex; align-items: center; justify-content: center; overflow: hidden;
  cursor: pointer;
}
.aic-media { width: 100%; height: 100%; object-fit: cover; display: block; }
.aic-card-body { padding: 10px 12px; }
.aic-card-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 6px; }
.aic-type-badge {
  font-size: 11px; padding: 2px 8px; border-radius: 10px; font-weight: 600;
  background: var(--primary-light, #e7f0ff); color: var(--primary);
}
.aic-type-video { background: #ffe9d6; color: #c2410c; }
.aic-type-background { background: #ddf4e7; color: #1a7f43; }
.aic-card-nm { font-size: 11px; color: var(--gray-500); font-family: var(--font-mono, monospace); }
.aic-card-tmpl { font-size: 12px; color: var(--gray-700); margin-bottom: 8px; }
.aic-card-foot { display: flex; justify-content: space-between; align-items: center; gap: 8px; }
.aic-card-meta { font-size: 11px; color: var(--gray-500); }
.aic-card-actions { display: flex; gap: 4px; }
.aic-card-actions .btn { padding: 4px 10px; font-size: 12px; }
.aic-reject-btn { background: var(--gray-100); color: var(--gray-600); }
.aic-reject-btn:hover { background: var(--red-light, #fee); color: var(--red, #c00); }
.aic-card-status { font-size: 11px; color: var(--gray-500); }
.aic-card-err {
  margin-top: 6px; font-size: 11px; color: var(--red, #c00);
  background: var(--red-light, #fee); padding: 4px 6px; border-radius: 4px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

/* Контент-ферма: live-стадии генерации в карточке + стейт «генерируется». */
.aic-media-loading, .aic-media-empty {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 10px; background: var(--gray-50); color: var(--gray-500);
  font-size: 13px; min-height: 200px;
}
.aic-spinner {
  width: 40px; height: 40px;
  border: 3px solid var(--gray-200);
  border-top-color: var(--primary);
  border-radius: 50%;
  animation: aic-spin 800ms linear infinite;
}
@keyframes aic-spin { to { transform: rotate(360deg); } }
.aic-loading-text { font-weight: 600; color: var(--primary); }

.aic-stages {
  margin: 8px 0; display: flex; flex-direction: column; gap: 3px;
  font-size: 11px;
}
.aic-stage {
  display: flex; justify-content: space-between; align-items: center;
  padding: 3px 6px; border-radius: 4px;
  background: var(--gray-50); color: var(--gray-600);
}
.aic-stage-ok   { background: #e6f7ed; color: #1a7f43; }
.aic-stage-done { background: #d4f0db; color: #0f5e2e; font-weight: 600; }
.aic-stage-fail { background: #fdecec; color: #c0392b; font-weight: 600; }
.aic-stage-info { font-size: 10px; opacity: 0.7; margin-left: 8px; font-family: monospace; }

/* Модалка «Сгенерить новую инфографику». */
.aic-modal-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,0.5);
  display: flex; align-items: center; justify-content: center;
  z-index: 1000;
}
.aic-modal {
  background: white; border-radius: 12px; width: 600px; max-width: 92vw;
  max-height: 90vh; overflow: auto; box-shadow: 0 12px 36px rgba(0,0,0,0.18);
}
.aic-modal-header {
  display: flex; justify-content: space-between; align-items: center;
  padding: 16px 20px; border-bottom: 1px solid var(--gray-100);
}
.aic-modal-header h3 { margin: 0; font-size: 16px; font-weight: 700; }
.aic-modal-close {
  background: transparent; border: 0; font-size: 24px; cursor: pointer;
  color: var(--gray-500); line-height: 1; padding: 0 4px;
}
.aic-modal-close:hover { color: var(--gray-900); }
.aic-modal-body { padding: 20px; display: flex; flex-direction: column; gap: 14px; }
.aic-modal-footer {
  display: flex; justify-content: flex-end; gap: 10px;
  padding: 14px 20px; border-top: 1px solid var(--gray-100);
}
.aic-modal-hint { font-size: 12px; color: var(--gray-500); margin-top: 4px; }
.aic-field { display: flex; flex-direction: column; gap: 4px; }
.aic-field > span { font-size: 13px; font-weight: 600; color: var(--gray-700); }
.aic-field-check {
  flex-direction: row; align-items: center; gap: 8px; padding: 8px 0;
}
.aic-field-check span { font-weight: 500; }

/* Drop-zone для собственного фото-референса. */
.aic-photo-drop {
  border: 2px dashed var(--gray-200);
  border-radius: 10px;
  padding: 16px;
  text-align: center;
  background: var(--gray-50);
  transition: border-color 120ms ease-out, background 120ms ease-out;
  position: relative;
}
.aic-photo-drop.drag-over {
  border-color: var(--primary);
  background: var(--primary-light);
}
.aic-photo-drop-empty {
  font-size: 13px;
  color: var(--gray-600);
}
.aic-photo-drop-empty a {
  color: var(--primary);
  font-weight: 600;
  text-decoration: underline;
}
.aic-photo-preview {
  position: relative;
  display: inline-block;
}
.aic-photo-preview img {
  max-width: 100%;
  max-height: 240px;
  border-radius: 8px;
  display: block;
}
.aic-photo-clear {
  position: absolute;
  top: -8px; right: -8px;
  width: 28px; height: 28px;
  border-radius: 50%;
  background: white;
  border: 1.5px solid var(--gray-200);
  color: var(--gray-600);
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
  box-shadow: 0 2px 6px rgba(0,0,0,0.12);
}
.aic-photo-clear:hover { color: var(--red, #c00); border-color: var(--red, #c00); }

/* Row из двух полей в модалке (провайдер + количество вариантов). */
.aic-field-row { display: flex; gap: 12px; }
.aic-field-row .aic-field { gap: 4px; }

/* Бейдж «Вариант N/M» в карточке. */
.aic-variant-badge {
  font-size: 10px;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 8px;
  background: var(--primary-light);
  color: var(--primary);
  letter-spacing: 0.02em;
}
/* Бейдж «🔗 От #N» — карточка является итерацией от другого draft'а. */
.aic-parent-badge {
  font-size: 10px;
  font-weight: 600;
  padding: 2px 7px;
  border-radius: 8px;
  background: #e6f7ed;
  color: #1a7f43;
  font-family: monospace;
}
/* Кнопка «🔄 Следующий шаг» — итерация на основе этого варианта. */
.aic-next-btn {
  background: #fff4d6;
  color: #8a6310;
  border: 1px solid #f0c419;
  font-size: 11px;
  padding: 4px 8px;
}
.aic-next-btn:hover { background: #f0c419; color: white; }
/* Баннер «🔄 Следующий шаг» в модалке генерации. */
.aic-iter-banner {
  padding: 10px 14px;
  background: #fff4d6;
  color: #8a6310;
  border-radius: 8px;
  border-left: 3px solid #f0c419;
  font-size: 13px;
  line-height: 1.5;
}
.aic-iter-banner code {
  background: rgba(0,0,0,0.06);
  padding: 1px 5px;
  border-radius: 4px;
  font-size: 12px;
}

/* Лайтбокс для крупного просмотра результата генерации. */
.aic-lightbox {
  position: fixed; inset: 0; background: rgba(0,0,0,0.88);
  display: flex; align-items: center; justify-content: center;
  z-index: 2000; padding: 20px;
  animation: aic-lightbox-fade 180ms ease-out;
}
@keyframes aic-lightbox-fade {
  from { opacity: 0; } to { opacity: 1; }
}
.aic-lightbox-media {
  max-width: 92vw; max-height: 92vh;
  object-fit: contain;
  border-radius: 8px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.4);
}
.aic-lightbox-close {
  position: absolute; top: 16px; right: 20px;
  width: 40px; height: 40px;
  border-radius: 50%;
  background: rgba(255,255,255,0.12);
  color: white; border: 0;
  font-size: 24px; cursor: pointer; line-height: 1;
  backdrop-filter: blur(8px);
  transition: background 120ms ease-out;
}
.aic-lightbox-close:hover { background: rgba(255,255,255,0.22); }
.aic-lightbox-download {
  position: absolute; bottom: 20px; left: 50%; transform: translateX(-50%);
  background: rgba(255,255,255,0.12); color: white;
  padding: 8px 18px; border-radius: 20px;
  font-size: 13px; font-weight: 600; text-decoration: none;
  backdrop-filter: blur(8px);
  transition: background 120ms ease-out;
}
.aic-lightbox-download:hover { background: rgba(255,255,255,0.22); }

/* Список шаблонов промптов. */
.aic-tpl-list { display: flex; flex-direction: column; gap: 8px; }
.aic-tpl-row {
  display: flex; gap: 12px; align-items: flex-start;
  padding: 12px 14px; border: 1px solid var(--gray-100);
  border-radius: 8px; background: var(--gray-50);
}
.aic-tpl-info { flex: 1; min-width: 0; }
.aic-tpl-name { font-size: 14px; font-weight: 700; color: var(--gray-800); margin-bottom: 4px; }
.aic-tpl-meta { font-size: 11px; color: var(--gray-500); margin-bottom: 6px; text-transform: uppercase; letter-spacing: 0.04em; }
.aic-tpl-preview { font-size: 12px; color: var(--gray-600); line-height: 1.4; word-break: break-word; }
.aic-tpl-delete {
  background: transparent; border: 1px solid var(--gray-200);
  color: var(--gray-500); padding: 6px 10px; border-radius: 6px;
  cursor: pointer; font-size: 14px;
}
.aic-tpl-delete:hover { color: var(--red, #c00); border-color: var(--red, #c00); }

/* ════════════════════════════════════════════════════════════════════════════
   AUTH + ONBOARDING — отдельные standalone-страницы (login, register, onboarding).
   Все классы префиксованы .auth-* / .onb-*. Темы НЕ применяются: на этих
   страницах нет <html data-theme="..."> и нет переключателя; визуал зафиксирован
   под slate-палитру (индиго акцент). Это сознательно: до логина пользователь
   ещё не настраивал тему, и стабильный фирменный экран важнее персонализации.
   ════════════════════════════════════════════════════════════════════════════ */

.auth-body {
  font-family: 'Geist', 'Inter', -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  min-height: 100vh;
  background:
    radial-gradient(1200px 600px at 10% 0%, rgba(99, 102, 241, 0.35), transparent 60%),
    radial-gradient(1000px 700px at 100% 100%, rgba(79, 70, 229, 0.40), transparent 55%),
    linear-gradient(135deg, #4F46E5 0%, #6366F1 50%, #818CF8 100%);
  color: #0F172A;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 32px 20px;
  margin: 0;
  -webkit-font-smoothing: antialiased;
  font-feature-settings: 'cv11', 'ss01';
}

.auth-shell {
  width: 100%;
  max-width: 480px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.auth-brand {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  color: #FFFFFF;
  font-weight: 700;
  font-size: 20px;
  letter-spacing: -0.01em;
  user-select: none;
}
.auth-brand-mark {
  width: 32px;
  height: 32px;
  border-radius: 9px;
  background: #FFFFFF;
  color: #4F46E5;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 17px;
  letter-spacing: -0.02em;
  box-shadow: 0 6px 20px rgba(15, 23, 42, 0.18);
}

.auth-card {
  background: #FFFFFF;
  border-radius: 16px;
  padding: 32px;
  box-shadow:
    0 20px 50px rgba(15, 23, 42, 0.18),
    0 4px 12px rgba(15, 23, 42, 0.08);
}

.auth-title {
  font-size: 24px;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: #0F172A;
  margin: 0 0 6px;
}
.auth-subtitle {
  font-size: 14px;
  color: #64748B;
  margin: 0 0 22px;
  line-height: 1.5;
}

.auth-tabs {
  display: flex;
  gap: 4px;
  padding: 4px;
  background: #F1F5F9;
  border-radius: 10px;
  margin-bottom: 22px;
}
.auth-tab {
  flex: 1;
  text-align: center;
  padding: 9px 12px;
  font-size: 14px;
  font-weight: 600;
  color: #64748B;
  background: transparent;
  border: 0;
  border-radius: 8px;
  cursor: pointer;
  text-decoration: none;
  transition: color 150ms cubic-bezier(0.23, 1, 0.32, 1), background 150ms cubic-bezier(0.23, 1, 0.32, 1);
}
.auth-tab:hover { color: #334155; }
.auth-tab.is-active {
  background: #FFFFFF;
  color: #0F172A;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
}

.auth-field { margin-bottom: 16px; }
.auth-field-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.auth-label {
  display: block;
  font-size: 13px;
  font-weight: 500;
  color: #334155;
  margin-bottom: 6px;
}
.auth-label-hint {
  font-size: 12px;
  color: #94A3B8;
  font-weight: 400;
  margin-left: 6px;
}

.auth-input,
.auth-textarea {
  width: 100%;
  padding: 11px 14px;
  font-size: 15px;
  font-family: inherit;
  color: #0F172A;
  background: #FFFFFF;
  border: 1.5px solid #E2E8F0;
  border-radius: 10px;
  outline: none;
  transition: border-color 120ms cubic-bezier(0.23, 1, 0.32, 1),
              box-shadow 120ms cubic-bezier(0.23, 1, 0.32, 1);
}
.auth-textarea {
  min-height: 88px;
  resize: vertical;
  font-family: 'Geist Mono', ui-monospace, Menlo, monospace;
  font-size: 13px;
  line-height: 1.5;
}
.auth-input::placeholder,
.auth-textarea::placeholder { color: #94A3B8; }
.auth-input:hover,
.auth-textarea:hover { border-color: #CBD5E1; }
.auth-input:focus,
.auth-textarea:focus {
  border-color: #4F46E5;
  box-shadow: 0 0 0 4px rgba(79, 70, 229, 0.12);
}
.auth-input[aria-invalid="true"],
.auth-textarea[aria-invalid="true"] {
  border-color: #B91C1C;
  box-shadow: 0 0 0 4px rgba(185, 28, 28, 0.10);
}

/* Поле с иконкой-кнопкой справа (eye toggle для пароля). */
.auth-input-wrap { position: relative; }
.auth-input-wrap .auth-input { padding-right: 44px; }
.auth-eye {
  position: absolute;
  top: 50%;
  right: 8px;
  transform: translateY(-50%);
  width: 32px;
  height: 32px;
  border: 0;
  border-radius: 8px;
  background: transparent;
  color: #94A3B8;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background 120ms cubic-bezier(0.23, 1, 0.32, 1),
              color 120ms cubic-bezier(0.23, 1, 0.32, 1);
}
.auth-eye:hover { color: #334155; background: #F1F5F9; }
.auth-eye:active { transform: translateY(-50%) scale(0.94); }
.auth-eye svg { width: 18px; height: 18px; }

/* Индикатор силы пароля (4 сегмента). */
.auth-strength {
  margin-top: 8px;
  display: flex;
  gap: 4px;
  align-items: center;
}
.auth-strength-bars {
  display: flex;
  gap: 4px;
  flex: 1;
}
.auth-strength-bar {
  flex: 1;
  height: 4px;
  background: #E2E8F0;
  border-radius: 2px;
  transition: background 150ms cubic-bezier(0.23, 1, 0.32, 1);
}
.auth-strength[data-level="1"] .auth-strength-bar:nth-child(-n+1) { background: #DC2626; }
.auth-strength[data-level="2"] .auth-strength-bar:nth-child(-n+2) { background: #B45309; }
.auth-strength[data-level="3"] .auth-strength-bar:nth-child(-n+3) { background: #4F46E5; }
.auth-strength[data-level="4"] .auth-strength-bar:nth-child(-n+4) { background: #15803D; }
.auth-strength-label {
  font-size: 11px;
  font-weight: 600;
  color: #64748B;
  min-width: 64px;
  text-align: right;
  letter-spacing: 0.02em;
}

/* Чекбоксы — Remember me / Принимаю оферту. */
.auth-check {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 13px;
  color: #334155;
  cursor: pointer;
  user-select: none;
  line-height: 1.45;
}
.auth-check input[type="checkbox"] {
  flex: 0 0 auto;
  margin-top: 2px;
  width: 16px;
  height: 16px;
  accent-color: #4F46E5;
  cursor: pointer;
}
.auth-check a {
  color: #4F46E5;
  text-decoration: none;
}
.auth-check a:hover { text-decoration: underline; }

/* Строка под полями: чекбокс слева, ссылка справа. */
.auth-row-aux {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 22px;
}
.auth-link {
  font-size: 13px;
  font-weight: 500;
  color: #4F46E5;
  text-decoration: none;
  background: none;
  border: 0;
  padding: 0;
  cursor: pointer;
}
.auth-link:hover { text-decoration: underline; }

.auth-btn {
  width: 100%;
  padding: 12px 16px;
  font-size: 15px;
  font-weight: 600;
  font-family: inherit;
  color: #FFFFFF;
  background: #4F46E5;
  border: 0;
  border-radius: 10px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: background 150ms cubic-bezier(0.23, 1, 0.32, 1),
              transform 100ms cubic-bezier(0.23, 1, 0.32, 1),
              box-shadow 150ms cubic-bezier(0.23, 1, 0.32, 1);
}
.auth-btn:hover { background: #4338CA; box-shadow: 0 8px 20px rgba(79, 70, 229, 0.25); }
.auth-btn:active { transform: scale(0.985); }
.auth-btn:disabled {
  opacity: 0.55;
  cursor: not-allowed;
  background: #4F46E5;
  box-shadow: none;
}

.auth-btn-ghost {
  background: #FFFFFF;
  color: #334155;
  border: 1.5px solid #E2E8F0;
}
.auth-btn-ghost:hover { background: #F8FAFC; border-color: #CBD5E1; color: #0F172A; box-shadow: none; }

/* Разделитель «или» с двумя линиями. */
.auth-divider {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 18px 0;
  color: #94A3B8;
  font-size: 12px;
  font-weight: 500;
  text-transform: lowercase;
  letter-spacing: 0.04em;
}
.auth-divider::before,
.auth-divider::after {
  content: "";
  flex: 1;
  height: 1px;
  background: #E2E8F0;
}

.auth-social-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.auth-social {
  padding: 10px 12px;
  font-size: 13px;
  font-weight: 600;
  font-family: inherit;
  color: #64748B;
  background: #FFFFFF;
  border: 1.5px solid #E2E8F0;
  border-radius: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  cursor: not-allowed;
  position: relative;
  opacity: 0.65;
  transition: border-color 120ms cubic-bezier(0.23, 1, 0.32, 1);
}
.auth-social:hover { border-color: #CBD5E1; }
.auth-social .auth-social-icon {
  width: 18px;
  height: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 14px;
  border-radius: 4px;
  color: #FFFFFF;
}
.auth-social .icon-google { background: linear-gradient(135deg, #EA4335 0%, #FBBC05 50%, #4285F4 100%); }
.auth-social .icon-yandex { background: #FC3F1D; }
.auth-tooltip {
  position: absolute;
  bottom: calc(100% + 6px);
  left: 50%;
  transform: translateX(-50%) translateY(4px);
  background: #0F172A;
  color: #FFFFFF;
  font-size: 11px;
  font-weight: 600;
  padding: 5px 10px;
  border-radius: 6px;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity 150ms cubic-bezier(0.23, 1, 0.32, 1),
              transform 150ms cubic-bezier(0.23, 1, 0.32, 1);
}
.auth-social:hover .auth-tooltip {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

/* Плашки сообщений (ошибка / успех / предупреждение / инфо). */
.auth-msg {
  margin-top: 14px;
  padding: 12px 14px;
  border-radius: 10px;
  font-size: 13px;
  line-height: 1.5;
  display: none;
}
.auth-msg.is-show { display: block; }
.auth-msg-error {
  background: #FEE2E2;
  color: #7F1D1D;
  border: 1px solid #FECACA;
}
.auth-msg-warn {
  background: #FEF3C7;
  color: #78350F;
  border: 1px solid #FDE68A;
}

/* Информационная плашка про защиту данных (под формой). */
.auth-safety {
  margin-top: 16px;
  padding: 14px 16px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.10);
  border: 1px solid rgba(255, 255, 255, 0.20);
  color: rgba(255, 255, 255, 0.92);
  font-size: 12px;
  line-height: 1.55;
  display: flex;
  gap: 10px;
  align-items: flex-start;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.auth-safety-icon {
  flex: 0 0 auto;
  width: 18px;
  height: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #C7D2FE;
}
.auth-safety strong { color: #FFFFFF; font-weight: 600; }

.auth-foot {
  text-align: center;
  margin-top: 14px;
  font-size: 13px;
  color: rgba(255, 255, 255, 0.78);
}
.auth-foot a {
  color: #FFFFFF;
  font-weight: 600;
  text-decoration: none;
}
.auth-foot a:hover { text-decoration: underline; }

/* ─── ONBOARDING ─────────────────────────────────────────────────────────── */

.onb-shell {
  width: 100%;
  max-width: 560px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.onb-progress {
  display: flex;
  align-items: center;
  gap: 12px;
  color: rgba(255, 255, 255, 0.85);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.01em;
}
.onb-progress-track {
  flex: 1;
  height: 6px;
  background: rgba(255, 255, 255, 0.18);
  border-radius: 999px;
  overflow: hidden;
}
.onb-progress-fill {
  height: 100%;
  background: #FFFFFF;
  border-radius: 999px;
  transition: width 400ms cubic-bezier(0.23, 1, 0.32, 1);
}
.onb-progress-step { white-space: nowrap; }

.onb-card { padding: 32px; }
.onb-eyebrow {
  font-family: 'Geist Mono', ui-monospace, Menlo, monospace;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: #4F46E5;
  margin: 0 0 8px;
}
.onb-title {
  font-size: 24px;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: #0F172A;
  margin: 0 0 6px;
  line-height: 1.2;
}
.onb-subtitle {
  font-size: 14px;
  color: #64748B;
  margin: 0 0 22px;
  line-height: 1.5;
}

.onb-section { margin-bottom: 16px; }
.onb-section:last-of-type { margin-bottom: 22px; }

.onb-radio-group {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.onb-radio {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 12px 14px;
  border: 1.5px solid #E2E8F0;
  border-radius: 10px;
  cursor: pointer;
  transition: border-color 150ms cubic-bezier(0.23, 1, 0.32, 1),
              background 150ms cubic-bezier(0.23, 1, 0.32, 1);
}
.onb-radio:hover { border-color: #CBD5E1; background: #F8FAFC; }
.onb-radio input[type="radio"] {
  flex: 0 0 auto;
  margin-top: 2px;
  width: 16px;
  height: 16px;
  accent-color: #4F46E5;
  cursor: pointer;
}
.onb-radio-body { display: flex; flex-direction: column; gap: 2px; }
.onb-radio-title {
  font-size: 14px;
  font-weight: 600;
  color: #0F172A;
}
.onb-radio-sub {
  font-size: 12px;
  color: #64748B;
  line-height: 1.45;
}
.onb-radio:has(input[type="radio"]:checked) {
  border-color: #4F46E5;
  background: #EEF2FF;
}

/* Сегментированный контрол (УСН / НДС). */
.onb-seg {
  display: flex;
  background: #F1F5F9;
  border-radius: 10px;
  padding: 4px;
  gap: 4px;
}
.onb-seg label {
  flex: 1;
  text-align: center;
  cursor: pointer;
}
.onb-seg input[type="radio"] {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.onb-seg-btn {
  display: block;
  padding: 9px 8px;
  font-size: 13px;
  font-weight: 600;
  color: #64748B;
  border-radius: 8px;
  transition: color 150ms cubic-bezier(0.23, 1, 0.32, 1),
              background 150ms cubic-bezier(0.23, 1, 0.32, 1),
              box-shadow 150ms cubic-bezier(0.23, 1, 0.32, 1);
}
.onb-seg label:hover .onb-seg-btn { color: #334155; }
.onb-seg input[type="radio"]:checked + .onb-seg-btn {
  background: #FFFFFF;
  color: #0F172A;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.10);
}
.onb-seg input[type="radio"]:focus-visible + .onb-seg-btn {
  outline: 2px solid #4F46E5;
  outline-offset: 2px;
}

/* Аккордеон «Как получить токен». */
.onb-accordion {
  border: 1px dashed #CBD5E1;
  border-radius: 10px;
  background: #F8FAFC;
  margin-top: 8px;
  overflow: hidden;
}
.onb-accordion-head {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 10px 14px;
  font-size: 13px;
  font-weight: 600;
  color: #334155;
  background: transparent;
  border: 0;
  cursor: pointer;
  text-align: left;
  font-family: inherit;
}
.onb-accordion-head:hover { background: #F1F5F9; }
.onb-accordion-chevron {
  transition: transform 200ms cubic-bezier(0.23, 1, 0.32, 1);
  color: #94A3B8;
}
.onb-accordion[data-open="true"] .onb-accordion-chevron { transform: rotate(180deg); }
.onb-accordion-body {
  max-height: 0;
  overflow: hidden;
  transition: max-height 250ms cubic-bezier(0.23, 1, 0.32, 1);
}
.onb-accordion[data-open="true"] .onb-accordion-body { max-height: 320px; }
.onb-accordion-body-inner {
  padding: 4px 14px 14px;
  font-size: 13px;
  color: #475569;
  line-height: 1.6;
}
.onb-accordion-body-inner ol { padding-left: 20px; margin: 0; }
.onb-accordion-body-inner li { margin-bottom: 4px; }

/* Кнопочный ряд (Назад / Пропустить / Завершить). */
.onb-actions {
  display: flex;
  gap: 10px;
  align-items: center;
}
.onb-actions .auth-btn { flex: 1; }
.onb-actions .auth-btn-ghost { flex: 0 0 auto; min-width: 140px; }

.onb-hint {
  font-size: 12px;
  color: #64748B;
  margin-top: 6px;
  line-height: 1.45;
}
.onb-hint code {
  font-family: 'Geist Mono', ui-monospace, Menlo, monospace;
  font-size: 11px;
  background: #F1F5F9;
  padding: 1px 5px;
  border-radius: 4px;
  color: #334155;
}

/* Адаптив. */
@media (max-width: 600px) {
  .auth-body { padding: 16px 12px; align-items: flex-start; }
  .auth-card, .onb-card { padding: 22px 18px; border-radius: 14px; }
  .auth-title, .onb-title { font-size: 21px; }
  .auth-field-row { grid-template-columns: 1fr; }
  .auth-social-row { grid-template-columns: 1fr; }
  .onb-actions { flex-direction: column-reverse; align-items: stretch; }
  .onb-actions .auth-btn-ghost { min-width: 0; }
}

@media (prefers-reduced-motion: reduce) {
  .auth-tab,
  .auth-input, .auth-textarea,
  .auth-btn, .auth-eye,
  .onb-radio, .onb-seg-btn,
  .onb-accordion-chevron, .onb-accordion-body,
  .onb-progress-fill,
  .auth-strength-bar,
  .auth-tooltip {
    transition-duration: 0.01ms !important;
  }
}

