@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;500;600&family=Space+Grotesk:wght@400;500;600&display=swap');

[hidden] {
  display: none !important;
}

:root {
  color-scheme: dark;
  --font-sans: 'Space Grotesk', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --font-mono: 'IBM Plex Mono', ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;

  --bg: #0f141b;
  --bg-elevated: #131a23;
  --bg-muted: #171f2a;
  --surface: #171f2a;
  --panel: #171f2a;
  --panel-2: #1b2430;

  --text: #e7eef8;
  --text-secondary: #9aa7ba;
  --text-tertiary: #7f8aa0;

  --border: rgba(120, 160, 255, 0.25);
  --separator: rgba(255, 255, 255, 0.08);

  --accent: #6fa8ff;
  --accent-strong: #5a93f2;
  --accent-weak: rgba(111, 168, 255, 0.12);

  --success: #2dbe7f;
  --success-weak: #e9f9f2;
  --warning: #ffb020;
  --warning-weak: #fff6e0;
  --danger: #ff3b30;
  --danger-weak: #ffedea;

  --set-control-bg: #2f2b20;
  --set-control-border: #8a6a2d;
  --set-control-text: #f5d38a;
  --set-control-hover-bg: #3a3426;
  --set-control-hover-border: #b38335;

  --ring: rgba(109, 168, 255, 0.35);

  --color-bg: var(--bg);
  --color-surface: var(--surface);
  --color-text: var(--text);
  --color-text-secondary: var(--text-secondary);
  --color-text-tertiary: var(--text-tertiary);
  --color-border: var(--border);
  --color-accent: var(--accent);
  --color-accent-strong: var(--accent-strong);
  --color-accent-weak: var(--accent-weak);
  --color-success: var(--success);
  --color-success-weak: var(--success-weak);
  --color-warning: var(--warning);
  --color-warning-weak: var(--warning-weak);
  --color-error: var(--danger);
  --color-error-weak: var(--danger-weak);
  --color-surface-alt: var(--bg-muted);

  --space-0: 0;
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --radius-s: 14px;
  --radius-m: 18px;
  --shadow-elevated: 0 0 24px rgba(16, 24, 40, 0.4);
  --shadow-button: 0 0 24px rgba(16, 24, 40, 0.35), 0 1px 3px rgba(15, 17, 21, 0.08);
  --motion-xfast: 120ms;
  --motion-fast: 150ms;
  --motion-regular: 180ms;
  --motion-medium: 220ms;
  --motion-slow: 260ms;
  --motion-slower: 500ms;
  --motion-pulse: 850ms;
  --motion-glow-fast: 1600ms;
  --motion-glow: 1800ms;
  --motion-ease: cubic-bezier(0.2, 0, 0, 1);
  --motion-ease-emph: cubic-bezier(0.22, 0.61, 0.36, 1);
  --motion-ease-loop: ease-in-out;
  --btn-pad-y: 10px;
  --btn-pad-x: 16px;
  --btn-font-size: 15px;
  --btn-min-height: 42px;
  --text-size: 14px;
  --title-size: 16px;
  --subtitle-size: 12px;
  --title-letter: 0.8px;
  --subtitle-letter: 1.2px;
  --app-bar-h: 56px;
  --icon-btn-size: 28px;
  --icon-btn-radius: var(--radius-s);
  --icon-btn-font: 18px;
  --icon-btn-color: var(--color-text-secondary);
  --icon-btn-bg: transparent;
  --icon-btn-border: 1px solid transparent;
  --icon-btn-shadow: none;
  --icon-btn-hover-bg: color-mix(in srgb, var(--color-accent) 16%, var(--color-surface));
  --icon-btn-hover-color: var(--color-accent);
  --icon-btn-hover-border: color-mix(in srgb, var(--color-accent) 35%, transparent);
  --icon-btn-hover-shadow: none;
  --keyboard-offset: 0px;
  --vv-top: 0px;
  --kb: 0px;
  --client-nav-height: 0px;
  font-size: 16px;
}

/* Floating plan detail */
.plan-detail-card--floating {
  position: fixed;
  right: 32px;
  top: 72px;
  max-width: 640px;
  width: min(640px, 90vw);
  max-height: calc(100vh - 120px);
  overflow: auto;
  z-index: 60;
  box-shadow: var(--shadow-elevated);
}

@media (prefers-color-scheme: dark) {
  :root {
    color-scheme: dark;
  }
}

  @media (prefers-color-scheme: light) {
  :root:not([data-theme]) {
    color-scheme: light;
    --bg: #f4f6f9;
    --bg-elevated: #e9edf3;
    --bg-muted: #ffffff;
    --surface: #ffffff;
    --panel: #ffffff;
    --panel-2: #f3f6fb;

    --text: #1c2533;
    --text-secondary: #5b6b80;
    --text-tertiary: #7a8799;

    --border: rgba(90, 120, 180, 0.22);
    --separator: rgba(0, 0, 0, 0.08);

    --accent: #3a6edc;
    --accent-strong: #2f5cc0;
    --accent-weak: rgba(58, 110, 220, 0.12);

    --ring: rgba(58, 110, 220, 0.28);
    --set-control-bg: #f7e6bf;
    --set-control-border: #e0b060;
    --set-control-text: #7a5116;
    --set-control-hover-bg: #f3dca7;
    --set-control-hover-border: #d39c45;
  }
  body:not([data-theme]) {
    background:
      radial-gradient(1200px 600px at 20% 10%, rgba(58,110,220,0.12), transparent 60%),
      radial-gradient(900px 500px at 85% 20%, rgba(255,138,58,0.12), transparent 60%),
      linear-gradient(180deg, var(--bg), var(--bg-elevated));
  }
  body:not([data-theme])::before {
    opacity: 0.18;
    mix-blend-mode: multiply;
  }
}

html[data-theme="light"] {
  color-scheme: light;
  --bg: #f4f6f9;
  --bg-elevated: #e9edf3;
  --bg-muted: #ffffff;
  --surface: #ffffff;
  --panel: #ffffff;
  --panel-2: #f3f6fb;

  --text: #1c2533;
  --text-secondary: #5b6b80;
  --text-tertiary: #7a8799;

  --border: rgba(90, 120, 180, 0.22);
  --separator: rgba(0, 0, 0, 0.08);

  --accent: #3a6edc;
  --accent-strong: #2f5cc0;
  --accent-weak: rgba(58, 110, 220, 0.12);

  --ring: rgba(58, 110, 220, 0.28);
  --set-control-bg: #f7e6bf;
  --set-control-border: #e0b060;
  --set-control-text: #7a5116;
  --set-control-hover-bg: #f3dca7;
  --set-control-hover-border: #d39c45;
}

html[data-theme="dark"] {
  color-scheme: dark;
  --bg: #0f141b;
  --bg-elevated: #131a23;
  --bg-muted: #171f2a;
  --surface: #171f2a;
  --panel: #171f2a;
  --panel-2: #1b2430;

  --text: #e7eef8;
  --text-secondary: #9aa7ba;
  --text-tertiary: #7f8aa0;

  --border: rgba(120, 160, 255, 0.25);
  --separator: rgba(255, 255, 255, 0.08);

  --accent: #6fa8ff;
  --accent-strong: #5a93f2;
  --accent-weak: rgba(111, 168, 255, 0.12);

  --ring: rgba(109, 168, 255, 0.35);
  --set-control-bg: #2f2b20;
  --set-control-border: #8a6a2d;
  --set-control-text: #f5d38a;
  --set-control-hover-bg: #3a3426;
  --set-control-hover-border: #b38335;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--text-size);
  background:
    radial-gradient(1200px 600px at 20% 10%, rgba(111,168,255,0.15), transparent 60%),
    radial-gradient(900px 500px at 85% 20%, rgba(255,159,90,0.15), transparent 60%),
    linear-gradient(180deg, var(--bg), var(--bg-elevated));
  color: var(--color-text);
  line-height: 1.6;
  padding: env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);
  position: relative;
  isolation: isolate;
}

html[data-theme="light"] body {
  background:
    radial-gradient(1200px 600px at 20% 10%, rgba(58,110,220,0.12), transparent 60%),
    radial-gradient(900px 500px at 85% 20%, rgba(255,138,58,0.12), transparent 60%),
    linear-gradient(180deg, var(--bg), var(--bg-elevated));
}

html[data-theme="dark"] body {
  background:
    radial-gradient(1200px 600px at 20% 10%, rgba(111,168,255,0.15), transparent 60%),
    radial-gradient(900px 500px at 85% 20%, rgba(255,159,90,0.15), transparent 60%),
    linear-gradient(180deg, var(--bg), var(--bg-elevated));
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background: repeating-linear-gradient(
    to bottom,
    rgba(255, 255, 255, 0.03) 0px,
    rgba(255, 255, 255, 0.03) 1px,
    transparent 2px,
    transparent 4px
  );
  opacity: 0.35;
  mix-blend-mode: screen;
  z-index: 0;
}

html[data-theme="light"] body::before {
  opacity: 0.18;
  mix-blend-mode: multiply;
}

html[data-theme="dark"] body::before {
  opacity: 0.35;
  mix-blend-mode: screen;
}

body[data-theme="light"] {
  --bg: #f4f6f9;
  --bg-elevated: #e9edf3;
  --bg-muted: #ffffff;
  --surface: #ffffff;
  --panel: #ffffff;
  --panel-2: #f3f6fb;

  --text: #1c2533;
  --text-secondary: #5b6b80;
  --text-tertiary: #7a8799;

  --border: rgba(90, 120, 180, 0.22);
  --separator: rgba(0, 0, 0, 0.08);

  --accent: #3a6edc;
  --accent-strong: #2f5cc0;
  --accent-weak: rgba(58, 110, 220, 0.12);

  --ring: rgba(58, 110, 220, 0.28);
  color-scheme: light;
  background:
    radial-gradient(1200px 600px at 20% 10%, rgba(58,110,220,0.12), transparent 60%),
    radial-gradient(900px 500px at 85% 20%, rgba(255,138,58,0.12), transparent 60%),
    linear-gradient(180deg, var(--bg), var(--bg-elevated));
}

body[data-theme="dark"] {
  --bg: #0f141b;
  --bg-elevated: #131a23;
  --bg-muted: #171f2a;
  --surface: #171f2a;
  --panel: #171f2a;
  --panel-2: #1b2430;

  --text: #e7eef8;
  --text-secondary: #9aa7ba;
  --text-tertiary: #7f8aa0;

  --border: rgba(120, 160, 255, 0.25);
  --separator: rgba(255, 255, 255, 0.08);

  --accent: #6fa8ff;
  --accent-strong: #5a93f2;
  --accent-weak: rgba(111, 168, 255, 0.12);

  --ring: rgba(109, 168, 255, 0.35);
  color-scheme: dark;
  background:
    radial-gradient(1200px 600px at 20% 10%, rgba(111,168,255,0.15), transparent 60%),
    radial-gradient(900px 500px at 85% 20%, rgba(255,159,90,0.15), transparent 60%),
    linear-gradient(180deg, var(--bg), var(--bg-elevated));
}

body[data-theme="dark"]::before {
  opacity: 0.35;
  mix-blend-mode: screen;
}

body[data-theme="light"]::before {
  opacity: 0.18;
  mix-blend-mode: multiply;
}

html.modal-open,
body.modal-open {
  overflow: hidden;
}

.text-accent {
  color: var(--color-accent);
}

.text-secondary {
  color: var(--color-text-secondary);
}

.text-tertiary {
  color: var(--color-text-tertiary);
}

.icon-close {
  font-size: 1em;
  font-weight: 700;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.app-bar {
  position: sticky;
  top: 0;
  left: 0;
  right: 0;
  height: var(--app-bar-h);
  background: var(--color-surface);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 var(--space-4);
  border-bottom: 1px solid var(--color-border);
  box-shadow: var(--shadow-elevated);
  z-index: 100;
  backdrop-filter: blur(20px);
}

.app-title {
  margin: 0;
  font-size: var(--title-size);
  font-weight: 600;
  letter-spacing: var(--title-letter);
  text-transform: uppercase;
  font-family: var(--font-mono);
}

.icon-button,
.builder-library__delete,
.technique-image-remove,
.entry-remove,
.superset-reorder__btn {
  width: var(--icon-btn-size);
  height: var(--icon-btn-size);
  border-radius: var(--icon-btn-radius);
  border: var(--icon-btn-border);
  background: var(--icon-btn-bg);
  color: var(--icon-btn-color);
  font-size: var(--icon-btn-font);
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: var(--icon-btn-shadow);
  transition: background var(--motion-fast) var(--motion-ease), color var(--motion-fast) var(--motion-ease), border-color var(--motion-fast) var(--motion-ease), box-shadow var(--motion-fast) var(--motion-ease);
}

.icon-button:hover,
.icon-button:focus-visible,
.builder-library__delete:hover,
.builder-library__delete:focus-visible,
.technique-image-remove:hover,
.technique-image-remove:focus-visible,
.entry-remove:hover,
.entry-remove:focus-visible,
.superset-reorder__btn:hover:not(:disabled),
.superset-reorder__btn:focus-visible:not(:disabled) {
  background: var(--icon-btn-hover-bg);
  color: var(--icon-btn-hover-color);
  border-color: var(--icon-btn-hover-border);
  box-shadow: var(--icon-btn-hover-shadow);
  outline: none;
}

.icon-button {
  --icon-btn-size: 44px;
  --icon-btn-radius: 22px;
  --icon-btn-font: 24px;
  --icon-btn-color: var(--color-accent);
  --icon-btn-bg: transparent;
  --icon-btn-border: none;
  --icon-btn-hover-bg: color-mix(in srgb, var(--color-accent) 12%, transparent);
  --icon-btn-hover-color: var(--color-accent);
  --icon-btn-hover-border: transparent;
}

.plan-list-close {
  --icon-btn-color: var(--color-error);
  --icon-btn-hover-color: var(--color-error);
  --icon-btn-hover-bg: color-mix(in srgb, var(--color-error) 14%, transparent);
}

.icon-button:focus-visible,
.btn:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px var(--ring);
}

.app-main {
  padding: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  min-height: calc(100vh - var(--app-bar-h));
}

body.client-auth-mode .app-main {
  align-items: center;
  justify-content: center;
}

body.admin-auth-mode .app-main {
  align-items: center;
  justify-content: center;
  min-height: 100vh;
}

body.client-app[data-client-stage="start"] .app-main {
  align-items: center;
  justify-content: center;
  min-height: 100vh;
}

body.client-app[data-client-stage="start"] #start-card {
  margin: 0 auto;
}

body.client-auth-mode #start-card {
  display: none !important;
}

body.client-auth-mode .app-main > .card {
  width: min(100%, 420px);
  margin: 0 auto;
}

body.admin-auth-mode .app-bar,
body.admin-auth-mode #admin-tab-nav {
  display: none !important;
}

body.admin-auth-mode #admin-workspace {
  display: none !important;
}

body.admin-auth-mode .app-main > .card {
  width: min(100%, 420px);
  margin: 0 auto;
}

body[data-client-stage="app"] #start-card,
body[data-client-stage="auth"] #start-card {
  display: none !important;
}

.workspace-shell {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.tab-nav {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  background: linear-gradient(180deg, var(--panel), var(--panel-2));
  border: 1px solid var(--color-border);
  border-radius: 999px;
  padding: var(--space-2);
  box-shadow: var(--shadow-elevated);
  position: relative;
  overflow: hidden;
  width: 100%;
}

body.client-app #client-tab-nav,
body.admin-app #admin-tab-nav {
  flex-wrap: nowrap;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  width: 100%;
}

body.client-app #client-tab-nav::-webkit-scrollbar,
body.admin-app #admin-tab-nav::-webkit-scrollbar {
  display: none;
}

body.admin-app.nav-locked #admin-tab-nav,
body.client-app.nav-locked #client-tab-nav {
  display: none !important;
}

body.client-app.nav-locked #client-workspace {
  display: none !important;
}

body.admin-app.nav-locked #admin-workspace {
  display: none !important;
}

.tab-nav a,
.tab-nav__button,
.tab-nav__profile {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-2) var(--space-3);
  border-radius: 999px;
  border: 1px solid transparent;
  background: transparent;
  color: var(--color-text-secondary);
  font-weight: 500;
  font-family: var(--font-mono);
  letter-spacing: var(--subtitle-letter);
  text-transform: uppercase;
  text-decoration: none;
  cursor: pointer;
  transition:
    background-color var(--motion-fast) var(--motion-ease),
    color var(--motion-fast) var(--motion-ease),
    border-color var(--motion-fast) var(--motion-ease),
    transform var(--motion-fast) var(--motion-ease);
  position: relative;
  z-index: 1;
}

.tab-nav__profile {
  gap: var(--space-2);
  margin-left: auto;
}

body.client-app #client-tab-nav a {
  border-radius: 999px;
}

body.client-app #client-tab-nav a,
body.client-app #client-tab-nav .tab-nav__profile {
  /* Match admin nav typography. Client width/scroll differs, but style stays consistent. */
  font-size: inherit;
}

.tab-nav__label {
  font-size: inherit;
  line-height: inherit;
}

:where(.workout-chip__title,
  .plan-list-item__title,
  .stats-section__title,
  .stats-card .card-title,
  .modal__title,
  .ai-report__title,
  .ai-plan-card__title,
  .plan-preview-exercises__title,
  .list-title,
  .entry-title,
  .entry-heading) {
  font-size: var(--title-size);
  font-weight: 600;
  letter-spacing: var(--title-letter);
}

:where(.field-label,
  .field-label-row,
  .field-label-hint,
  .stats-period-label,
  .kpi-label,
  .plan-alert-item__title,
  .plan-detail-summary__label,
  .plan-detail-note__label,
  .plan-detail-value__label,
  .calendar-hint__label,
  .calendar-hint__title,
  .plan-mode__label,
  .exercise-rest__label,
  .profile-set-label,
  .entry-sets__label,
  .entry-set-label,
  .library-tree__label,
  .filter-section > summary,
  .filter-section > summary::after,
  .ai-plan-assign__title) {
  font-family: var(--font-mono);
  font-size: var(--subtitle-size);
  letter-spacing: var(--subtitle-letter);
  color: var(--color-text-secondary);
}

:where(.stats-period-label,
  .kpi-label,
  .plan-alert-item__title,
  .plan-detail-summary__label,
  .plan-detail-note__label,
  .plan-detail-value__label,
  .calendar-hint__label,
  .calendar-hint__title,
  .plan-mode__label,
  .stats-section__title) {
  text-transform: uppercase;
}

.tab-nav a:hover,
.tab-nav__button:hover,
.tab-nav__profile:hover {
  color: var(--color-text);
  border-color: color-mix(in srgb, var(--color-accent) 35%, transparent);
}

.tab-nav a.is-active,
.tab-nav__button.is-active,
.tab-nav__profile.is-active {
  color: var(--color-surface);
  background: transparent;
}

.tab-nav__highlight {
  position: absolute;
  top: 0;
  left: 0;
  width: 0;
  height: 0;
  border-radius: 999px;
  background: var(--color-accent);
  opacity: 0;
  transform: translate(0, 0);
  transition:
    transform var(--motion-medium) var(--motion-ease),
    width var(--motion-medium) var(--motion-ease),
    height var(--motion-medium) var(--motion-ease),
    opacity var(--motion-fast) var(--motion-ease);
  z-index: 0;
  pointer-events: none;
  box-shadow: 0 0 22px rgba(109, 168, 255, 0.35);
}

.tab-nav__profile.is-active .tab-nav__avatar {
  border-color: rgba(255, 255, 255, 0.65);
}

.tab-nav a.is-disabled {
  opacity: 0.5;
  pointer-events: none;
  cursor: not-allowed;
}

.tab-nav a:focus-visible,
.tab-nav__button:focus-visible,
.tab-nav__profile:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px var(--ring);
}



.card {
  background: linear-gradient(180deg, var(--panel), var(--panel-2));
  border: 1px solid var(--color-border);
  border-radius: var(--radius-m);
  padding: var(--space-5);
  box-shadow: var(--shadow-elevated);
  transition:
    border-color var(--motion-medium) var(--motion-ease),
    box-shadow var(--motion-medium) var(--motion-ease),
    transform var(--motion-medium) var(--motion-ease);
}

.card:hover {
  border-color: color-mix(in srgb, var(--color-accent) 35%, var(--color-border));
  box-shadow: 0 0 28px rgba(109, 168, 255, 0.22);
  transform: translateY(-1px);
}

/* Widget debug identifiers (overlay, no layout impact) */
[data-widget-code] {
  position: relative;
}

[data-widget-code]::after {
  content: attr(data-widget-code);
  position: absolute;
  top: 6px;
  left: 8px;
  z-index: 9999;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: rgba(13, 16, 22, 0.78);
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.2);
  pointer-events: none;
  user-select: none;
}

.card h2 {
  margin-top: 0;
  margin-bottom: var(--space-3);
  font-size: 18px;
  letter-spacing: 0.6px;
  font-weight: 600;
}

.card--start {
  padding: clamp(24px, 4vw, 48px);
  width: min(100%, 1200px);
  margin: 0 auto;
  border-radius: 32px;
  --btn-pad-y: 14px;
  --btn-pad-x: 24px;
  --btn-font-size: 20px;
  --btn-min-height: 60px;
}

.start-shell {
  display: flex;
  align-items: center;
  gap: var(--space-5);
}

.start-left {
  flex: 1.1;
  min-width: 0;
  padding-right: clamp(24px, 6vw, 64px);
}

.start-right {
  flex: 1;
  min-width: 0;
  padding-left: clamp(20px, 5vw, 56px);
  padding-top: var(--space-2);
}

.start-divider {
  width: 2px;
  align-self: stretch;
  border-radius: 999px;
  background: color-mix(in srgb, var(--color-border) 70%, transparent);
}

.start-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: 10px 18px;
  border-radius: 999px;
  background: var(--color-accent-weak);
  color: var(--color-accent);
  font-size: 18px;
  font-weight: 700;
}

.start-brand {
  margin-top: var(--space-5);
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.start-logo {
  width: 88px;
  height: 88px;
  color: var(--color-accent);
  flex: 0 0 auto;
}

.start-brand-name {
  font-size: clamp(32px, 4.4vw, 54px);
  font-weight: 800;
  letter-spacing: -0.5px;
  color: var(--color-text);
  line-height: 1;
}

.start-product {
  margin-top: var(--space-4);
  font-size: clamp(26px, 3.4vw, 40px);
  font-weight: 700;
  letter-spacing: -0.3px;
  color: var(--color-text);
}

.start-description {
  margin: var(--space-4) 0 0;
  color: var(--color-text-secondary);
  font-size: clamp(13px, 2vw, 16px);
  max-width: 36ch;
}

.start-heading {
  margin: 0;
  font-size: clamp(28px, 4vw, 44px);
  font-weight: 600;
  letter-spacing: 0;
  color: var(--color-text);
  line-height: 1.2;
}

.start-sub {
  margin: var(--space-2) 0 0;
  font-size: clamp(12px, 2vw, 16px);
  color: var(--color-text-secondary);
  line-height: 1.4;
  width: min(100%, 520px);
  letter-spacing: 0.2px;
}

.invite-banner {
  border: 1px solid var(--color-accent-strong);
  background: color-mix(in srgb, var(--color-accent-weak) 70%, transparent);
  color: var(--color-text);
  padding: var(--space-3);
  border-radius: 999px;
  margin-bottom: var(--space-4);
  font-size: 14px;
}

.invite-banner__code code {
  font-weight: 700;
}

.start-actions {
  margin-top: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  align-items: flex-start;
}

.start-actions .btn {
  width: min(100%, 520px);
  margin: 0;
}

.card--start .btn {
  border-radius: 18px;
  font-weight: 800;
}

.card--start .btn-primary {
  min-height: 72px;
}

.card--start .btn-outline {
  min-height: 60px;
}

@media (min-width: 980px) {
  .start-heading {
    font-size: 46px;
  }

  .start-sub {
    font-size: 19px;
  }
}

@media (max-width: 980px) {
  .card--start {
    padding: var(--space-4);
    --btn-pad-y: 12px;
    --btn-pad-x: 20px;
    --btn-font-size: 18px;
    --btn-min-height: 52px;
  }

  .start-shell {
    flex-direction: column;
    align-items: stretch;
  }

  .start-divider {
    display: none;
  }

  .start-left {
    padding-right: 0;
    text-align: center;
  }

  .start-right {
    padding-left: 0;
    padding-top: var(--space-4);
    text-align: center;
  }

  .start-actions {
    width: 100%;
    align-items: stretch;
  }

  .start-actions .btn {
    width: 100%;
  }

  .start-badge {
    font-size: 16px;
    padding: 8px 16px;
    margin: 0 auto;
  }

  .start-brand {
    margin-top: var(--space-4);
    gap: var(--space-3);
    justify-content: center;
  }

  .start-logo {
    width: 64px;
    height: 64px;
  }

  .start-brand-name {
    font-size: 32px;
  }

  .start-product {
    font-size: 26px;
  }

  .start-description {
    font-size: 16px;
    max-width: 100%;
  }

  .start-heading {
    font-size: 28px;
  }

  .start-sub {
    font-size: 16px;
  }
}

.card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  margin-bottom: var(--space-3);
}

.card-header input[type="date"] {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-s);
  padding: var(--space-2) var(--space-3);
  min-height: 44px;
  font: inherit;
}

.plan-alert,
.notice {
  margin-bottom: var(--space-3);
  padding: var(--space-3);
  border-radius: var(--radius-s);
  border-left: 4px solid var(--color-warning);
  background: color-mix(in srgb, var(--color-warning) 15%, var(--color-surface));
  color: var(--color-text);
  font-weight: 600;
}

.notice--danger {
  border-left-color: var(--color-error);
  background: color-mix(in srgb, var(--danger-weak) 70%, var(--color-surface));
}

.plan-alert {
  width: 100%;
  text-align: left;
  border-top: 0;
  border-right: 0;
  border-bottom: 0;
  cursor: pointer;
  font: inherit;
  background-clip: padding-box;
}

.plan-alert:focus-visible {
  outline: 2px solid var(--ring);
  outline-offset: 2px;
}

.plan-alert-list {
  display: grid;
  gap: var(--space-2);
  margin: calc(var(--space-2) * -1) 0 var(--space-3);
  padding-top: var(--space-2);
  overflow-y: auto;
  padding-right: var(--space-1);
}

.plan-alert-list.is-scroll {
  padding-right: var(--space-2);
}

.plan-alert-item {
  border-radius: var(--radius-s);
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  padding: var(--space-2) var(--space-3);
  text-align: left;
  display: flex;
  align-items: center;
  gap: var(--space-2);
  cursor: pointer;
  transition: border-color var(--motion-xfast) var(--motion-ease), box-shadow var(--motion-xfast) var(--motion-ease), transform var(--motion-xfast) var(--motion-ease);
}

.plan-alert-item:hover {
  border-color: color-mix(in srgb, var(--color-accent) 40%, var(--color-border));
  box-shadow: 0 10px 20px rgba(15, 17, 21, 0.08);
  transform: translateY(-1px);
}

.plan-alert-item__main {
  flex: 1;
  display: grid;
  gap: var(--space-1);
  border: 0;
  padding: 0;
  background: transparent;
  text-align: left;
  color: inherit;
  cursor: pointer;
}

.plan-alert-item__main:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--color-accent) 60%, transparent);
  outline-offset: 3px;
}

.plan-alert-item__title {
  font-weight: 600;
}

.plan-alert-item__meta {
  color: var(--color-text-secondary);
  font-size: 13px;
}

.plan-alert-item__skip {
  flex: 0 0 auto;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--color-warning) 55%, var(--color-border));
  background: color-mix(in srgb, var(--color-warning) 18%, var(--color-surface));
  color: var(--color-warning);
  font-size: 12px;
  font-weight: 600;
  padding: 6px 12px;
  line-height: 1;
  cursor: pointer;
  transition: transform var(--motion-xfast) var(--motion-ease), box-shadow var(--motion-xfast) var(--motion-ease), border-color var(--motion-xfast) var(--motion-ease);
}

.plan-alert-item__skip:hover,
.plan-alert-item__skip:focus-visible {
  border-color: color-mix(in srgb, var(--color-warning) 75%, var(--color-border));
  box-shadow: 0 6px 14px rgba(15, 17, 21, 0.12);
  transform: translateY(-1px);
}

.form-edit-indicator {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-s);
  font-weight: 600;
}

.form-edit-indicator--create {
  border-left: 4px solid var(--color-success);
  background: color-mix(in srgb, var(--color-success) 18%, var(--color-surface));
  color: color-mix(in srgb, var(--color-text) 70%, var(--color-success) 30%);
}

.form-edit-indicator--edit {
  border-left: 4px solid var(--color-warning);
  background: color-mix(in srgb, var(--color-warning) 20%, var(--color-surface));
  color: var(--color-text);
}

.notice {
  border-left-color: var(--color-accent);
  background: color-mix(in srgb, var(--color-accent) 10%, var(--color-surface));
  font-weight: 500;
}

.settings-block {
  margin-top: var(--space-4);
  padding: var(--space-4);
  border-radius: var(--radius-m);
  border: 1px solid var(--color-border);
  background: color-mix(in srgb, var(--color-surface) 88%, var(--color-bg));
}

.settings-block h3 {
  margin-top: 0;
  margin-bottom: var(--space-3);
}

.settings-actions {
  margin-top: var(--space-4);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.result-actions {
  display: flex;
  gap: var(--space-2);
  margin-top: var(--space-3);
}

.result-actions .btn {
  margin-block: 0;
}

.workout-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  margin-bottom: var(--space-2);
}

.workout-header h2 {
  margin: 0;
}

.workout-close {
  flex: 0 0 auto;
  --icon-btn-color: var(--color-error);
  --icon-btn-hover-color: var(--color-error);
  --icon-btn-hover-bg: color-mix(in srgb, var(--color-error) 14%, transparent);
}

.workout-chip {
  width: 100%;
  border-radius: var(--radius-m);
  border: 1px solid var(--color-border);
  background: linear-gradient(180deg, var(--panel), var(--panel-2));
  padding: var(--space-3);
  display: grid;
  gap: 4px;
  text-align: left;
  font-weight: 500;
  cursor: pointer;
  transition:
    border-color var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease),
    transform var(--motion-fast) var(--motion-ease);
}

.workout-chip__title {
  font-size: 16px;
  line-height: 1.3;
  font-weight: 600;
  color: var(--color-text);
}

.workout-chip:hover {
  border-color: color-mix(in srgb, var(--color-accent) 40%, var(--color-border));
  box-shadow: 0 0 24px rgba(109, 168, 255, 0.25);
  transform: translateY(-1px);
}

.workout-chip__meta {
  font-size: 12px;
  color: var(--color-text-secondary);
  font-weight: 500;
}

.result-card.is-collapsed {
  padding-bottom: var(--space-3);
}

.workout-progress {
  margin: 0 0 var(--space-2);
  font-size: 13px;
  color: var(--color-text-secondary);
}

.workout-progress__text {
  margin: 0;
}

.result-note {
  margin: 0 0 var(--space-2);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-s);
  background: color-mix(in srgb, var(--color-warning-weak) 80%, var(--color-surface) 20%);
  font-size: 13px;
  color: var(--color-text-secondary);
}

.result-notes-field {
  margin-top: var(--space-2);
}

.field {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  margin-bottom: var(--space-3);
  pointer-events: none;
}
.field > * {
  pointer-events: auto;
}

/* Чтобы клики по подписям не фокусировали инпут (не блокируем кнопки внутри) */
.field .field-label {
  pointer-events: none !important;
}
.field-label-row {
  pointer-events: none;
}
.field-label-row .field-help-btn {
  pointer-events: auto;
}

.client-display {
  font-size: 15px;
  font-weight: 600;
  color: var(--color-text-primary);
  padding: 2px 0;
}

.client-display:not(.is-empty) {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px;
  border-radius: 999px;
  background: #a855f7;
  color: #fff;
  font-size: 16px;
  line-height: 1.2;
  box-shadow: 0 6px 16px color-mix(in srgb, #a855f7 20%, transparent);
}

.client-display.is-empty {
  color: var(--color-text-secondary);
  font-weight: 500;
}

.field-inline {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.field-inline input,
.field-inline select {
  flex: 1;
  margin-block: 0;
}

.field-inline .btn {
  margin-block: 0;
  white-space: nowrap;
}

.field-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: var(--space-3);
}

.field--full {
  grid-column: 1 / -1;
}

.field-grid--single {
  grid-template-columns: 1fr;
}

.field-helper {
  margin-top: var(--space-2);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-2);
}

.form-actions--compact {
  justify-content: flex-start;
  gap: var(--space-2);
  margin-top: var(--space-2);
}

.status--inline {
  margin-top: var(--space-2);
}

.form-actions .status--inline {
  margin-top: 0;
  align-self: center;
  font-size: 13px;
}

.ai-plan-settings {
  margin-bottom: var(--space-2);
  row-gap: var(--space-2);
}

.taxonomy-edit-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-3);
}

.field-label {
  font-size: 13px;
  color: var(--color-text-secondary);
  letter-spacing: 1px;
  text-transform: uppercase;
}

.field-label--danger {
  color: #b91c1c;
}

.field input,
.field select,
.field textarea {
  border: 1px solid var(--color-border);
  border-radius: 999px;
  padding: var(--space-2) var(--space-3);
  min-height: 44px;
  background: color-mix(in srgb, var(--color-surface) 92%, var(--color-bg) 8%);
  color: inherit;
  font: inherit;
}

/* Prevent mobile Safari auto-zoom on focus: keep text inputs >= 16px. */
input[type="text"],
input[type="password"],
input[type="email"],
input[type="number"],
input[type="search"],
input[type="tel"],
input[type="url"],
input[type="date"],
input[type="time"],
input[type="datetime-local"],
textarea,
select {
  font-size: 16px !important;
}

/* Plan builder (2004): compact density without touching global form ergonomics. */
.plan-builder--compact .field {
  margin-bottom: var(--space-2);
}

.plan-builder--compact .field-label {
  font-size: 12px;
  letter-spacing: 0.9px;
}

.plan-builder--compact .field input,
.plan-builder--compact .field select,
.plan-builder--compact .field textarea {
  min-height: 38px;
  padding: 8px 12px;
}

.plan-builder--compact .field textarea {
  /* Keep textareas readable but less tall by default. */
  min-height: 72px;
  border-radius: var(--radius-s);
}

.field input.input-secret {
  -webkit-text-security: disc;
  text-security: disc;
}

.field textarea {
  min-height: 88px;
  resize: vertical;
  border-radius: var(--radius-s);
  background: color-mix(in srgb, var(--color-surface) 90%, var(--color-bg) 10%);
}

.field textarea.field-textarea-compact {
  min-height: 64px;
}

.field textarea[name="technique"],
.field textarea[name="mistakes"] {
  min-height: 120px;
}

.technique-images-preview {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(90px, 1fr));
  gap: var(--space-2);
  margin-top: var(--space-2);
}

.technique-images-preview--stacked {
  grid-template-columns: minmax(0, 1fr);
}

.technique-images-preview > img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border-radius: var(--radius-s);
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  display: block;
}

#taxonomy-modal .modal__dialog {
  max-height: min(84vh, 860px);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

#taxonomy-modal #taxonomy-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  min-height: 0;
  overflow: hidden;
}

.taxonomy-editor {
  display: grid;
  gap: var(--space-4);
  overflow: auto;
  min-height: 0;
  padding-right: 4px;
}

.taxonomy-editor__group {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-m);
  padding: var(--space-3);
  background: rgba(0, 0, 0, 0.02);
}

.taxonomy-editor__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  margin-bottom: var(--space-2);
}

.taxonomy-editor__title {
  font-size: 15px;
  font-weight: 600;
  margin: 0;
}

.taxonomy-editor__list {
  display: grid;
  gap: var(--space-2);
}

.taxonomy-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) auto;
  gap: var(--space-2);
  align-items: center;
}

.taxonomy-row input {
  width: 100%;
}

.taxonomy-row__remove {
  min-width: 36px;
  min-height: 36px;
}

.taxonomy-modal__hint {
  margin-bottom: var(--space-3);
}

.taxonomy-modal__warning {
  display: flex;
  gap: var(--space-2);
  align-items: flex-start;
  padding: var(--space-2);
  border-radius: var(--radius-s);
  background: color-mix(in srgb, var(--color-warning-weak) 30%, transparent);
  border: 1px solid color-mix(in srgb, var(--color-warning) 45%, transparent);
  color: var(--color-text);
  margin-bottom: var(--space-2);
}

.taxonomy-modal__warning-icon {
  font-size: 18px;
  line-height: 1;
  color: var(--color-warning);
}

.taxonomy-modal__list {
  margin: 0;
  padding-left: 18px;
  display: grid;
  gap: 6px;
}

.taxonomy-modal__status {
  margin-top: var(--space-2);
}

.technique-images-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  margin-top: var(--space-1);
}

.technique-images-count {
  font-size: 12px;
  color: var(--color-text-secondary);
}

.technique-images-count.is-limit {
  color: var(--color-warning);
  font-weight: 600;
}

.technique-image-item {
  position: relative;
  display: grid;
  gap: var(--space-1);
  cursor: grab;
  border-radius: var(--radius-s);
}

.technique-image-item.is-dragging {
  opacity: 0.6;
}

.technique-drag-ghost {
  position: fixed;
  z-index: 9999;
  pointer-events: none;
  opacity: 0.92;
  transform: translate(-50%, -50%);
  box-shadow: 0 12px 24px rgba(24, 40, 68, 0.25);
  border-radius: var(--radius-s);
}

.technique-images-preview.is-dragging .technique-image-item {
  outline: 1px dashed color-mix(in srgb, var(--color-accent) 35%, transparent);
  outline-offset: 4px;
  background: color-mix(in srgb, var(--color-accent) 4%, transparent);
}

.technique-image-item.is-drop-target {
  outline: 2px solid var(--color-accent);
  outline-offset: 4px;
  background: color-mix(in srgb, var(--color-accent) 8%, transparent);
  box-shadow: 0 8px 20px color-mix(in srgb, var(--color-accent) 14%, transparent);
}

.technique-image-item.is-drop-target::after {
  content: attr(data-drop-position);
  position: absolute;
  left: 10px;
  top: 10px;
  padding: 2px 8px;
  border-radius: 999px;
  background: var(--color-accent);
  color: #fff;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  pointer-events: none;
}

.technique-image-item[data-drop-position="before"]::after {
  content: 'ВСТАВИТЬ ДО';
}

.technique-image-item[data-drop-position="after"]::after {
  content: 'ВСТАВИТЬ ПОСЛЕ';
}

.technique-image-order {
  position: absolute;
  top: 6px;
  left: 6px;
  background: rgba(15, 22, 41, 0.7);
  color: #fff;
  font-size: 12px;
  line-height: 1;
  padding: 4px 6px;
  border-radius: 999px;
}

.technique-image-remove {
  position: absolute;
  top: 6px;
  right: 6px;
  --icon-btn-size: 24px;
  --icon-btn-radius: 999px;
  --icon-btn-font: 16px;
  --icon-btn-color: #fff;
  --icon-btn-bg: rgba(218, 30, 40, 0.85);
  --icon-btn-border: none;
  --icon-btn-hover-bg: rgba(218, 30, 40, 1);
  --icon-btn-hover-color: #fff;
  --icon-btn-hover-border: transparent;
}

.technique-image-item img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border-radius: var(--radius-s);
  border: 1px solid var(--color-border);
  background: var(--color-surface);
}

[data-technique-drop].is-dragover {
  outline: 2px dashed var(--color-primary);
  outline-offset: 6px;
  background: color-mix(in srgb, var(--color-primary) 6%, transparent);
}

[data-technique-drop] {
  cursor: default;
}

.field-checkbox {
  flex-direction: row;
  align-items: center;
  gap: var(--space-2);
}

.field-checkbox input[type="checkbox"] {
  width: 22px;
  height: 22px;
}

.client-edit-form {
  margin: var(--space-3) 0;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-m);
  padding: var(--space-3);
  background: color-mix(in srgb, var(--color-surface) 92%, var(--color-bg) 8%);
  box-shadow: var(--shadow-elevated);
}

.client-edit-form.is-collapsed {
  display: none;
}


.field-label.is-hidden {
  visibility: hidden;
  margin-bottom: var(--space-1);
}
.field-note input {
  min-height: 44px;
}

.btn {
  border: 1px solid var(--color-border);
  border-radius: 999px;
  padding: var(--btn-pad-y) var(--btn-pad-x);
  font-size: var(--btn-font-size);
  font-weight: 600;
  font-family: var(--font-mono);
  letter-spacing: var(--subtitle-letter);
  cursor: pointer;
  min-height: var(--btn-min-height);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  text-decoration: none;
  background: rgba(111, 168, 255, 0.08);
  color: var(--color-text);
  margin-block: var(--space-3);
  box-shadow: 0 0 16px rgba(16, 24, 40, 0.25);
  transition:
    transform var(--motion-fast) var(--motion-ease),
    background var(--motion-fast) var(--motion-ease),
    color var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease),
    border-color var(--motion-fast) var(--motion-ease);
}

.btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 0 22px rgba(16, 24, 40, 0.35);
}

.btn:active {
  transform: translateY(1px);
  box-shadow: 0 6px 12px rgba(15, 17, 21, 0.12);
}

.button-grid .btn,
.form-actions .btn {
  margin-block: 0;
}

.form-actions--inline {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: nowrap;
}

.form-actions--inline .btn {
  margin-block: 0;
}

.card-actions {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
}

.plan-card-actions {
  justify-content: flex-start;
}

.plan-card-header {
  justify-content: flex-start;
}

.card-actions .btn {
  margin-block: 0;
}

#admin-login-card form {
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

#admin-login-card form > .btn-primary {
  align-self: flex-end;
}

.client-avatar-block {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin-bottom: var(--space-4);
  padding: var(--space-3);
  border-radius: var(--radius-m);
  background: var(--color-surface-alt);
}

.client-edit-controls {
  margin-left: auto;
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
}

.client-edit-controls .btn {
  margin-block: 0;
}

.profile-avatar-block {
  margin-top: var(--space-3);
}

.profile-avatar-block .avatar-actions {
  display: none;
}

.profile-subtabs {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: var(--space-3);
}

.profile-subtabs .btn {
  margin-block: 0;
}

.profile-subtabs .btn.is-active {
  background: var(--color-accent);
  color: #fff;
  border-color: var(--color-accent);
}

.profile-pane {
  margin-top: var(--space-4);
}

.profile-pane--plans {
  margin-top: var(--space-3);
}

.profile-plans-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(220px, 320px);
  gap: var(--space-4);
  align-items: start;
}

.profile-plans-preview {
  min-height: 200px;
}

.profile-plan-card {
  border-radius: var(--radius-m);
  border: 1px solid var(--color-border);
  background: var(--color-surface-alt);
  padding: var(--space-4);
  display: grid;
  gap: var(--space-3);
}

.profile-set-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-2);
  padding: var(--space-2) 0;
  border-bottom: 1px dashed var(--color-border);
  font-size: 14px;
}

.profile-set-row:last-child {
  border-bottom: none;
}

.profile-set-label {
  font-weight: 600;
  color: var(--color-text);
}

.profile-set-values {
  color: var(--color-text-secondary);
  text-align: right;
}

.profile-plan-header h3 {
  margin: 0 0 var(--space-1);
}

.profile-plan-meta {
  color: var(--color-text-secondary);
  font-size: 14px;
}

.profile-plans-list {
  padding: 2px 0;
  max-height: none;
  overflow: auto;
  background: transparent;
  border: none;
}

.profile-plans-title {
  margin: 0;
  font-size: 16px;
}

.profile-plans-list__items {
  display: grid;
  gap: var(--space-2);
}

.plan-list-item {
  border-radius: var(--radius-s);
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  padding: var(--space-2) var(--space-3);
  text-align: left;
  display: grid;
  gap: var(--space-1);
  cursor: pointer;
  transition: border-color var(--motion-xfast) var(--motion-ease), box-shadow var(--motion-xfast) var(--motion-ease), transform var(--motion-xfast) var(--motion-ease);
}

.plan-list-item:hover {
  border-color: color-mix(in srgb, var(--color-accent) 40%, var(--color-border));
  box-shadow: 0 10px 20px rgba(15, 17, 21, 0.08);
  transform: translateY(-1px);
}

.plan-list-item.is-active {
  border-color: var(--color-accent);
  box-shadow: 0 12px 24px rgba(31, 58, 95, 0.18);
}

.plan-list-item__title {
  font-weight: 600;
}

.plan-list-item__meta {
  color: var(--color-text-secondary);
  font-size: 13px;
}

.profile-plans-preview .exercise-card__sets {
  display: flex;
}

.profile-plans-preview .exercise-card__controls,
.profile-plans-preview .exercise-card__rest,
.profile-plans-preview .exercise-card__save,
.profile-plans-preview .set-ok-button {
  display: none;
}

.profile-plans-preview .set-row {
  opacity: 1;
  pointer-events: none;
}

.profile-plans-preview .set-row input:disabled {
  opacity: 1;
  color: var(--color-text);
  background: var(--color-surface);
}

.profile-plans-preview .exercise-card[data-exercise-state="idle"] .set-row,
.profile-plans-preview .exercise-card[data-exercise-state="finalized"] .set-row {
  opacity: 1;
}

/* Stats */
.stats-card .card-title {
  margin: 0;
}

.stats-header {
  align-items: flex-start;
  gap: var(--space-4);
}

.stats-period-label {
  margin: var(--space-1) 0 0;
  font-size: 14px;
  color: var(--color-text-secondary);
}

.stats-period {
  display: inline-flex;
  gap: var(--space-2);
  flex-wrap: wrap;
}

.stats-period-btn {
  margin-block: 0;
  font-size: 14px;
}

.stats-period-btn.is-active {
  background: var(--color-accent);
  color: #fff;
  border-color: var(--color-accent);
}

.stats-body {
  display: grid;
  gap: var(--space-3);
}

.stats-empty {
  margin-top: var(--space-2);
  padding: var(--space-4);
  border-radius: var(--radius-m);
  border: 1px dashed var(--color-border);
  background: var(--color-surface-alt);
  display: grid;
  gap: var(--space-3);
  text-align: left;
}

.kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: var(--space-3);
}

.kpi-tile {
  border-radius: var(--radius-m);
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  padding: var(--space-3);
  display: grid;
  gap: 6px;
  min-height: 86px;
}

.kpi-label {
  font-size: 13px;
  color: var(--color-text-secondary);
}

.kpi-value {
  font-size: 22px;
  font-weight: 700;
  color: var(--color-text);
}

.stats-section {
  display: grid;
  gap: var(--space-2);
}

.stats-section__title {
  margin: 0;
  font-size: 16px;
  font-weight: 600;
}

.heatmap {
  display: grid;
  gap: var(--space-2);
  position: relative;
}

.heatmap__grid {
  display: grid;
  --heatmap-cell: clamp(12px, 1.6vw, 18px);
  grid-template-rows: repeat(7, var(--heatmap-cell));
  grid-auto-flow: column;
  grid-auto-columns: var(--heatmap-cell);
  gap: 4px;
  align-items: stretch;
  justify-content: start;
}

.heatmap-cell {
  width: 100%;
  height: 100%;
  border-radius: 4px;
  background: var(--color-surface-alt);
  border: 1px solid color-mix(in srgb, var(--color-border) 70%, transparent);
  cursor: pointer;
}

.heatmap-tooltip {
  position: absolute;
  z-index: 5;
  background: var(--color-surface);
  color: var(--color-text);
  border: 1px solid var(--color-border);
  border-radius: 10px;
  padding: 6px 8px;
  font-size: 12px;
  line-height: 1.3;
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.15);
  opacity: 0;
  transform: translateY(4px);
  pointer-events: none;
  transition: opacity var(--motion-fast) var(--motion-ease), transform var(--motion-fast) var(--motion-ease);
}

.heatmap-tooltip.show {
  opacity: 1;
  transform: translateY(0);
}

.heatmap-cell--lvl1 {
  background: color-mix(in srgb, var(--color-accent) 18%, var(--color-surface));
  border-color: color-mix(in srgb, var(--color-accent) 35%, transparent);
}

.heatmap-cell--lvl2 {
  background: color-mix(in srgb, var(--color-accent) 32%, var(--color-surface));
  border-color: color-mix(in srgb, var(--color-accent) 45%, transparent);
}

.heatmap-cell--lvl3 {
  background: color-mix(in srgb, var(--color-accent) 48%, var(--color-surface));
  border-color: color-mix(in srgb, var(--color-accent) 55%, transparent);
}

.heatmap-cell--lvl4 {
  background: color-mix(in srgb, var(--color-accent) 68%, var(--color-surface));
  border-color: color-mix(in srgb, var(--color-accent) 70%, transparent);
}

.heatmap__legend {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: 12px;
  color: var(--color-text-secondary);
}

.heatmap__legend .legend-scale {
  display: inline-flex;
  gap: 4px;
}

.heatmap__legend .legend-cell {
  width: 12px;
  height: 12px;
  border-radius: 4px;
  background: color-mix(in srgb, var(--color-border) 40%, var(--color-surface));
}

.muscle-bars {
  display: grid;
  gap: var(--space-2);
}

.muscle-bar {
  display: grid;
  gap: 6px;
  opacity: 0;
  transform: translateY(4px);
  animation: muscleBarIn var(--motion-slow) var(--motion-ease) forwards;
  animation-delay: var(--muscle-bar-delay, 0ms);
}

.muscle-bar__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  font-size: 14px;
}

.muscle-bar__label {
  font-weight: 600;
}

.muscle-bar__value {
  color: var(--color-text-secondary);
}

.muscle-bar__track {
  position: relative;
  height: 8px;
  border-radius: 999px;
  background: var(--color-surface-alt);
  overflow: hidden;
}

.muscle-bar__fill {
  position: absolute;
  inset: 0 auto 0 0;
  width: 0;
  background: var(--color-accent);
  transition: width var(--motion-slower) var(--motion-ease);
  will-change: width;
}

@keyframes muscleBarIn {
  from {
    opacity: 0;
    transform: translateY(4px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.stats-summary {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: var(--space-2);
  font-size: 14px;
  color: var(--color-text);
}

#stats-heatmap-legend {
  display: none;
}

.stats-summary li {
  padding-left: 18px;
  position: relative;
}

.stats-summary li::before {
  content: '•';
  position: absolute;
  left: 0;
  color: var(--color-accent);
}

.stats-strength-note {
  color: var(--color-text-secondary);
  font-size: 14px;
}

@media (max-width: 700px) {
  .stats-header {
    flex-direction: column;
    align-items: flex-start;
  }
  .kpi-grid {
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  }
  .heatmap__grid {
    --heatmap-cell: 12px;
    gap: 3px;
  }
}

@media (max-width: 900px) {
  .profile-plans-layout {
    grid-template-columns: 1fr;
  }
  .profile-plans-list {
    max-height: none;
  }
}

.profile-avatar-block.editing {
  outline: 2px dashed var(--color-accent);
  outline-offset: 4px;
}

.profile-avatar-block.editing .avatar-actions {
  display: flex;
}

.profile-avatar-block .avatar-actions {
  display: none;
}

.avatar-preview {
  position: relative;
  width: 88px;
  height: 88px;
  border-radius: 50%;
  border: 1px dashed var(--color-border);
  background: var(--color-surface);
  background-size: cover;
  background-position: center;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 32px;
  color: var(--color-muted);
  flex-shrink: 0;
  overflow: hidden;
}

body.client-app .tab-nav__avatar.avatar-preview {
  width: 30px;
  height: 30px;
  font-size: 14px;
}

.avatar-preview.has-avatar {
  border-style: solid;
  border-color: color-mix(in srgb, var(--color-accent) 30%, var(--color-border) 70%);
}

.avatar-preview.is-editing {
  cursor: pointer;
  animation: training-edit-glow var(--motion-glow) var(--motion-ease-loop) infinite;
  box-shadow: 0 0 0 3px rgba(255, 214, 10, 0.45);
  border-color: rgba(255, 214, 10, 0.65);
}

.avatar-preview.is-editing:focus-visible {
  outline: 2px solid rgba(255, 214, 10, 0.75);
  outline-offset: 3px;
}

.avatar-placeholder {
  font-weight: 700;
  line-height: 1;
}

.avatar-preview.has-avatar .avatar-placeholder {
  opacity: 0;
}

.avatar-highlight {
  border-style: dashed;
  border-color: rgba(255, 214, 10, 0.75);
  animation: training-edit-glow var(--motion-glow-fast) var(--motion-ease-loop) infinite;
}

.avatar-hint {
  margin-top: var(--space-1);
  font-size: 12px;
  color: var(--color-muted);
}

.avatar-actions {
  display: grid;
  gap: var(--space-2);
}

.avatar-cropper {
  display: grid;
  gap: var(--space-3);
  align-items: center;
  justify-items: center;
}

.avatar-cropper.is-hidden {
  display: none;
}

.avatar-cropper__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  justify-content: center;
  margin-bottom: var(--space-2);
  width: 100%;
}

#avatar-cropper .avatar-cropper__actions .btn,
.avatar-cropper__actions .btn {
  flex: 1 1 140px;
  min-width: 110px;
}

#avatar-crop-empty {
  text-align: center;
}

.avatar-cropper__frame {
  width: min(260px, 70vw);
  aspect-ratio: 1;
  border-radius: 24px;
  background: var(--color-surface-alt);
  border: 1px solid var(--color-border);
  overflow: hidden;
  position: relative;
  touch-action: none;
}

.avatar-cropper__frame img {
  position: absolute;
  top: 0;
  left: 0;
  transform-origin: top left;
  user-select: none;
  -webkit-user-drag: none;
  max-width: none;
}

.avatar-cropper__controls {
  width: min(320px, 80vw);
  display: grid;
  gap: var(--space-2);
}

/* Taxonomy combobox */
.taxonomy-field {
  position: relative;
}
.taxonomy-input {
  width: 100%;
}
.taxonomy-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  margin-top: 6px;
  border-radius: 12px;
  background: var(--pill-bg, #eef3ff);
  color: var(--pill-fg, #1a3b7a);
  font-size: 13px;
  flex: 0 0 auto;
  width: fit-content;
  max-width: 100%;
  white-space: nowrap;
}
.field-label-row {
  display: flex;
  align-items: center;
  gap: 8px;
  pointer-events: none !important;
}
.field-label-hint {
  font-size: 12px;
  color: var(--color-text-secondary);
}
.field-help-btn {
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  color: var(--color-text);
  border-radius: 50%;
  width: 22px;
  height: 22px;
  font-size: 12px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  padding: 0;
  flex: 0 0 auto;
  position: relative;
  z-index: 1;
  pointer-events: auto;
}
.field-help-btn:hover {
  background: rgba(26, 59, 122, 0.08);
}

.experience-flash {
  animation: experience-flash var(--motion-pulse) var(--motion-ease-loop);
}

@keyframes experience-flash {
  0% { background-color: transparent; }
  20% { background-color: rgba(255, 200, 120, 0.25); }
  60% { background-color: rgba(255, 200, 120, 0.15); }
  100% { background-color: transparent; }
}

#client-create-level-hint,
#client-edit-level-hint {
  display: none;
}

.experience-flash {
  animation: experience-flash var(--motion-pulse) var(--motion-ease-loop);
}

@keyframes experience-flash {
  0% { background-color: transparent; }
  20% { background-color: rgba(255, 200, 120, 0.25); }
  60% { background-color: rgba(255, 200, 120, 0.15); }
  100% { background-color: transparent; }
}
.help-modal__body {
  font-size: 14px;
  color: var(--color-text);
  line-height: 1.5;
  padding: 8px 0;
  white-space: pre-line;
}
.taxonomy-chip__clear {
  border: none;
  background: transparent;
  cursor: pointer;
  font-size: 14px;
  line-height: 1;
  color: inherit;
  padding: 0 2px;
}
.taxonomy-list {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  z-index: 5;
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: 10px;
  box-shadow: 0 8px 24px rgba(16, 24, 40, 0.12);
  max-height: 240px;
  overflow: auto;
  padding: 4px 0;
}
.taxonomy-list[hidden] {
  display: none !important;
  pointer-events: none;
}
.taxonomy-list__item {
  padding: 8px 12px;
  cursor: pointer;
}
.taxonomy-list__item:hover,
.taxonomy-list__item:focus {
  background: rgba(26, 59, 122, 0.08);
}

.taxonomy-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 6px;
  align-items: center;
}
.taxonomy-chip--multi {
  margin-top: 0;
}

.field--compact .field-label {
  font-size: 12px;
  letter-spacing: 0.04em;
}

@media (max-width: 720px) {
  .client-avatar-block {
    flex-direction: column;
    align-items: flex-start;
  }
  .avatar-actions {
    width: 100%;
  }
}

.btn-primary {
  background: var(--color-accent);
  border-color: color-mix(in srgb, var(--color-accent) 75%, #000000 25%);
  color: #0b1321;
  box-shadow: 0 0 20px rgba(109, 168, 255, 0.35);
}

.btn-primary:hover {
  background: color-mix(in srgb, var(--color-accent) 88%, #ffffff 12%);
  border-color: color-mix(in srgb, var(--color-accent) 80%, #000000 20%);
  box-shadow: 0 0 26px rgba(109, 168, 255, 0.45);
  transform: translateY(-0.5px);
}

.btn-primary:active {
  transform: translateY(0.5px);
}

.btn-secondary {
  background: rgba(111, 168, 255, 0.08);
  border-color: var(--color-border);
  color: var(--color-text);
}

.btn-secondary:hover {
  background: rgba(111, 168, 255, 0.14);
}

.btn-outline {
  background: transparent;
  border: 1px solid color-mix(in srgb, var(--color-accent) 70%, transparent);
  color: var(--color-accent);
}

.btn-outline:hover {
  background: rgba(111, 168, 255, 0.12);
}

.btn-toggle {
  display: inline-flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  align-items: center;
}

.btn-toggle .btn.is-active {
  background: var(--color-accent);
  color: #fff;
  border-color: var(--color-accent);
}

.btn--active {
  border: 1px solid color-mix(in srgb, var(--color-accent) 80%, transparent);
  background: color-mix(in srgb, var(--color-accent) 16%, var(--color-surface) 84%);
  color: var(--color-accent);
  box-shadow: 0 6px 14px rgba(15, 17, 21, 0.1);
}

.btn-danger {
  background: var(--color-error);
  border-color: var(--color-error);
  color: #fff;
  box-shadow: var(--shadow-button);
  background-image: linear-gradient(180deg,
      color-mix(in srgb, var(--color-error) 88%, #ffffff 12%) 0%,
      color-mix(in srgb, var(--color-error) 94%, #000000 6%) 100%);
}

.btn-ghost {
  background: linear-gradient(180deg,
      color-mix(in srgb, var(--color-error-weak) 60%, transparent) 0%,
      color-mix(in srgb, var(--color-error-weak) 50%, transparent) 100%);
  color: var(--color-error);
  border: 1px solid color-mix(in srgb, var(--color-error) 45%, transparent);
  box-shadow: var(--shadow-button);
}

.btn-close {
  background: linear-gradient(180deg,
      color-mix(in srgb, var(--color-error) 14%, var(--color-surface) 86%) 0%,
      color-mix(in srgb, var(--color-error) 10%, var(--bg-elevated) 90%) 100%);
  border-color: color-mix(in srgb, var(--color-error) 65%, transparent);
  color: var(--color-error);
  padding: var(--space-2) var(--space-3);
  min-width: 44px;
  gap: 0;
  box-shadow: var(--shadow-button);
}

.btn-close .icon-close {
  font-size: 1.2em;
}

.btn-close:hover,
.btn-close:focus-visible {
  color: #fff;
  background: linear-gradient(180deg,
      color-mix(in srgb, var(--color-error) 40%, var(--color-surface) 60%) 0%,
      color-mix(in srgb, var(--color-error) 45%, var(--bg-elevated) 55%) 100%);
  border-color: color-mix(in srgb, var(--color-error) 85%, transparent);
}

.btn-danger:hover,
.btn-danger:focus-visible {
  color: #fff;
  background: color-mix(in srgb, var(--color-error) 88%, #000000 12%);
  background-image: linear-gradient(180deg,
      color-mix(in srgb, var(--color-error) 40%, var(--color-surface) 60%) 0%,
      color-mix(in srgb, var(--color-error) 45%, var(--bg-elevated) 55%) 100%);
  border-color: color-mix(in srgb, var(--color-error) 85%, transparent);
}

.card.is-editing {
  animation: training-edit-glow var(--motion-glow) var(--motion-ease-loop) infinite;
  box-shadow: 0 0 0 3px rgba(255, 214, 10, 0.45);
}

.result-card.is-editing {
  border-color: rgba(255, 214, 10, 0.65);
}

.btn-editing {
  background: linear-gradient(180deg,
      rgba(255, 214, 10, 0.18) 0%,
      rgba(255, 214, 10, 0.28) 100%);
  border-color: rgba(255, 214, 10, 0.65);
  color: var(--color-text);
  box-shadow: 0 12px 24px rgba(255, 214, 10, 0.25), 0 2px 4px rgba(15, 17, 21, 0.1);
}

.btn-editing:hover {
  background: linear-gradient(180deg,
      rgba(255, 214, 10, 0.26) 0%,
      rgba(255, 214, 10, 0.36) 100%);
  box-shadow: 0 16px 28px rgba(255, 214, 10, 0.32), 0 3px 6px rgba(15, 17, 21, 0.12);
}

@keyframes training-edit-glow {
  0%, 100% {
    box-shadow: 0 0 0 3px rgba(255, 214, 10, 0.25), 0 8px 30px rgba(15, 17, 21, 0.08);
  }
  50% {
    box-shadow: 0 0 0 5px rgba(255, 214, 10, 0.45), 0 12px 36px rgba(15, 17, 21, 0.12);
  }
}

@media (prefers-reduced-motion: reduce) {
  .card.is-editing {
    animation: none;
    box-shadow: 0 0 0 4px rgba(255, 214, 10, 0.4);
  }
}

@keyframes modalFadeIn {
  from {
    opacity: 1;
  }
  to {
    opacity: 1;
  }
}

@keyframes modalDialogIn {
  from {
    transform: translateY(14px) scale(0.98);
  }
  to {
    transform: translateY(0) scale(1);
  }
}

@keyframes listItemIn {
  from {
    opacity: 0;
    transform: translateY(6px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes panelReveal {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .modal,
  .modal__dialog,
  .list > *,
  .workout-chip,
  .plan-subpanel,
  .profile-pane,
  .client-edit-form {
    animation: none !important;
    transition: none !important;
  }
}

.modal {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
  z-index: calc(var(--modal-z, 200) + var(--modal-stack, 0));
  overflow-y: auto;
  overscroll-behavior: contain;
  opacity: 1;
  animation: modalFadeIn var(--motion-regular) var(--motion-ease) forwards;
}

#plan-list-modal,
#client-plan-list-modal {
  --modal-z: 210;
}

#profile-plan-modal,
#plan-preview-modal {
  --modal-z: 220;
}

#calendar-plan-hint-modal {
  background: transparent;
  --modal-z: 9010;
}

#calendar-plan-hint-modal .modal__dialog {
  position: fixed;
  width: min(168px, 56vw);
  padding: var(--space-3);
  background: var(--color-surface);
  border: 1px solid rgba(42, 51, 66, 0.65);
  box-shadow: 0 16px 32px rgba(15, 17, 21, 0.18);
  cursor: pointer;
  transition: box-shadow var(--motion-regular) var(--motion-ease), border-color var(--motion-regular) var(--motion-ease), transform var(--motion-regular) var(--motion-ease);
}

@media (prefers-color-scheme: dark) {
  #calendar-plan-hint-modal .modal__dialog {
    border-color: rgba(190, 200, 215, 0.35);
  }
}

#admin-calendar-modal .modal__title {
  display: none;
}

#admin-calendar-modal .modal__header {
  justify-content: flex-end;
}

.calendar-hint--pulse {
  animation: training-edit-glow var(--motion-glow) var(--motion-ease-loop) infinite;
}

#calendar-plan-hint-modal .modal__dialog:hover {
  border-color: color-mix(in srgb, var(--color-accent) 45%, rgba(42, 51, 66, 0.35));
  box-shadow: 0 20px 36px rgba(15, 17, 21, 0.22);
  transform: translateY(-1px);
}

.calendar-hint {
  display: grid;
  gap: var(--space-1);
}

.calendar-hint__label {
  margin: 0;
  font-size: 12px;
  text-transform: none;
  letter-spacing: 0.04em;
  color: var(--color-warning);
}

.calendar-hint__title {
  margin: 0;
  font-size: 15px;
  font-weight: 600;
  color: var(--color-text);
}

.modal[hidden] {
  display: none !important;
}

.modal__backdrop {
  position: absolute;
  inset: 0;
  cursor: pointer;
}

.modal__dialog {
  background: var(--color-surface);
  border-radius: var(--radius-m);
  box-shadow: var(--shadow-elevated);
  width: min(480px, 100%);
  max-height: 90vh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-4);
  position: relative;
  z-index: 1;
  opacity: 1;
  animation: modalDialogIn var(--motion-medium) var(--motion-ease) forwards;
}

.modal__dialog--wide {
  width: min(820px, 100%);
}

.list > *,
.workout-chip,
.plan-preview-exercise {
  animation: listItemIn var(--motion-regular) var(--motion-ease) both;
}

.plan-subpanel.is-active,
.profile-pane:not([hidden]),
.client-edit-form:not(.is-collapsed) {
  animation: panelReveal var(--motion-medium) var(--motion-ease) both;
}

.modal__body {
  overscroll-behavior: contain;
}

.modal__body--scrollbar {
  scrollbar-gutter: stable;
  padding-right: var(--space-2);
}

#profile-plan-modal .modal__body {
  flex: 1 1 auto;
  min-height: 0;
  overflow: auto;
  overscroll-behavior: contain;
}

#plan-preview-modal .modal__body {
  flex: 1 1 auto;
  min-height: 0;
  overflow: auto;
  overscroll-behavior: contain;
}

.technique-image-modal__body {
  display: flex;
  justify-content: center;
  align-items: center;
  max-height: 70vh;
  overflow: auto;
}

.technique-image-modal__body img {
  max-width: 100%;
  height: auto;
  border-radius: var(--radius-s);
  border: 1px solid var(--color-border);
  background: var(--color-surface);
}

.modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
}

.modal__header-main {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  min-width: 0;
}

.modal__header-filter {
  display: inline-flex;
  align-items: center;
  margin: 0;
}

.modal__header-select {
  appearance: none;
  border: 1px solid var(--color-border);
  border-radius: 999px;
  background: var(--color-surface);
  color: var(--color-text);
  font-size: 14px;
  padding: 6px 28px 6px 12px;
  line-height: 1.1;
  min-width: 160px;
  max-width: 210px;
  background-image: linear-gradient(45deg, transparent 50%, var(--color-text-muted) 50%),
    linear-gradient(135deg, var(--color-text-muted) 50%, transparent 50%),
    linear-gradient(to right, transparent, transparent);
  background-position: calc(100% - 16px) calc(50% - 2px),
    calc(100% - 11px) calc(50% - 2px),
    0 0;
  background-size: 5px 5px, 5px 5px, 100% 100%;
  background-repeat: no-repeat;
}

.modal__header-select:focus {
  outline: none;
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.15);
}

.modal__title {
  margin: 0;
  font-size: 20px;
}

#profile-plan-modal .profile-plan-card,
#plan-preview-modal .profile-plan-card {
  border: 0;
  background: transparent;
  padding: 0;
  box-shadow: none;
}

#profile-plan-modal .exercise-card,
#plan-preview-modal .exercise-card {
  border: 1px solid var(--color-border);
  box-shadow: 0 10px 20px rgba(15, 17, 21, 0.08);
  background: var(--color-surface);
  padding: var(--space-3);
  border-radius: var(--radius-s);
}

#profile-plan-modal .exercise-card + .exercise-card,
#plan-preview-modal .exercise-card + .exercise-card {
  margin-top: var(--space-3);
}

#profile-plan-modal .exercise-technique,
#plan-preview-modal .exercise-technique {
  border: 0;
  background: transparent;
  padding: var(--space-2) 0 0;
}

#profile-plan-modal .exercise-technique__header,
#plan-preview-modal .exercise-technique__header {
  border-bottom: 1px solid var(--color-border);
  padding-bottom: var(--space-2);
}



.modal__close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--color-error);
}

.modal__close .icon-close {
  font-size: 26px;
}

.modal__close:hover,
.modal__close:focus-visible {
  color: #fff;
  background: color-mix(in srgb, var(--color-error) 16%, var(--color-surface));
}

.calendar {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.calendar__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}

.calendar__month {
  font-weight: 600;
  text-transform: capitalize;
}

.calendar__weekdays,
.calendar__grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: var(--space-2);
}

.calendar__weekday {
  text-align: center;
  font-size: 14px;
  color: var(--color-text-secondary);
}

.calendar-day {
  position: relative;
  border-radius: var(--radius-s);
  min-height: 64px;
  padding: var(--space-2);
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  align-items: flex-start;
  justify-content: flex-start;
  background: color-mix(in srgb, var(--color-surface) 85%, var(--color-bg));
  border: 1px solid transparent;
}

.calendar-day__number {
  font-weight: 600;
  font-size: 16px;
}

.calendar-day__status {
  font-size: 12px;
  color: var(--color-text-secondary);
  text-transform: uppercase;
}

.calendar-day--muted {
  opacity: 0.4;
}

.calendar-day--today {
  border-color: var(--color-accent);
}

.calendar-day--selectable {
  cursor: pointer;
}

.calendar-day--selected {
  border-color: var(--color-accent);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--color-accent) 60%, transparent) inset;
}

.calendar-day--completed {
  background: color-mix(in srgb, var(--color-success) 25%, var(--color-surface));
  color: var(--color-text);
}

.calendar-day--planned {
  background: color-mix(in srgb, var(--color-warning) 30%, var(--color-surface));
  color: var(--color-text);
}

.calendar-day--missed {
  background: color-mix(in srgb, var(--color-error) 20%, var(--color-surface));
  color: var(--color-text);
}

.calendar__legend {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  font-size: 13px;
  color: var(--color-text-secondary);
}

.calendar__actions {
  margin-top: var(--space-3);
  display: flex;
  justify-content: center;
  gap: var(--space-2);
  flex-wrap: wrap;
}

#client-calendar-modal .modal__dialog,
#admin-calendar-modal .modal__dialog {
  max-height: calc(100vh - var(--space-6));
  overflow: auto;
  gap: var(--space-2);
  padding: var(--space-3);
}

#client-calendar-modal .calendar,
#admin-calendar-modal .calendar {
  gap: var(--space-2);
}

#client-calendar-modal .calendar__weekdays,
#admin-calendar-modal .calendar__weekdays {
  font-size: 12px;
}

#client-calendar-modal .calendar-day,
#admin-calendar-modal .calendar-day {
  min-height: 56px;
  padding: var(--space-1);
}

#client-calendar-modal .calendar__legend,
#admin-calendar-modal .calendar__legend {
  gap: var(--space-1);
  font-size: 12px;
}

#client-calendar-modal .calendar__actions .btn {
  margin-block: 0;
  width: 100%;
  max-width: 260px;
}

#admin-calendar-modal[data-context="client"] #calendar-select-date {
  display: none;
}

#admin-calendar-modal[data-context="client"] .modal__title {
  display: none;
}

#admin-calendar-modal[data-context="client"] .modal__header {
  justify-content: flex-end;
}

.calendar-legend {
  display: inline-block;
  width: 16px;
  height: 16px;
  border-radius: var(--radius-s);
  margin-right: var(--space-1);
  vertical-align: middle;
}

.calendar-legend--completed {
  background: color-mix(in srgb, var(--color-success) 60%, transparent);
}

.calendar-legend--planned {
  background: color-mix(in srgb, var(--color-warning) 60%, transparent);
}

.calendar-legend--missed {
  background: color-mix(in srgb, var(--color-error) 60%, transparent);
}

.calendar-selected-date {
  margin: var(--space-2) 0 0;
  font-weight: 600;
  color: var(--color-text-secondary);
}

@media (max-height: 760px) {
  #client-calendar-modal .modal__dialog {
    max-height: 96vh;
    padding: var(--space-3);
  }

  #client-calendar-modal .calendar {
    gap: var(--space-2);
  }

  #client-calendar-modal .calendar-day {
    min-height: 52px;
  }
}

.plan-details {
  margin-top: var(--space-2);
}

.plan-details__summary {
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-s);
  border: 1px solid color-mix(in srgb, var(--color-border) 75%, transparent);
  background: color-mix(in srgb, var(--color-surface) 92%, var(--color-border));
  cursor: pointer;
}

.plan-details__summary::-webkit-details-marker {
  display: none;
}

.plan-details__summary::after {
  content: '▾';
  color: var(--color-text-tertiary);
  font-size: 14px;
  line-height: 1;
  transition: transform var(--motion-fast) var(--motion-ease);
}

.plan-details[open] .plan-details__summary::after {
  transform: rotate(180deg);
}

.plan-details__summary-text {
  color: var(--color-text-secondary);
  font-size: 14px;
}

.plan-details__content {
  margin-top: var(--space-3);
}

.btn:active {
  transform: scale(0.98);
}

.hint {
  margin: 0;
  color: var(--color-text-secondary);
  font-size: 14px;
}

.plan-date-warning {
  color: var(--color-error);
  font-weight: 600;
  opacity: 0;
  transition: opacity var(--motion-medium) var(--motion-ease);
}

.plan-date-warning.is-visible {
  opacity: 1;
}

.plan-date-warning.is-flashing {
  animation: plan-date-warning-pulse var(--motion-pulse) var(--motion-ease-loop) 2;
}

.plan-mode {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-m);
  background: var(--color-surface-muted);
  color: var(--color-text-secondary);
  font-size: 13px;
}

.plan-mode__label {
  font-weight: 600;
  color: var(--color-text-primary);
}

.plan-mode__meta {
  color: var(--color-text-tertiary);
}

.plan-workflow {
  margin-top: var(--space-2);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-m);
  background: var(--color-surface-muted);
  display: grid;
  gap: var(--space-2);
}

.plan-workflow .field-label {
  font-size: 12px;
  color: var(--color-text-secondary);
}

.plan-workflow.is-locked {
  opacity: 0.7;
}

.plan-client-fields.is-locked {
  opacity: 0.7;
}

@keyframes plan-date-warning-pulse {
  0%,
  100% {
    opacity: 1;
  }
  50% {
    opacity: 0.2;
  }
}

#plan-calendar-button[data-locked="true"] {
  cursor: not-allowed;
  opacity: 0.7;
}

#plan-calendar-button[data-locked="true"]:focus-visible {
  box-shadow: 0 0 0 3px rgba(255, 59, 48, 0.4);
}

.error {
  color: var(--color-error);
  margin-top: var(--space-2);
}

.status {
  margin-top: var(--space-2);
  color: var(--color-success);
  font-size: 15px;
}

.status.error {
  color: var(--color-error);
}

.button-grid {
  display: grid;
  gap: var(--space-3);
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.button-grid .btn {
  width: 100%;
  justify-self: stretch;
  text-align: center;
}

.plan-body,
.result-list,
.list,
.entry-grid {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.plan-overview {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.plan-overview__line {
  margin: 0;
  color: var(--color-text-secondary);
  font-size: 15px;
}

.plan-overview__notes {
  margin: var(--space-2) 0 0;
  color: var(--color-text);
  white-space: pre-line;
}

.plan-overview__fact {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: 0;
  border: 0;
  background: none;
  color: var(--color-text-secondary);
  font-size: 15px;
  cursor: pointer;
  text-align: left;
}

.plan-overview__fact:hover,
.plan-overview__fact:focus-visible {
  color: var(--color-text);
}

.plan-overview__fact-link {
  color: var(--color-accent);
  font-weight: 600;
}

/* Сохраняем переносы строк/форматирование в текстовых полях при отображении */
.field textarea {
  white-space: pre-line;
}

.plan-overview__hint {
  margin: var(--space-2) 0 0;
  color: var(--color-text-tertiary);
  font-size: 14px;
}

.client-item {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.client-item__header {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: var(--space-3);
  align-items: flex-start;
}

.client-item__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.client-item__actions .btn {
  margin-block: 0;
  min-width: 0;
}

.client-item__badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  margin-top: var(--space-1);
  padding: var(--space-1) var(--space-2);
  border-radius: 999px;
  font-size: 12px;
  background: rgba(255, 204, 0, 0.16);
  color: #8c6f00;
}

.client-item__login {
  font-size: 13px;
  margin-top: 0.25rem;
  color: var(--text-muted, #555);
}

.client-item__login-value {
  font-weight: 600;
  color: var(--text-primary, #111);
}

.client-item__temp-pin {
  margin-top: 0.2rem;
  font-size: 13px;
  color: var(--color-accent, #007aff);
}

.client-item__temp-pin span {
  font-weight: 600;
}

.plan-summary {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.plan-summary li {
  display: grid;
  grid-template-columns: minmax(80px, auto) 1fr auto;
  gap: var(--space-2);
  align-items: center;
  font-size: 14px;
}

.plan-summary__date {
  font-weight: 600;
}

.plan-summary__status {
  padding: var(--space-1) var(--space-2);
  border-radius: 999px;
  font-size: 12px;
  background: rgba(0, 122, 255, 0.12);
  color: var(--color-accent);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.plan-summary__status--planned {
  background: rgba(0, 122, 255, 0.12);
  color: var(--color-accent);
}

.plan-summary__status--completed {
  background: rgba(52, 199, 89, 0.12);
  color: var(--color-success);
}

.plan-summary__status--skipped {
  background: rgba(255, 59, 48, 0.12);
  color: var(--color-error);
}

.plan-summary__status--done {
  background: rgba(52, 199, 89, 0.12);
  color: var(--color-success);
}

.superset {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-s);
  padding: var(--space-4);
  background: color-mix(in srgb, var(--color-surface) 90%, var(--color-accent) 10%);
}

.superset__entries {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-top: var(--space-3);
}

.superset-entry {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
  font-size: 14px;
}

.superset-entry__order {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 28px;
  height: 28px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--color-accent) 12%, transparent);
  color: var(--color-accent);
  font-weight: 600;
  font-size: 13px;
}

.superset-entry__name {
  font-weight: 500;
}

.superset-entry__prescribed {
  color: var(--color-text-secondary);
  font-size: 13px;
}

.superset-entry--combined {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.superset-entry__combined-line {
  font-size: 14px;
  color: var(--color-text);
}

.superset-entry__plus-line {
  font-weight: 700;
  color: var(--color-text-secondary);
}

.client-details-meta {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: var(--space-2);
  margin-bottom: var(--space-3);
  font-size: 14px;
  color: var(--color-text-secondary);
}

.client-details-login {
  grid-column: 1 / -1;
  font-size: 16px;
  font-weight: 600;
  color: var(--color-text-primary, #111);
}

.client-details-temp-pin {
  grid-column: 1 / -1;
  font-size: 16px;
  font-weight: 600;
  color: var(--color-accent, #007aff);
}

.superset-editor__title {
  font-weight: 600;
}

.superset-editor__actions {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.superset-reorder {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.superset-reorder__btn {
  --icon-btn-size: 28px;
  --icon-btn-radius: var(--radius-s);
  --icon-btn-font: 14px;
  --icon-btn-color: var(--color-text-secondary);
  --icon-btn-bg: transparent;
  --icon-btn-border: 1px solid var(--color-border);
  --icon-btn-hover-bg: transparent;
  --icon-btn-hover-color: var(--color-accent);
  --icon-btn-hover-border: var(--color-accent);
  --icon-btn-hover-shadow: none;
  font-weight: 600;
}

.superset-reorder__btn:disabled {
  opacity: 0.4;
  cursor: default;
}

.superset-toggle {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  font-size: 14px;
  color: var(--color-text-secondary);
}

.superset-toggle input {
  width: 20px;
  height: 20px;
}

.superset-editor__alert {
  margin: var(--space-2) 0;
  font-weight: 600;
  color: var(--color-warning);
}

.superset-editor__sets {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  flex-wrap: wrap;
  margin-bottom: var(--space-3);
}

.set-stepper {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  background: color-mix(in srgb, var(--color-surface) 96%, transparent);
  border-radius: var(--radius-s);
  padding: var(--space-1) var(--space-2);
  border: 1px solid var(--color-border);
}

.set-stepper button {
  width: 32px;
  height: 32px;
  border: none;
  border-radius: var(--radius-s);
  background: var(--color-surface);
  font-size: 20px;
  line-height: 1;
  cursor: pointer;
}

.set-stepper input {
  width: 56px;
  border: none;
  text-align: center;
  font-size: 16px;
  background: transparent;
}

.set-stepper input:focus-visible {
  outline: none;
}

.superset-title {
  font-weight: 600;
}

.superset-meta {
  font-size: 14px;
  color: var(--color-text-secondary);
}

.exercise-card__controls {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
  justify-content: flex-start;
}

.exercise-card__launch {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 10px 14px;
  border-radius: 999px;
  border: none;
  background: var(--color-accent);
  color: #fff;
  font-weight: 600;
  font-size: 14px;
  cursor: pointer;
  box-shadow: var(--shadow-soft);
  transition: background var(--motion-fast) var(--motion-ease), box-shadow var(--motion-fast) var(--motion-ease);
}

.exercise-card__launch:hover,
.exercise-card__launch:focus-visible {
  background: var(--color-accent);
  box-shadow: var(--shadow-soft);
  transform: none;
}

.exercise-card__launch-text {
  white-space: nowrap;
}

.exercise-card__launch-arrow {
  display: inline-block;
  font-size: 18px;
  transition: transform var(--motion-slow) var(--motion-ease);
}

.exercise-card__launch.is-launching .exercise-card__launch-arrow {
  transform: translateX(6px);
}

.exercise-card__save {
  align-self: flex-start;
  margin-block: 0;
}

.exercise-card__sets .exercise-card__save {
  margin-top: var(--space-2);
}

.exercise-rest {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 8px 12px;
  border-radius: var(--radius-s);
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  box-shadow: var(--shadow-soft);
  max-width: 100%;
  flex-wrap: wrap;
}

.exercise-card__rest {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-2);
}

.exercise-rest__meta {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.exercise-rest__caption {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.3px;
  color: var(--color-text-secondary);
}

.exercise-rest__label {
  font-size: 13px;
  font-weight: 600;
  color: var(--color-text);
}

.exercise-rest__timer {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border: none;
  background: color-mix(in srgb, var(--color-surface) 85%, transparent);
  padding: 6px 10px;
  font-size: 22px;
  font-weight: 700;
  color: var(--color-text);
  cursor: pointer;
  border-radius: var(--radius-s);
}

.exercise-rest__timer:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--color-accent) 35%, transparent);
  outline-offset: 4px;
  border-radius: var(--radius-s);
}

.exercise-rest__timer.is-disabled {
  opacity: 0.6;
  cursor: default;
}

.exercise-rest__unit {
  font-size: 12px;
  font-weight: 600;
  color: var(--color-text-secondary);
}

.exercise-rest__reset {
  font-size: 18px;
  color: var(--color-accent);
  margin-left: 4px;
}

.exercise-rest.rest-state-ok,
.exercise-card--active .exercise-card__rest.rest-state-ok {
  background: color-mix(in srgb, var(--color-success) 60%, var(--bg));
  border-color: color-mix(in srgb, var(--color-success) 65%, var(--color-border));
}

.exercise-rest.rest-state-warn,
.exercise-card--active .exercise-card__rest.rest-state-warn {
  background: color-mix(in srgb, var(--color-warning) 58%, var(--bg));
  border-color: color-mix(in srgb, var(--color-warning) 65%, var(--color-border));
}

.exercise-rest.rest-state-alert,
.exercise-card--active .exercise-card__rest.rest-state-alert {
  background: color-mix(in srgb, var(--danger) 52%, var(--bg));
  border-color: color-mix(in srgb, var(--danger) 70%, var(--color-border));
}

.exercise-rest.rest-state-expired,
.exercise-card--active .exercise-card__rest.rest-state-expired {
  background: color-mix(in srgb, var(--danger) 65%, var(--bg));
  border-color: var(--danger);
}

.exercise-rest.rest-state-ok .exercise-rest__timer {
  background: color-mix(in srgb, var(--color-success) 55%, var(--color-surface));
}

.exercise-rest.rest-state-warn .exercise-rest__timer {
  background: color-mix(in srgb, var(--color-warning) 60%, var(--color-surface));
}

.exercise-rest.rest-state-alert .exercise-rest__timer {
  background: color-mix(in srgb, var(--danger) 55%, var(--color-surface));
}

.exercise-rest.rest-state-expired .exercise-rest__timer {
  background: color-mix(in srgb, var(--danger) 70%, var(--color-surface));
}

.exercise-rest.rest-state-blink {
  animation: rest-expired-blink var(--motion-pulse) var(--motion-ease-loop) infinite;
}

.exercise-card {
  position: relative;
  border-radius: var(--radius-m);
  border: 1px solid color-mix(in srgb, var(--color-accent) 14%, transparent);
  padding: var(--space-4);
  background: color-mix(in srgb, var(--color-surface) 97%, var(--color-accent) 3%);
  box-shadow: var(--shadow-elevated);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  max-width: 100%;
}

.exercise-card[data-exercise-state="idle"] {
  background: color-mix(in srgb, var(--color-surface) 96%, var(--color-text-secondary) 6%);
  opacity: 0.9;
}

.exercise-card__header {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.exercise-card--active .exercise-card__rest {
  position: sticky;
  top: 12px;
  z-index: 12;
  background: color-mix(in srgb, var(--color-surface) 97%, var(--color-accent) 3%);
  padding: var(--space-2) var(--space-3);
}

.exercise-card__status {
  display: none;
  align-items: center;
  gap: var(--space-2);
  font-size: 13px;
  color: var(--color-text-secondary);
  margin-bottom: 2px;
}

.exercise-card__active-label {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: 0;
  border-radius: 0;
  background: transparent;
  color: var(--color-text-secondary);
  font-weight: 600;
}

.exercise-card--active .exercise-card__status {
  display: flex;
}

.exercise-card__title {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: 16px;
  font-weight: 600;
}

.exercise-card__name-btn,
.superset-header__name-btn {
  background: none;
  border: none;
  padding: 0;
  margin: 0;
  font: inherit;
  color: inherit;
  cursor: pointer;
  text-align: left;
  display: inline;
}

.exercise-card__info-btn {
  width: 26px;
  height: 26px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--color-warning) 55%, var(--color-border));
  background: color-mix(in srgb, var(--color-surface) 92%, var(--color-warning) 8%);
  color: var(--color-warning);
  font-weight: 700;
  font-size: 13px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: border-color var(--motion-medium) var(--motion-ease), color var(--motion-medium) var(--motion-ease), transform var(--motion-medium) var(--motion-ease);
}

.exercise-card__info-btn:hover {
  color: var(--color-warning);
  border-color: var(--color-warning);
  transform: translateY(-1px);
}

.exercise-card__info-btn.is-hidden {
  visibility: hidden;
  pointer-events: none;
}

.exercise-card__technique {
  margin-top: var(--space-2);
  display: grid;
  gap: var(--space-2);
}

.exercise-technique {
  border-radius: var(--radius-s);
  border: 1px dashed color-mix(in srgb, var(--color-accent) 30%, var(--color-border));
  background: color-mix(in srgb, var(--color-surface) 92%, var(--color-accent) 8%);
  padding: var(--space-3);
  display: grid;
  gap: var(--space-2);
  cursor: pointer;
  max-height: 720px;
  opacity: 1;
  transform: translateY(0);
  overflow: hidden;
  transition:
    max-height var(--motion-medium) var(--motion-ease),
    opacity var(--motion-fast) var(--motion-ease),
    transform var(--motion-fast) var(--motion-ease),
    padding-top var(--motion-fast) var(--motion-ease),
    padding-bottom var(--motion-fast) var(--motion-ease),
    border-color var(--motion-fast) var(--motion-ease);
}

.exercise-technique.is-collapsed {
  max-height: 0;
  opacity: 0;
  transform: translateY(-4px);
  padding-top: 0;
  padding-bottom: 0;
  border-width: 0;
  border-color: transparent;
  pointer-events: none;
}

.exercise-technique.no-motion {
  transition: none !important;
}

.exercise-technique__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  font-size: 12px;
  font-weight: 600;
  color: var(--color-text-secondary);
}

.exercise-technique__close {
  width: 28px;
  height: 28px;
  padding: 0;
  border-radius: 999px;
}

.exercise-technique__text {
  font-size: 14px;
  line-height: 1.45;
  color: var(--color-text-primary);
}

.exercise-technique__images {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--space-2);
}

.exercise-technique__images img {
  width: 100%;
  border-radius: var(--radius-s);
  border: 1px solid var(--color-border);
  object-fit: cover;
  background: var(--color-surface);
}

.exercise-card__badge {
  position: absolute;
  top: var(--space-3);
  right: var(--space-3);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 4px 10px;
  min-height: 24px;
  border-radius: 999px;
  background: var(--color-warning);
  color: #fff;
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.2px;
}

.exercise-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  align-items: center;
  color: var(--color-text-secondary);
  font-size: 13px;
}

.exercise-card__result-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--space-1);
  font-size: 13px;
  color: var(--color-text-secondary);
}

.exercise-card__result-list li {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  align-items: baseline;
}

.exercise-card__result-empty {
  font-size: 13px;
  color: var(--color-text-secondary);
  margin-top: var(--space-1);
}

.exercise-card__result-set {
  font-weight: 600;
  color: var(--color-text);
  min-width: 88px;
}

.exercise-card--active .exercise-card__meta,
.exercise-card--active .superset-header__prescribed {
  display: none;
}

.exercise-card__cycles {
  font-weight: 500;
}

.exercise-card__prescribed {
  color: var(--color-text-secondary);
}

.exercise-card {
  transition: border-color var(--motion-medium) var(--motion-ease), box-shadow var(--motion-medium) var(--motion-ease), background var(--motion-medium) var(--motion-ease), opacity var(--motion-medium) var(--motion-ease);
}

.exercise-card[data-exercise-state="idle"] {
  opacity: 0.95;
  background: color-mix(in srgb, var(--color-panel) 90%, var(--color-border) 6%);
}

.exercise-card--active {
  border-color: color-mix(in srgb, var(--color-accent) 45%, var(--color-border));
  box-shadow: 0 12px 28px -12px rgba(0,0,0,0.22);
  background: color-mix(in srgb, var(--color-panel) 85%, var(--color-accent) 6%);
}

.exercise-card--active .exercise-card__status {
  display: flex;
}

.exercise-card__note {
  margin-top: var(--space-2);
}

.exercise-card__note input {
  width: 100%;
  min-height: 44px;
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-s);
  background: var(--color-surface);
}

.exercise-card__sets {
  display: none;
  flex-direction: column;
  gap: var(--space-3);
}

.exercise-card__sets--text {
  display: flex;
}

.exercise-card[data-exercise-state="active"] .exercise-card__sets {
  display: flex;
}

.exercise-card__set-controls {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-1);
}

.exercise-card__set-controls .set-control-btn {
  width: 36px;
  height: 36px;
  border-radius: 999px;
  font-size: 20px;
  line-height: 1;
  padding: 0;
  border: 1px solid var(--set-control-border);
  background: var(--set-control-bg);
  color: var(--set-control-text);
  box-shadow: 0 6px 14px rgba(15, 23, 42, 0.12);
}

.exercise-card__set-controls .set-control-btn:hover {
  border-color: var(--set-control-hover-border);
  background: var(--set-control-hover-bg);
  box-shadow: 0 8px 18px rgba(217, 162, 70, 0.18);
}

.exercise-card__set-controls .set-control-btn:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

.exercise-card__set-controls .set-control-hint {
  font-size: 12px;
  color: var(--color-text-secondary);
  font-weight: 500;
}

.result-group {
  display: grid;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}

.result-group:last-child {
  margin-bottom: 0;
}

.set-row {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-3) 0;
  border-top: 1px solid color-mix(in srgb, var(--color-border) 70%, transparent);
}

.set-row--enter {
  opacity: 0;
  transform: translateY(-6px);
}

.set-row--enter.is-in {
  opacity: 1;
  transform: translateY(0);
  transition: opacity var(--motion-medium) var(--motion-ease), transform var(--motion-medium) var(--motion-ease);
}

.set-row--exit {
  opacity: 1;
  transform: translateY(0);
  transition: opacity var(--motion-regular) var(--motion-ease), transform var(--motion-regular) var(--motion-ease);
  will-change: opacity, transform;
}

.set-row--exit.is-out {
  opacity: 0;
  transform: translateY(-6px);
}

.set-row--invalid {
  background: color-mix(in srgb, var(--color-error-weak) 65%, transparent);
  border-top-color: color-mix(in srgb, var(--color-error) 45%, var(--color-border));
}

.set-row--invalid input {
  border-color: color-mix(in srgb, var(--color-error) 60%, var(--color-border));
  background: color-mix(in srgb, var(--color-error-weak) 60%, #fff);
}

.set-row--skipped {
  opacity: 0.7;
}

.set-row--missed {
  border-top-color: color-mix(in srgb, var(--color-error) 50%, var(--color-border));
  background: color-mix(in srgb, var(--color-error-weak) 40%, transparent);
}

.exercise-card[data-exercise-state="idle"] .set-row,
.exercise-card[data-exercise-state="finalized"] .set-row {
  pointer-events: none;
  opacity: 0.75;
}

.exercise-card[data-exercise-state="active"] .set-row {
  pointer-events: auto;
  opacity: 1;
}

.exercise-card[data-exercise-state="idle"] .exercise-card__note input,
.exercise-card[data-exercise-state="finalized"] .exercise-card__note input,
.exercise-card[data-exercise-state="idle"] .superset-note,
.exercise-card[data-exercise-state="finalized"] .superset-note {
  pointer-events: none;
  opacity: 0.7;
}

.exercise-card[data-exercise-state="idle"] .exercise-card__note,
.exercise-card[data-exercise-state="finalized"] .exercise-card__note,
.exercise-card[data-exercise-state="idle"] .superset-header__note,
.exercise-card[data-exercise-state="finalized"] .superset-header__note {
  display: none;
}

.exercise-card__sets .set-row:first-child {
  padding-top: 0;
  border-top: none;
}

.set-ok-wrap {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  justify-content: flex-end;
}

.set-ok-wrap .field-label.is-hidden {
  display: block;
  min-height: 20px;
}


.set-row__main .field {
  margin-bottom: 0;
}
.set-row__main {
  display: grid;
  grid-template-columns:
    minmax(70px, 0.8fr)
    minmax(110px, 1fr)
    minmax(110px, 1fr)
    minmax(110px, 1fr)
    52px;
  gap: var(--space-2);
  align-items: end;
}

.set-row__main .field {
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.set-row__main .field input,
.set-row__main .field input:focus-visible {
  background: var(--color-surface);
}

.skip-toggle {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  font-size: 13px;
  color: var(--color-text-secondary);
  margin-top: var(--space-2);
}

.skip-toggle input {
  width: 16px;
  height: 16px;
}

.field--rest .rest-input {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--space-2);
  min-width: 0;
}

.field--rest .rest-input input {
  justify-self: stretch;
  width: 100%;
  min-width: 0;
}

.field--rest.rest-state-reset .rest-input input {
  padding-right: 34px;
  background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAyNCAyNCIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjMjU2M2ViIiBzdHJva2Utd2lkdGg9IjIiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIgc3Ryb2tlLWxpbmVqb2luPSJyb3VuZCI+PHBhdGggZD0iTTMgMTJhOSA5IDAgMSAwIDMtNi43Ii8+PHBvbHlsaW5lIHBvaW50cz0iMyA0IDMgMTAgOSAxMCIvPjwvc3ZnPg==");
  background-repeat: no-repeat;
  background-position: right 8px center;
  background-size: 18px 18px;
}

.field--rest .rest-input .unit {
  margin-left: 0;
  text-align: center;
  min-width: 3ch;
  font-variant-numeric: tabular-nums;
}

.field--rest {
  max-width: 100%;
  width: 100%;
  justify-self: stretch;
}

.exercise-card__actions {
  display: flex;
  justify-content: flex-end;
  margin-bottom: var(--space-2);
}

.exercise-skip-button {
  border: none;
  background: none;
  color: var(--color-text-secondary);
  font-size: 13px;
  cursor: pointer;
  padding: 0;
  text-decoration: underline dotted;
}

.exercise-skip-button:hover,
.exercise-skip-button:focus-visible {
  color: var(--color-accent);
}

.exercise-skip-button.is-active {
  color: var(--color-accent);
}

.exercise-skip-button--superset {
  margin-top: var(--space-1);
}

.result-skip-button {
  margin-right: auto;
}

.result-skip-button.is-active {
  background: color-mix(in srgb, var(--color-warning) 20%, var(--color-surface));
  color: var(--color-warning);
  border-color: color-mix(in srgb, var(--color-warning) 60%, var(--color-border));
}

.result-skip-button.is-disabled {
  opacity: 0.6;
  cursor: default;
}

.set-order-field {
  justify-content: flex-end;
}

.set-order-field .set-order {
  font-weight: 600;
  color: var(--color-accent);
  display: block;
  min-height: 44px;
  white-space: normal;
  word-break: normal;
  overflow-wrap: break-word;
}

@media (max-width: 900px) {
  .set-row__main {
    grid-template-columns:
      minmax(68px, 0.7fr)
      minmax(100px, 1fr)
      minmax(100px, 1fr)
      minmax(120px, 1fr)
      52px;
    grid-auto-rows: auto;
  }

  .set-order-field,
  .set-ok-wrap {
    justify-content: flex-end;
  }
}

@media (max-width: 560px) {
  .set-row {
    padding: var(--space-2) 0;
    gap: var(--space-1);
  }

  .set-row + .set-row {
    margin-top: var(--space-2);
    padding-top: var(--space-3);
  }

  .set-row__main {
    position: relative;
    padding-top: calc(var(--space-4) + 4px);
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) minmax(0, 1fr) 52px;
    grid-template-areas:
      "weight reps rpe ok";
    gap: var(--space-2);
  }

  .set-row__main::before {
    content: attr(data-set-label);
    position: absolute;
    top: 0;
    left: 0;
    font-size: 12px;
    font-weight: 600;
    line-height: 1.2;
    color: var(--color-accent);
    max-width: 70%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .set-row__main .set-order-field {
    display: none;
  }

  .field--weight {
    grid-area: weight;
  }

  .field--reps {
    grid-area: reps;
  }

  .field--rpe {
    grid-area: rpe;
  }

  .set-ok-wrap {
    grid-area: ok;
    align-self: end;
  }

  .set-row__main .field {
    min-height: 44px;
  }

  .set-row__main input[data-type="weight"],
  .set-row__main input[data-type="reps"],
  .set-row__main input[data-type="rpe"] {
    width: 100%;
    max-width: 100%;
    min-width: 0;
  }

  .set-row .set-row__main .field--weight .field-label.is-hidden,
  .set-row .set-row__main .field--reps .field-label.is-hidden,
  .set-row .set-row__main .field--rpe .field-label.is-hidden {
    visibility: visible;
  }
}

.set-ok-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-2);
  cursor: pointer;
  position: relative;
}

.set-ok-checkbox {
  position: absolute;
  opacity: 0;
  width: 1px;
  height: 1px;
}

.set-ok-visual {
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--color-border) 75%, transparent);
  background: var(--color-surface);
  color: var(--color-text-secondary);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  line-height: 1;
  user-select: none;
  transition: background var(--motion-fast) var(--motion-ease), border-color var(--motion-fast) var(--motion-ease), color var(--motion-fast) var(--motion-ease), box-shadow var(--motion-fast) var(--motion-ease), transform var(--motion-fast) var(--motion-ease);
}

.set-ok-toggle:hover .set-ok-visual,
.set-ok-checkbox:focus-visible + .set-ok-visual {
  border-color: var(--color-accent);
  background: color-mix(in srgb, var(--color-accent) 10%, var(--color-surface));
}

.set-ok-checkbox:checked + .set-ok-visual,
.set-ok-checkbox.is-active + .set-ok-visual {
  border-color: var(--color-success);
  background: var(--color-success);
  color: #fff;
}

.set-ok-checkbox.is-complete + .set-ok-visual {
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-success) 35%, transparent);
}

.set-ok-checkbox:disabled + .set-ok-visual {
  opacity: 0.6;
  cursor: default;
}

.set-order {
  font-weight: 600;
  color: var(--color-accent);
}

.set-ok-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  align-self: stretch;
  min-width: 140px;
  height: 44px;
  padding: 0 var(--space-4);
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--color-border) 75%, transparent);
  background: var(--color-surface);
  color: var(--color-text);
  font-weight: 600;
  font-size: 15px;
  line-height: 1.2;
  cursor: pointer;
  transition: background var(--motion-fast) var(--motion-ease), border-color var(--motion-fast) var(--motion-ease), color var(--motion-fast) var(--motion-ease);
  justify-self: stretch;
  gap: var(--space-2);
}

.set-ok-button .set-ok-icon {
  font-size: 22px;
  line-height: 1;
}

.set-ok-button .set-ok-text {
  font-weight: 600;
  letter-spacing: 0.1px;
}

.set-ok-button:hover:not(.is-disabled),
.set-ok-button:focus-visible {
  border-color: var(--color-accent);
  background: color-mix(in srgb, var(--color-accent) 10%, var(--color-surface));
}

.set-ok-button.is-active {
  border-color: var(--color-success);
  background: var(--color-success);
  color: #fff;
}

.set-ok-button.is-disabled {
  opacity: 0.6;
  cursor: default;
}

.set-row__main input[data-type="weight"],
.set-row__main input[data-type="reps"],
.set-row__main input[data-type="rpe"] {
  width: 12ch;
  max-width: 100%;
  min-width: 8ch;
  font-variant-numeric: tabular-nums;
}


.rest-field input {
  background: var(--color-surface);
  border-radius: 999px;
  transition: background var(--motion-medium) var(--motion-ease), border-color var(--motion-medium) var(--motion-ease);
}

.rest-field.rest-state-ok input {
  background-color: var(--success-weak);
  border-color: color-mix(in srgb, var(--color-success) 45%, var(--color-border));
}

.rest-field.rest-state-warn input {
  background-color: var(--warning-weak);
  border-color: color-mix(in srgb, var(--color-warning) 45%, var(--color-border));
}

.rest-field.rest-state-alert input {
  background-color: color-mix(in srgb, var(--danger-weak) 80%, var(--color-surface));
  border-color: color-mix(in srgb, var(--danger) 50%, var(--color-border));
}

.rest-field.rest-state-expired input {
  background-color: var(--danger-weak);
  border-color: var(--danger);
}

.rest-field.rest-state-blink input {
  animation: rest-expired-blink var(--motion-pulse) var(--motion-ease-loop) infinite;
}

@keyframes rest-expired-blink {
  0%,
  100% {
    background-color: var(--danger-weak);
  }
  50% {
    background-color: color-mix(in srgb, var(--danger-weak) 40%, var(--color-surface));
  }
}

.rest-field.rest-state-expired.rest-state-reset input {
  padding-right: 34px;
  background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAyNCAyNCIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjMjU2M2ViIiBzdHJva2Utd2lkdGg9IjIiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIgc3Ryb2tlLWxpbmVqb2luPSJyb3VuZCI+PHBhdGggZD0iTTMgMTJhOSA5IDAgMSAwIDMtNi43Ii8+PHBvbHlsaW5lIHBvaW50cz0iMyA0IDMgMTAgOSAxMCIvPjwvc3ZnPg==");
  background-repeat: no-repeat;
  background-position: right 8px center;
  background-size: 18px 18px;
}

.exercise-card--readonly {
  background: color-mix(in srgb, var(--color-surface) 98%, var(--color-accent) 2%);
  box-shadow: none;
}

.plan-detail-meta {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: var(--space-2);
  font-size: 14px;
  color: var(--color-text-secondary);
  margin-bottom: var(--space-3);
}

.plan-detail-summary {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
}

.plan-detail-summary__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: var(--space-3);
}

.plan-detail-summary__label {
  font-size: 13px;
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.plan-detail-summary__value {
  font-size: 18px;
  font-weight: 600;
}

.plan-detail-note {
  margin: 0;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-s);
  background: color-mix(in srgb, var(--color-accent) 10%, transparent);
  color: var(--color-text);
  font-size: 14px;
}

.plan-detail-note__label {
  font-weight: 600;
  margin-right: var(--space-1);
}

.plan-detail-note--inline {
  background: transparent;
  padding: 0;
  margin-top: var(--space-2);
  color: var(--color-text-secondary);
  font-size: 13px;
}

.plan-detail-content {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.plan-detail-superset {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.plan-detail-values {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: var(--space-3);
}

.plan-detail-value {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  padding: var(--space-2);
  border-radius: var(--radius-s);
  background: color-mix(in srgb, var(--color-surface) 96%, transparent);
  border: 1px solid color-mix(in srgb, var(--color-border) 50%, transparent);
}

.plan-detail-value__label {
  font-size: 12px;
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.plan-detail-value__value {
  font-size: 16px;
  font-weight: 600;
  color: var(--color-text);
}

.plan-detail-flag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 2px 10px;
  border-radius: 999px;
  font-size: 12px;
  color: var(--color-success);
  background: color-mix(in srgb, var(--color-success) 16%, transparent);
}

.plan-detail-flag--ok {
  color: var(--color-success);
  background: color-mix(in srgb, var(--color-success) 22%, transparent);
}

@media (min-width: 640px) {
  .exercise-card__header {
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    gap: var(--space-3);
  }

  .exercise-card__meta {
    justify-content: flex-end;
  }
}

/* Superset headers: держим столбцом, чтобы техника раскрывалась под заголовками */
.exercise-card[data-superset-id] .exercise-card__header {
  flex-direction: column;
  align-items: stretch;
  gap: var(--space-2);
}

.unit {
  font-size: 12px;
  color: var(--color-text-secondary);
  margin-left: var(--space-1);
}

.list-item {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-s);
  padding: var(--space-3);
  background: var(--color-surface);
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.list-title {
  font-weight: 600;
}

.list-meta {
  font-size: 14px;
  color: var(--color-text-secondary);
}

.list-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: var(--space-2);
}

.list-actions .btn {
  margin-block: 0;
}

.plan-preview-exercises {
  margin-top: var(--space-3);
  padding-top: var(--space-2);
  border-top: 1px dashed var(--color-border);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.plan-preview-exercises__title {
  font-size: 13px;
  font-weight: 600;
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.plan-preview-exercises__list {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  max-height: 180px;
  overflow: auto;
  padding-right: var(--space-2);
  scrollbar-gutter: stable;
}

.plan-preview-exercise {
  display: inline-flex;
  align-items: center;
  align-self: flex-start;
  max-width: 100%;
  font-size: 14px;
  color: var(--color-text-primary);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-s);
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  box-shadow: var(--shadow-elevated);
}

.client-search-item {
  appearance: none;
  width: 100%;
  text-align: left;
  cursor: pointer;
  font: inherit;
}

.client-search-item:hover {
  border-color: var(--color-accent);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--color-accent) 18%, transparent);
}

.client-search-item.is-selected {
  border-color: var(--color-accent);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--color-accent) 24%, transparent);
}

.client-search-item:focus-visible {
  outline: 3px solid color-mix(in srgb, var(--color-accent) 32%, transparent);
  outline-offset: 2px;
}

#client-list,
#assign-client-list {
  --client-row-height: 93px;
  --client-row-gap: var(--space-3);
  --client-row-item-height: calc(var(--client-row-height) - var(--client-row-gap));
  --client-list-hint-height: 22px;
  max-height: calc(var(--client-row-height) * 5 + var(--client-list-hint-height));
  overflow: auto;
  padding-right: 2px;
  display: block;
}

.client-list-hint {
  margin: 0 0 var(--space-2);
  height: var(--client-list-hint-height);
  line-height: var(--client-list-hint-height);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  animation: none !important;
}

.client-list-virtual {
  position: relative;
  width: 100%;
  animation: none !important;
}

.client-list-virtual .client-search-item {
  position: absolute;
  left: 0;
  right: 0;
  height: var(--client-row-item-height);
  overflow: hidden;
  animation: none !important;
}

.client-search-item .list-title,
.client-search-item .list-meta {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.btn-compact {
  --btn-pad-y: 8px;
  --btn-pad-x: 14px;
  --btn-font-size: 14px;
  --btn-min-height: 36px;
}

.superset-editor {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-s);
  padding: var(--space-3);
  background: var(--color-surface);
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.superset-editor.is-dragging {
  opacity: 0.62;
}

.superset-editor.is-drop-target {
  border-color: var(--color-accent);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--color-accent) 22%, transparent);
}

.superset-editor.is-drop-before::before {
  content: '';
  position: absolute;
  left: -1px;
  right: -1px;
  top: -1px;
  height: 8px;
  border-radius: var(--radius-s);
  background: linear-gradient(
    90deg,
    color-mix(in srgb, var(--color-accent) 72%, white 28%),
    var(--color-accent) 20%,
    var(--color-accent) 80%,
    color-mix(in srgb, var(--color-accent) 72%, white 28%)
  );
  box-shadow:
    0 0 0 3px color-mix(in srgb, var(--color-accent) 55%, transparent),
    0 0 16px 4px color-mix(in srgb, var(--color-accent) 35%, transparent);
}

.superset-editor.is-drop-after::after {
  content: '';
  position: absolute;
  left: -1px;
  right: -1px;
  bottom: -1px;
  height: 8px;
  border-radius: var(--radius-s);
  background: linear-gradient(
    90deg,
    color-mix(in srgb, var(--color-accent) 72%, white 28%),
    var(--color-accent) 20%,
    var(--color-accent) 80%,
    color-mix(in srgb, var(--color-accent) 72%, white 28%)
  );
  box-shadow:
    0 0 0 3px color-mix(in srgb, var(--color-accent) 55%, transparent),
    0 0 16px 4px color-mix(in srgb, var(--color-accent) 35%, transparent);
}

.superset-editor__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.entry {
  border: 2px solid color-mix(in srgb, var(--color-border) 80%, transparent);
  border-radius: var(--radius-s);
  padding: var(--space-3);
  background: color-mix(in srgb, var(--color-surface) 96%, var(--color-accent) 4%);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  position: relative;
}

.entry--exercise-only {
  border-style: dashed;
  background: color-mix(in srgb, var(--color-surface) 98%, var(--color-accent) 2%);
  min-height: 215px;
}

.entry--reordering {
  opacity: 0.7;
}

.entry--reorder-target {
  border-color: var(--color-accent);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--color-accent) 30%, transparent);
}

.entry--reorder-before::before,
.entry--reorder-after::before {
  content: '';
  position: absolute;
  left: -1px;
  right: -1px;
  height: 6px;
  border-radius: var(--radius-s);
  background: var(--color-accent);
  box-shadow:
    0 0 0 3px color-mix(in srgb, var(--color-accent) 35%, transparent),
    0 0 14px 4px color-mix(in srgb, var(--color-accent) 25%, transparent);
}

.entry--reorder-before::before {
  top: -1px;
}

.entry--reorder-after::before {
  bottom: -1px;
}

.entry.is-drop-target {
  border-color: var(--color-success);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--color-success) 35%, transparent);
}

.entry--drop-replace {
  border-color: var(--color-error);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--color-error) 35%, transparent);
}

.entry-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-2);
}

.entry-heading {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  min-width: 0;
}

.entry-order {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 999px;
  background: var(--color-accent-weak);
  color: var(--color-accent);
  font-weight: 600;
  font-size: 14px;
}

.entry-title {
  margin: 0;
  font-size: 18px;
  font-weight: 600;
  color: var(--color-text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.entry-title--placeholder {
  color: var(--color-text-tertiary);
  font-style: italic;
  font-weight: 500;
}

.entry-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  flex-wrap: wrap;
}

.entry-sets {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.entry-sets__label {
  font-size: 14px;
  color: var(--color-text-secondary);
}

.entry-remove {
  --icon-btn-size: 40px;
  --icon-btn-radius: var(--radius-s);
  --icon-btn-font: 16px;
  --icon-btn-color: var(--color-error);
  --icon-btn-bg: transparent;
  --icon-btn-border: 1px solid var(--color-error);
  --icon-btn-hover-bg: color-mix(in srgb, var(--color-error) 20%, var(--color-surface));
  --icon-btn-hover-color: #fff;
  --icon-btn-hover-border: var(--color-error);
  --icon-btn-hover-shadow: 0 0 0 3px rgba(255, 59, 48, 0.18);
  font-weight: 700;
}

.entry-remove .icon-close {
  font-size: inherit;
  font-weight: inherit;
  text-transform: uppercase;
}

.entry--drop-replace::after {
  content: 'Заменить';
  position: absolute;
  top: var(--space-2);
  right: var(--space-2);
  padding: 4px 10px;
  border-radius: var(--radius-s);
  background: color-mix(in srgb, var(--color-error) 18%, var(--color-surface));
  color: var(--color-error);
  font-weight: 600;
  pointer-events: none;
}

.entry-fields {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: var(--space-3);
}

.entry-set-grid {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-top: var(--space-3);
}

.entry-set-row {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-3);
  border-radius: var(--radius-s);
  border: 1px solid var(--color-border);
  background: color-mix(in srgb, var(--color-surface) 96%, var(--color-accent) 4%);
}

.entry-set-label {
  font-size: 14px;
  font-weight: 600;
  color: var(--color-text);
}

.entry-set-fields {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: var(--space-3);
}

.entry-note {
  margin-top: var(--space-3);
}

.form-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  justify-content: flex-end;
  margin-top: var(--space-4);
}

.exercise-library {
  margin-top: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.exercise-library h3 {
  margin: 0;
  font-size: 18px;
  font-weight: 600;
}

.builder-subtabs {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
}

.plan-builder--compact {
  /* Slightly smaller pills inside the builder to reduce vertical bloat. */
  --btn-pad-y: 6px;
  --btn-pad-x: 12px;
  --btn-font-size: 13px;
  --btn-min-height: 32px;
}

.plan-builder--compact.card {
  padding: var(--space-2);
}

.plan-builder--compact .builder-subtabs {
  margin-bottom: var(--space-2);
}

.plan-builder--compact .plan-mode {
  padding: 6px 10px;
  font-size: 12px;
}

.plan-builder--compact .superset-editor {
  padding: var(--space-2);
  gap: var(--space-2);
}

.plan-builder--compact .entry-meta {
  gap: var(--space-2);
}

.plan-builder--compact .entry-sets__label {
  font-size: 12px;
}

.plan-builder--compact .entry-title {
  font-size: 15px;
}

.plan-builder--compact .entry-order {
  width: 24px;
  height: 24px;
  font-size: 12px;
}

.plan-builder--compact .entry-remove {
  --icon-btn-size: 34px;
  --icon-btn-font: 14px;
}

.plan-builder--compact .entry-set-grid {
  gap: var(--space-2);
  margin-top: var(--space-2);
}

.plan-builder--compact .entry-set-row {
  padding: var(--space-2);
  gap: 6px;
}

.plan-builder--compact .entry-set-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.8px;
}

.plan-builder--compact .entry-set-fields {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--space-2);
}

.plan-builder--compact .entry-set-fields .field {
  margin-bottom: 0;
  position: relative;
}

/* Keep labels for accessibility but remove the visual bloat inside each set row. */
.plan-builder--compact .entry-set-fields .field-label {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.plan-builder--compact .entry-set-fields input {
  min-height: 32px;
  padding: 6px 9px;
  text-align: center;
}

.plan-builder--compact .entry-note {
  margin-top: var(--space-2);
}

.plan-builder--compact .hint {
  font-size: 13px;
}

.builder-subtabs .builder-subtab {
  margin-block: 0;
}

.builder-subtab {
  /* Keep constructor sub-tabs as true pills (same shape as other buttons). */
  border-radius: 999px;
}

.builder-subtab.is-active {
  background: var(--color-accent);
  color: #fff;
  border-color: var(--color-accent);
}

.plan-subpanel {
  display: none;
}

.plan-subpanel.is-active {
  display: block;
}

.builder-library {
  display: block;
}

.builder-library__column {
  display: none;
  border: 1px solid transparent;
  border-radius: var(--radius-m);
  padding: var(--space-3);
  background: var(--color-surface);
  transition: border-color var(--motion-medium) var(--motion-ease), box-shadow var(--motion-medium) var(--motion-ease), transform var(--motion-medium) var(--motion-ease);
}

.builder-library__column.is-active {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  border-color: color-mix(in srgb, var(--color-accent) 60%, transparent);
  box-shadow: 0 8px 18px -10px rgba(0, 0, 0, 0.2);
  transform: translateY(-2px);
}

.builder-library__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  margin-bottom: var(--space-2);
}

.builder-library__actions {
  display: none;
  gap: var(--space-2);
}

.builder-library__actions.is-visible {
  display: inline-flex;
}

.builder-library__actions .btn {
  font-size: 18px;
  padding: var(--space-1) var(--space-2);
}

.builder-library__controls {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: var(--space-3);
  margin-bottom: var(--space-3);
}

.builder-library__toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-2);
}

.builder-library__folders {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
}

.builder-library-tree {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-m);
  background: var(--color-surface-muted);
  padding: var(--space-3);
  max-height: 520px;
  overflow: auto;
}

.library-tree__section {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.library-tree__root {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.library-tree__row {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: 4px 8px;
  border-radius: var(--radius-s);
  border: 1px solid transparent;
  cursor: pointer;
}

.library-tree__row--root {
  background: color-mix(in srgb, var(--color-accent) 8%, var(--color-surface));
  font-weight: 600;
}

.library-tree__row--folder {
  background: color-mix(in srgb, var(--color-surface) 80%, var(--color-accent) 8%);
}

.library-tree__row--folder.is-open {
  border-color: color-mix(in srgb, var(--color-accent) 35%, transparent);
  background: color-mix(in srgb, var(--color-accent) 14%, var(--color-surface));
}

.library-tree__row--item {
  background: var(--color-surface);
}

.library-tree__row.is-selected {
  border-color: color-mix(in srgb, var(--color-accent) 60%, transparent);
  background: color-mix(in srgb, var(--color-accent) 12%, var(--color-surface));
}

.library-tree__row.is-drop-target {
  border-color: var(--color-accent);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--color-accent) 35%, transparent);
}

.library-tree__row.is-dragging {
  opacity: 0.6;
}

.library-tree__list {
  list-style: none;
  margin: 4px 0 0 18px;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.library-tree__toggle {
  border: none;
  background: transparent;
  color: var(--color-text-muted);
  cursor: pointer;
  font-size: 14px;
  width: 20px;
  height: 20px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.library-tree__toggle--empty {
  width: 20px;
  height: 20px;
  display: inline-block;
}

.library-tree__icon {
  font-size: 14px;
  color: var(--color-text-muted);
}

.library-tree__label {
  flex: 1 1 auto;
  min-width: 0;
  word-break: break-word;
}

.library-tree__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 22px;
  height: 20px;
  padding: 0 8px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--color-accent) 12%, var(--color-surface));
  color: var(--color-text-secondary);
  font-size: 12px;
  font-weight: 600;
}

.library-context {
  position: fixed;
  min-width: 190px;
  padding: 6px;
  border-radius: var(--radius-s);
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  box-shadow: var(--shadow-elevated);
  z-index: 1200;
}

.library-context__item {
  display: flex;
  width: 100%;
  padding: 8px 10px;
  border-radius: 10px;
  border: 1px solid transparent;
  background: transparent;
  color: var(--color-text);
  font: inherit;
  text-align: left;
  cursor: pointer;
}

.library-context__item:hover {
  background: color-mix(in srgb, var(--color-accent) 10%, var(--color-surface));
  border-color: color-mix(in srgb, var(--color-accent) 20%, transparent);
}

.library-context__item:disabled {
  cursor: default;
  opacity: 0.45;
}

.pin-overlay {
  position: fixed;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10050;
}

.pin-overlay[hidden] {
  display: none;
}

.pin-overlay__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(12, 18, 30, 0.5);
}

.pin-overlay__dialog {
  position: relative;
  background: var(--color-surface);
  color: var(--color-text);
  border: 1px solid var(--color-border);
  border-radius: 18px;
  padding: 20px;
  width: min(320px, 92vw);
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.18);
  display: grid;
  gap: 12px;
}

.pin-overlay__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.pin-overlay__title {
  font-weight: 600;
}

.pin-overlay__close {
  background: none;
  border: none;
  font-size: 20px;
  cursor: pointer;
  color: inherit;
}

.pin-overlay__field {
  display: grid;
  gap: 6px;
}

.pin-overlay__label {
  font-size: 13px;
  color: var(--color-text-muted);
}

.pin-overlay__field input {
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid var(--color-border);
  background: var(--field-bg);
  color: inherit;
}

.pin-overlay__actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}

.pin-input-slot {
  min-height: 40px;
  border-radius: 14px;
  border: 1px solid var(--color-border);
  background: var(--field-bg);
  display: flex;
  align-items: center;
  padding: 8px 12px;
  font-size: 16px;
  letter-spacing: 4px;
  color: var(--color-text);
  cursor: pointer;
}

.library-context__divider {
  height: 1px;
  margin: 4px 6px;
  background: var(--separator);
}

.builder-library__search {
  flex: 1 1 260px;
  min-width: 240px;
}

.builder-library__filter-toggle {
  align-self: flex-end;
}


.library-mode {
  display: inline-flex;
  gap: var(--space-2);
  align-items: center;
}

.library-mode .btn {
  min-width: 120px;
}

.library-mode .btn.is-active {
  background: var(--color-accent);
  color: #fff;
  border-color: var(--color-accent);
}

.library-trash-type {
  min-width: 200px;
}

.library-trash-type .field {
  margin: 0;
}

.builder-library__tools {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
}

.builder-library__actions .btn {
  margin-block: 0;
}

.library-scope-select {
  border: 1px solid color-mix(in srgb, var(--color-accent) 70%, transparent);
  border-radius: var(--radius-s);
  padding: 6px 10px;
  font-size: 14px;
  font-weight: 600;
  min-height: 34px;
  background: transparent;
  color: var(--color-accent);
  cursor: pointer;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.builder-library__list {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-m);
  padding: 0;
  background: var(--color-surface-muted);
}

.builder-library__list .clusterize-scroll {
  max-height: 460px;
  overflow-y: auto;
  padding: var(--space-3);
}

.builder-library__empty {
  color: var(--color-text-muted);
  font-size: 14px;
  padding: var(--space-2);
}

.builder-library__item {
  padding: 6px 8px;
  border-radius: var(--radius-s);
}

.builder-library__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
}

.builder-library__label {
  min-width: 0;
}

.builder-library__delete {
  --icon-btn-size: 28px;
  --icon-btn-radius: var(--radius-s);
  --icon-btn-font: 18px;
  --icon-btn-color: var(--color-text-muted);
  --icon-btn-bg: transparent;
  --icon-btn-border: 1px solid transparent;
  --icon-btn-hover-bg: color-mix(in srgb, var(--color-error) 15%, var(--color-surface));
  --icon-btn-hover-color: var(--color-error);
  --icon-btn-hover-border: color-mix(in srgb, var(--color-error) 30%, transparent);
  flex: 0 0 auto;
}

.builder-library__item.is-selected {
  background: color-mix(in srgb, var(--color-accent) 10%, var(--color-surface));
  border: 1px solid color-mix(in srgb, var(--color-accent) 40%, transparent);
}

.builder-library__item + .builder-library__item {
  border-top: 1px solid var(--color-border-muted);
}

.builder-library__title {
  font-weight: 600;
}

.builder-library__meta {
  font-size: 13px;
  color: var(--color-text-muted);
}

.pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 999px;
  background: var(--color-surface-muted);
  color: var(--color-text-muted);
  font-size: 12px;
  font-weight: 600;
  font-family: var(--font-mono);
  letter-spacing: var(--subtitle-letter);
  text-transform: uppercase;
}

.pill--warning {
  background: #fff4d6;
  color: #7a4d00;
}

.ai-key-row {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
}

.ai-key-row .form-actions {
  display: flex;
  gap: var(--space-2);
  align-items: center;
  flex-wrap: wrap;
}

.ai-tabs {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.ai-tab {
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  color: var(--color-text);
  padding: 8px 14px;
  border-radius: 999px;
  font-weight: 600;
  cursor: pointer;
  transition:
    background var(--motion-fast) var(--motion-ease),
    border-color var(--motion-fast) var(--motion-ease),
    color var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease),
    transform var(--motion-fast) var(--motion-ease);
}

.ai-tab.is-active {
  background: var(--color-accent);
  color: #fff;
  border-color: transparent;
}

.ai-tab-panel {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.ai-plan-list {
  display: grid;
  gap: var(--space-2);
}

.ai-plan-assign__summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  margin-bottom: var(--space-3);
}

.ai-plan-assign__title {
  font-weight: 600;
  color: var(--text-primary, #1d2027);
}

.ai-plan-assign__counter {
  font-weight: 600;
  color: var(--text-muted, #6b7280);
}

.ai-plan-assign__calendar {
  margin-bottom: var(--space-3);
}

.ai-plan-card {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-m);
  padding: 12px 14px;
  background: var(--color-surface);
  box-shadow: var(--shadow-elevated);
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.ai-plan-card__header {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  justify-content: space-between;
}

.ai-plan-card__title {
  font-weight: 600;
  color: var(--color-text);
}

.ai-plan-card__title-input {
  font-weight: 600;
  color: var(--color-text);
  border: 1px solid var(--color-border);
  border-radius: 999px;
  padding: 6px 12px;
  background: var(--color-surface);
  min-width: 220px;
}

.ai-plan-card__title-input:focus {
  outline: none;
  border-color: var(--color-accent);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--color-accent) 25%, transparent);
}

.ai-plan-card__meta {
  font-size: 13px;
  color: var(--color-text-muted);
}

.ai-plan-card__actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.ai-plan-card__status {
  font-size: 12px;
  color: var(--color-text-muted);
  margin-left: auto;
}

.ai-plan-card__status.is-error {
  color: var(--color-danger, #d54);
}

.ai-plan-preview {
  border-top: 1px solid var(--color-border-muted);
  padding-top: 10px;
  display: grid;
  gap: 8px;
}

.ai-debug {
  margin-top: var(--space-3);
  padding: var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-s);
  background: color-mix(in srgb, var(--color-surface) 88%, var(--color-bg) 12%);
  box-shadow: var(--shadow-elevated);
}

.ai-debug summary {
  font-weight: 700;
  cursor: pointer;
  color: var(--color-text);
}

.ai-debug pre {
  margin: var(--space-2) 0 0;
  padding: var(--space-3);
  background: var(--bg-muted);
  border-radius: var(--radius-s);
  white-space: pre-wrap;
  word-break: break-word;
  font-family: ui-monospace, SFMono-Regular, Consolas, 'Liberation Mono', Menlo, monospace;
  font-size: 14px;
  max-height: 360px;
  overflow: auto;
  border: 1px dashed var(--color-border);
}

.ai-report {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.ai-report__meta {
  font-size: 13px;
  color: var(--color-text-muted);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  align-items: center;
}

.ai-report__state {
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.01em;
  border: 1px solid var(--color-border);
  background: var(--color-surface-muted);
  color: var(--color-text);
}

.ai-report__state--draft {
  background: color-mix(in srgb, var(--color-surface-muted) 80%, var(--color-warning) 20%);
  border-color: color-mix(in srgb, var(--color-warning) 40%, var(--color-border) 60%);
}

.ai-report__state--published {
  background: color-mix(in srgb, var(--color-surface-muted) 70%, var(--color-success) 30%);
  border-color: color-mix(in srgb, var(--color-success) 45%, var(--color-border) 55%);
}

.ai-report__period {
  font-size: 13px;
  color: var(--color-text-muted);
}

.ai-report__summary {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 6px;
}

.ai-report__summary li {
  padding: 8px 12px;
  border-radius: var(--radius-s);
  background: var(--color-surface-muted);
  border: 1px solid var(--color-border);
  color: var(--color-text);
  font-size: 14px;
}

.ai-plan-rationale {
  padding: 10px 12px;
  border-radius: var(--radius-s);
  background: var(--color-surface-muted);
  border: 1px solid var(--color-border);
  color: var(--color-text);
  font-size: 14px;
  line-height: 1.5;
  white-space: pre-wrap;
}

.ai-plan-rationale:empty {
  display: none;
}

.ai-report__cards {
  display: grid;
  gap: var(--space-2);
}

.ai-report__card {
  padding: 14px 16px;
  border-radius: var(--radius-m);
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  box-shadow: var(--shadow-elevated);
}

.ai-report__card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 8px;
}

.ai-report__title {
  font-weight: 700;
  font-size: 15px;
  color: var(--color-text);
}

.ai-report__badge {
  padding: 4px 10px;
  border-radius: 999px;
  background: var(--color-surface-muted);
  color: var(--color-text-muted);
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
}

.ai-report__text {
  margin: 0 0 8px;
  color: var(--color-text);
  font-size: 14px;
  line-height: 1.5;
}

.ai-report__list {
  margin: 0;
  padding-left: 18px;
  display: grid;
  gap: 6px;
  color: var(--color-text);
  font-size: 13.5px;
}

.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.35);
  backdrop-filter: blur(6px);
  z-index: 9000;
}

.modal-overlay--confirm {
  z-index: 12000;
}

.modal--confirm {
  z-index: 12001;
}

.modal--confirm .modal__body p {
  margin: 0;
  color: var(--color-text-secondary);
}

.workout-complete__body p {
  margin: 0 0 var(--space-2);
}

.workout-complete__body .workout-complete__note {
  margin-top: var(--space-2);
  font-size: 13px;
  color: var(--color-text-secondary);
}

#exercise-preview-modal .modal__dialog {
  width: min(840px, 95vw);
  max-height: 90vh;
  display: flex;
  flex-direction: column;
}

#exercise-preview-modal .modal__body {
  max-height: calc(90vh - 140px);
  overflow: auto;
  padding-right: 8px;
}

.modal__actions {
  display: flex;
  gap: var(--space-2);
  justify-content: flex-end;
  margin-top: var(--space-3);
}

.modal__error {
  margin: 0 0 var(--space-3);
  color: var(--danger);
  font-size: 13px;
}

.plan-builder-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 360px);
  gap: var(--space-4);
  align-items: start;
}

/* Compact mode must override admin desktop layout helpers (which use `body.admin-app`). */
body.admin-app .plan-builder--compact .plan-builder-layout {
  /* Denser builder: keep right rail but reduce gutters. */
  grid-template-columns: minmax(0, 1fr) minmax(300px, 340px);
  gap: var(--space-3);
}

.plan-builder__main {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  min-height: 0;
}

.plan-builder--compact .plan-builder__main {
  gap: var(--space-3);
}

.plan-subpanel[data-plan-panel="plan"] .plan-builder__main {
  background: color-mix(in srgb, var(--color-surface) 70%, var(--color-border));
  border-radius: var(--radius-m);
  padding: var(--space-4);
  /* The archive rail is intentionally tall. Prevent the main panel from stretching to its height. */
  align-self: start;
}

.plan-builder--compact .plan-subpanel[data-plan-panel="plan"] .plan-builder__main {
  padding: var(--space-3);
}

.plan-subpanel[data-plan-panel="assign"] .plan-builder__main {
  background: color-mix(in srgb, var(--color-surface) 70%, var(--color-border));
  border-radius: var(--radius-m);
  padding: var(--space-4);
}

.plan-subpanel[data-plan-panel="plan"] .plan-drop-zone {
  background: var(--color-surface);
}

.plan-builder__archive {
  position: sticky;
  top: calc(var(--app-bar-h) + var(--space-4));
  /* Avoid forcing the whole builder card to viewport height (keeps layout compact). */
  max-height: min(calc(100vh - var(--app-bar-h) - (var(--space-4) * 2)), 720px);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-m);
  background: color-mix(in srgb, var(--color-surface) 92%, var(--color-accent) 8%);
  padding: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  z-index: 2;
  box-shadow: var(--shadow-elevated);
  overflow: hidden;
}

body.admin-app .plan-builder--compact .plan-builder__archive {
  top: calc(var(--app-bar-h) + var(--space-3));
  max-height: min(calc(100vh - var(--app-bar-h) - (var(--space-3) * 2)), 680px);
  padding: var(--space-3);
  gap: var(--space-2);
  /* Some theme/layout CSS sets a fixed width (360px). Compact rail should follow the grid column. */
  width: 100%;
}

.plan-subpanel[data-plan-panel="assign"] .plan-builder__archive {
  position: static;
  top: auto;
  height: auto;
  align-self: stretch;
  max-height: var(--assign-archive-max, 70vh);
  overflow: hidden;
}

.plan-subpanel[data-plan-panel="assign"] .archive-anchor {
  height: 100%;
}

.plan-subpanel[data-plan-panel="assign"] .builder-library__list {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  min-height: 0;
  overflow: hidden;
}

.plan-subpanel[data-plan-panel="assign"] .assign-template-scroll {
  flex: 1 1 auto;
  min-height: 0;
  max-height: none;
  overflow-y: auto;
}

.archive-anchor {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  height: 100%;
  justify-content: flex-start;
}

.plan-builder--compact .archive-anchor {
  gap: var(--space-2);
}

.archive-anchor h3 {
  margin-top: 0;
}

.archive-anchor > .btn {
  margin-block: 0;
}

.archive-anchor > .hint {
  margin-bottom: 0;
}

.exercise-archive {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  flex: 1 1 auto;
  min-height: 0;
  max-height: none;
  overflow-y: auto;
  padding-right: 4px;
}

.plan-builder--compact .exercise-archive {
  gap: var(--space-2);
  padding-right: 2px;
}

.plan-builder__archive .exercise-archive {
  /* Avoid hardcoded heights inside the sticky rail. */
  height: auto;
  max-height: none;
}

.plan-builder--compact .exercise-archive__item {
  padding: var(--space-2) var(--space-3);
}

@media (max-width: 1024px) {
  .plan-builder-layout {
    grid-template-columns: 1fr;
  }

  .plan-builder__main,
  .plan-builder__archive {
    width: 100%;
  }

  .plan-builder__archive {
    position: static;
    top: auto;
    height: auto;
    max-height: none;
    padding: var(--space-3);
    box-shadow: none;
  }

  .archive-anchor {
    height: auto;
    align-items: stretch;
  }

  .exercise-archive {
    max-height: min(480px, 60vh);
    padding-right: 0;
  }
}

@media (max-width: 600px) {
  .plan-drop-zone {
    padding: var(--space-4) var(--space-3);
    min-height: 180px;
  }

  .plan-drop-zone__hint {
    position: static;
    height: auto;
    border-width: 1px;
    margin-bottom: var(--space-3);
  }

  .exercise-filter-overlay {
    top: 64px;
    right: 16px;
    left: 16px;
    width: auto;
    max-height: calc(100vh - 112px);
  }

  .exercise-filter-overlay .exercise-filter {
    max-height: calc(100vh - 176px);
  }
}

.exercise-filter {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.exercise-filter__sections {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--space-2);
}

.exercise-filter input[type="search"] {
  width: 100%;
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-s);
  background: var(--color-surface);
  color: inherit;
}

.filter-section {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-s);
  background: var(--color-surface);
  padding: var(--space-2);
}

.filter-section > summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  cursor: pointer;
  font-weight: 600;
  user-select: none;
  list-style: none;
}

.filter-section > summary::marker,
.filter-section > summary::-webkit-details-marker {
  display: none;
}

.filter-section > summary::after {
  content: '▾';
  font-size: 12px;
  color: var(--color-muted);
  transition: transform var(--motion-medium) var(--motion-ease);
}

.filter-section[open] > summary::after {
  transform: rotate(180deg);
}

.filter-options {
  display: grid;
  gap: 6px;
  margin-top: var(--space-2);
}

.filter-option {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--color-text);
}

.filter-options--radios {
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
}

.filter-option input {
  accent-color: var(--color-accent);
}

.exercise-filter .hint {
  margin: 0;
}

.exercise-filter.is-loading {
  opacity: 0.7;
  pointer-events: none;
}

.exercise-filter-overlay {
  position: fixed;
  top: 96px;
  right: 24px;
  width: min(360px, calc(100vw - 32px));
  max-height: calc(100vh - 132px);
  background: color-mix(in srgb, var(--color-surface) 95%, var(--color-accent) 5%);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-m);
  box-shadow: var(--shadow-elevated);
  padding: var(--space-3);
  overflow: hidden;
  z-index: 1200;
}

.exercise-filter-overlay[hidden] {
  display: none !important;
}

.exercise-filter-overlay.is-loading {
  opacity: 0.7;
  pointer-events: none;
}

.exercise-filter__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
  cursor: move;
  user-select: none;
}

.exercise-filter__header h4 {
  margin: 0;
  font-size: 16px;
  font-weight: 600;
}

.exercise-filter__header-actions {
  display: flex;
  gap: var(--space-2);
  align-items: center;
}

.exercise-filter-overlay .exercise-filter {
  overflow-y: auto;
  max-height: calc(100vh - 196px);
  padding-right: 4px;
}


.plan-drop-zone {
  position: relative;
  border: 2px dashed var(--color-border);
  border-radius: var(--radius-m);
  padding: calc(var(--space-3) + 120px) var(--space-3) var(--space-3);
  min-height: 220px;
  transition: border-color var(--motion-fast) var(--motion-ease), background var(--motion-fast) var(--motion-ease);
}

.plan-builder--compact .plan-drop-zone {
  /* Make builder denser: hint is part of the flow, not a big absolute block. */
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-3);
  min-height: 140px;
}

.plan-drop-zone__hint {
  position: absolute;
  top: var(--space-3);
  left: var(--space-3);
  right: var(--space-3);
  height: 100px;
  border: 2px dashed var(--color-border);
  border-radius: var(--radius-s);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-tertiary);
  font-size: 14px;
  font-style: italic;
  letter-spacing: 0.01em;
  pointer-events: none;
  text-transform: none;
}

.plan-builder--compact .plan-drop-zone__hint {
  position: static;
  inset: auto;
  height: 48px;
  border-width: 1px;
  font-size: 13px;
}

.plan-drop-zone.has-content .plan-drop-zone__hint {
  display: none;
}

.plan-drop-zone.is-drop-target .plan-drop-zone__hint {
  border-color: var(--color-success);
  color: color-mix(in srgb, var(--color-success) 45%, var(--color-text-secondary));
}

.plan-drop-zone__inner {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.plan-builder--compact .plan-drop-zone__inner {
  gap: var(--space-2);
}

.plan-drop-zone.is-drop-target {
  border-color: var(--color-success);
  background: color-mix(in srgb, var(--color-success) 14%, var(--color-surface));
}

.plan-drop-zone.is-drop-target::after {
  content: 'Добавить';
  position: absolute;
  top: var(--space-3);
  right: var(--space-3);
  padding: 4px 12px;
  border-radius: var(--radius-s);
  background: color-mix(in srgb, var(--color-success) 20%, var(--color-surface));
  color: color-mix(in srgb, var(--color-text) 70%, var(--color-success) 30%);
  font-weight: 600;
  pointer-events: none;
}

.exercise-archive {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  padding-right: 4px;
}

.exercise-archive__item {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-s);
  padding: var(--space-3);
  background: var(--color-surface);
  cursor: grab;
  display: flex;
  flex-direction: column;
  gap: 4px;
  transition: transform var(--motion-xfast) var(--motion-ease), box-shadow var(--motion-xfast) var(--motion-ease);
}

.exercise-archive__item:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
}

.exercise-archive__item.is-dragging {
  opacity: 0.6;
  transform: scale(0.98);
  box-shadow: var(--shadow-elevated);
}

.exercise-archive__title {
  font-weight: 600;
}

.exercise-archive__title mark {
  background: color-mix(in srgb, var(--color-highlight, #ffeb3b) 35%, transparent);
  padding: 0 2px;
  border-radius: var(--radius-s);
}

.exercise-archive__meta {
  font-size: 13px;
  color: var(--color-text-secondary);
}

.exercise-archive__aliases {
  font-size: 13px;
  color: var(--color-text-secondary);
}

.exercise-archive__aliases mark {
  background: color-mix(in srgb, var(--color-highlight, #ffeb3b) 35%, transparent);
  padding: 0 2px;
  border-radius: var(--radius-s);
}

.exercise-archive__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 2px 6px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--color-accent) 18%, transparent);
  color: var(--color-text-secondary);
  font-size: 12px;
  font-weight: 600;
  margin-top: 2px;
}

.exercise-item__aliases {
  font-size: 13px;
  color: var(--color-text-secondary);
  margin-top: 4px;
}

.exercise-item__aliases mark {
  background: color-mix(in srgb, var(--color-highlight, #ffeb3b) 35%, transparent);
  padding: 0 2px;
  border-radius: var(--radius-s);
}

@media (min-width: 768px) {
  .app-main {
    max-width: 960px;
    margin: 0 auto;
  }

  body.admin-app .app-main {
    max-width: none;
    width: 100%;
    margin: 0;
  }

  body.admin-app .workspace-shell {
    width: 100%;
  }

  .card {
    padding: var(--space-6);
  }
}

@media (max-width: 520px) {
  .app-main {
    padding: var(--space-2);
    gap: var(--space-3);
  }

  body.client-app[data-client-stage="app"] .app-main {
    padding-top: calc(var(--space-2) + var(--client-nav-height) + var(--vv-top) + env(safe-area-inset-top));
    padding-bottom: calc(var(--space-2) + env(safe-area-inset-bottom));
  }

  :root[data-kb="1"] body.client-app[data-client-stage="app"] .app-main {
    padding-top: calc(var(--space-2) + env(safe-area-inset-top));
  }

  .workspace-shell {
    gap: var(--space-3);
  }

  .card {
    padding: var(--space-3) var(--space-2);
    background: transparent;
    border: none;
    box-shadow: none;
    border-radius: 0;
  }

  .card h2 {
    font-size: 18px;
  }

  .card--start {
    padding: var(--space-3) var(--space-2);
    gap: var(--space-4);
    background: transparent;
    box-shadow: none;
  }

  .start-logo {
    width: 64px;
    height: 64px;
  }

  .start-title {
    font-size: 24px;
  }

  .start-subtitle {
    font-size: 18px;
  }

  .start-description {
    max-width: none;
    font-size: 15px;
  }

  .start-actions {
    gap: var(--space-2);
  }

  .start-actions .btn {
    width: 100%;
  }

  .tab-nav {
    flex-wrap: nowrap;
    overflow-x: auto;
    gap: var(--space-2);
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }

  .tab-nav::-webkit-scrollbar {
    display: none;
  }

  .tab-nav a {
    flex: 0 0 auto;
    padding: var(--space-2) var(--space-3);
  }

  .field {
    margin-bottom: var(--space-2);
  }

  .field-grid {
    grid-template-columns: 1fr;
  }

  .field-inline {
    flex-direction: column;
    align-items: stretch;
  }

  .field-inline .btn {
    width: 100%;
  }

  .settings-actions,
  .result-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .result-actions .btn,
  .settings-actions .btn {
    width: 100%;
  }

  .plan-detail-meta,
  .plan-detail-summary__grid {
    grid-template-columns: 1fr;
  }

  .modal {
    align-items: flex-start;
    padding: var(--space-3);
  }

  #calendar-plan-hint-modal {
    align-items: center;
  }

  #calendar-plan-hint-modal .modal__dialog {
    width: min(calc(260px * 0.8), calc(88vw * 0.8));
  }

  .modal__dialog {
    width: 100%;
    border-radius: var(--radius-s);
    padding: var(--space-3);
  }
}

@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;
  }
}

.superset-header {
  justify-items: start;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: var(--space-3);
  align-items: center;
}

.superset-header__item {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.superset-header__line {
  display: flex;
  gap: var(--space-1);
  align-items: center;
}

.superset-header__prefix {
  font-weight: 700;
  color: var(--color-accent);
}

.superset-header__name {
  font-weight: 600;
}

.superset-header__prescribed {
  font-size: 13px;
  color: var(--color-text-secondary);
}

.superset-header__note input {
  width: 100%;
  min-height: 44px;
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-s);
  background: var(--color-surface);
}

.superset-header__plus {
  justify-self: center;
  font-size: 24px;
  font-weight: 700;
  color: var(--color-text-secondary);
  align-self: center;
  line-height: 1;
}

.badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.2px;
}

.badge.neutral {
  background: #e5e7eb;
  color: #374151;
}

.badge.success {
  background: #dcfce7;
  color: #166534;
}

.admin-app #trainer-admin-panel .form-actions {
  margin-bottom: var(--space-3);
}

.admin-app #invite-list {
  margin-top: var(--space-2);
  display: grid;
  gap: var(--space-2);
}

.admin-app .log-viewer {
  margin-top: var(--space-3);
  padding: var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-m);
  background: color-mix(in srgb, var(--color-panel) 92%, var(--color-border) 8%);
  max-width: 100%;
  max-height: 70vh;
  overflow: auto;
  box-sizing: border-box;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-size: 12px;
  line-height: 1.35;
}

.modal.invite-modal .form-actions {
  justify-content: flex-end;
}

.modal.invite-modal .field-grid {
  margin-bottom: var(--space-3);
}

@media (max-width: 700px) {
  .superset-header {
    grid-template-columns: 1fr;
    justify-items: start;
    gap: var(--space-2);
  }

  .superset-header__plus {
    display: flex;
  }

  body.client-app[data-client-stage="app"] .app-main {
    padding-top: calc(var(--space-3) + env(safe-area-inset-top));
    padding-bottom: calc(var(--space-3) + env(safe-area-inset-bottom));
  }

  .exercise-card--active .exercise-card__rest {
    top: var(--space-2);
  }

  .tab-nav a,
  .tab-nav__button,
  .tab-nav__profile {
    border-radius: 999px;
  }

  body.client-app #client-tab-nav a,
  body.client-app #client-tab-nav .tab-nav__button,
  body.client-app #client-tab-nav .tab-nav__profile {
    width: auto;
    flex: 0 0 auto;
    padding: var(--space-2) var(--space-2);
    font-size: 16px;
    white-space: nowrap;
  }

  body.client-app #client-tab-nav .tab-nav__profile {
    justify-self: end;
  }

  .card {
    padding: var(--space-3) var(--space-2);
    background: transparent;
    border: none;
    box-shadow: none;
    border-radius: 0;
  }

  .card--start {
    padding: var(--space-3) var(--space-2);
    background: transparent;
    box-shadow: none;
  }
}
@keyframes exercise-launch-arrow {
  0% {
    transform: translateX(0);
    opacity: 1;
  }
  100% {
    transform: translateX(14px);
    opacity: 0;
  }
}
