/* Layout: оболочка, шапка, сайдбар, main */
.dashboard-layout {
  height: 100vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.dashboard-header {
  flex-shrink: 0;
  height: var(--header-height);
  border-bottom: var(--border-width-thin) solid var(--color-border);
  background-color: var(--color-bg-card);
  padding-left: var(--header-padding-x);
  padding-right: var(--header-padding-x);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-md);
}
.dashboard-header__left {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  min-width: 0;
}
.dashboard-header__title {
  flex-shrink: 0;
  font-size: var(--form-heading-size-section);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text);
  max-width: 28rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.dashboard-header__toast {
  flex: 1;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-sm);
  min-width: 0;
}
.dashboard-toast {
  padding: 0.5rem 0.75rem;
  border-radius: var(--radius-input);
  font-size: var(--font-size-helper);
  font-weight: var(--font-weight-medium);
  white-space: nowrap;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  transition: opacity 0.3s ease-out;
  pointer-events: auto;
  cursor: default;
}
.dashboard-toast--dismissing {
  opacity: 0;
  pointer-events: none;
}
.dashboard-toast--success {
  background-color: var(--emerald-700, #047857);
  color: var(--color-text);
  border: none;
}
.dashboard-toast--error {
  background-color: var(--color-error);
  color: var(--white);
  border: none;
}
.dashboard-toast--warning {
  background-color: var(--gray-500);
  color: var(--white);
  border: none;
}
.dashboard-toast--info {
  background-color: var(--blue-500);
  color: var(--white);
  border: none;
}
.dashboard-layout-body {
  display: flex;
  flex: 1;
  min-height: 0;
  overflow: hidden;
}
.dashboard-layout-body--no-sidebar .dashboard-main {
  flex: 1 1 100%;
}
.dashboard-sidebar {
  flex-shrink: 0;
  width: var(--sidebar-width);
  background-color: var(--color-bg-card);
  border-right: var(--border-width-thin) solid var(--color-border);
  padding: var(--sidebar-padding);
  overflow-y: auto;
}
.dashboard-nav {
  display: flex;
  flex-direction: column;
  gap: var(--nav-item-gap);
}
.dashboard-nav-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  text-align: left;
  padding: var(--nav-item-padding-x) var(--nav-item-padding-y);
  border-radius: var(--radius-input);
  border: var(--border-width-thin) solid transparent;
  transition: border-color var(--transition-base), background-color var(--transition-base);
}
.dashboard-nav-item:hover {
  border-color: var(--color-border);
  background-color: var(--color-hover-bg);
}
.dashboard-nav-item.nav-item-active {
  border-color: var(--color-accent);
}
.dashboard-nav-item__count {
  font-size: var(--font-size-ui);
  font-weight: var(--font-weight-medium);
  font-variant-numeric: tabular-nums;
  color: var(--color-text-muted);
}
.dashboard-nav-item__growth {
  color: var(--emerald-600);
  font-weight: var(--font-weight-semibold);
}
.dashboard-main {
  flex: 1 1 0%;
  min-width: 0;
  padding: var(--main-padding);
  overflow-y: auto;
}

/* Главная дашборда: плашки сервисов и состав системы.
   Переиспользует токены: --color-bg-card, --color-border, --radius-card, --form-heading-size-section, --color-text-muted. */
.dashboard-home-plates {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-md);
  max-width: 56rem;
  margin-left: auto;
  margin-right: auto;
}
.dashboard-home-plate {
  display: flex;
  flex-direction: column;
  gap: var(--form-block-heading-gap);
  padding: var(--spacing-form-card);
  background-color: var(--color-bg-card);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--radius-card);
  text-decoration: none;
  color: inherit;
  box-sizing: border-box;
  transition: border-color var(--transition-base), background-color var(--transition-base);
}
.dashboard-home-plate:hover {
  border-color: var(--color-border);
  background-color: var(--color-hover-bg);
}
.dashboard-home-plate-button {
  width: 100%;
  text-align: left;
  font: inherit;
  cursor: pointer;
}

.dashboard-project-plates {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 18rem));
  gap: var(--space-md);
  justify-content: center;
  justify-items: stretch;
  max-width: calc(18rem * 3 + var(--space-md) * 2);
  margin-left: auto;
  margin-right: auto;
}

.dashboard-project-plate {
  width: 18rem;
  aspect-ratio: 7 / 5;
  min-height: 0;
  justify-content: center;
  text-align: center;
}

.dashboard-project-plate .dashboard-home-plate__row {
  align-items: center;
  justify-content: center;
}

.dashboard-project-plate--create {
  align-items: center;
  justify-content: center;
}

.dashboard-project-plate__plus {
  color: var(--color-form-heading);
  font-size: 3rem;
  font-weight: var(--font-weight-semibold);
  line-height: 1;
}

@media (max-width: 1200px) {
  .dashboard-project-plates {
    grid-template-columns: repeat(2, minmax(0, 18rem));
    max-width: calc(18rem * 2 + var(--space-md));
  }
}

@media (max-width: 900px) {
  .dashboard-project-plates {
    grid-template-columns: repeat(1, minmax(0, 18rem));
    max-width: 18rem;
  }
}
.dashboard-home-plate__row {
  display: flex;
  align-items: flex-start;
  gap: var(--space-sm);
}
.dashboard-home-plate__status {
  flex-shrink: 0;
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 50%;
  margin-top: 0.4rem;
}
.dashboard-home-plate__status--ok {
  background-color: var(--emerald-600);
}
.dashboard-home-plate__status--error {
  background-color: var(--red-500);
}
.dashboard-home-plate__icon {
  flex-shrink: 0;
  width: 1.25rem;
  height: 1.25rem;
  color: var(--color-text-muted);
}
.dashboard-home-plate__icon svg {
  display: block;
  width: 100%;
  height: 100%;
}
.dashboard-home-plate__title {
  font-size: var(--form-heading-size-section);
  font-weight: var(--form-heading-weight-section);
  color: var(--color-form-heading);
  margin: 0;
}
.dashboard-home-plate__description {
  font-size: var(--font-size-helper);
  color: var(--color-text-muted);
  line-height: 1.4;
  margin: 0;
}
@media (max-width: 900px) {
  .dashboard-home-plates {
    grid-template-columns: 1fr;
  }
}

/* Страница входа */
.dashboard-login-page {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--login-page-padding);
}
.dashboard-login-card {
  width: 100%;
  max-width: var(--login-card-max-width);
}
.dashboard-login-card .dashboard-form-card {
  max-width: var(--login-card-max-width);
}
.dashboard-login-header {
  margin-bottom: var(--page-toolbar-margin-bottom);
}
.dashboard-login-title {
  font-size: var(--page-title-size);
  font-weight: var(--page-title-weight);
  color: var(--color-text);
}
.dashboard-login-subtitle {
  font-size: var(--page-subtitle-size);
  color: var(--color-text-muted);
  margin-top: var(--space-xs);
}
.dashboard-login-field {
  display: flex;
  flex-direction: column;
  gap: var(--form-block-heading-gap);
}

/* Левая панель дашборда: без подчёркивания, размер шрифта названий, выделение активного */
.dashboard-sidebar nav a {
  text-decoration: none;
  border-style: solid;
  border-width: var(--border-width-thin);
  cursor: pointer;
}
.dashboard-sidebar nav a .nav-item-name {
  font-size: var(--font-size-ui);
}
.dashboard-sidebar nav a.nav-item-active {
  border: var(--border-width-thin) solid var(--color-accent);
}
.dashboard-sidebar nav a.nav-item-active .nav-item-name {
  color: var(--color-accent);
  font-weight: var(--font-weight-medium);
}
.dashboard-sidebar nav a:not(.nav-item-active) .nav-item-name {
  color: var(--color-text);
}

/* Таблицы дашборда: фон, обводка, скругление, overflow — всё в компоненте */
.dashboard-table-wrapper {
  background-color: var(--color-bg-card);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--radius-table);
  overflow: hidden;
}

/* Таблицы дашборда: thead серый, разделители строк через border-t у tbody tr */
.dashboard-table {
  border-collapse: collapse;
}
.dashboard-table thead {
  background-color: var(--color-hover-bg);
}
.dashboard-table thead th {
  text-align: left;
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-secondary);
  padding: var(--table-header-padding-y) var(--table-header-padding-x);
  font-size: var(--font-size-ui);
}
.dashboard-table tbody tr {
  border-top: var(--border-width-thin) solid var(--color-border);
}
.dashboard-table tbody td {
  padding: var(--table-cell-padding-y) var(--table-cell-padding-x);
  font-size: var(--font-size-ui);
}
.dashboard-journal-table .dashboard-table tbody td {
  padding: 1rem var(--table-cell-padding-x);
}
.dashboard-journal-table .dashboard-table thead th {
  padding: 1rem var(--table-header-padding-x);
}
.dashboard-table-th--right {
  text-align: right;
}
.dashboard-table-empty-cell {
  padding-top: var(--table-empty-cell-padding-y);
  padding-bottom: var(--table-empty-cell-padding-y);
  text-align: center;
  color: var(--color-text-muted);
}
.dashboard-table-cell--right {
  text-align: right;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-sm);
}
.dashboard-table-cell--right .dashboard-form-inline {
  margin-left: 0;
}
.dashboard-channel-list__actions {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  justify-content: flex-end;
}

/*
  Dropdown menu (контекстное меню) — универсальный компонент дизайн-системы.
  Использование: обёртка с data-dashboard-dropdown, внутри — кнопка с
  data-dashboard-dropdown-trigger и панель с data-dashboard-dropdown-panel.
  В панели — ссылки или кнопки с классом dashboard-dropdown-menu__item.
  Подключить скрипт: dashboard/js/dropdown-menu.js
*/
.dashboard-dropdown-menu {
  position: relative;
}
.dashboard-dropdown-menu__trigger {
  width: var(--height-button);
  min-width: var(--height-button);
  padding: 0;
  border-radius: 50%;
}
.dashboard-dropdown-menu__trigger .ds-btn__icon {
  display: flex;
  align-items: center;
  justify-content: center;
}
.dashboard-dropdown-menu__panel {
  /* Позиция задаётся из JS (position: fixed), чтобы не обрезалось overflow родителя */
  min-width: 12rem;
  padding: var(--space-xs);
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: 12px;
  box-shadow: var(--shadow-md, 0 4px 12px rgba(0, 0, 0, 0.12));
  z-index: 1000;
}
.dashboard-dropdown-menu__panel[hidden] {
  display: none;
}
.dashboard-dropdown-menu__item {
  display: flex;
  align-items: center;
  width: 100%;
  min-height: 42px;
  padding: 0 var(--space-md);
  font-size: var(--font-size-ui);
  color: var(--color-text);
  text-decoration: none;
  text-align: left;
  border: none;
  border-radius: 8px;
  background: transparent;
  cursor: pointer;
  white-space: nowrap;
  box-sizing: border-box;
  font-family: inherit;
}
.dashboard-dropdown-menu__item:hover {
  background: var(--gray-100, #f3f4f6);
}
.dashboard-dropdown-menu__item-form {
  margin: 0;
  padding: 0;
}
.dashboard-dropdown-menu__item-form .dashboard-dropdown-menu__item {
  box-sizing: border-box;
}
.dashboard-table-cell--muted {
  color: var(--color-text-secondary);
}
.dashboard-table-cell--medium {
  font-weight: var(--font-weight-medium);
}
.dashboard-table-cell--truncate {
  max-width: var(--help-popover-max-width);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.dashboard-table-cell--name {
  max-width: var(--table-cell-name-max-width);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Сетка иконок: 100px ячейки, ховер со скруглённым квадратом */
.dashboard-icon-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(100px, 100px));
  gap: var(--space-md);
}

.dashboard-icon-grid__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: var(--space-md);
  text-decoration: none;
  color: var(--color-text);
}

.dashboard-icon-grid__preview {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100px;
  height: 100px;
  flex-shrink: 0;
  padding: 12px;
  box-sizing: border-box;
  background-color: var(--color-bg-card);
  border-radius: 14px;
  overflow: hidden;
  border: 2px solid transparent;
  transition: background-color 0.15s ease, border-color 0.15s ease;
}

/* Подсветка только при наведении на скруглённый квадрат, не на текст под ним */
.dashboard-icon-grid__item .dashboard-icon-grid__preview:hover {
  background-color: var(--color-hover-bg);
  border-color: var(--color-border);
}

.dashboard-icon-grid__img {
  width: 100%;
  height: 100%;
  max-width: 76px;
  max-height: 76px;
  object-fit: contain;
}

.dashboard-icon-grid__placeholder {
  font-size: var(--font-size-helper);
  color: var(--color-text-muted);
}

.dashboard-icon-grid__name {
  margin-top: var(--space-xs);
  font-size: var(--font-size-helper);
  color: var(--color-text-secondary);
  text-align: center;
  word-break: break-word;
}

.dashboard-icon-grid__empty {
  grid-column: 1 / -1;
  color: var(--color-text-muted);
  padding: var(--space-lg);
}

/* Превью иконки в форме редактирования */
.dashboard-icon-form-preview {
  display: flex;
  align-items: center;
  justify-content: flex-start;
}

.dashboard-icon-form-preview__img {
  width: 100px;
  height: 100px;
  object-fit: contain;
  border-radius: 14px;
  border: var(--border-width-thin) solid var(--color-border);
}

.dashboard-icon-form-preview__img--hidden {
  display: none;
}
.dashboard-icon-form-preview__placeholder--hidden {
  display: none;
}
.dashboard-icon-form-preview__placeholder {
  font-size: var(--font-size-helper);
  color: var(--color-text-muted);
}

/* Превью истории в списке */
.dashboard-story-list-preview {
  display: block;
  height: var(--preview-story-height);
  width: auto;
  object-fit: contain;
  border-radius: var(--radius-md);
  vertical-align: middle;
}

/* Превью слайда в списке: соотношение сторон 9:16 (вертикальное) */
.dashboard-slide-list-preview {
  display: inline-block;
  width: var(--preview-slide-size);
  aspect-ratio: 9 / 16;
  overflow: hidden;
  border-radius: var(--radius-sm);
  background-color: var(--color-hover-bg);
  vertical-align: middle;
}
.dashboard-slide-list-preview img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  user-select: none;
  pointer-events: none;
}

/* Переключатель режима просмотра слайдов (список / плитка): круглые кнопки */
.dashboard-slide-view-toggle {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
}
.dashboard-slide-view-btn {
  width: var(--height-button);
  height: var(--height-button);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: var(--border-width-thin) solid var(--color-border);
  background-color: var(--color-bg-card);
  color: var(--color-text-secondary);
  border-radius: var(--radius-button);
  cursor: pointer;
  transition: background-color var(--transition-base), border-color var(--transition-base), color var(--transition-base);
}
.dashboard-slide-view-btn:hover {
  background-color: var(--color-hover-bg);
  border-color: var(--color-hover-border);
  color: var(--color-text);
}
.dashboard-slide-view-btn[aria-pressed="true"] {
  background-color: var(--btn-secondary-bg);
  border-color: var(--color-hover-border);
  color: var(--color-text);
}
.dashboard-slide-view-btn[aria-pressed="true"]:hover {
  background-color: var(--gray-300);
  border-color: var(--gray-400);
  color: var(--color-text);
}
.dashboard-slide-view-icon {
  flex-shrink: 0;
}

/* Пикер фильтра статуса (Все / В работе / Скрытые): полностью скруглённый селект со стрелкой, ховер как у кнопок списка/плиток */
.dashboard-filter-picker-wrap {
  display: inline-block;
}
.dashboard-filter-picker {
  display: inline-flex;
  cursor: pointer;
}
.dashboard-filter-picker__select-wrap {
  display: inline-flex;
  align-items: center;
  height: var(--height-button);
  min-width: var(--filter-picker-min-width);
  padding-left: var(--btn-padding-x);
  padding-right: calc(var(--btn-padding-x) + var(--filter-picker-arrow-size) + var(--filter-picker-arrow-offset));
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--radius-button);
  background-color: var(--color-bg-card);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23374151' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--filter-picker-arrow-offset) center;
  background-size: var(--filter-picker-arrow-size) var(--filter-picker-arrow-size);
  transition: background-color var(--transition-base), border-color var(--transition-base);
  pointer-events: none;
}
.dashboard-filter-picker__select-wrap .dashboard-filter-picker__select {
  pointer-events: auto;
}
.dashboard-filter-picker:hover .dashboard-filter-picker__select-wrap {
  background-color: var(--color-hover-bg);
  border-color: var(--color-hover-border);
}
.dashboard-filter-picker__select {
  appearance: none;
  -webkit-appearance: none;
  margin: 0;
  padding: 0;
  border: none;
  background: transparent;
  font-family: inherit;
  font-size: var(--font-size-ui);
  font-weight: var(--font-weight-medium);
  color: var(--color-text);
  cursor: pointer;
  width: 100%;
  min-width: 0;
}
.dashboard-filter-picker__select:focus {
  outline: none;
}
.dashboard-filter-picker__select option {
  color: var(--color-text);
}

/* Контейнер слайдов: список или плитка */
.dashboard-slides-container {
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.dashboard-slides-header {
  display: none;
}
.dashboard-slides--list .dashboard-slides-header {
  display: grid;
  grid-template-columns: var(--slide-list-order-width) var(--slide-list-preview-width) 1fr var(--slide-list-time-width) var(--slide-list-time-width) var(--slide-list-actions-width);
  gap: 0 var(--space-md);
  align-items: center;
  background-color: var(--color-hover-bg);
  padding: var(--table-cell-padding-y) var(--table-cell-padding-x);
  font-size: var(--font-size-ui);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-secondary);
}
.dashboard-slides--list .dashboard-slides-header-cell--actions {
  text-align: right;
}
.dashboard-slides--list .dashboard-slide-item {
  display: grid;
  grid-template-columns: var(--slide-list-order-width) var(--slide-list-preview-width) 1fr var(--slide-list-time-width) var(--slide-list-time-width) var(--slide-list-actions-width);
  gap: 0 var(--space-md);
  align-items: center;
  padding: var(--table-cell-padding-y) var(--table-cell-padding-x);
  border-top: var(--border-width-thin) solid var(--color-border);
  font-size: var(--font-size-ui);
  cursor: grab;
}
.dashboard-slides--list .dashboard-slide-item:active {
  cursor: grabbing;
}
.dashboard-slides--list .dashboard-slide-item .dashboard-slide-actions-cell {
  text-align: right;
}
.dashboard-slides--list .dashboard-slide-title-cell {
  font-weight: var(--font-weight-medium);
  color: var(--color-text);
}
.dashboard-slides--list .dashboard-slide-order,
.dashboard-slides--list .dashboard-slide-time {
  color: var(--color-text-secondary);
}
.dashboard-slides--tile .dashboard-slides-header {
  display: none;
}
.dashboard-slides--tile {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--slide-tile-padding);
  padding: var(--slide-tile-padding);
}
.dashboard-slides--tile .dashboard-slide-item {
  display: flex;
  flex-direction: column;
  background-color: var(--color-bg-card);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--radius-card);
  overflow: hidden;
  cursor: grab;
  min-width: 0;
}
.dashboard-slides--tile .dashboard-slide-item:active {
  cursor: grabbing;
}
.dashboard-slides--tile .dashboard-slide-drag-handle {
  position: absolute;
  top: var(--space-sm);
  left: var(--space-sm);
  z-index: 1;
}
.dashboard-slides--tile .dashboard-slide-item {
  position: relative;
}
.dashboard-slides--tile .dashboard-slide-preview-cell {
  width: 100%;
  aspect-ratio: 9 / 16;
  background-color: var(--color-hover-bg);
  overflow: hidden;
  flex-shrink: 0;
}
.dashboard-slides--tile .dashboard-slide-preview-cell .dashboard-slide-list-preview {
  width: 100%;
  height: 100%;
  display: block;
  border-radius: 0;
}
.dashboard-slides--tile .dashboard-slide-preview-cell .dashboard-slide-list-preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.dashboard-slides--tile .dashboard-slide-preview-cell .dashboard-slide-preview-empty,
.dashboard-slides--list .dashboard-slide-preview-cell .dashboard-slide-preview-empty {
  color: var(--color-text-muted);
}
.dashboard-slides--tile .dashboard-slide-preview-cell .dashboard-slide-preview-empty {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  min-height: var(--slide-tile-min-height);
}
.dashboard-slides--tile .dashboard-slide-title-cell,
.dashboard-slides--tile .dashboard-slide-order,
.dashboard-slides--tile .dashboard-slide-time {
  padding: 0 var(--table-cell-padding-x);
  font-size: var(--font-size-ui);
}
.dashboard-slides--tile .dashboard-slide-title-cell {
  padding-top: var(--table-cell-padding-y);
  padding-bottom: var(--form-heading-margin-top);
  font-weight: var(--font-weight-medium);
  color: var(--color-text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.dashboard-slides--tile .dashboard-slide-order {
  padding-top: var(--space-sm);
  padding-bottom: var(--form-heading-margin-top);
  color: var(--color-text-secondary);
}
.dashboard-slides--tile .dashboard-slide-order::before {
  content: "Порядок: ";
}
.dashboard-slides--tile .dashboard-slide-time {
  padding-top: var(--space-sm);
  padding-bottom: var(--table-cell-padding-y);
  color: var(--color-text-secondary);
}
.dashboard-slides--tile .dashboard-slide-time::before {
  content: "Длительность: ";
}
.dashboard-slides--tile .dashboard-slide-time::after {
  content: " сек";
}
.dashboard-slides--tile .dashboard-slide-actions-cell {
  padding: var(--table-cell-padding-y) var(--table-cell-padding-x);
  margin-top: auto;
}
.dashboard-slides--tile .dashboard-slide-actions-cell :is(.ds-btn, .btn-filled-gray) {
  width: 100%;
  justify-content: center;
}
.dashboard-slides-empty {
  grid-column: 1 / -1;
  padding: var(--space-xl) var(--table-cell-padding-x);
  text-align: center;
  color: var(--color-text-muted);
  font-size: var(--font-size-ui);
}
.dashboard-slides--tile .dashboard-slides-empty {
  padding: var(--space-xl);
}

@media (max-width: 639px) {
  .dashboard-slides--tile {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 640px) and (max-width: 1023px) {
  .dashboard-slides--tile {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (min-width: 1024px) {
  .dashboard-slides--tile {
    grid-template-columns: repeat(4, 1fr);
  }
}

/* Перетаскивание слайдов (общий контейнер) */
.dashboard-slide-item--dragging {
  opacity: 0.5;
  background-color: var(--color-hover-bg);
}
.dashboard-slide-drag-handle {
  display: inline-block;
  color: var(--color-text-muted);
  font-size: var(--form-heading-size-field);
  letter-spacing: -0.2em;
  user-select: none;
  cursor: grab;
}
.dashboard-slide-reorder-form--hidden {
  display: none;
}

/* Карточка формы: токены радиуса и отступа */
.dashboard-form-card {
  background-color: var(--color-bg-card);
  border: var(--border-width-thin) solid var(--color-border);
  padding: var(--spacing-form-card);
  border-radius: var(--radius-card);
}
/* Единый отступ после заголовка секции во всех карточках (как в .dashboard-form с gap) */
.dashboard-form-card > .dashboard-form-section-title + * {
  margin-top: var(--form-sections-gap);
}
.dashboard-form {
  display: flex;
  flex-direction: column;
  gap: var(--form-sections-gap);
}
.dashboard-form-section {
  display: flex;
  flex-direction: column;
  gap: var(--form-sections-gap);
}
.dashboard-form-section--spaced {
  padding-top: var(--spacing-form-card);
}
.dashboard-form-field {
  display: flex;
  flex-direction: column;
  gap: var(--form-block-heading-gap);
}
.dashboard-form-card label {
  gap: var(--form-block-heading-gap);
}
.dashboard-page-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--page-toolbar-gap);
  margin-bottom: var(--page-toolbar-margin-bottom);
  height: var(--height-page-toolbar);
  flex-shrink: 0;
  box-sizing: border-box;
}
.dashboard-page-toolbar__filters {
  display: flex;
  align-items: center;
  gap: var(--page-toolbar-gap);
}
.dashboard-tab {
  padding: var(--nav-item-padding-x) var(--nav-item-padding-y);
  border-radius: var(--radius-button, var(--radius-md));
  color: var(--color-text-secondary);
  text-decoration: none;
  font-size: var(--font-size-ui);
}
.dashboard-tab:hover {
  color: var(--color-text);
}
.dashboard-tab--active {
  font-weight: var(--font-weight-medium);
  color: var(--color-text);
}
.dashboard-page-toolbar__actions {
  display: flex;
  align-items: center;
  gap: var(--page-toolbar-gap);
}
.dashboard-page-toolbar__actions .dashboard-form-inline {
  margin-left: 0;
}
.dashboard-search-form {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}
.dashboard-search-form .dashboard-form-input {
  min-width: var(--search-form-input-min-width);
}
.dashboard-post-list-filter-row {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--space-sm);
  margin: 0;
}
.dashboard-post-list-filter-row .dashboard-form-label {
  flex-shrink: 0;
}
.dashboard-post-list-filter-row > * + * {
  margin-top: 0;
}

/* Кнопка «Фильтры»: круглая, нежная серая обводка, иконка без акцента */
.dashboard-post-filter-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--height-button);
  height: var(--height-button);
  padding: 0;
  border: var(--border-width-thin) solid var(--gray-200);
  border-radius: 50%;
  background-color: transparent;
  color: var(--color-text-muted);
  cursor: pointer;
  transition: color var(--transition-base), border-color var(--transition-base), background-color var(--transition-base);
}
.dashboard-post-filter-btn:hover {
  color: var(--color-text);
  border-color: var(--gray-300);
  background-color: var(--color-hover-bg, var(--gray-100));
}
.dashboard-post-filter-btn--active {
  border-color: var(--gray-300);
  color: var(--color-text);
}
.dashboard-post-filter-btn--active:hover {
  border-color: var(--gray-400);
  color: var(--color-text);
  background-color: var(--color-hover-bg, var(--gray-100));
}
.dashboard-post-filter-btn:focus-visible {
  outline: 2px solid var(--gray-400);
  outline-offset: 2px;
}
.dashboard-post-filter-btn__icon {
  display: block;
  line-height: 0;
}
.dashboard-post-filter-btn__icon svg {
  display: block;
  width: 20px;
  height: 20px;
}

/* Модальное окно фильтров постов */
.dashboard-post-filter-modal {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-lg);
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--transition-base), visibility var(--transition-base);
}
.dashboard-post-filter-modal--open {
  opacity: 1;
  visibility: visible;
}
.dashboard-post-filter-modal__backdrop {
  position: absolute;
  inset: 0;
  background-color: var(--modal-backdrop-bg);
  cursor: pointer;
}
.dashboard-post-filter-modal__content {
  position: relative;
  width: 100%;
  max-width: 24rem;
  background-color: var(--color-bg-card);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--radius-card);
  padding: var(--space-xl);
  box-shadow: var(--modal-shadow);
}
.dashboard-post-filter-modal__title {
  font-size: var(--form-heading-size-section);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text);
  margin: 0 0 var(--space-lg);
}
.dashboard-post-filter-modal__form .dashboard-form-block {
  margin-bottom: var(--space-md);
}
.dashboard-post-filter-modal__form .dashboard-form-block:last-of-type {
  margin-bottom: var(--space-xl);
}
.dashboard-post-filter-modal__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--page-toolbar-gap);
  margin-top: var(--space-lg);
}
.dashboard-post-filter-modal__actions .ds-btn {
  flex: 1 1 0;
  min-width: 0;
  height: var(--height-button);
  min-height: var(--height-button);
  box-sizing: border-box;
  justify-content: center;
}
/* Селекты в модалке фильтра: при фокусе без акцента, серая обводка */
.dashboard-post-filter-modal .dashboard-form-input:focus,
.dashboard-post-filter-modal .dashboard-form-select:focus {
  border-color: var(--gray-400);
  outline: none;
}

/* Модальное окно «Добавить тег» в форме категории */
.dashboard-category-tag-modal {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-lg);
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--transition-base), visibility var(--transition-base);
}
.dashboard-category-tag-modal--open {
  opacity: 1;
  visibility: visible;
}
.dashboard-category-tag-modal__backdrop {
  position: absolute;
  inset: 0;
  background-color: var(--modal-backdrop-bg);
  cursor: pointer;
}
.dashboard-category-tag-modal__content {
  position: relative;
  width: 100%;
  max-width: 24rem;
  background-color: var(--color-bg-card);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--radius-card);
  padding: var(--space-xl);
  box-shadow: var(--modal-shadow);
}
.dashboard-category-tag-modal__title {
  font-size: var(--form-heading-size-section);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text);
  margin: 0 0 var(--space-lg);
}
.dashboard-category-tag-modal .dashboard-form-block {
  margin-bottom: var(--space-md);
}
.dashboard-category-tag-modal__error {
  margin-top: var(--space-xs);
}
.dashboard-category-tag-modal__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--page-toolbar-gap);
  margin-top: var(--space-lg);
}
.dashboard-category-tag-modal__actions .ds-btn {
  flex: 1 1 0;
  min-width: 0;
  height: var(--height-button);
  min-height: var(--height-button);
  box-sizing: border-box;
  justify-content: center;
}
.dashboard-category-tag-modal .dashboard-form-input:focus {
  border-color: var(--gray-400);
  outline: none;
}

/* Модальное окно «Добавить тег» в форме топика (алиасы для topic) */
.dashboard-topic-tag-modal {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-lg);
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--transition-base), visibility var(--transition-base);
}
.dashboard-topic-tag-modal--open {
  opacity: 1;
  visibility: visible;
}
.dashboard-topic-tag-modal__backdrop {
  position: absolute;
  inset: 0;
  background-color: var(--modal-backdrop-bg);
  cursor: pointer;
}
.dashboard-topic-tag-modal__content {
  position: relative;
  width: 100%;
  max-width: 24rem;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  background-color: var(--color-bg-card);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--radius-card);
  padding: var(--space-xl);
  box-shadow: var(--modal-shadow);
  overflow: hidden;
}
.dashboard-topic-tag-modal__title {
  font-size: var(--form-heading-size-section);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text);
  margin: 0 0 var(--space-lg);
  flex-shrink: 0;
}

.dashboard-topic-tag-modal__content .dashboard-picker-list {
  max-height: min(50vh, 20rem);
}
.dashboard-topic-tag-modal .dashboard-form-block {
  margin-bottom: var(--space-md);
}
.dashboard-topic-tag-modal__error {
  margin-top: var(--space-xs);
}
.dashboard-topic-tag-modal__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--page-toolbar-gap);
  margin-top: var(--space-lg);
}
.dashboard-topic-tag-modal__actions .ds-btn {
  flex: 1 1 0;
  min-width: 0;
  height: var(--height-button);
  min-height: var(--height-button);
  box-sizing: border-box;
  justify-content: center;
}
.dashboard-topic-tag-modal .dashboard-form-input:focus {
  border-color: var(--gray-400);
  outline: none;
}

.dashboard-picker-list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  margin-bottom: var(--space-lg);
}

.dashboard-topic-tag-modal .dashboard-picker-list {
  overflow-y: auto;
  min-height: 0;
}
.dashboard-picker-list__btn {
  max-width: 100%;
  min-width: 0;
}

/* Индикатор и модалка тайм-кодов в описании (редактирование поста) */
.dashboard-description-timestamps-indicator-wrap {
  margin-top: var(--space-sm);
}
.dashboard-description-timestamps-indicator {
  display: inline-flex;
  align-items: center;
  padding: var(--space-xs) var(--space-sm);
  font-size: var(--font-size-ui);
  color: var(--color-text);
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  border: 1px solid color-mix(in srgb, var(--accent) 40%, transparent);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: background var(--transition-base), border-color var(--transition-base);
}
.dashboard-description-timestamps-indicator:hover {
  background: color-mix(in srgb, var(--accent) 22%, transparent);
  border-color: color-mix(in srgb, var(--accent) 60%, transparent);
}

.dashboard-description-timestamps-modal {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-xl) var(--space-lg);
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--transition-base), visibility var(--transition-base);
}
.dashboard-description-timestamps-modal--open {
  opacity: 1;
  visibility: visible;
}
.dashboard-description-timestamps-modal__backdrop {
  position: absolute;
  inset: 0;
  background-color: var(--modal-backdrop-bg);
  cursor: pointer;
}
.dashboard-description-timestamps-modal__content {
  position: relative;
  width: 100%;
  max-width: 28rem;
  max-height: calc(90vh - 2 * var(--space-xl));
  display: flex;
  flex-direction: column;
  background-color: var(--color-bg-card);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--radius-card);
  padding: var(--space-xl);
  box-shadow: var(--modal-shadow);
  overflow: hidden;
}
.dashboard-description-timestamps-modal__title {
  font-size: var(--form-heading-size-section);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text);
  margin: 0 0 var(--space-md);
  padding: 0;
  flex-shrink: 0;
}
.dashboard-description-timestamps-modal__section {
  margin-top: 0;
  margin-bottom: var(--space-lg);
  padding: 0;
}
.dashboard-description-timestamps-modal__section:first-of-type {
  margin-top: 0;
}
.dashboard-description-timestamps-modal__section:last-of-type {
  margin-bottom: 0;
}
.dashboard-description-timestamps-modal__section-label {
  display: block;
  font-size: var(--font-size-ui);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-muted);
  margin-bottom: var(--space-xs);
}
.dashboard-description-timestamps-modal__section-content {
  font-size: var(--font-size-ui);
  color: var(--color-text);
  white-space: pre-wrap;
  word-break: break-word;
  line-height: 1.4;
}
#description-timestamps-modal-body {
  overflow-y: auto;
  min-height: 0;
  flex: 1 1 auto;
  padding-top: var(--space-sm);
  padding-bottom: var(--space-sm);
}
.dashboard-description-timestamps-modal__list {
  margin: 0;
  margin-top: var(--space-xs);
  padding-left: 0;
  list-style: none;
}
.dashboard-description-timestamps-modal__list li {
  margin-bottom: var(--space-sm);
  font-size: var(--font-size-ui);
  color: var(--color-text);
  line-height: 1.4;
}
.dashboard-description-timestamps-modal__list li:last-child {
  margin-bottom: 0;
}
.dashboard-description-timestamps-modal__list .dashboard-description-timestamps-modal__item-raw {
  color: var(--color-text-muted);
  font-size: 0.9em;
}
.dashboard-description-timestamps-modal__actions {
  margin-top: var(--space-lg);
  flex-shrink: 0;
}
.dashboard-description-timestamps-modal__actions .ds-btn {
  min-height: var(--height-button);
}

.dashboard-picker-list__btn .ds-btn__label {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dashboard-form-order-rows {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  margin-top: var(--space-md);
}
.dashboard-form-order-row {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  flex-wrap: wrap;
}
.dashboard-form-order-row__name {
  font-size: var(--font-size-ui);
  color: var(--color-text);
  min-width: 8rem;
  flex-shrink: 0;
}
.dashboard-form-order-row__input {
  width: 6rem;
  min-width: 6rem;
  flex-shrink: 0;
}

/* Ячейка категории в таблице: иконка, название, описание */
.dashboard-table-cell-category {
  vertical-align: middle;
  max-width: var(--table-cell-name-max-width);
  overflow: hidden;
}
.dashboard-category-cell {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
  align-items: flex-start;
  min-width: 0;
}
.dashboard-category-cell__row {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  min-width: 0;
}
.dashboard-category-cell__icon-slot {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  flex-shrink: 0;
}
.dashboard-category-cell__img {
  display: block;
  width: 32px;
  height: 32px;
  object-fit: contain;
}
.dashboard-category-cell__name {
  font-weight: var(--font-weight-medium);
  color: var(--color-text);
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.dashboard-category-cell__description {
  font-size: var(--font-size-helper);
  color: var(--color-text-muted);
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  margin-left: calc(32px + var(--space-md));
}

/* Ячейка топика в таблице (алиасы для topic) */
.dashboard-table-cell-topic {
  vertical-align: middle;
  max-width: var(--table-cell-name-max-width);
  overflow: hidden;
}
.dashboard-topic-cell {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--space-md);
  min-width: 0;
}
.dashboard-topic-cell__icon-slot {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  flex-shrink: 0;
  align-self: center;
}
.dashboard-topic-cell__body {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
  min-width: 0;
  overflow: hidden;
}
.dashboard-topic-cell__img {
  display: block;
  width: 32px;
  height: 32px;
  object-fit: contain;
}
.dashboard-topic-cell__name {
  font-weight: var(--font-weight-medium);
  color: var(--color-text);
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.dashboard-topic-cell__description {
  font-size: var(--font-size-helper);
  color: var(--color-text-muted);
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Универсальный пикер иконки (категории, теги, каналы) */
.dashboard-icon-picker {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-md);
}
.dashboard-icon-picker__trigger {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 80px;
  height: 80px;
  padding: 0;
  margin: 0;
  background: none;
  border: 2px dashed var(--color-border);
  border-radius: var(--radius-md);
  cursor: pointer;
  color: var(--color-text-muted);
  transition: border-color var(--transition-base), background-color var(--transition-base);
}
.dashboard-icon-picker__trigger:hover {
  border-color: var(--gray-400);
  background-color: var(--color-hover-bg);
}
.dashboard-icon-picker__placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  box-sizing: border-box;
}
.dashboard-icon-picker__placeholder-inner {
  width: 24px;
  height: 24px;
  opacity: 0.5;
  background: linear-gradient(to bottom, transparent 40%, currentColor 40%, currentColor 60%, transparent 60%),
    linear-gradient(to right, transparent 40%, currentColor 40%, currentColor 60%, transparent 60%);
  border-radius: 2px;
}
.dashboard-icon-picker__placeholder--hidden,
.dashboard-icon-picker__preview--hidden {
  display: none !important;
}
.dashboard-icon-picker__preview {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  box-sizing: border-box;
  padding: var(--space-xs);
}
.dashboard-icon-picker__img {
  display: block;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}
.dashboard-icon-picker__remove {
  flex-shrink: 0;
}
.dashboard-icon-picker__remove--hidden {
  display: none;
}

/* Модалка выбора иконки */
.dashboard-icon-picker-modal {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-lg);
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--transition-base), visibility var(--transition-base);
}
.dashboard-icon-picker-modal--open {
  opacity: 1;
  visibility: visible;
}
.dashboard-icon-picker-modal__backdrop {
  position: absolute;
  inset: 0;
  background-color: var(--modal-backdrop-bg);
  cursor: pointer;
}
.dashboard-icon-picker-modal__content {
  position: relative;
  width: min(40rem, 90vh);
  max-width: 40rem;
  height: min(40rem, 90vh);
  max-height: 90vh;
  overflow: auto;
  display: flex;
  flex-direction: column;
  background-color: var(--color-bg-card);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--radius-card);
  padding: var(--space-xl);
  box-shadow: var(--modal-shadow);
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.dashboard-icon-picker-modal__content::-webkit-scrollbar {
  display: none;
}
.dashboard-icon-picker-modal__title {
  font-size: var(--form-heading-size-section);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text);
  margin: 0 0 var(--space-lg);
}
.dashboard-icon-picker-modal__grid {
  margin: 0;
  justify-content: center;
}
.dashboard-icon-picker-modal__item {
  cursor: pointer;
  border: none;
  background: none;
  font: inherit;
  text-align: center;
  appearance: none;
}
.dashboard-icon-picker-modal__item:focus {
  outline: none;
}
.dashboard-icon-picker-modal__item:focus-visible .dashboard-icon-grid__preview {
  border-color: var(--color-focus-ring);
  box-shadow: 0 0 0 2px var(--color-focus-ring);
}
/* В модалке подсветка только при наведении на квадрат превью */
.dashboard-icon-picker-modal .dashboard-icon-grid__item:hover .dashboard-icon-grid__preview {
  background-color: var(--color-bg-card);
  border-color: transparent;
}
.dashboard-icon-picker-modal .dashboard-icon-grid__item .dashboard-icon-grid__preview:hover {
  background-color: var(--color-hover-bg);
  border-color: var(--color-border);
}
.dashboard-icon-grid__preview--empty {
  background-color: var(--color-hover-bg);
}
.dashboard-icon-grid__preview--empty .dashboard-icon-grid__placeholder {
  font-style: italic;
}

.dashboard-form-inline {
  display: inline-block;
  margin-left: var(--space-sm);
}
.dashboard-form-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-sm);
  margin-top: var(--space-lg);
}
.dashboard-form-actions .ds-btn {
  height: var(--height-button);
  min-height: var(--height-button);
  box-sizing: border-box;
}
.dashboard-form-actions .dashboard-form-plates {
  flex-wrap: wrap;
  gap: var(--space-md);
}
.dashboard-page-subtitle {
  font-size: var(--font-size-ui);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-md);
}
.dashboard-page-subtitle--medium {
  font-weight: var(--font-weight-medium);
  color: var(--color-text);
}
.dashboard-slide-view-toggle-wrap {
  display: flex;
  align-items: center;
  gap: var(--page-toolbar-gap);
}
.dashboard-form-card label {
  gap: var(--form-block-heading-gap);
}
/* Заголовки формы: отступы и цвет из переменных, размер — по уровню */
.dashboard-form-section-title {
  font-size: var(--form-heading-size-section);
  font-weight: var(--form-heading-weight-section);
  color: var(--color-form-heading);
  margin-top: var(--form-heading-margin-top);
  margin-bottom: var(--form-heading-margin-bottom);
}
.dashboard-form-label {
  font-size: var(--form-heading-size-field);
  font-weight: var(--form-heading-weight-field);
  color: var(--color-form-heading);
  margin-top: var(--form-heading-margin-top);
  margin-bottom: var(--form-heading-margin-bottom);
}
.dashboard-form-card label:first-of-type .dashboard-form-label {
  margin-top: 0;
}
/* Единый отступ после заголовка секции: у поля сразу под заголовком не добавляем margin-top */
.dashboard-form-section-title + label .dashboard-form-label {
  margin-top: 0;
}
.dashboard-form-card form > .dashboard-form-section-title:first-of-type,
.dashboard-form-card form > .dashboard-form-section-title:first-child {
  margin-top: 0;
}

/* Опциональное объяснение секции: тот же стиль что helper, выравнивание как у заголовка и полей (без сдвига) */
.dashboard-form-section-helper {
  font-size: var(--font-size-helper);
  color: var(--color-text-muted);
}

/* Редактор Markdown: слева — поле ввода, справа — превью (как в справке), одинаковой высоты */
.dashboard-form-markdown-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-lg);
  align-items: stretch;
  min-height: var(--form-markdown-row-min-height);
}
@media (max-width: 768px) {
  .dashboard-form-markdown-row {
    grid-template-columns: 1fr;
    min-height: 0;
  }
}
.dashboard-form-markdown-editor {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  min-height: 0;
}
.dashboard-form-markdown-editor-field {
  flex: 1;
  min-height: 0;
  display: flex;
}
.dashboard-form-markdown-editor-field .dashboard-form-input {
  flex: 1;
  min-height: 0;
  width: 100%;
}
.dashboard-form-markdown-preview-wrap {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  min-height: 0;
}
.dashboard-form-markdown-preview {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  padding: var(--table-cell-padding-y) var(--table-cell-padding-x);
  background-color: var(--color-bg-card);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--radius-input);
  box-sizing: border-box;
}
.dashboard-form-markdown-preview:empty::before,
.dashboard-form-markdown-preview-placeholder {
  color: var(--color-text-muted);
  font-size: var(--font-size-helper);
}
.dashboard-form-markdown-preview:empty::before {
  content: 'Здесь будет отображаться превью…';
}
.dashboard-form-markdown-preview-placeholder {
  margin: 0;
}

/* Блок формы: заголовок + контент. Единый отступ между всеми элементами (label, поле, ошибка, helper) — form-block-heading-gap */
.dashboard-form-block {
  display: flex;
  flex-direction: column;
}
.dashboard-form-block > * + * {
  margin-top: var(--form-block-heading-gap);
}
.dashboard-form-card label.dashboard-form-block {
  gap: 0;
}
.dashboard-form-block > .dashboard-form-label:first-child,
.dashboard-form-block > .dashboard-form-section-title:first-child {
  margin-bottom: 0;
}
/* Обёртка для ошибки и helper под полем: один отступ для обоих — половина скругления поля */
.dashboard-form-field-notes {
  padding-left: calc(var(--radius-input) / 2);
  display: flex;
  flex-direction: column;
  gap: 0;
}
.dashboard-form-field-notes > * + * {
  margin-top: var(--form-block-heading-gap);
}
.dashboard-form-field-notes > .dashboard-form-error,
.dashboard-form-field-notes > .dashboard-form-helper {
  padding-left: 0;
}
.dashboard-form-helper {
  font-size: var(--font-size-helper);
  color: var(--color-text-muted);
}
.dashboard-form-helper--flush {
  padding-left: 0;
}

/* Блок: отступ сверху (как после заголовка секции) */
.dashboard-form-block {
  margin-top: var(--form-block-margin-top);
}
.dashboard-form-block--tight {
  margin-top: var(--form-block-margin-top-tight);
}
/* Кнопки действий — по ширине контента, не на всю ширину */
.dashboard-form-block--actions {
  width: fit-content;
}
.dashboard-form-checkboxes-col {
  display: flex;
  flex-direction: column;
  gap: var(--form-block-heading-gap);
}
.dashboard-form-checkboxes-col .dashboard-form-plate-checkbox {
  min-height: var(--height-form-row);
  align-items: center;
}


/* Поля формы: токены радиуса и шрифта */
.dashboard-form-input {
  display: block;
  width: 100%;
  padding: 0 var(--table-cell-padding-x);
  font-size: var(--font-size-ui);
  font-family: inherit;
  color: var(--color-text);
  background-color: var(--color-bg-card);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--radius-input);
  transition: border-color var(--transition-base);
  box-sizing: border-box;
}
input.dashboard-form-input:not([type="file"]),
select.dashboard-form-input {
  min-height: var(--height-form-row);
  line-height: var(--height-form-row);
  padding-top: 0;
  padding-bottom: 0;
}
select.dashboard-form-input--select-tall {
  padding-top: var(--table-cell-padding-y);
  padding-bottom: var(--table-cell-padding-y);
  min-height: auto;
  line-height: 1.25;
}
textarea.dashboard-form-input {
  padding-top: var(--table-cell-padding-y);
  padding-bottom: var(--table-cell-padding-y);
  resize: vertical;
}
.dashboard-form-input:focus {
  outline: none;
  border-color: var(--input-focus-border);
}
.dashboard-form-input.dashboard-form-input--error {
  border-color: var(--input-error-border);
}
.dashboard-form-input.dashboard-form-input--error:focus {
  border-color: var(--input-error-border);
}
.dashboard-form-input.dashboard-form-input--readonly {
  min-height: var(--height-form-row);
  line-height: var(--height-form-row);
  padding-top: 0;
  padding-bottom: 0;
  background-color: var(--input-readonly-bg);
  color: var(--input-readonly-text);
  cursor: not-allowed;
}
.dashboard-form-input.dashboard-form-input--open-link {
  cursor: pointer;
  text-decoration: none;
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.dashboard-form-input.dashboard-form-input--open-link:hover {
  color: var(--color-text);
  background-color: var(--input-readonly-bg);
}
.dashboard-form-input.dashboard-form-input--copy {
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-md);
}
.dashboard-form-input--copy__value {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.dashboard-form-input--copy__feedback {
  display: none;
  align-items: center;
  gap: var(--space-sm);
  flex-shrink: 0;
  font-size: var(--font-size-ui);
  font-weight: var(--font-weight-medium);
  color: var(--color-copy-success, var(--emerald-600));
}
.dashboard-form-input--copy.is-copied .dashboard-form-input--copy__feedback {
  display: inline-flex;
}
.dashboard-form-input--copy__check {
  font-size: var(--form-heading-size-field);
  line-height: 1;
}

/* Кнопка выбора файла: ховер только по площади кнопки, не по имени файла (избегаем мигания курсора) */
.dashboard-form-file-wrap {
  display: inline-flex;
  align-items: center;
  gap: var(--space-md);
  position: relative;
}
.dashboard-form-file-btn {
  display: inline-block;
  padding: var(--table-cell-padding-y) var(--table-cell-padding-x);
  font-size: var(--font-size-ui);
  font-weight: var(--font-weight-medium);
  color: var(--color-text);
  background-color: var(--color-bg-card);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--radius-input);
  transition: border-color var(--transition-base), background-color var(--transition-base);
}
.dashboard-form-file-btn-wrap {
  display: inline-block;
  position: relative;
  cursor: pointer;
}
.dashboard-form-file-btn-wrap:hover .dashboard-form-file-btn {
  border-color: var(--input-hover-border);
  background-color: var(--input-hover-bg);
}
.dashboard-form-file-name {
  font-size: var(--font-size-ui);
  color: var(--color-text-muted);
  max-width: var(--form-plate-min-width-lg);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.dashboard-form-file-input {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  cursor: pointer;
  font-size: 0;
}
.dashboard-form-file-wrap:has(.dashboard-form-input--error) .dashboard-form-file-btn {
  border-color: var(--input-error-border);
  color: var(--color-error-text);
}

/* Предпросмотр выбранного изображения — только в модалке по клику на имя, мини не показываем */
.dashboard-form-file-preview {
  margin-top: var(--space-md);
  padding: var(--table-cell-padding-y);
  background-color: var(--gray-50);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--radius-input);
  min-height: 0;
  display: inline-block;
  width: fit-content;
  max-width: 100%;
}
.dashboard-form-file-preview--hidden {
  display: none;
}
.dashboard-form-file-preview:empty {
  display: none;
}
.dashboard-form-file-preview__img {
  display: block;
  max-width: 100%;
  max-height: var(--modal-content-max-height);
  width: auto;
  height: auto;
  object-fit: contain;
  border-radius: var(--radius-md);
}

/* Кликабельное имя файла — открывает превью в модалке */
.dashboard-form-file-name {
  cursor: default;
}
.dashboard-form-file-name.dashboard-form-file-name--has-file {
  cursor: pointer;
  text-decoration: underline;
  text-decoration-style: dotted;
  text-underline-offset: var(--link-underline-offset);
}
.dashboard-form-file-name.dashboard-form-file-name--has-file:hover {
  color: var(--color-text);
}

/* Модальное окно превью по клику на имя файла */
.dashboard-form-file-modal {
  position: fixed;
  inset: 0;
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-form-card);
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--transition-base), visibility var(--transition-base);
}
.dashboard-form-file-modal--open {
  opacity: 1;
  visibility: visible;
}
.dashboard-form-file-modal__backdrop {
  position: absolute;
  inset: 0;
  background-color: var(--modal-backdrop-bg);
  cursor: pointer;
}
.dashboard-form-file-modal__content {
  position: relative;
  max-width: 90vw;
  max-height: 90vh;
  background-color: var(--color-bg-card);
  border-radius: var(--radius-card);
  padding: var(--space-md);
  box-shadow: var(--modal-shadow);
}
.dashboard-form-file-modal__img {
  display: block;
  max-width: 85vw;
  max-height: 85vh;
  width: auto;
  height: auto;
  object-fit: contain;
  border-radius: var(--radius-md);
}
.dashboard-form-file-modal__close {
  position: absolute;
  top: var(--space-sm);
  right: var(--space-sm);
  width: var(--space-xl);
  height: var(--space-xl);
  padding: 0;
  font-size: var(--help-fullview-h1-size);
  line-height: 1;
  color: var(--color-text-muted);
  background: none;
  border: none;
  cursor: pointer;
  border-radius: var(--radius-sm);
}
.dashboard-form-file-modal__close:hover {
  color: var(--color-text);
  background-color: var(--color-hover-bg);
}

/* Кастомный диалог подтверждения */
.dashboard-confirm {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-lg);
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--transition-base), visibility var(--transition-base);
}
.dashboard-confirm.is-open {
  opacity: 1;
  visibility: visible;
}
.dashboard-confirm__backdrop {
  position: absolute;
  inset: 0;
  background-color: var(--modal-backdrop-bg);
  cursor: pointer;
}
.dashboard-confirm__content {
  position: relative;
  width: 100%;
  max-width: 24rem;
  background-color: var(--color-bg-card);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--radius-card);
  padding: var(--space-xl);
  box-shadow: var(--modal-shadow);
  text-align: center;
}
.dashboard-confirm__title {
  font-size: var(--form-heading-size-section);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text);
  margin: 0 0 var(--space-md);
}
.dashboard-confirm__message {
  font-size: var(--font-size-ui);
  color: var(--color-text-secondary);
  margin: 0 0 var(--space-xl);
  line-height: 1.5;
}
.dashboard-confirm__actions {
  display: flex;
  justify-content: center;
  gap: var(--page-toolbar-gap);
  flex-wrap: wrap;
}
.dashboard-confirm--loading .dashboard-confirm__backdrop {
  cursor: wait;
  pointer-events: none;
}
.dashboard-confirm__loading {
  padding: var(--space-sm) 0 var(--space-xs);
}
.dashboard-confirm__spinner {
  width: 2.5rem;
  height: 2.5rem;
  margin: 0 auto var(--space-md);
  border: 3px solid var(--color-border);
  border-top-color: var(--color-accent);
  border-radius: 50%;
  animation: dashboard-confirm-spin 0.75s linear infinite;
}
@keyframes dashboard-confirm-spin {
  to {
    transform: rotate(360deg);
  }
}
.dashboard-confirm__loading-text {
  margin: 0;
  font-size: var(--font-size-ui);
  color: var(--color-text-secondary);
  line-height: 1.4;
}

/* Диалог прогресса при сохранении поста (загрузка вложений + текст) */
.dashboard-save-progress {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-lg);
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--transition-base), visibility var(--transition-base);
}
.dashboard-save-progress--open {
  opacity: 1;
  visibility: visible;
}
.dashboard-save-progress__backdrop {
  position: absolute;
  inset: 0;
  background-color: var(--modal-backdrop-bg);
  cursor: wait;
}
.dashboard-save-progress__content {
  position: relative;
  width: 100%;
  max-width: 22rem;
  background-color: var(--color-bg-card);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--radius-card);
  padding: var(--space-xl);
  box-shadow: var(--modal-shadow);
  text-align: center;
}
.dashboard-save-progress__title {
  font-size: var(--form-heading-size-section);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text);
  margin: 0 0 var(--space-sm);
}
.dashboard-save-progress__message {
  font-size: var(--font-size-ui);
  color: var(--color-text-secondary);
  margin: 0 0 var(--space-md);
  line-height: 1.4;
}
.dashboard-save-progress__bar-wrap {
  height: 0.5rem;
  background-color: var(--gray-200);
  border-radius: var(--radius-button);
  overflow: hidden;
}
.dashboard-save-progress__bar {
  height: 100%;
  width: 0%;
  background-color: var(--color-accent);
  border-radius: var(--radius-button);
  transition: width 0.15s ease-out;
}

/* Select: стрелка, отступ от края, ховер как у однострочных полей */
.dashboard-form-select {
  appearance: none;
  -webkit-appearance: none;
  padding-right: var(--form-select-padding-right);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23374151' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--form-select-arrow-offset) center;
  background-size: var(--form-select-arrow-size) var(--form-select-arrow-size);
  cursor: pointer;
  transition: border-color var(--transition-base), background-color var(--transition-base);
}
.dashboard-form-select:hover {
  border-color: var(--input-hover-border);
  background-color: var(--input-hover-bg);
}
.dashboard-form-select--rounded-full {
  border-radius: var(--radius-button);
}

/* Строка из трёх плашек: статус, iOS, Android */
.dashboard-form-plates {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
}
.dashboard-form-plates--single-row {
  flex-wrap: nowrap;
}
/* Один ряд: две плашки-чекбокса и поле Роль в одну строку (форма пользователя) */
.dashboard-form-checkboxes-role-row {
  display: flex;
  flex-wrap: nowrap;
  align-items: flex-end;
  gap: var(--space-lg);
}
.dashboard-form-checkboxes-role-row .dashboard-form-plates {
  flex: 0 0 auto;
}
.dashboard-form-checkboxes-role-row .dashboard-form-block {
  flex: 1;
  min-width: 0;
}
.dashboard-form-plate {
  flex: 1;
  min-width: var(--form-plate-min-width);
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: var(--height-form-row);
  padding: 0 var(--table-cell-padding-x);
  background-color: var(--color-bg-card);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--radius-input);
  cursor: pointer;
}
/* Плашка с селектом: единый отступ от краёв, стрелка у правого края */
.dashboard-form-plate--select-only {
  padding-left: var(--table-cell-padding-x);
  padding-right: var(--space-sm);
}
.dashboard-form-plate--select-only .dashboard-form-input {
  background-color: transparent;
  border: none;
  padding-left: 0;
  padding-top: 0;
  padding-bottom: 0;
  min-height: var(--height-form-row);
  line-height: var(--height-form-row);
  cursor: pointer;
}
.dashboard-form-plate--select-only .dashboard-form-input:focus {
  border: none;
  box-shadow: none;
}

/* Плашка с числовым полем: без стрелок, в общем стиле */
.dashboard-form-plate--number {
  padding-left: var(--table-cell-padding-x);
  padding-right: var(--table-cell-padding-x);
}
.dashboard-form-plate--number .dashboard-form-input {
  background-color: transparent;
  border: none;
  padding-left: 0;
  padding-top: 0;
  padding-bottom: 0;
  min-height: var(--height-form-row);
  line-height: var(--height-form-row);
}
.dashboard-form-plate--number .dashboard-form-input:focus {
  border: none;
  box-shadow: none;
}

/* Числовое поле без дефолтных стрелок (спиннеров) */
.dashboard-form-input--number-no-spinners {
  -moz-appearance: textfield;
  appearance: textfield;
}
.dashboard-form-input--number-no-spinners::-webkit-outer-spin-button,
.dashboard-form-input--number-no-spinners::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* Строка с двумя цветовыми полями (заголовок + текст) */
.dashboard-form-color-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
}
.dashboard-form-color-wrap {
  flex: 1;
  min-width: var(--form-plate-min-width);
  display: flex;
  flex-direction: column;
  gap: var(--form-block-heading-gap);
}
.dashboard-form-color-label {
  font-size: var(--form-heading-size-field);
  font-weight: var(--form-heading-weight-field);
  color: var(--color-form-heading);
}
.dashboard-form-color-input-row {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}
/* Единый квадрат выбора цвета: фиксированный размер, не сжимается */
.dashboard-form-color-picker {
  width: var(--color-picker-size);
  height: var(--color-picker-size);
  min-width: var(--color-picker-size);
  min-height: var(--color-picker-size);
  flex-shrink: 0;
  padding: var(--form-plate-inner-padding);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--radius-input);
  cursor: pointer;
  background: var(--color-bg-card);
  box-sizing: border-box;
}
.dashboard-form-color-picker::-webkit-color-swatch-wrapper {
  padding: 0;
  width: 100%;
  height: 100%;
  box-sizing: border-box;
}
.dashboard-form-color-picker::-webkit-color-swatch {
  border: none;
  border-radius: var(--radius-md);
  width: 100%;
  height: 100%;
}
.dashboard-form-color-picker::-moz-color-swatch {
  border: none;
  border-radius: var(--radius-md);
}
.dashboard-form-color-hex {
  flex: 1;
  min-width: var(--form-plate-min-width-sm);
}

/* Две колонки: слева цвета (друг на друге), справа позиция и время */
.dashboard-form-block--cols {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: var(--space-md);
}

/* Форма в 2 колонки: обёртка с grid */
.dashboard-form-grid-two-cols {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-md) var(--space-lg);
}
.dashboard-form-grid-two-cols .dashboard-form-block--span-2 {
  grid-column: 1 / -1;
}
@media (max-width: 640px) {
  .dashboard-form-grid-two-cols {
    grid-template-columns: 1fr;
  }
}
.dashboard-form-col {
  flex: 1;
  min-width: var(--form-plate-min-width-lg);
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}
.dashboard-form-col--colors .dashboard-form-color-wrap {
  min-width: 0;
}
.dashboard-form-col--right .dashboard-form-plate {
  width: 100%;
}
.dashboard-form-right-field {
  display: flex;
  flex-direction: column;
  gap: var(--form-block-heading-gap);
  cursor: pointer;
}
.dashboard-form-plate-label {
  font-size: var(--font-size-ui);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-secondary);
}
.dashboard-form-plate-checkbox {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin: 0;
  cursor: pointer;
}
.dashboard-form-plate-checkbox .rounded-lg {
  flex-shrink: 0;
}
.dashboard-form-plate-checkbox-label {
  font-size: var(--font-size-ui);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-secondary);
  cursor: pointer;
}

/* Плашка с чекбоксом: label на всю плашку, чтобы клик по всей области переключал чекбокс */
.dashboard-form-plate:has(.dashboard-form-plate-checkbox) .dashboard-form-plate-checkbox {
  width: 100%;
  min-height: 100%;
}

/* Разделитель секций в форме (как разделители строк в таблице) */
.dashboard-form-divider {
  border-top: var(--border-width-thin) solid var(--color-border);
  padding-top: var(--spacing-form-card);
}

/* Подпись ошибки под полем */
.dashboard-form-error {
  font-size: var(--font-size-ui);
  color: var(--color-error-text);
}

/* Строка с полем и кнопкой справа (например, токен + копировать) */
.dashboard-form-input-row {
  display: flex;
  align-items: stretch;
  gap: var(--space-sm);
}
.dashboard-form-input-row .dashboard-form-input {
  flex: 1;
  min-width: 0;
}
/* Кнопка копирования: переиспользует ds-btn secondary, только отличия для строки ввода */
.dashboard-form-copy-btn {
  flex-shrink: 0;
  align-self: stretch;
  height: auto;
  border-radius: var(--radius-input);
}

/* Токен: копирование по клику, подсказка при наведении */
.dashboard-form-token-copy-wrap {
  position: relative;
  display: flex;
  align-items: center;
  cursor: pointer;
  border-radius: var(--radius-input);
  transition: background-color var(--transition-base);
}
.dashboard-form-token-copy-wrap:hover {
  background-color: var(--color-hover-bg);
}
.dashboard-form-token-copy-wrap .dashboard-form-input {
  flex: 1;
  min-width: 0;
  cursor: pointer;
  padding-right: var(--form-token-copy-hint-space);
}
.dashboard-form-token-copy-hint {
  position: absolute;
  right: var(--table-cell-padding-x);
  font-size: var(--font-size-helper);
  color: var(--color-text-muted);
  pointer-events: none;
  opacity: 0;
  transition: opacity var(--transition-base);
}
.dashboard-form-token-copy-wrap:hover .dashboard-form-token-copy-hint,
.dashboard-form-token-copy-wrap:focus-within .dashboard-form-token-copy-hint {
  opacity: 1;
}
.dashboard-form-token-copy-hint--copied {
  color: var(--color-accent);
  font-weight: var(--font-weight-medium);
}

/* Кастомные чекбоксы в таблицах */
input[type="checkbox"].rounded-lg {
  appearance: none;
  -webkit-appearance: none;
  width: var(--checkbox-size);
  height: var(--checkbox-size);
  border-radius: var(--radius-sm);
  border: var(--border-width-focus) solid var(--color-hover-border);
  cursor: pointer;
  vertical-align: middle;
  flex-shrink: 0;
  background-color: var(--color-bg-card);
}

input[type="checkbox"].rounded-lg:hover {
  border-color: var(--gray-400);
}

input[type="checkbox"].rounded-lg:checked {
  background-color: var(--color-accent);
  border-color: var(--color-accent);
  background-image: var(--checkbox-check-icon);
  background-size: 100%;
}

input[type="checkbox"].rounded-lg:indeterminate {
  background-color: var(--color-accent);
  border-color: var(--color-accent);
  background-image: var(--checkbox-indeterminate-icon);
  background-size: 100%;
}

/* Обёртка кнопки «?» и попапа: попап под кнопкой, а не справа */
.dashboard-help-wrap {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

/* Круглая кнопка-подсказка (?): высота как у основных кнопок, серый стиль */
.dashboard-help-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--height-button);
  height: var(--height-button);
  padding: 0;
  font-size: var(--form-heading-size-section);
  font-weight: var(--font-weight-semibold);
  color: var(--btn-secondary-color);
  background: var(--btn-secondary-bg);
  border: none;
  border-radius: var(--radius-button);
  cursor: pointer;
  transition: background var(--transition-base), color var(--transition-base);
}
.dashboard-help-btn:hover {
  background: var(--btn-secondary-bg-hover);
  color: var(--btn-secondary-color-hover);
}
.dashboard-help-popover {
  display: none;
  margin-top: var(--space-md);
  padding: var(--help-popover-padding);
  font-size: var(--font-size-ui);
  line-height: 1.5;
  color: var(--color-text-secondary);
  background-color: var(--color-hover-bg);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--radius-input);
  max-width: var(--help-popover-max-width);
}
.dashboard-help-popover.is-open {
  display: block;
}

/* Markdown content inside popover: hierarchy and spacing */
.dashboard-help-popover__content {
  font-size: var(--help-h3-size);
  line-height: 1.55;
}
.dashboard-help-popover__content h1,
.dashboard-help-popover__content h2,
.dashboard-help-popover__content h3 {
  font-weight: var(--font-weight-semibold);
  color: var(--color-text);
  margin-top: var(--space-md);
  margin-bottom: var(--space-sm);
}
.dashboard-help-popover__content h1:first-child,
.dashboard-help-popover__content h2:first-child,
.dashboard-help-popover__content h3:first-child {
  margin-top: 0;
}
.dashboard-help-popover__content h1 { font-size: var(--help-h1-size); }
.dashboard-help-popover__content h2 { font-size: var(--help-h2-size); }
.dashboard-help-popover__content h3 { font-size: var(--help-h3-size); }
.dashboard-help-popover__content p {
  margin: 0 0 var(--help-gap-vertical);
}
.dashboard-help-popover__content p:last-child {
  margin-bottom: 0;
}
.dashboard-help-popover__content ul,
.dashboard-help-popover__content ol {
  margin: var(--space-sm) 0 var(--help-gap-vertical);
  padding-left: var(--help-list-indent);
}
.dashboard-help-popover__content li {
  margin-bottom: var(--form-heading-margin-top);
}
.dashboard-help-popover__content strong {
  font-weight: var(--font-weight-semibold);
  color: var(--gray-900);
}
.dashboard-help-popover__content code {
  font-family: ui-monospace, monospace;
  font-size: var(--help-code-size);
  padding: 0.15em 0.35em;
  background: var(--btn-secondary-bg);
  border-radius: var(--radius-sm);
}
.dashboard-help-popover__content pre {
  margin: var(--space-md) 0;
  padding: var(--table-cell-padding-y) var(--table-cell-padding-x);
  overflow-x: auto;
  background: var(--btn-secondary-bg);
  border-radius: var(--radius-input);
  font-size: var(--font-size-ui);
}
.dashboard-help-popover__content pre code {
  padding: 0;
  background: none;
}

/* Fullview help: seamless switch — header stays, table/form replaced by help in same frame */
.dashboard-view {
  position: relative;
  min-height: 0;
}

/* Close button: hidden by default, shown only when help is open (override btn-filled-gray display) */
.dashboard-view button[data-help-close] {
  display: none;
}
.dashboard-view--help-open button[data-help-close] {
  display: inline-flex;
}
.dashboard-view--help-open [data-help-primary-action] {
  display: none;
}

/* When help open: keep page content visible (header), hide only table or form card */
.dashboard-view--help-open .dashboard-table-wrapper,
.dashboard-view--help-open .dashboard-form-card {
  display: none;
}

/* Help fullview: in-flow block below header, no overlay */
.dashboard-help-fullview {
  display: none;
}
.dashboard-view--help-open .dashboard-help-fullview {
  display: block;
}

/* Help content wrapper: same frame as table (border, radius, background) */
.dashboard-help-content-wrapper {
  display: none;
  background-color: var(--color-bg-card);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--radius-table);
  overflow: hidden;
}
.dashboard-view--help-open .dashboard-help-content-wrapper {
  display: block;
}

.dashboard-help-fullview__inner {
  padding: var(--help-content-padding);
  overflow-y: auto;
}
.dashboard-help-fullview__title {
  font-size: var(--help-fullview-h1-size);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text);
  margin: 0 0 var(--space-md);
}
.dashboard-help-fullview__content {
  font-size: var(--help-fullview-body-size);
  line-height: 1.6;
  color: var(--gray-800);
}
.dashboard-help-fullview__content h1,
.dashboard-help-fullview__content h2,
.dashboard-help-fullview__content h3 {
  font-weight: var(--font-weight-semibold);
  color: var(--color-text);
  margin-top: var(--space-lg);
  margin-bottom: var(--space-sm);
}
.dashboard-help-fullview__content h1:first-child,
.dashboard-help-fullview__content h2:first-child,
.dashboard-help-fullview__content h3:first-child {
  margin-top: 0;
}
.dashboard-help-fullview__content h1 { font-size: var(--help-fullview-h1-size); }
.dashboard-help-fullview__content h2 { font-size: var(--help-fullview-h2-size); }
.dashboard-help-fullview__content h3 { font-size: var(--help-fullview-h3-size); }
.dashboard-help-fullview__content p {
  margin: 0 0 var(--space-md);
}
.dashboard-help-fullview__content p:last-child {
  margin-bottom: 0;
}
.dashboard-help-fullview__content ul,
.dashboard-help-fullview__content ol {
  margin: var(--space-sm) 0 var(--space-md);
  padding-left: var(--spacing-form-card);
}
.dashboard-help-fullview__content li {
  margin-bottom: var(--form-helper-margin-bottom);
}
.dashboard-help-fullview__content strong {
  font-weight: var(--font-weight-semibold);
  color: var(--gray-900);
}
.dashboard-help-fullview__content code {
  font-family: ui-monospace, monospace;
  font-size: 0.9375em;
  padding: 0.15em 0.4em;
  background: var(--btn-secondary-bg);
  border-radius: var(--radius-sm);
}
.dashboard-help-fullview__content pre {
  margin: var(--space-md) 0;
  padding: var(--table-cell-padding-y) var(--table-cell-padding-x);
  overflow-x: auto;
  background: var(--btn-secondary-bg);
  border-radius: var(--radius-input);
  font-size: var(--help-fullview-body-size);
}
.dashboard-help-fullview__content pre code {
  padding: 0;
  background: none;
}

/* Блок прав по разделу: скруглённая карточка в стиле дашборда */
.dashboard-permissions-group {
  background-color: var(--color-bg-card);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--radius-table);
  padding: var(--help-popover-padding);
}
.dashboard-permissions-group__title {
  font-size: var(--form-heading-size-field);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text);
  margin-bottom: var(--space-md);
}
.dashboard-permissions-group__list {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}
.dashboard-permissions-group label {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  cursor: pointer;
  font-size: var(--font-size-ui);
  color: var(--color-text-secondary);
  margin: 0;
}
.dashboard-permissions-group label .rounded-lg {
  flex-shrink: 0;
}
.dashboard-permissions-groups {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}
.dashboard-permissions-group input:disabled {
  cursor: not-allowed;
  opacity: 0.7;
}
.dashboard-permissions-group input:disabled + span {
  color: var(--color-text-muted);
  cursor: not-allowed;
}

/* Кнопка «только вид»: как вторичная, но некликабельная. Те же размеры и вид, что и у ссылки. */
span.dashboard-btn-disabled.btn-filled-gray {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: var(--height-button);
  min-height: var(--height-button);
  padding: var(--btn-padding-y) var(--btn-padding-x);
  font-size: var(--font-size-ui);
  font-weight: var(--font-weight-medium);
  white-space: nowrap;
  box-sizing: border-box;
  background: var(--btn-secondary-bg);
  color: var(--btn-secondary-color);
  border-radius: var(--radius-button);
  border: none;
  cursor: not-allowed;
  opacity: 0.85;
  pointer-events: none;
}

/* Значения списка: сетка полей по 3 в ряд + кнопка «+» */
.dashboard-form-list-values {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
}
.dashboard-form-list-values .dashboard-form-list-value-input,
.dashboard-form-list-values .dashboard-form-list-value-add {
  flex: 0 0 calc((100% - var(--space-md)) / 3);
  min-width: 0;
  box-sizing: border-box;
  height: var(--height-form-row);
}
.dashboard-form-list-values .dashboard-form-list-value-add {
  flex-shrink: 0;
  padding: 0;
}
.dashboard-form-list-values--error .dashboard-form-list-value-input {
  border-color: var(--input-error-border);
}

.dashboard-form-textarea--medium {
  min-height: var(--form-textarea-medium-min-height);
  resize: vertical;
}

/* Динамический список (шапка топика: нумерованный список и resources) */
.dashboard-dynamic-list-rows {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}
.dashboard-dynamic-list-row {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}
.dashboard-dynamic-list-row__num {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: var(--height-form-row);
  min-width: var(--height-form-row);
  height: var(--height-form-row);
  border-radius: var(--radius-input);
  background-color: var(--color-accent);
  font-size: var(--font-size-ui);
  font-weight: var(--font-weight-medium);
  color: #000;
}
.dashboard-dynamic-list-row__input {
  flex: 1;
  min-width: 0;
}
.dashboard-dynamic-list-row__remove {
  flex-shrink: 0;
}
.dashboard-dynamic-list-add {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: var(--height-form-row);
  margin-top: var(--space-sm);
  padding: 0 var(--space-md);
  border: var(--border-width-thin) dashed var(--color-border);
  border-radius: var(--radius-input);
  background-color: var(--color-bg-card);
  cursor: pointer;
  transition: border-color 0.15s ease, background-color 0.15s ease;
}
.dashboard-form-block[data-dashboard-dynamic-list="list"]:has(.dashboard-dynamic-list-row) .dashboard-dynamic-list-add {
  margin-left: calc(var(--height-form-row) + var(--space-sm));
}
.dashboard-dynamic-list-add:hover {
  border-color: var(--input-hover-border);
  background-color: var(--input-hover-bg);
}
.dashboard-dynamic-list-add__icon {
  font-size: 1.25rem;
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-muted);
}

/* Список постов: карточки с раскрытием (только токены дизайн-системы) */
.dashboard-post-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}
.dashboard-post-card {
  background-color: var(--color-bg-card);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--radius-card);
  overflow: hidden;
}
.dashboard-post-card__collapsed {
  padding: var(--space-md);
  cursor: pointer;
  background-color: var(--color-bg-card);
}
.dashboard-post-card__collapsed:hover {
  background-color: var(--gray-50);
}
.dashboard-post-card--open .dashboard-post-card__collapsed {
  background-color: var(--gray-50);
}
.dashboard-post-card__header-row {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  flex-wrap: wrap;
}
.dashboard-post-card__meta {
  flex: 1;
  min-width: var(--form-plate-min-width-lg);
}
.dashboard-post-card__meta-title {
  font-weight: 400;
  font-size: var(--font-size-ui);
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0 var(--space-xs);
}
.dashboard-post-card__channel-name {
  /* Название канала */
}
.dashboard-post-card__chips {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
}
.dashboard-post-card__chips .dashboard-chip {
  margin-left: 0;
}
.dashboard-post-card__meta-date {
  color: var(--color-text-secondary);
  font-size: var(--font-size-helper);
  margin-top: var(--space-sm);
}
.dashboard-post-card__post-title {
  margin-top: var(--space-sm);
  font-size: var(--font-size-ui);
  font-weight: 500;
  color: var(--color-text);
  line-height: 1.35;
}
.dashboard-post-card__actions {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  flex-shrink: 0;
}
.dashboard-post-card__actions .ds-btn {
  height: var(--height-button);
  min-height: var(--height-button);
  box-sizing: border-box;
}
.dashboard-post-card__content-row {
  margin-top: var(--space-md);
}
.dashboard-post-card__text-preview {
  font-weight: 400;
  font-size: var(--font-size-ui);
  margin-bottom: var(--space-sm);
}
.dashboard-post-card__media-summary {
  color: var(--color-text-secondary);
  font-size: var(--font-size-ui);
}
.dashboard-post-card__media-summary div {
  margin-top: var(--space-sm);
}
.dashboard-post-card__expanded {
  display: none;
  padding: 0 var(--space-md) var(--space-md) var(--space-md);
  border-top: var(--border-width-thin) solid var(--color-border);
}
.dashboard-post-card--open .dashboard-post-card__expanded {
  display: block;
}
.dashboard-post-card__expanded .dashboard-post-card__text {
  white-space: pre-wrap;
  margin: var(--space-lg) 0;
}
.dashboard-post-card__expanded .dashboard-post-card__attachments {
  margin-top: var(--space-lg);
}
.dashboard-post-card__att {
  margin: var(--space-md) 0;
}
.dashboard-post-card__att img {
  max-width: 100%;
  max-height: var(--post-attachment-preview-max);
  border-radius: var(--radius-input);
}
.dashboard-post-card__att video,
.dashboard-post-card__att .dashboard-post-card__att-video {
  max-width: 100%;
  max-height: var(--post-attachment-preview-max);
  border-radius: var(--radius-input);
}
.dashboard-post-card__att .dashboard-audio-player {
  max-width: 100%;
}
.dashboard-post-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-md);
  margin-top: var(--space-lg);
  padding-top: var(--space-md);
  border-top: var(--border-width-thin) solid var(--color-border);
}
.dashboard-post-pagination__link {
  color: var(--color-accent);
  text-decoration: none;
}
.dashboard-post-pagination__link:hover {
  text-decoration: underline;
}
.dashboard-post-pagination__link--disabled {
  color: var(--color-text-secondary);
  cursor: default;
  pointer-events: none;
}
.dashboard-post-pagination__info {
  font-size: var(--font-size-ui);
  color: var(--color-text-secondary);
}

/* Расстояние между секциями на странице редактирования поста */
.dashboard-post-edit-sections {
  display: flex;
  flex-direction: column;
  gap: var(--form-sections-gap);
}

/* Настройка публикации — на всю ширину сверху. Один источник отступов (gap формы). */
.dashboard-post-edit-publish-fullwidth {
  width: 100%;
}
.dashboard-post-edit-publish-fullwidth .dashboard-form .dashboard-form-block {
  margin-top: 0;
}
/* Между блоками внутри «Шаг 2» — отступ по дизайн-системе (--form-block-margin-top). */
.dashboard-post-publish-config {
  display: flex;
  flex-direction: column;
  gap: var(--form-block-margin-top);
}
/* Превью обложки: по аналогии с пикером иконки — фиксированный квадрат, без растягивания */
#post-display-cover-block .dashboard-form-section-helper {
  margin-bottom: var(--space-md);
}
.dashboard-cover-picker {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-md);
  margin-top: 0;
}
.dashboard-cover-picker__form {
  margin: 0;
  padding: 0;
}
.dashboard-cover-picker__trigger {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 320px;
  height: 180px;
  padding: 0;
  margin: 0;
  border: 2px dashed var(--color-border);
  border-radius: var(--radius-input);
  cursor: pointer;
  color: var(--color-text-muted);
  background: var(--gray-200);
  position: relative;
  overflow: hidden;
  transition: border-color var(--transition-base), background-color var(--transition-base);
}
/* Квадратное превью обложки для карточки книги */
.dashboard-cover-picker--square .dashboard-cover-picker__trigger {
  width: 180px;
  height: 180px;
}
.dashboard-cover-picker__trigger:hover {
  border-color: var(--gray-400);
  background-color: var(--color-hover-bg);
}
.dashboard-cover-picker__placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  box-sizing: border-box;
}
.dashboard-cover-picker__placeholder-inner {
  width: 24px;
  height: 24px;
  opacity: 0.5;
  background: linear-gradient(to bottom, transparent 40%, currentColor 40%, currentColor 60%, transparent 60%),
    linear-gradient(to right, transparent 40%, currentColor 40%, currentColor 60%, transparent 60%);
  border-radius: 2px;
}
.dashboard-cover-picker__preview {
  display: block;
  width: 100%;
  height: 100%;
  text-decoration: none;
  color: inherit;
}
.dashboard-cover-picker__img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.dashboard-cover-picker__img--hidden {
  display: none !important;
}
.dashboard-cover-picker__placeholder--hidden,
.dashboard-cover-picker__preview--hidden {
  display: none !important;
}
.dashboard-cover-picker__overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-helper);
  font-weight: var(--font-weight-medium);
  color: #fff;
  background: rgba(0, 0, 0, 0.6);
  opacity: 0;
  transition: opacity 0.15s ease;
}
.dashboard-cover-picker__trigger:hover .dashboard-cover-picker__overlay {
  opacity: 1;
}
.dashboard-cover-picker__file-input {
  position: absolute;
  width: 0;
  height: 0;
  opacity: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
}
.dashboard-post-edit-publish-fullwidth .dashboard-post-edit-tags-block .dashboard-form-tag-buttons {
  margin-bottom: 0;
}
.dashboard-post-edit-publish-fullwidth > .dashboard-form-section-helper {
  margin-bottom: 0;
}
.dashboard-post-edit-publish-fullwidth > .dashboard-form-section-helper + form {
  margin-top: var(--form-sections-gap);
}

/* Два блока «Информация о посте» и «Raw данные» в две колонки */
.dashboard-post-edit-two-cols {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--form-sections-gap);
  align-items: start;
}
.dashboard-post-edit-two-cols > .dashboard-form-card {
  min-height: 0;
}
.dashboard-post-edit-two-cols .dashboard-form-card > .dashboard-form-section-title:not(:first-of-type) {
  margin-top: var(--form-sections-gap);
}

/* Текст поста: только чтение, обычный перенос строк */
.dashboard-post-edit-text-display {
  padding: 0.5rem 0.75rem;
  font-family: inherit;
  font-size: var(--font-size-ui);
  line-height: 1.5;
  color: var(--input-readonly-text);
  background-color: var(--input-readonly-bg);
  border: 1px solid var(--input-border-color, var(--color-border));
  border-radius: var(--radius-md);
  white-space: pre-wrap;
  word-wrap: break-word;
  max-width: 100%;
  min-height: var(--height-form-row);
}

/* Блок тегов поста: отступ снизу перед следующей секцией */
.dashboard-post-edit-tags-block .dashboard-form-tag-buttons {
  margin-bottom: 1rem;
}

/* Карточка «Редактирование текста»: кнопка сверху, поле ввода на всю высоту */
.dashboard-form-card--fill {
  display: flex;
  flex-direction: column;
  min-height: 0;
}
.dashboard-form-card--fill .dashboard-form--post-edit-text {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  gap: var(--form-sections-gap);
}
.dashboard-form-card--fill .dashboard-form-block--fill {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
}
.dashboard-form-card--fill .dashboard-form-block--fill .dashboard-form-input.dashboard-form-textarea--fill {
  flex: 1;
  min-height: 0;
  resize: vertical;
}

/* Чипы: полностью скруглённые, токены дизайн-системы */
.dashboard-chip {
  display: inline-flex;
  align-items: center;
  padding: calc(var(--space-xs) + var(--chip-padding-extra)) calc(var(--space-sm) + var(--chip-padding-extra));
  border-radius: var(--radius-button);
  font-size: var(--font-size-ui);
  font-weight: var(--font-weight-medium);
  vertical-align: middle;
  margin-left: var(--space-sm);
}
.dashboard-chip:first-child {
  margin-left: 0;
}
.dashboard-chip--success {
  background-color: var(--color-success-bg);
  color: var(--color-success-text);
}
.dashboard-chip--muted {
  background-color: var(--gray-200);
  color: var(--color-text-secondary);
}
.dashboard-chip--neutral {
  background-color: var(--gray-200);
  color: var(--color-text-secondary);
}
/* Тег поста: в стиле кнопки «Опубликовать» (primary) */
.dashboard-chip--tag {
  background-color: var(--btn-primary-bg);
  color: var(--btn-primary-color);
  border: var(--border-width-thin) solid var(--btn-primary-border);
}
.dashboard-chip--compact {
  font-size: var(--font-size-helper);
  font-weight: var(--font-weight-medium);
  padding: var(--space-xs) var(--space-sm);
}
.dashboard-chip--compact:first-child,
.dashboard-post-card__chips .dashboard-chip {
  margin-left: 0;
}

/* В таблице топиков: ограничить ширину тегов и категорий (≥25 символов — обрезка) */
.dashboard-chip--truncate {
  max-width: 25ch;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Ряд кнопок-тегов в форме категории: только layout */
.dashboard-form-tag-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
}
/* Выбранный тег — акцентный цвет, как подсветка тегов в постах */
.dashboard-form-tag-buttons .ds-btn--primary {
  background-color: var(--color-accent);
  border-color: var(--color-accent);
  color: var(--btn-primary-color);
}
.dashboard-form-tag-buttons .ds-btn--primary:hover {
  background-color: var(--color-accent);
  border-color: var(--color-accent);
  color: var(--btn-primary-color);
  filter: brightness(0.95);
}

/* Подсветка тега в тексте поста: акцентный цвет и medium */
.dashboard-post-card__tag-in-text {
  color: var(--color-accent);
  font-weight: var(--font-weight-medium);
}

/* Превью текста поста: до 3 строк */
.dashboard-post-card__text-preview--clamp {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Редактирование поста: карточка вложения, raw JSON — радиусы по дизайн-системе */
.dashboard-post-edit-att-card {
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--radius-card);
  padding: var(--space-lg);
  margin-bottom: var(--space-lg);
}
.dashboard-post-edit-att-card:last-child {
  margin-bottom: 0;
}
.dashboard-post-edit-att-preview {
  margin-bottom: var(--space-md);
}
.dashboard-post-edit-att-preview img {
  max-width: 100%;
  max-height: var(--post-attachment-edit-preview-max);
  border-radius: var(--radius-input);
}
.dashboard-post-edit-att-preview video {
  max-width: 100%;
  max-height: var(--post-attachment-edit-preview-max);
  border-radius: var(--radius-input);
}
.dashboard-post-edit-att-preview .dashboard-audio-player {
  max-width: 100%;
}
/* Скрытый native audio внутри кастомного плеера */
.dashboard-audio-player audio {
  position: absolute;
  width: 0;
  height: 0;
  opacity: 0;
  pointer-events: none;
}

/* Кастомный аудиоплеер: кнопка play/pause, прогресс, длительность */
.dashboard-audio-player {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-sm) var(--space-md);
  background-color: var(--gray-50);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--radius-input);
  font-size: var(--font-size-ui);
  color: var(--color-text-secondary);
  min-height: var(--height-button);
}
.dashboard-audio-player__play {
  flex-shrink: 0;
  width: var(--height-button);
  height: var(--height-button);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border: none;
  background: var(--color-bg-card);
  border-radius: var(--radius-button);
  color: var(--color-text);
  cursor: pointer;
  transition: background-color var(--transition-base), color var(--transition-base);
  border: var(--border-width-thin) solid var(--color-border);
}
.dashboard-audio-player__play:hover {
  background-color: var(--input-hover-bg);
  border-color: var(--input-hover-border);
}
.dashboard-audio-player__play:focus-visible {
  outline: 2px solid var(--color-focus);
  outline-offset: 2px;
}
.dashboard-audio-player__play svg {
  width: 1.25rem;
  height: 1.25rem;
}
.dashboard-audio-player__progress-wrap {
  flex: 1;
  min-width: 0;
  height: 0.5rem;
  background-color: var(--gray-200);
  border-radius: var(--radius-button);
  cursor: pointer;
  overflow: hidden;
}
.dashboard-audio-player__progress {
  height: 100%;
  width: 0%;
  background-color: var(--color-accent);
  border-radius: var(--radius-button);
  transition: width 0.1s linear;
}
.dashboard-audio-player__time {
  flex-shrink: 0;
  font-variant-numeric: tabular-nums;
  min-width: 5ch;
  text-align: right;
}
.dashboard-audio-player__time--loading::after {
  content: '…';
}
.dashboard-post-edit-att-meta {
  font-size: var(--font-size-ui);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-md);
}
.dashboard-post-edit-att-kind {
  font-weight: var(--font-weight-semibold);
}
.dashboard-post-edit-att-status {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-sm);
  font-size: var(--font-size-helper);
  margin-bottom: var(--space-md);
}
.dashboard-post-edit-att-actions {
  display: flex;
  gap: var(--space-md);
  align-items: center;
  flex-wrap: wrap;
  margin-top: var(--space-sm);
}
.dashboard-post-edit-raw-block {
  margin-top: var(--space-lg);
  margin-bottom: var(--space-lg);
}
.dashboard-post-edit-raw-block:first-child {
  margin-top: 0;
}
.dashboard-post-edit-raw-block:last-child {
  margin-bottom: 0;
}
/* Raw JSON: акцентная обводка, системный monospace, клик — копирование */
.dashboard-post-edit-raw-wrap {
  position: relative;
  width: 100%;
  padding: var(--space-md);
  border: var(--border-width-thin) solid var(--color-accent);
  border-radius: var(--radius-input);
  cursor: pointer;
  min-height: calc(2 * var(--space-xl));
}
.dashboard-post-edit-raw-wrap .dashboard-form-input--copy__value {
  white-space: pre-wrap;
  text-overflow: unset;
  font-family: ui-monospace, monospace;
  font-size: var(--font-size-ui);
}
.dashboard-post-edit-raw-pre {
  margin: 0;
  font-family: ui-monospace, monospace;
  font-size: var(--font-size-ui);
  line-height: 1.5;
  white-space: pre-wrap;
  word-break: break-all;
  overflow: visible;
}
.dashboard-post-edit-raw-code {
  display: block;
  font-family: ui-monospace, monospace;
}
.dashboard-post-edit-raw-wrap .dashboard-form-input--copy__feedback {
  position: absolute;
  top: var(--space-md);
  right: var(--space-md);
}
.dashboard-post-edit-att-override-filename {
  color: var(--color-text-secondary);
  font-size: var(--font-size-helper);
}
.dashboard-post-edit-att-actions form {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
}
