/* === fonts =================================================== */
@font-face {
  font-family: 'Craftwork Grotesk';
  src: url('/static/fonts/CraftworkGrotesk-Regular.ttf') format('truetype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Craftwork Grotesk';
  src: url('/static/fonts/CraftworkGrotesk-Medium.ttf') format('truetype');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Craftwork Grotesk';
  src: url('/static/fonts/CraftworkGrotesk-SemiBold.ttf') format('truetype');
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Manrope';
  src: url('/static/fonts/Manrope-Regular.ttf') format('truetype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

/* === tokens ================================================== */
:root {
  --academy-cream: #F7F9FA;
  --academy-ink: #1C1C1C;
  --academy-black: #000000;
  --academy-red: #E83838;
  --academy-white: #FFFFFF;
  --academy-card-dark: #242424;
  --academy-divider-dark: #333333;
  --academy-gray-soft: #B6BDC0;
  --academy-gray: #6F6F6F;
  --academy-gray-mute: #585C5D;

  --radius-card: 2px;
  --radius-pill: 30px;
}

/* === reset & base ============================================ */
*, *::before, *::after { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0;
  font-family: 'Craftwork Grotesk', system-ui, -apple-system, sans-serif;
  font-size: 14px;
  color: var(--academy-ink);
  background: var(--academy-cream);
  -webkit-font-smoothing: antialiased;
}
button { font: inherit; cursor: pointer; }
a { color: inherit; text-decoration: none; }
input, button { font-family: inherit; }

/* === app shell — full viewport, sidebar fixed, main scrolls === */
.app {
  display: block;
  height: 100vh;
}

/* === sidebar ================================================= */
.sidebar {
  position: fixed;
  left: 0;
  top: 0;
  bottom: 0;
  width: 95px;
  z-index: 10;
  background: var(--academy-ink);
  color: var(--academy-gray-soft);
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 22px 0;
  gap: 18px;
}
.brand {
  width: 44px; height: 44px;
  display: flex; align-items: center; justify-content: center;
  background: transparent;
  color: var(--academy-ink);
  border-radius: var(--radius-pill);
}
.brand svg { width: 22px; height: 22px; }
.brand-logo { width: 40px; height: 24px; object-fit: contain; }
.sidebar nav {
  display: flex; flex-direction: column; gap: 6px;
  margin-top: 12px;
  flex: 1;
}
.nav-item {
  width: 44px; height: 44px;
  display: flex; align-items: center; justify-content: center;
  border-radius: var(--radius-pill);
  color: var(--academy-gray);
  text-transform: lowercase;
  transition: color .15s ease, background .15s ease;
}
.nav-item:hover { color: var(--academy-white); background: var(--academy-card-dark); }
.nav-item.is-active { color: var(--academy-white); background: var(--academy-card-dark); }
.nav-item svg { width: 22px; height: 22px; }
.logout { margin-top: auto; }

/* === main column ============================================ */
.main {
  margin-left: 95px;
  padding: 28px 32px 24px;
  height: 100vh;
  overflow-y: auto;
  min-height: 0;
}

/* === page header ============================================ */
.page-header {
  display: flex;
  justify-content: space-between;
  align-items: end;
  gap: 24px;
}
.eyebrow {
  margin: 0 0 4px;
  font-size: 12px;
  font-weight: 500;
  color: var(--academy-gray);
  letter-spacing: .04em;
  text-transform: lowercase;
}
.page-header h1 {
  margin: 0;
  font-size: 28px;
  font-weight: 600;
  letter-spacing: -.01em;
  display: flex; align-items: center; gap: 10px;
}
.count-pill {
  display: inline-flex; align-items: center;
  padding: 2px 10px;
  font-size: 13px;
  font-weight: 500;
  background: var(--academy-white);
  color: var(--academy-gray-mute);
  border-radius: var(--radius-pill);
}
.user-chip {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 6px 14px 6px 6px;
  background: var(--academy-white);
  border-radius: var(--radius-pill);
  font-weight: 500;
}
.user-chip-avatar {
  width: 32px; height: 32px;
  border-radius: var(--radius-pill);
  background: var(--academy-gray-soft);
  color: var(--academy-ink);
  display: inline-flex; align-items: center; justify-content: center;
  font-weight: 600;
}

/* === metrics ================================================ */
.metrics {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
.metric {
  background: var(--academy-white);
  border-radius: var(--radius-card);
  padding: 20px 22px;
  position: relative;
  overflow: hidden;
}
.metric::after {
  content: "";
  position: absolute; right: -20px; top: -20px;
  width: 90px; height: 90px;
  border-radius: 999px;
  opacity: .35;
}
.metric-mint::after     { background: #c9e6d4; }
.metric-lavender::after { background: #ddd2f2; }
.metric-peach::after    { background: #f6dec5; }
.metric-sky::after      { background: #c8d9f3; }
.metric-label {
  margin: 0 0 8px;
  color: var(--academy-gray);
  font-size: 13px;
  font-weight: 500;
  text-transform: lowercase;
}
.metric-value {
  margin: 0;
  font-size: 28px;
  font-weight: 600;
  letter-spacing: -.01em;
}

/* === card =================================================== */
.card {
  background: var(--academy-white);
  border-radius: var(--radius-card);
  padding: 22px 24px 20px;
  display: flex;
  flex-direction: column;
  min-height: 0;
}
.card-header {
  display: flex; justify-content: space-between; align-items: end;
  margin-bottom: 12px;
}
.card-header h2 {
  margin: 0;
  font-size: 18px;
  font-weight: 600;
}
.card-sub {
  margin: 4px 0 0;
  color: var(--academy-gray);
  font-size: 13px;
}

/* === table ================================================== */
.table-wrap {
  flex: 1;
  min-height: 0;
  overflow: auto;
  border-radius: var(--radius-card);
}
.table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
}
.table thead th {
  position: sticky; top: 0;
  background: var(--academy-white);
  text-align: left;
  font-weight: 500;
  font-size: 12px;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--academy-gray);
  padding: 10px 12px;
  border-bottom: 1px solid #ececec;
  white-space: nowrap;
}
.table tbody td {
  padding: 12px;
  border-bottom: 1px solid #f3f1ec;
  vertical-align: middle;
  text-transform: none;
}
.table tbody tr:last-child td { border-bottom: none; }
.table .num { text-align: right; white-space: nowrap; }
.table th.num { text-align: right; }
.table .empty {
  text-align: center;
  color: var(--academy-gray-soft);
  padding: 36px 0;
}
.muted { color: var(--academy-gray); }

.cell-when { white-space: nowrap; }
.when-date { display: inline-block; font-weight: 500; margin-right: 8px; }
.when-time { display: inline-block; color: var(--academy-gray); }

/* === tag, status =========================================== */
.tag {
  display: inline-block;
  padding: 3px 10px;
  border-radius: var(--radius-pill);
  font-size: 12px;
  font-weight: 500;
  background: var(--academy-cream);
  color: var(--academy-gray-mute);
}
.status {
  display: inline-block;
  padding: 3px 10px;
  border-radius: var(--radius-pill);
  font-size: 12px;
  font-weight: 500;
}
.status-pending    { background: #fff3d9; color: #8a6a16; }
.status-confirmed  { background: #d9ecdb; color: #2f6a3e; }
.status-completed  { background: #e7e1f4; color: #534785; }
.status-cancelled  { background: #f4dada; color: #843a3a; }

.status-pay-unpaid   { background: #f4ece1; color: #826438; }
.status-pay-paid     { background: #d9ecdb; color: #2f6a3e; }
.status-pay-refunded { background: #e1e3eb; color: #545862; }

/* === header controls (filter tabs + search side-by-side) === */
.header-controls {
  display: flex; align-items: center; gap: 14px;
}

/* === filter tabs =========================================== */
.filter-tabs { display: flex; gap: 6px; flex-wrap: wrap; }
.filter-tab {
  padding: 6px 14px;
  border-radius: var(--radius-pill);
  font-size: 13px;
  font-weight: 500;
  color: var(--academy-gray-mute);
  background: var(--academy-white);
  text-transform: lowercase;
}
.filter-tab.is-active { background: var(--academy-ink); color: var(--academy-cream); }

/* === search =============================================== */
.search-wrap {
  position: relative;
  display: inline-flex; align-items: center;
  width: 360px;
}
.search-wrap svg {
  position: absolute; left: 14px;
  width: 18px; height: 18px;
  color: var(--academy-gray-soft);
}
.search-input {
  width: 100%;
  background: var(--academy-white);
  border: 1px solid transparent;
  border-radius: var(--radius-card);
  padding: 10px 14px 10px 40px;
  font-size: 14px;
  outline: none;
  transition: border-color .15s ease;
}
.search-input:focus { border-color: var(--academy-ink); }
.search-clear {
  position: absolute; right: 12px;
  font-size: 12px; color: var(--academy-gray);
}
.search-clear:hover { color: var(--academy-ink); }

/* === inline-edit ========================================== */
.table-edit td.ed {
  cursor: text;
  position: relative;
}
.table-edit td.ed:hover {
  background: var(--academy-cream);
}
.table-edit td.ed.empty-cell::before {
  content: "—";
  color: var(--academy-gray-soft);
}
.table-edit td.ed.is-editing {
  padding: 4px;
  background: var(--academy-white);
}
.table-edit td.ed input {
  width: 100%;
  padding: 8px 10px;
  border: 1px solid var(--academy-ink);
  border-radius: var(--radius-card);
  outline: none;
  font: inherit;
  background: var(--academy-white);
}
.table-edit tr.row-editing td.readonly {
  background: var(--academy-cream);
}
.actions-col { width: 96px; text-align: right; white-space: nowrap; }
.icon-btn {
  width: 32px; height: 32px;
  border: none; background: transparent;
  border-radius: var(--radius-card);
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--academy-gray);
  transition: background .15s ease, color .15s ease;
}
.icon-btn:hover { background: var(--academy-cream); color: var(--academy-ink); }
.icon-btn svg { width: 18px; height: 18px; }
.save-btn { color: #2f6a3e; }
.save-btn:hover { background: #d9ecdb; }
.danger-btn { color: #843a3a; }
.danger-btn:hover { background: #f4dada; color: #5d2828; }
.icon-btn:disabled { opacity: .45; cursor: not-allowed; }

/* === audit changes column ================================ */
.audit-changes {
  font-family: 'SF Mono', Menlo, Consolas, monospace;
  font-size: 12px;
  color: var(--academy-gray-mute);
  max-width: 480px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* === toast =============================================== */
.toast {
  position: fixed;
  bottom: 24px; left: 50%;
  transform: translateX(-50%);
  background: var(--academy-ink);
  color: var(--academy-white);
  padding: 10px 18px;
  border-radius: var(--radius-pill);
  font-size: 13px;
  font-weight: 500;
  z-index: 100;
  box-shadow: 0 6px 18px rgba(0,0,0,.15);
}
.toast.is-error { background: var(--academy-red); }

/* === buttons (academy) =================================== */
.btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  height: 40px;
  padding: 0 20px;
  min-width: 170px;
  font-family: inherit;
  font-size: 13px;
  font-weight: 500;
  line-height: 16px;
  text-transform: lowercase;
  border: 1px solid transparent;
  border-radius: var(--radius-card);
  background: transparent;
  cursor: pointer;
  transition: border-color .3s ease-out, color .3s ease-out, background .3s ease-out;
}
.btn .btn-arrow {
  width: 24px;
  height: 8px;
  flex-shrink: 0;
  transition: transform .3s ease-out;
}
.btn:hover .btn-arrow { transform: translateX(4px); }

.btn-outline-dark {
  border-color: var(--academy-ink);
  color: var(--academy-ink);
}
.btn-outline-dark:hover {
  border-color: var(--academy-red);
  color: var(--academy-red);
}

.btn-outline-red {
  border-color: var(--academy-red);
  color: var(--academy-red);
}
.btn-outline-red:hover {
  background: var(--academy-red);
  color: var(--academy-cream);
}

.btn-primary {
  border-color: var(--academy-red);
  background: var(--academy-red);
  color: var(--academy-cream);
}
.btn-primary:hover {
  background: transparent;
  color: var(--academy-red);
}

/* ghost — нейтральная кнопка для иконок без стрелки */
.btn-ghost {
  background: var(--academy-white);
  color: var(--academy-ink);
  display: inline-flex; align-items: center; gap: 8px;
  min-width: 0;
  justify-content: center;
  border: 1px solid transparent;
}
.btn-ghost:hover { background: var(--academy-cream); }
.btn-ghost svg { width: 18px; height: 18px; }

/* === LOGIN PAGE (academy) ================================ */
.login-academy {
  margin: 0;
  min-height: 100vh;
  background: var(--academy-ink);
  color: var(--academy-cream);
  font-family: 'Craftwork Grotesk', system-ui, sans-serif;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px 16px;
}
.login-academy-main {
  width: 100%;
  display: flex;
  justify-content: center;
}
.login-academy-stack {
  width: 100%;
  max-width: 360px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 48px;
}
.login-academy-brand {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}
.login-academy-logo {
  width: 80px;
  height: 48px;
  object-fit: contain;
}
.login-academy-subtitle {
  font-size: 14px;
  letter-spacing: 0.05em;
  text-transform: lowercase;
  color: var(--academy-cream);
}
.login-academy-form {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 28px;
}
.login-academy-field {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.login-academy-label {
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--academy-gray-soft);
}
.input-dark {
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--academy-gray-mute);
  border-radius: 0;
  padding: 10px 0;
  color: var(--academy-cream);
  font: 500 14px/1.4 'Craftwork Grotesk', system-ui, sans-serif;
  outline: none;
  transition: border-color .25s ease;
}
.input-dark::placeholder { color: var(--academy-gray); }
.input-dark:focus { border-bottom-color: var(--academy-cream); }
.login-academy-error {
  margin: 0;
  font-size: 13px;
  color: var(--academy-red);
}
.login-academy-submit {
  width: 100%;
  justify-content: center;
  min-width: 0;
  margin-top: 12px;
}

/* === forms (admin pages) ================================ */
.field { display: flex; flex-direction: column; gap: 6px; }
.field-label {
  font-size: 13px;
  font-weight: 500;
  color: var(--academy-gray-mute);
}
.input {
  background: var(--academy-cream);
  border: 1px solid transparent;
  border-radius: var(--radius-card);
  padding: 12px 14px;
  font-size: 14px;
  outline: none;
  transition: border-color .15s ease, background .15s ease;
}
.input:focus { background: var(--academy-white); border-color: var(--academy-ink); }

/* === academy-style underline inputs (форма редактирования клиента) === */
.input-academy {
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--academy-ink);
  border-radius: 0;
  padding: 10px 0;
  font: 500 14px/1.4 'Craftwork Grotesk', system-ui, sans-serif;
  color: var(--academy-ink);
  outline: none;
  transition: border-color .25s ease;
  width: 100%;
}
.input-academy::placeholder { color: var(--academy-gray); }
.input-academy:focus { border-bottom-color: var(--academy-red); }
select.input-academy {
  appearance: none;
  -webkit-appearance: none;
  background-image: none;
}
.edit-form .field { position: relative; }
.edit-form .field-label {
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--academy-gray);
}
.edit-form .field:has(select.input-academy)::after {
  content: "";
  position: absolute;
  right: 0;
  bottom: 18px;
  width: 8px;
  height: 8px;
  border-right: 1px solid var(--academy-ink);
  border-bottom: 1px solid var(--academy-ink);
  transform: rotate(45deg);
  pointer-events: none;
}

.alert {
  border-radius: var(--radius-card);
  padding: 10px 14px;
  font-size: 13px;
  margin-bottom: 4px;
}
.alert-error { background: #f4dada; color: #843a3a; }

/* responsive */
@media (max-width: 880px) {
  .sidebar { width: 64px; }
  .main { margin-left: 64px; padding: 20px; }
  .metrics { grid-template-columns: repeat(2, 1fr); }
}

/* === customers-api admin: client card, edit =================== */

.back-link { color: var(--academy-gray); }
.back-link:hover { color: var(--academy-ink); }
.card-tags { display: flex; gap: 8px; margin-top: 8px; }

/* — шапка карточки клиента — */
.page-header h1.client-card-title {
  font: 400 22px/1 'Manrope', system-ui, sans-serif;
  letter-spacing: -0.02em;
  text-transform: lowercase;
  color: var(--academy-ink);
  margin: 0;
}
.page-header .back-link {
  font-family: 'Manrope', system-ui, sans-serif;
  font-size: 12px;
  letter-spacing: 0.05em;
  text-transform: lowercase;
  color: var(--academy-gray);
}
.page-header .card-tags .tag {
  font-family: 'Manrope', system-ui, sans-serif;
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.page-header .btn-primary {
  font-family: 'Manrope', system-ui, sans-serif;
}

/* — сетка карточек — */
.client-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}
.client-grid .card {
  padding: 20px 22px 18px;
  border-radius: 3px;
  background: var(--academy-white);
  overflow: hidden;
  min-height: 0;
}

/* — заголовки секций — */
.client-grid .card .card-header {
  margin-bottom: 14px;
}
.client-grid .card .card-header h2 {
  font: 500 13px/1 'Manrope', system-ui, sans-serif;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--academy-gray);
  margin: 0;
}
.client-grid .card .card-header .card-sub {
  font: 400 12px/1.4 'Manrope', system-ui, sans-serif;
  color: var(--academy-gray);
  margin-top: 4px;
}

/* — контакты (.kv сетка) — */
.client-grid .card .kv {
  display: grid;
  grid-template-columns: 130px minmax(0, 1fr);
  gap: 10px 16px;
  margin: 0;
  font-family: 'Manrope', system-ui, sans-serif;
}
.client-grid .card .kv dt {
  font: 500 11px/1.4 'Manrope', system-ui, sans-serif;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--academy-gray);
  align-self: center;
}
.client-grid .card .kv dd {
  font: 400 14px/1.45 'Manrope', system-ui, sans-serif;
  color: var(--academy-ink);
  margin: 0;
  overflow-wrap: anywhere;
  word-break: break-word;
}

/* — кнопка «показать чувствительные данные» — */
.client-grid .card .btn-outline-red {
  font-family: 'Manrope', system-ui, sans-serif;
}

/* — списки (.list-bare) — */
.client-grid .card .list-bare {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.client-grid .card .list-bare li {
  font: 400 14px/1.45 'Manrope', system-ui, sans-serif;
  color: var(--academy-ink);
  display: flex;
  align-items: center;
  gap: 8px;
  overflow-wrap: anywhere;
}
.client-grid .card .list-bare .muted {
  color: var(--academy-gray);
  font-size: 13px;
}
.client-grid .card .list-bare .tag {
  font: 500 11px/1 'Manrope', system-ui, sans-serif;
  letter-spacing: 0.05em;
  padding: 4px 10px;
}

/* — таблица сессий — */
.client-grid .card .table-wrap {
  border: 1px solid var(--ui-table-border);
  border-radius: 3px;
}
.client-grid .card .table {
  font-family: 'Manrope', system-ui, sans-serif;
}
.client-grid .card .table thead th {
  font: 500 11px/1.4 'Manrope', system-ui, sans-serif;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--academy-gray);
  padding: 10px 14px;
  background: transparent;
  border-bottom: 1px solid var(--ui-table-border);
}
.client-grid .card .table tbody td {
  font: 400 14px/1.4 'Manrope', system-ui, sans-serif;
  color: var(--academy-ink);
  padding: 12px 14px;
  border-bottom: 1px solid var(--ui-table-border);
}
.client-grid .card .table tbody tr:last-child td {
  border-bottom: none;
}
.client-grid .card .table .num {
  text-align: right;
}
.client-grid .card .muted {
  color: var(--academy-gray);
}

/* — заметки — */
.client-grid .card .note-form {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 14px;
}
.client-grid .card .note-form textarea.input {
  background: transparent;
  border: 1px solid var(--ui-table-border);
  border-radius: 3px;
  padding: 12px 14px;
  font: 400 14px/1.45 'Manrope', system-ui, sans-serif;
  color: var(--academy-ink);
  outline: none;
  transition: border-color .25s ease;
  resize: vertical;
  min-height: 70px;
}
.client-grid .card .note-form textarea.input:focus {
  border-color: var(--academy-ink);
}
.client-grid .card .note-form textarea.input::placeholder {
  color: var(--academy-gray);
}
.client-grid .card .note-form .btn-primary {
  align-self: flex-start;
  min-width: 120px;
  font-family: 'Manrope', system-ui, sans-serif;
}
.client-grid .card .notes {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.client-grid .card .notes li {
  background: var(--academy-cream);
  border-radius: 3px;
  padding: 12px 14px;
}
.client-grid .card .note-body {
  font: 400 14px/1.45 'Manrope', system-ui, sans-serif;
  color: var(--academy-ink);
  white-space: pre-wrap;
  overflow-wrap: anywhere;
}
.client-grid .card .note-meta {
  font: 400 11px/1.4 'Manrope', system-ui, sans-serif;
  letter-spacing: 0.05em;
  color: var(--academy-gray);
  margin-top: 6px;
}

/* — пустые состояния — */
.client-grid .card > .muted {
  font: 400 14px/1.4 'Manrope', system-ui, sans-serif;
  color: var(--academy-gray);
  margin: 0;
}

.edit-card { max-width: 720px; }
.form-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px 16px;
}
.form-actions {
  display: flex; justify-content: flex-end;
  gap: 12px;
  margin-top: 18px;
}

@media (max-width: 880px) {
  .client-grid { grid-template-columns: 1fr; }
  .form-grid { grid-template-columns: 1fr; }
  .client-grid .card .kv { grid-template-columns: 1fr; }
}

/* === clients page (новый дизайн) ============================== */

:root {
  --ui-kpi-bg: #F0F0F0;
  --ui-kpi-border: #DFE9ED;
  --ui-table-border: #EEF4F6;
}

/* Страница клиентов длинная: разрешаем вертикальный скролл .main,
   ломая жёсткую сетку grid-template-rows: auto auto 1fr на этой странице. */
.main:has(.clients-header) {
  display: flex;
  flex-direction: column;
  padding: 28px 31px 28px;
  height: 100vh;
  overflow-y: auto;
  gap: 24px;
}

.clients-header { align-items: center; }
.clients-title {
  margin: 0;
  font-family: 'Craftwork Grotesk', sans-serif;
  font-weight: 400;
  font-size: 24px;
  line-height: 1;
  letter-spacing: -0.03em;
  text-transform: lowercase;
  color: var(--academy-black);
}

.clients-title-row {
  display: flex;
  align-items: baseline;
  gap: 12px;
}
.clients-count {
  font: 400 13px/1 'Manrope', system-ui, sans-serif;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--academy-gray);
}

.clients-search {
  position: relative;
  display: flex;
  align-items: center;
  width: 190px;
  color: var(--academy-ink);
  transition: color .25s ease;
}
.clients-search:focus-within {
  color: var(--academy-red);
}
.clients-search-input {
  width: 100%;
  background: transparent;
  border: none;
  border-bottom: 1px solid currentColor;
  border-radius: 0;
  padding: 8px 24px 8px 0;
  font: 500 13px/16px 'Craftwork Grotesk', sans-serif;
  text-transform: lowercase;
  color: inherit;
  outline: none;
  transition: border-color .25s ease, color .25s ease;
}
.clients-search-input::placeholder {
  color: var(--academy-ink);
  opacity: 1;
  transition: color .25s ease;
}
.clients-search:focus-within .clients-search-input::placeholder {
  color: var(--academy-red);
}
.clients-search-arrow {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  background: transparent;
  border: none;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.clients-search-arrow svg {
  width: 10px;
  height: 7px;
  stroke: currentColor;
  transition: stroke .25s ease;
}

.clients-tabs {
  display: flex;
  gap: 24px;
  margin: 4px 0 16px;
}
.clients-tab {
  font: 500 14px/1 'Craftwork Grotesk', sans-serif;
  text-transform: lowercase;
  color: var(--academy-gray);
  text-decoration: none;
  padding-bottom: 4px;
  border-bottom: 1px solid transparent;
}
.clients-tab.is-active {
  color: var(--academy-ink);
  border-bottom-color: var(--academy-ink);
}

.kpi-row {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 16px;
}
.kpi-card {
  background: var(--ui-kpi-bg);
  border: 1px solid var(--ui-kpi-border);
  border-radius: 3px;
  padding: 20px 22px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 125px;
}
.kpi-label {
  margin: 0;
  font: 400 13px/1 'Manrope', sans-serif;
  letter-spacing: 0.1em;
  text-transform: lowercase;
  color: #6F6F6F;
}
.kpi-value {
  margin: 0;
  font: 500 35px/42px 'Craftwork Grotesk', sans-serif;
  text-transform: lowercase;
  color: var(--academy-red);
}

.clients-filters {
  display: grid;
  grid-template-columns: 190px 190px 1fr auto;
  align-items: center;
  gap: 24px;
  margin: 16px 0 12px;
}
.clients-select {
  position: relative;
}
.clients-select::after {
  content: "";
  position: absolute;
  right: 0;
  top: 50%;
  width: 8px;
  height: 8px;
  border-right: 1px solid var(--academy-ink);
  border-bottom: 1px solid var(--academy-ink);
  transform: translateY(-70%) rotate(45deg);
  pointer-events: none;
}
.clients-select select {
  appearance: none;
  -webkit-appearance: none;
  width: 100%;
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--academy-ink);
  border-radius: 0;
  padding: 8px 24px 8px 0;
  font: 500 13px/16px 'Craftwork Grotesk', sans-serif;
  text-transform: lowercase;
  color: var(--academy-ink);
  outline: none;
}

.clients-tags-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.tag-pill {
  display: inline-flex;
  align-items: center;
  padding: 6px 16px;
  border-radius: var(--radius-pill);
  border: 1px solid var(--academy-gray-soft);
  background: transparent;
  color: var(--academy-gray-soft);
  font: 500 13px/16px 'Craftwork Grotesk', sans-serif;
  text-transform: lowercase;
  cursor: pointer;
  user-select: none;
  transition: background .25s ease, color .25s ease, border-color .25s ease;
}
.tag-pill input {
  display: none;
}
.tag-pill:hover {
  border-color: var(--academy-red);
  color: var(--academy-red);
}
.tag-pill.is-active {
  background: var(--academy-red);
  border-color: var(--academy-red);
  color: var(--academy-cream);
  transition: background .25s ease, color .25s ease, border-color .25s ease;
}

.clients-actions {
  display: inline-flex;
  gap: 6px;
}
.clients-filters-therapy {
  grid-template-columns: 1fr auto;
  justify-content: end;
}
.clients-filters-therapy .clients-actions {
  grid-column: 2;
}
.btn-square {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 96px;
  height: 40px;
  padding: 0 16px;
  border: 1px solid var(--academy-ink);
  border-radius: 2px;
  background: transparent;
  font: 500 12px/14px 'Craftwork Grotesk', sans-serif;
  text-transform: lowercase;
  color: var(--academy-ink);
  cursor: pointer;
  text-decoration: none;
  transition: background .25s ease, color .25s ease, border-color .25s ease;
}
.btn-square:hover {
  background: var(--academy-red);
  color: var(--academy-cream);
  border-color: var(--academy-red);
}

.clients-table-wrap {
  background: var(--academy-white);
  border: 1px solid var(--ui-table-border);
  border-radius: 3px;
  margin-top: 8px;
}
.clients-table {
  width: 100%;
  border-collapse: collapse;
}
.clients-table thead th {
  text-align: left;
  padding: 16px 24px;
  font: 500 13px/16px 'Manrope', 'Craftwork Grotesk', system-ui, sans-serif;
  text-transform: lowercase;
  color: var(--academy-gray);
  border-bottom: 1px solid var(--ui-table-border);
  background: var(--academy-white);
}
.clients-table tbody td {
  padding: 16px 24px;
  font: 500 14px/1 'Manrope', 'Craftwork Grotesk', system-ui, sans-serif;
  color: var(--academy-ink);
  border-bottom: 1px solid var(--ui-table-border);
  text-transform: none;
}
.clients-table tbody tr.clients-row {
  cursor: pointer;
}
.clients-table tbody tr.clients-row:hover {
  background: var(--academy-red);
  color: var(--academy-cream);
}
.clients-table tbody tr.clients-row:hover td {
  color: var(--academy-cream);
  border-color: transparent;
}
.clients-table tbody tr.clients-row:hover .tag-mini {
  background: transparent;
  border-color: var(--academy-cream);
  color: var(--academy-cream);
}
.tag-mini {
  display: inline-flex;
  align-items: center;
  padding: 4px 14px;
  border-radius: var(--radius-pill);
  background: var(--academy-white);
  border: 1px solid var(--academy-gray-soft);
  font: 500 12px/16px 'Craftwork Grotesk', sans-serif;
  text-transform: lowercase;
  color: var(--academy-ink);
}
.clients-empty {
  text-align: center;
  padding: 36px 0;
  color: var(--academy-gray-soft);
}

.clients-loadmore-wrap {
  display: flex;
  justify-content: flex-start;
  margin-top: 16px;
}
.btn-square-loadmore {
  gap: 12px;
  min-width: 130px;
}
.btn-square-loadmore .btn-arrow {
  width: 20px;
  height: 7px;
  transition: transform .3s ease-out;
}
.btn-square-loadmore:hover .btn-arrow {
  transform: translateX(4px);
}

@media (max-width: 1100px) {
  .kpi-row { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 880px) {
  .kpi-row { grid-template-columns: repeat(2, 1fr); }
  .clients-filters { grid-template-columns: 1fr; }
}

/* === KPI reveal animation ===================================== */
@keyframes admin-reveal {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}
.kpi-card { animation: admin-reveal .5s cubic-bezier(0.16, 1, 0.3, 1) both; }
.kpi-card:nth-child(1) { animation-delay: .05s; }
.kpi-card:nth-child(2) { animation-delay: .12s; }
.kpi-card:nth-child(3) { animation-delay: .19s; }
.kpi-card:nth-child(4) { animation-delay: .26s; }
.kpi-card:nth-child(5) { animation-delay: .33s; }

@media (prefers-reduced-motion: reduce) {
  .kpi-card { animation: none; }
}
