/* Брендовые шрифты ASUTLab (Manrope/Inter/JetBrains Mono) — как в брендбуке DESIGN-SYSTEM.md.
   Подключено здесь, т.к. admin.css линкуют все страницы (админка, кабинет, лендинг, формы). */
@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap');

/* ===== Админка АСУТ Партнёры — раскладка ===== */
* { box-sizing: border-box; }
body { margin: 0; font-family: var(--font-text); color: var(--fg-primary); background: var(--bg-canvas); }
a { text-decoration: none; }
h1, h2, h3, .adm-h1, .adm-section-title, .adm-login-title { font-family: var(--font-display); }

.adm-layout { display: grid; grid-template-columns: var(--sidebar-w) 1fr; min-height: 100vh; }
.adm-sidebar {
  background: var(--bg-inverse); color: var(--fg-inverse);
  display: flex; flex-direction: column; gap: var(--space-6); padding: var(--space-5);
}
.adm-brand { font-family: var(--font-display); font-weight: 700; letter-spacing: var(--tracking-tight); }
.adm-nav { display: flex; flex-direction: column; gap: var(--space-1); }
.adm-nav-item {
  color: var(--fg-inverse-muted); text-decoration: none; padding: var(--space-2) var(--space-3);
  border-radius: var(--r-md);
}
.adm-nav-item:hover { background: var(--bg-inverse-2); color: var(--fg-inverse); }
.adm-logout { margin-top: auto; display: flex; align-items: center; gap: var(--space-3); }
.adm-user { font-size: var(--t-caption); color: var(--fg-inverse-muted); }

.adm-content { padding: var(--space-8); max-width: var(--layout-max); }
.adm-h1 { font-family: var(--font-display); font-size: 30px; margin: 0 0 var(--space-6); }

.tbl { width: 100%; border-collapse: collapse; background: var(--bg-surface); border: var(--bw-1) solid var(--border-default); border-radius: 5px; overflow: hidden; }
.tbl th, .tbl td { text-align: left; padding: var(--space-3) var(--space-4); border-bottom: var(--bw-1) solid var(--border-subtle); font-size: var(--t-body); }
.tbl th { background: var(--bg-sunken); font-size: var(--t-caption); color: var(--fg-secondary); text-transform: uppercase; letter-spacing: var(--tracking-wide); }
.tbl tr:last-child td { border-bottom: none; }
.tbl a { color: var(--fg-accent); text-decoration: none; }

.badge { display: inline-block; padding: 2px var(--space-2); border-radius: var(--r-pill); font-size: var(--t-mono); }
.badge-status { background: var(--bg-sunken); color: var(--fg-secondary); }
.badge.is-ok { background: var(--status-ok-bg); color: var(--status-ok); }
.badge.is-warn { background: var(--status-warn-bg); color: var(--status-warn); }
.badge.is-bad { background: var(--status-bad-bg); color: var(--status-bad); }
.badge.is-info { background: var(--status-info-bg); color: var(--status-info); }

.adm-login { display: grid; place-items: center; min-height: 100vh; }
.adm-login-card { width: 360px; padding: var(--space-8); display: grid; gap: var(--space-4); background: var(--bg-surface); border: var(--bw-1) solid var(--border-default); border-radius: 5px; }
.adm-login-title { font-family: var(--font-display); font-size: var(--t-h2); margin: 0 0 var(--space-2); }
.adm-error { color: var(--status-bad); margin: 0; }

.field { display: grid; gap: var(--space-1); }
.field-label { font-size: var(--t-caption); color: var(--fg-secondary); }
.field-input, .field-select, .field-textarea {
  width: 100%; padding: var(--space-2) var(--space-3); font: inherit;
  border: var(--bw-1) solid var(--border-default); border-radius: var(--r-md); background: var(--bg-surface); color: var(--fg-primary);
}
.field-input:focus-visible, .field-select:focus-visible, .field-textarea:focus-visible {
  outline: var(--bw-2) solid var(--border-accent); outline-offset: 1px;
}

/* Кнопки — по брендовому components.css */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2);
  min-height: 50px; padding: 0 20px; font-family: var(--font-text); font-weight: 500;
  font-size: var(--t-body); line-height: 1; border: var(--bw-1) solid transparent;
  border-radius: 5px; background: transparent; color: inherit; cursor: pointer; white-space: nowrap; }
.btn:focus-visible { outline: none; box-shadow: 0 0 0 2px var(--bg-canvas), 0 0 0 4px var(--c-signal-500); }
.btn:disabled { opacity: .4; cursor: not-allowed; }
.btn-primary { background: var(--c-graphite-800); color: var(--c-paper-100); border-color: var(--c-graphite-800); }
.btn-primary:hover { background: var(--c-graphite-700); border-color: var(--c-graphite-700); }
.btn-accent { background: var(--c-signal-500); color: #fff; border-color: var(--c-signal-500); }
.btn-accent:hover { background: var(--c-signal-600); border-color: var(--c-signal-600); }
.btn-secondary { background: var(--bg-surface); color: var(--fg-primary); border-color: var(--border-default); }
.btn-secondary:hover { background: var(--bg-sunken); border-color: var(--border-strong); }
.btn-ghost { background: transparent; color: var(--fg-primary); border-color: transparent; }
.btn-ghost:hover { background: var(--bg-sunken); }
.btn-danger { background: transparent; color: var(--c-bad-500); border-color: var(--c-bad-500); }
.btn-danger:hover { background: var(--c-bad-500); color: #fff; }

.card { background: var(--bg-surface); border: var(--bw-1) solid var(--border-default); border-radius: 5px; }
.adm-grid { display: grid; grid-template-columns: 2fr 1fr; gap: var(--space-6); align-items: start; }
.adm-section { padding: var(--space-5); }
.adm-section + .adm-section { border-top: var(--bw-1) solid var(--border-subtle); }
.adm-section-title { font-size: var(--t-h3); margin: 0 0 var(--space-3); }
.kv { display: grid; grid-template-columns: 160px 1fr; gap: var(--space-2) var(--space-4); font-size: var(--t-body); }
.kv dt { color: var(--fg-secondary); }
.kv dd { margin: 0; }
.muted { color: var(--c-steel-500); }  /* AA: #5A6376 на белом = 6.2:1 (было #8C93A4 = 3.1:1) */
.stack { display: grid; gap: var(--space-3); }
.comment { padding: var(--space-3); border: var(--bw-1) solid var(--border-subtle); border-radius: var(--r-md); }
.comment.msg-staff { border-left: 3px solid var(--c-signal-500); background: var(--c-signal-50); }
.attach { margin-top: var(--space-2); }
.attach a { color: var(--fg-accent); text-decoration: none; }
.attach-thumb { max-width: 220px; max-height: 160px; border-radius: var(--r-md); border: var(--bw-1) solid var(--border-default); display: block; }
.comment-meta { font-size: var(--t-caption); color: var(--fg-muted); margin-bottom: var(--space-1); }
.audit-row { font-size: var(--t-caption); color: var(--fg-secondary); padding: var(--space-1) 0; border-bottom: var(--bw-1) dashed var(--border-subtle); }
@media (prefers-reduced-motion: no-preference) { .btn { transition: background var(--dur-fast) var(--ease-out); } }
@media (max-width: 720px) {
  .adm-layout { grid-template-columns: 1fr; }
  .adm-sidebar { flex-direction: row; flex-wrap: wrap; align-items: center; gap: var(--space-3); }
  .adm-nav { flex-direction: row; flex-wrap: wrap; }
  .adm-logout { margin-top: 0; }
  .adm-content { padding: var(--space-5); }
  .tbl { display: block; overflow-x: auto; white-space: nowrap; }
  .adm-grid, .kpi-row, .kpi-row-4, .stage-add { grid-template-columns: 1fr; }
}
.stage-inline { display: flex; gap: var(--space-2); align-items: end; }
.stage-inline .field-input { width: 120px; }
.stage-add { display: grid; grid-template-columns: 2fr 1fr; gap: var(--space-3); }
.stage-add-row { display: grid; grid-template-columns: 2fr 1fr auto; gap: var(--space-3); align-items: end; }
@media (max-width: 720px) { .stage-add-row { grid-template-columns: 1fr; } }
.payout-actions { display: flex; gap: var(--space-2); align-items: end; flex-wrap: wrap; }
.payout-actions form { display: flex; gap: var(--space-2); align-items: end; }
.payout-comment { width: 140px; }
.login-links { display: flex; justify-content: space-between; font-size: var(--t-caption); }
.login-links a { color: var(--fg-accent); text-decoration: none; }
.field-check { display: flex; gap: var(--space-2); align-items: start; font-size: var(--t-body); }
.field-check a { color: var(--fg-accent); }
.filter-bar { display: flex; gap: var(--space-2); margin-bottom: var(--space-4); flex-wrap: wrap; }
.chip { padding: var(--space-1) var(--space-3); border-radius: var(--r-pill); border: var(--bw-1) solid var(--border-default); color: var(--fg-secondary); text-decoration: none; font-size: var(--t-caption); }
.chip-on { background: var(--bg-inverse); color: var(--fg-inverse); border-color: var(--bg-inverse); }
.kpi-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-4); margin-bottom: var(--space-6); }
.kpi-card { background: var(--bg-surface); border: var(--bw-1) solid var(--border-default); border-radius: 5px; padding: var(--space-5); }
.kpi-label { font-size: var(--t-caption); color: var(--fg-secondary); text-transform: uppercase; letter-spacing: var(--tracking-wide); }
.kpi-num { font-family: var(--font-mono, monospace); font-size: var(--t-num-lg, 28px); margin-top: var(--space-2); }
.row-muted td { opacity: 0.55; }
.tbl code { font-family: var(--font-mono, monospace); font-size: var(--t-caption); }
.nav-badge { display: inline-block; min-width: 18px; padding: 0 6px; border-radius: var(--r-pill); background: var(--fg-accent); color: var(--c-white); font-size: var(--t-mono); text-align: center; }
.note-unread { border-left: 3px solid var(--fg-accent); }
.adm-main { display: flex; flex-direction: column; min-width: 0; }
.adm-topbar { display: flex; justify-content: flex-end; align-items: center; height: 56px; padding: 0 var(--space-8); border-bottom: var(--bw-1) solid var(--border-subtle); background: var(--bg-surface); }
.bell { position: relative; display: inline-flex; align-items: center; justify-content: center; min-width: 44px; min-height: 44px; color: var(--fg-secondary); text-decoration: none; padding: var(--space-2); border-radius: var(--r-md); }
.bell:hover { color: var(--fg-primary); background: var(--bg-sunken); }
.bell-on { color: var(--fg-accent); }
.bell-badge { position: absolute; top: 4px; right: 4px; min-width: 16px; height: 16px; padding: 0 4px; border-radius: var(--r-pill); background: var(--c-signal-700); color: var(--c-white); font-size: 11px; line-height: 16px; text-align: center; }
.report-filter { display: flex; gap: var(--space-3); align-items: end; margin-bottom: var(--space-6); flex-wrap: wrap; }
.kpi-row-4 { grid-template-columns: repeat(4, 1fr); }
.report-partner td { border-top: var(--bw-2) solid var(--border-default); font-weight: 500; }
.report-link td { color: var(--fg-secondary); font-size: var(--t-caption); }
.report-link-name { padding-left: var(--space-5) !important; }
.lead-grid-top, .lead-grid-bottom { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-6); align-items: start; margin-bottom: var(--space-6); }
@media (max-width: 900px) { .lead-grid-top, .lead-grid-bottom { grid-template-columns: 1fr; } }
.stats-head { display: flex; justify-content: space-between; align-items: center; gap: var(--space-4); flex-wrap: wrap; }
.stats-head .filter-bar { margin-bottom: 0; }
.spark { display: flex; align-items: flex-end; gap: 1px; height: 36px; min-width: 160px; }
.spark-bar { flex: 1 1 auto; min-width: 1px; background: var(--c-signal-500); border-radius: 1px; }
.spark-bar[style*="height: 0%"] { background: var(--border-default); min-height: 1px; }

/* ===== Hover-анимации ===== */
.tbl tbody tr { transition: background var(--dur-fast, .12s) var(--ease-out, ease); }
.tbl tbody tr:hover { background: var(--bg-sunken); }
.chip { transition: background .12s ease, border-color .12s ease, color .12s ease; }
.chip:hover { border-color: var(--border-strong); color: var(--fg-primary); }
.copy-btn, .cab-bell, .cab-nav-item, .adm-nav-item { transition: background .12s ease, color .12s ease, border-color .12s ease; }
@media (prefers-reduced-motion: no-preference) {
  .card { transition: border-color .15s var(--ease-out, ease), box-shadow .15s var(--ease-out, ease); }
  .card:hover { border-color: var(--border-strong); }
  .kpi-card { transition: transform .15s var(--ease-out, ease), border-color .15s var(--ease-out, ease); }
  .kpi-card:hover { transform: translateY(-2px); border-color: var(--c-signal-400); }
  .badge { transition: transform .12s var(--ease-out, ease); }
  .badge:hover { transform: translateY(-1px); }
}
.spark-bar { transition: background .12s ease; }
.spark-bar:hover { background: var(--c-signal-700); }

/* ===== Брендовые окна входа / регистрации ===== */
.adm-login { background-color: var(--bg-canvas);
  background-image: radial-gradient(120% 80% at 50% -10%, var(--c-signal-50) 0%, transparent 55%);
  padding: var(--space-6); }
.adm-login-card { width: 400px; max-width: 100%; padding: var(--space-8);
  border-radius: 12px; box-shadow: 0 10px 34px rgba(27, 34, 48, .10); }
.auth-brand { display: inline-flex; align-items: center; gap: var(--space-2); justify-self: start;
  text-decoration: none; font-family: var(--font-display); font-weight: 700;
  color: var(--fg-primary); letter-spacing: var(--tracking-tight); }
.auth-mark { height: 22px; width: auto; display: block; }
.auth-sub { color: var(--c-steel-500); margin: calc(-1 * var(--space-2)) 0 var(--space-1); }

/* Регистрация — поля в 2 колонки, карточка шире */
.auth-wide { width: 640px; grid-template-columns: 1fr 1fr; column-gap: var(--space-4); align-items: start; }
.auth-wide > .auth-brand, .auth-wide > .adm-login-title, .auth-wide > .auth-sub,
.auth-wide > .adm-error, .auth-wide > .field-check, .auth-wide > .btn,
.auth-wide > .login-links, .auth-wide > .auth-full { grid-column: 1 / -1; }
@media (max-width: 560px) { .auth-wide { grid-template-columns: 1fr; } }
