/* =========================================
 * Десктоп: shell, реестр, фильтры, карточка, формы.
 * Минимум дизайна, нейтральная палитра, тщательная вёрстка.
 * ========================================= */

/* ---------- Layout ---------- */

.layout {
  display: grid;
  grid-template-columns: 240px 1fr;
  min-height: 100vh;
}

.sidebar {
  background: var(--c-bg);
  border-right: 1px solid var(--c-border);
  display: flex;
  flex-direction: column;
  padding: var(--sp-4) 0;
  position: sticky;
  top: 0;
  height: 100vh;
  overflow-y: auto;
}

.sidebar__brand {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: 0 var(--sp-5) var(--sp-5);
  border-bottom: 1px solid var(--c-border);
  margin-bottom: var(--sp-3);
}
.sidebar__logo {
  width: 32px; height: 32px;
  background: var(--c-text);
  color: var(--c-text-on-accent);
  border-radius: var(--r-md);
  display: flex; align-items: center; justify-content: center;
  font-weight: 700;
  font-size: var(--fs-lg);
}
.sidebar__brand-name {
  font-weight: 600;
  font-size: var(--fs-md);
}

.sidebar__nav {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 0 var(--sp-3);
}
.sidebar__nav-item {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-2) var(--sp-3);
  border-radius: var(--r-md);
  color: var(--c-text-muted);
  text-decoration: none;
  font-size: var(--fs-sm);
  font-weight: 500;
  transition: background-color 80ms, color 80ms;
}
.sidebar__nav-item:hover {
  background: var(--c-bg-hover);
  color: var(--c-text);
  text-decoration: none;
}
.sidebar__nav-item.is-active {
  background: var(--c-bg-active);
  color: var(--c-text);
}
.sidebar__nav-badge {
  margin-left: auto;
  background: var(--c-bg-active);
  color: var(--c-text-muted);
  font-size: var(--fs-xs);
  padding: 1px var(--sp-2);
  border-radius: 10px;
  font-weight: 600;
}
.sidebar__nav-item.is-active .sidebar__nav-badge {
  background: var(--c-text);
  color: var(--c-text-on-accent);
}

.sidebar__bottom {
  margin-top: auto;
  padding: var(--sp-3);
  border-top: 1px solid var(--c-border);
}
.sidebar__user {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  width: 100%;
  padding: var(--sp-2);
  border-radius: var(--r-md);
  text-align: left;
}
.sidebar__user:hover { background: var(--c-bg-hover); }
.sidebar__user-text { display: flex; flex-direction: column; min-width: 0; }
.sidebar__user-name { font-weight: 600; font-size: var(--fs-sm); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sidebar__user-role { font-size: var(--fs-xs); color: var(--c-text-muted); }

/* ---------- Main + Topbar ---------- */

.main { min-width: 0; display: flex; flex-direction: column; }

.topbar {
  position: sticky; top: 0; z-index: 10;
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  padding: var(--sp-3) var(--sp-6);
  background: var(--c-bg);
  border-bottom: 1px solid var(--c-border);
}
.topbar__search {
  flex: 1;
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-3);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  background: var(--c-bg-soft);
  max-width: 480px;
  color: var(--c-text-muted);
}
.topbar__search input {
  flex: 1; border: none; background: transparent; outline: none; min-width: 0;
  color: var(--c-text);
  font-size: var(--fs-sm);
}
.topbar__search input::placeholder { color: var(--c-text-subtle); }
.topbar__kbd {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  border: 1px solid var(--c-border);
  background: var(--c-bg);
  padding: 1px var(--sp-2);
  border-radius: var(--r-sm);
  color: var(--c-text-subtle);
}
.topbar__actions { display: flex; gap: var(--sp-1); align-items: center; }
.topbar__dot {
  position: absolute; top: 6px; right: 6px;
  width: 6px; height: 6px;
  background: var(--c-live);
  border-radius: 50%;
}
.topbar__actions .btn--icon { position: relative; }

.content {
  flex: 1;
  padding: var(--sp-6) var(--sp-8);
  max-width: 1280px;
  margin: 0 auto;
  width: 100%;
}

/* ---------- Page header ---------- */

.page-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  margin-bottom: var(--sp-5);
}
.page-header__left {
  display: flex;
  align-items: baseline;
  gap: var(--sp-3);
}
.page-header__count {
  font-size: var(--fs-sm);
  color: var(--c-text-muted);
}
.page-title {
  margin: 0;
  font-size: var(--fs-2xl);
  font-weight: 700;
  letter-spacing: -0.01em;
}

/* ---------- Banner ---------- */

.banner {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  padding: var(--sp-3) var(--sp-4);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  background: var(--c-accent-soft);
  margin-bottom: var(--sp-5);
}
.banner__icon {
  width: 36px; height: 36px;
  border-radius: var(--r-md);
  background: var(--c-bg);
  display: flex; align-items: center; justify-content: center;
  color: var(--c-accent);
  flex-shrink: 0;
}
.banner__body { flex: 1; display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.banner__body strong { font-size: var(--fs-md); font-weight: 600; }
.banner__body span { font-size: var(--fs-sm); color: var(--c-text-muted); }
.banner__actions { display: flex; gap: var(--sp-2); align-items: center; flex-shrink: 0; }

/* ---------- Filters ---------- */

.filters {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  margin-bottom: var(--sp-5);
}
.filters__search {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}
.filters__search-icon {
  position: absolute;
  margin-left: var(--sp-3);
  color: var(--c-text-muted);
  pointer-events: none;
}
.filters__search-input {
  flex: 1;
  padding: var(--sp-3) var(--sp-3) var(--sp-3) var(--sp-10);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  font-size: var(--fs-md);
  background: var(--c-bg);
  outline: none;
  transition: border-color 80ms;
}
.filters__search-input:focus { border-color: var(--c-text); }
.filters__deep {
  padding: var(--sp-3) var(--sp-4);
  border: 1px dashed var(--c-border-strong);
  border-radius: var(--r-md);
  background: transparent;
  color: var(--c-text-muted);
  font-size: var(--fs-sm);
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  white-space: nowrap;
}
.filters__deep:hover {
  background: var(--c-bg-hover);
  color: var(--c-text);
}
.filters__row {
  display: flex;
  gap: var(--sp-2);
  flex-wrap: wrap;
  align-items: center;
}
.filters__reset {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-1);
  padding: var(--sp-2) var(--sp-3);
  border-radius: var(--r-md);
  color: var(--c-text-muted);
  background: transparent;
  border: none;
  font-size: var(--fs-sm);
}
.filters__reset:hover { background: var(--c-bg-hover); color: var(--c-text); }

.select {
  position: relative;
  display: inline-block;
}
.select select {
  appearance: none;
  padding: var(--sp-2) var(--sp-8) var(--sp-2) var(--sp-3);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  background: var(--c-bg);
  font-size: var(--fs-sm);
  cursor: pointer;
  outline: none;
}
.select select:hover { background: var(--c-bg-hover); }
.select select:focus { border-color: var(--c-text); }
.select svg {
  position: absolute;
  right: var(--sp-2);
  top: 50%;
  transform: translateY(-50%);
  pointer-events: none;
  color: var(--c-text-muted);
}

/* ---------- List / Groups ---------- */

.list { display: flex; flex-direction: column; gap: var(--sp-6); }

.group { display: flex; flex-direction: column; gap: var(--sp-2); }
.group__title {
  display: flex;
  align-items: baseline;
  gap: var(--sp-2);
  margin: 0 0 var(--sp-1);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--c-text-muted);
  font-weight: 600;
}
.group__count {
  font-size: var(--fs-xs);
  color: var(--c-text-subtle);
  font-weight: 400;
}
.group__rows {
  display: flex;
  flex-direction: column;
  background: var(--c-bg);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  overflow: hidden;
}

/* ---------- Meeting row ---------- */

.row {
  display: grid;
  grid-template-columns: 100px 1fr auto auto;
  align-items: center;
  gap: var(--sp-4);
  padding: var(--sp-3) var(--sp-4);
  border-bottom: 1px solid var(--c-border);
  cursor: pointer;
  transition: background-color 80ms;
}
.row:last-child { border-bottom: none; }
.row:hover { background: var(--c-bg-hover); }
.row:focus-visible { outline: 2px solid var(--c-accent); outline-offset: -2px; background: var(--c-bg-hover); }

.row__time-col {
  display: flex;
  flex-direction: column;
  font-variant-numeric: tabular-nums;
}
.row__time { font-size: var(--fs-md); font-weight: 600; }
.row__duration { font-size: var(--fs-xs); color: var(--c-text-muted); }

.row__main { min-width: 0; }
.row__title-line {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  margin-bottom: 2px;
}
.row__title {
  margin: 0;
  font-size: var(--fs-md);
  font-weight: 600;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
}
.row__visibility { color: var(--c-text-muted); display: inline-flex; flex-shrink: 0; }
.row__visibility--open { color: var(--c-text-subtle); }

.row__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  font-size: var(--fs-sm);
  color: var(--c-text-muted);
}
.row__meta > span {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.row__meta .icon { color: var(--c-text-subtle); }

.row__role {
  padding: 1px var(--sp-2);
  font-size: var(--fs-xs);
  border-radius: var(--r-sm);
  background: var(--c-bg-active);
}
.role--creator { background: var(--c-accent-soft); color: var(--c-accent); }
.role--participant { background: var(--c-bg-active); }
.role--observer { background: var(--c-warn-soft); color: var(--c-warn); }

.row__guests-marker {
  padding: 1px var(--sp-2);
  font-size: var(--fs-xs);
  color: var(--c-warn);
  border-radius: var(--r-sm);
  background: var(--c-warn-soft);
}

.row__artifacts { display: flex; align-items: center; }
.row__actions { display: flex; align-items: center; gap: var(--sp-2); }

/* ---------- Artifact icons ---------- */

.artifact-icons {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}
.artifact {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px; height: 24px;
  color: var(--c-text-subtle);
  position: relative;
}
.artifact.is-ready { color: var(--c-text); }
.artifact.is-processing { color: var(--c-warn); }
.artifact.is-absent { color: var(--c-text-subtle); opacity: 0.35; }
.artifact.is-processing::after {
  content: '';
  position: absolute;
  bottom: 2px; right: 2px;
  width: 5px; height: 5px;
  background: var(--c-warn);
  border-radius: 50%;
  animation: pulse 1.4s ease-in-out infinite;
}
.artifact--with-count { gap: 2px; width: auto; padding: 0 var(--sp-1); }
.artifact__count { font-size: var(--fs-xs); font-weight: 600; }

/* ---------- Empty ---------- */

.empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: var(--sp-12) var(--sp-6);
  background: var(--c-bg);
  border: 1px dashed var(--c-border);
  border-radius: var(--r-lg);
  gap: var(--sp-3);
}
.empty--in-tab { background: transparent; border: none; padding: var(--sp-12) var(--sp-6); }
.empty__icon {
  width: 48px; height: 48px;
  display: flex; align-items: center; justify-content: center;
  background: var(--c-bg-active);
  border-radius: 50%;
  color: var(--c-text-muted);
}
.empty__icon .icon { width: 24px; height: 24px; }
.empty__title { font-size: var(--fs-lg); font-weight: 600; }
.empty__text {
  max-width: 420px;
  color: var(--c-text-muted);
  font-size: var(--fs-sm);
}

/* ---------- Modal ---------- */

.modal-root[hidden] { display: none; }
.modal-root {
  position: fixed;
  inset: 0;
  z-index: var(--z-modal);
  display: flex;
  align-items: center;
  justify-content: center;
}
.modal-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.4);
  backdrop-filter: blur(4px);
}
.modal {
  position: relative;
  background: var(--c-bg);
  border-radius: var(--r-xl);
  width: 100%;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border: 1px solid var(--c-border);
}
.modal[data-size="md"] { max-width: 560px; }
.modal[data-size="lg"] { max-width: 920px; }
.modal__body { display: flex; flex-direction: column; min-height: 0; overflow: hidden; }

/* ---------- Card (meeting popup) ---------- */

.card { display: flex; flex-direction: column; min-height: 0; }

.card__header {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-4);
  padding: var(--sp-5) var(--sp-6);
  border-bottom: 1px solid var(--c-border);
}
.card__header-main { flex: 1; min-width: 0; }
.card__title-row {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  margin-bottom: var(--sp-2);
}
.card__title {
  margin: 0;
  font-size: var(--fs-xl);
  font-weight: 700;
  letter-spacing: -0.01em;
}
.card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-4);
  font-size: var(--fs-sm);
  color: var(--c-text-muted);
}
.card__meta > span { display: inline-flex; align-items: center; gap: 4px; }
.card__chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.card__header-actions { display: flex; gap: var(--sp-1); align-items: center; flex-shrink: 0; }

.card__tabs {
  display: flex;
  gap: var(--sp-1);
  padding: 0 var(--sp-4);
  border-bottom: 1px solid var(--c-border);
  overflow-x: auto;
}
.card__tab {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-3) var(--sp-3);
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--c-text-muted);
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  white-space: nowrap;
}
.card__tab:hover { color: var(--c-text); }
.card__tab.is-active {
  color: var(--c-text);
  border-bottom-color: var(--c-text);
}
.card__tab-count {
  background: var(--c-bg-active);
  color: var(--c-text-muted);
  font-size: var(--fs-xs);
  padding: 1px var(--sp-2);
  border-radius: 10px;
  font-weight: 600;
}
.card__tab.is-active .card__tab-count {
  background: var(--c-text);
  color: var(--c-text-on-accent);
}

.card__content {
  flex: 1;
  overflow-y: auto;
  padding: var(--sp-5) var(--sp-6);
}

.muted { color: var(--c-text-muted); }

/* ---------- Participants ---------- */

.participants { display: flex; flex-direction: column; gap: var(--sp-6); }
.participants__section { display: flex; flex-direction: column; gap: var(--sp-3); }
.participants__heading {
  margin: 0;
  font-size: var(--fs-sm);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--c-text-muted);
}
.people-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--sp-3);
}
.person {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-3);
  background: var(--c-bg-soft);
  border-radius: var(--r-md);
  border: 1px solid var(--c-border);
}
.person--no-show { background: transparent; opacity: 0.65; }
.person__info { min-width: 0; flex: 1; }
.person__name {
  font-size: var(--fs-sm);
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}
.person__role { font-size: var(--fs-xs); color: var(--c-text-muted); }

/* ---------- Media ---------- */

.media { display: flex; flex-direction: column; gap: var(--sp-4); }
.media__player {
  aspect-ratio: 16 / 9;
  background: #18181b;
  border-radius: var(--r-lg);
  display: flex;
  align-items: center;
  justify-content: center;
}
.media__player-stub {
  width: 64px; height: 64px;
  background: rgba(255,255,255,0.15);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: white;
}
.media__player-stub .icon { width: 28px; height: 28px; }
.media__actions {
  display: flex;
  gap: var(--sp-2);
  flex-wrap: wrap;
}

/* ---------- Transcript ---------- */

.transcript { display: flex; flex-direction: column; gap: var(--sp-3); }
.transcript__toolbar {
  display: flex;
  gap: var(--sp-3);
  align-items: center;
  flex-wrap: wrap;
}
.transcript__search {
  flex: 1;
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-3);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  background: var(--c-bg-soft);
  color: var(--c-text-muted);
  min-width: 200px;
}
.transcript__search input { flex: 1; border: none; background: transparent; outline: none; color: var(--c-text); }
.transcript__actions { display: flex; gap: var(--sp-1); flex-wrap: wrap; }
.transcript__body { display: flex; flex-direction: column; }
.t-line {
  display: grid;
  grid-template-columns: 60px 1fr;
  gap: var(--sp-3);
  padding: var(--sp-3) 0;
  border-bottom: 1px solid var(--c-border);
}
.t-line:last-child { border-bottom: none; }
.t-line--hidden { display: none; }
.t-line--highlighted { background: var(--c-accent-soft); margin: 0 calc(var(--sp-3) * -1); padding-left: var(--sp-3); padding-right: var(--sp-3); border-radius: var(--r-md); }
.t-line__ts {
  align-self: flex-start;
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  color: var(--c-accent);
  padding: 2px var(--sp-2);
  border-radius: var(--r-sm);
}
.t-line__ts:hover { background: var(--c-accent-soft); }
.t-line__content { display: flex; flex-direction: column; gap: var(--sp-1); min-width: 0; }
.t-line__speaker { display: flex; align-items: center; gap: var(--sp-2); font-size: var(--fs-xs); color: var(--c-text-muted); }
.t-line__name { font-weight: 600; color: var(--c-text); }
.t-line__text { margin: 0; font-size: var(--fs-sm); line-height: var(--lh-relaxed); }

mark { background: var(--c-warn-soft); color: inherit; padding: 0 2px; border-radius: 2px; }

/* ---------- Protocol ---------- */

.protocol { display: flex; flex-direction: column; gap: var(--sp-4); }
.protocol__toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--sp-3);
  flex-wrap: wrap;
}
.protocol__variants { display: flex; gap: var(--sp-1); }
.protocol__variant {
  padding: var(--sp-2) var(--sp-3);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  font-size: var(--fs-sm);
  background: var(--c-bg);
}
.protocol__variant:hover { background: var(--c-bg-hover); }
.protocol__variant.is-active { background: var(--c-text); color: var(--c-text-on-accent); border-color: var(--c-text); }
.protocol__actions { display: flex; gap: var(--sp-1); flex-wrap: wrap; }
.protocol__body { display: flex; flex-direction: column; gap: var(--sp-5); }
.protocol__section h4 {
  margin: 0 0 var(--sp-2);
  font-size: var(--fs-sm);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--c-text-muted);
}
.protocol__section p, .protocol__section ul {
  margin: 0;
  font-size: var(--fs-sm);
  line-height: var(--lh-relaxed);
}
.protocol__section ul { padding-left: var(--sp-5); display: flex; flex-direction: column; gap: var(--sp-1); }
.protocol__actions-list { padding-left: 0; list-style: none; }
.protocol__actions-list li {
  display: flex;
  justify-content: space-between;
  gap: var(--sp-3);
  padding: var(--sp-2) 0;
  border-bottom: 1px solid var(--c-border);
}
.protocol__actions-list li:last-child { border-bottom: none; }
.protocol__actions-list .muted { font-size: var(--fs-xs); flex-shrink: 0; white-space: nowrap; }

/* ---------- Tasks tab ---------- */

.tasks-tab { display: flex; flex-direction: column; gap: var(--sp-5); }
.tasks-tab__section { display: flex; flex-direction: column; gap: var(--sp-3); }
.tasks-tab__heading {
  margin: 0;
  font-size: var(--fs-sm);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--c-text-muted);
}
.tasks-tab__propose {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  padding: var(--sp-4);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  background: var(--c-accent-soft);
}
.tasks-tab__propose h3 { margin-bottom: var(--sp-1); }
.tasks-tab__propose p { margin: 0; font-size: var(--fs-sm); }
.tasks-tab__hint { font-size: var(--fs-sm); }

.tasks-list { display: flex; flex-direction: column; gap: var(--sp-2); }
.task {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  padding: var(--sp-3) var(--sp-4);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  background: var(--c-bg);
}
.task__main { flex: 1; min-width: 0; }
.task__title { font-weight: 500; font-size: var(--fs-sm); margin-bottom: 4px; }
.task__meta {
  display: flex;
  gap: var(--sp-3);
  flex-wrap: wrap;
  font-size: var(--fs-xs);
  color: var(--c-text-muted);
}
.task__meta > span { display: inline-flex; align-items: center; gap: 4px; }
.task__link {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  color: var(--c-text-muted);
  padding: var(--sp-1) var(--sp-2);
  border-radius: var(--r-sm);
}
.task__link:hover { background: var(--c-bg-hover); color: var(--c-text); text-decoration: none; }

/* ---------- Propose tasks (внутри карточки) ---------- */

.propose { display: flex; flex-direction: column; min-height: 0; }
.propose__header {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-4) var(--sp-6);
  border-bottom: 1px solid var(--c-border);
}
.propose__title-block { min-width: 0; }
.propose__title { margin: 0; font-size: var(--fs-lg); font-weight: 700; }
.propose__sub { font-size: var(--fs-sm); }

.propose__intro {
  display: flex;
  gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-6);
  background: var(--c-accent-soft);
  color: var(--c-text);
  font-size: var(--fs-sm);
}
.propose__intro > span { color: var(--c-accent); flex-shrink: 0; padding-top: 2px; }

.propose__list {
  padding: var(--sp-4) var(--sp-6);
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  overflow-y: auto;
  flex: 1;
  min-height: 0;
}
.candidate {
  display: grid;
  grid-template-columns: 32px 1fr 32px;
  align-items: flex-start;
  gap: var(--sp-3);
  padding: var(--sp-4);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  background: var(--c-bg);
  transition: opacity 100ms;
}
.candidate--off { opacity: 0.5; background: var(--c-bg-soft); }
.candidate__check {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-top: 6px;
  cursor: pointer;
}
.candidate__check input { width: 18px; height: 18px; cursor: pointer; accent-color: var(--c-accent); }
.candidate__body { display: flex; flex-direction: column; gap: var(--sp-3); min-width: 0; }
.candidate__title {
  font-size: var(--fs-md);
  font-weight: 600;
  border: none;
  border-bottom: 1px solid transparent;
  padding: var(--sp-1) 0;
  background: transparent;
  outline: none;
  width: 100%;
}
.candidate__title:hover { border-bottom-color: var(--c-border); }
.candidate__title:focus { border-bottom-color: var(--c-accent); }
.candidate__fields { display: flex; gap: var(--sp-4); flex-wrap: wrap; }
.candidate__field { display: flex; flex-direction: column; gap: 4px; min-width: 180px; }
.candidate__field-label { font-size: var(--fs-xs); color: var(--c-text-muted); text-transform: uppercase; letter-spacing: 0.04em; font-weight: 600; }
.candidate__field input, .candidate__field select {
  padding: var(--sp-2) var(--sp-3);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  font-size: var(--fs-sm);
  background: var(--c-bg);
  outline: none;
}
.candidate__field input:focus, .candidate__field select:focus { border-color: var(--c-text); }
.candidate__quote { font-size: var(--fs-sm); }
.candidate__quote summary {
  cursor: pointer;
  color: var(--c-text-muted);
  display: inline-flex;
  align-items: center;
  gap: var(--sp-1);
  padding: var(--sp-1) 0;
}
.candidate__quote summary:hover { color: var(--c-text); }
.candidate__quote blockquote {
  margin: var(--sp-2) 0 0;
  padding: var(--sp-2) var(--sp-3);
  border-left: 3px solid var(--c-border);
  background: var(--c-bg-soft);
  font-style: italic;
  color: var(--c-text-muted);
  border-radius: 0 var(--r-sm) var(--r-sm) 0;
}
.candidate__remove {
  width: 32px; height: 32px;
  border-radius: var(--r-md);
  color: var(--c-text-muted);
  display: flex; align-items: center; justify-content: center;
}
.candidate__remove:hover { background: var(--c-danger-soft); color: var(--c-danger); }

.propose__add { padding: 0 var(--sp-6) var(--sp-4); }

.propose__footer {
  border-top: 1px solid var(--c-border);
  padding: var(--sp-4) var(--sp-6);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  background: var(--c-bg-soft);
}
.propose__footer-info { font-size: var(--fs-sm); color: var(--c-text-muted); }
.propose__footer-info strong { color: var(--c-text); font-size: var(--fs-md); }
.propose__footer-actions { display: flex; gap: var(--sp-2); }

/* ---------- Create meeting ---------- */

.create { display: flex; flex-direction: column; }
.create__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--sp-4) var(--sp-5);
  border-bottom: 1px solid var(--c-border);
}
.create__header h2 { margin: 0; font-size: var(--fs-lg); font-weight: 700; }
.create__body {
  padding: var(--sp-5);
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
}
.create__footer {
  border-top: 1px solid var(--c-border);
  padding: var(--sp-3) var(--sp-5);
  display: flex;
  justify-content: flex-end;
  gap: var(--sp-2);
  background: var(--c-bg-soft);
}

.field { display: flex; flex-direction: column; gap: var(--sp-2); }
.field--checkbox {
  flex-direction: row;
  align-items: center;
  gap: var(--sp-2);
  font-size: var(--fs-sm);
  cursor: pointer;
}
.field--checkbox input { width: 16px; height: 16px; accent-color: var(--c-accent); cursor: pointer; }
.field__label {
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--c-text-muted);
  font-weight: 600;
}
.field__input {
  padding: var(--sp-3) var(--sp-3);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  background: var(--c-bg);
  font-size: var(--fs-md);
  outline: none;
  transition: border-color 80ms;
  width: 100%;
}
.field__input:focus { border-color: var(--c-text); }
.field__hint { font-size: var(--fs-xs); margin: 0; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-3); }

.segmented {
  display: inline-flex;
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  overflow: hidden;
}
.segmented__option {
  padding: var(--sp-2) var(--sp-4);
  background: var(--c-bg);
  font-size: var(--fs-sm);
  color: var(--c-text-muted);
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  border-right: 1px solid var(--c-border);
}
.segmented__option:last-child { border-right: none; }
.segmented__option:hover { background: var(--c-bg-hover); }
.segmented__option.is-active {
  background: var(--c-text);
  color: var(--c-text-on-accent);
}

.invited {
  display: flex;
  gap: var(--sp-2);
  flex-wrap: wrap;
  margin-top: var(--sp-2);
}
.chip {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-1) var(--sp-2) var(--sp-1) var(--sp-1);
  background: var(--c-bg-active);
  border-radius: var(--r-lg);
  font-size: var(--fs-sm);
}
.chip button {
  padding: 2px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  color: var(--c-text-muted);
}
.chip button:hover { background: var(--c-bg); color: var(--c-text); }

.copy-row { display: flex; gap: var(--sp-2); }
.copy-row input { flex: 1; font-family: var(--font-mono); font-size: var(--fs-sm); }

.create__body--choice { gap: var(--sp-3); padding: var(--sp-5); }

.create__header { position: relative; }
.create__header > h2 { flex: 1; text-align: center; }
.create__header > .btn--ghost { position: absolute; }
.create__header > .btn--ghost:first-child { left: var(--sp-3); }
.create__header > .btn--ghost:last-child { right: var(--sp-3); }
.create__header > .btn--ghost:only-child { position: static; }

.choice {
  display: grid;
  grid-template-columns: 56px 1fr 24px;
  align-items: flex-start;
  gap: var(--sp-4);
  width: 100%;
  text-align: left;
  padding: var(--sp-4);
  background: var(--c-bg);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  transition: border-color 100ms, background-color 100ms;
}
.choice:hover {
  background: var(--c-bg-hover);
  border-color: var(--c-text);
}
.choice:focus-visible {
  outline: 2px solid var(--c-accent);
  outline-offset: 2px;
}
.choice__icon {
  width: 56px; height: 56px;
  background: var(--c-bg-active);
  color: var(--c-text);
  border-radius: var(--r-md);
  display: flex; align-items: center; justify-content: center;
}
.choice__icon .icon { width: 24px; height: 24px; }
.choice__text { min-width: 0; display: flex; flex-direction: column; gap: var(--sp-2); }
.choice__text h3 { margin: 0; font-size: var(--fs-lg); font-weight: 700; }
.choice__text p { margin: 0; font-size: var(--fs-sm); color: var(--c-text-muted); line-height: var(--lh-relaxed); }
.choice__bullets {
  margin: var(--sp-1) 0 0;
  padding-left: var(--sp-5);
  display: flex;
  flex-direction: column;
  gap: 2px;
  font-size: var(--fs-xs);
  color: var(--c-text-muted);
}
.choice__arrow {
  align-self: center;
  color: var(--c-text-subtle);
  display: inline-flex;
}

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

textarea.field__input {
  resize: vertical;
  min-height: 80px;
  font-family: inherit;
  line-height: var(--lh-normal);
}

.create__footer { flex-wrap: wrap; }
.create__footer-hint {
  flex: 1;
  display: inline-flex;
  align-items: center;
  gap: var(--sp-1);
  font-size: var(--fs-xs);
  white-space: normal;
}
.create__footer-buttons { display: flex; gap: var(--sp-2); }

.create__success-banner {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  background: var(--c-ok-soft);
  border-radius: var(--r-md);
}
.create__success-icon {
  width: 32px; height: 32px;
  background: var(--c-ok);
  color: var(--c-text-on-accent);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
}

/* ---------- Video room (заглушка) ---------- */

.video-room {
  background: #18181b;
  color: #f4f4f5;
  min-height: calc(100vh - 60px);
  margin: calc(var(--sp-6) * -1) calc(var(--sp-8) * -1);
  padding: var(--sp-6) var(--sp-8);
  display: flex;
  flex-direction: column;
}
.video-room__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--sp-5);
}
.video-room__title { font-size: var(--fs-lg); font-weight: 600; }
.video-room__live { display: flex; align-items: center; gap: var(--sp-2); font-family: var(--font-mono); }
.video-room__stage {
  flex: 1;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: var(--sp-3);
  margin-bottom: var(--sp-5);
}
.video-room__tile {
  background: #27272a;
  border-radius: var(--r-lg);
  aspect-ratio: 16 / 9;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--sp-3);
}
.video-room__tile--empty { background: transparent; border: 1px dashed #3f3f46; color: #71717a; }
.video-room__avatar {
  width: 80px; height: 80px;
  background: #3f3f46;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: var(--fs-2xl);
  font-weight: 600;
}
.video-room__name { color: #d4d4d8; }
.video-room__controls {
  display: flex;
  justify-content: center;
  gap: var(--sp-2);
}
.video-room__control {
  width: 48px; height: 48px;
  background: #27272a;
  color: #f4f4f5;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
}
.video-room__control:hover { background: #3f3f46; }
.video-room__control--leave {
  background: var(--c-danger);
  width: auto;
  padding: 0 var(--sp-5);
  border-radius: 24px;
  font-weight: 600;
  font-size: var(--fs-sm);
}
.video-room__control--leave:hover { background: #b91c1c; }

/* ---------- Stub screens ---------- */

.stub-screen {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: var(--sp-8);
  align-items: start;
  padding: var(--sp-6);
  background: var(--c-bg);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
}
.stub-screen__viz { min-height: 320px; }
.stub-screen__caption h3 {
  margin: 0 0 var(--sp-2);
  font-size: var(--fs-lg);
  font-weight: 700;
}
.stub-screen__caption p {
  margin: 0 0 var(--sp-3);
  font-size: var(--fs-sm);
  color: var(--c-text-muted);
  line-height: var(--lh-relaxed);
}

.stub-calendar__head {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  font-size: var(--fs-xs);
  color: var(--c-text-muted);
  padding: var(--sp-2) 0;
  text-align: center;
}
.stub-calendar__grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 1px;
  background: var(--c-border);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  overflow: hidden;
}
.stub-calendar__cell {
  background: var(--c-bg);
  min-height: 56px;
  padding: var(--sp-2);
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.stub-calendar__cell.is-empty { background: var(--c-bg-soft); }
.stub-calendar__day { font-size: var(--fs-xs); color: var(--c-text-muted); }
.stub-calendar__event {
  height: 14px;
  background: var(--c-accent-soft);
  border-left: 3px solid var(--c-accent);
  border-radius: 2px;
}

.stub-rooms { display: flex; flex-direction: column; gap: var(--sp-2); }
.stub-room {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  background: var(--c-bg-soft);
}
.stub-room__icon {
  width: 40px; height: 40px;
  border-radius: var(--r-md);
  background: var(--c-bg);
  border: 1px solid var(--c-border);
  display: flex; align-items: center; justify-content: center;
  color: var(--c-text-muted);
}

.stub-analytics { display: flex; flex-direction: column; gap: var(--sp-4); }
.stub-chart {
  background: var(--c-bg-soft);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  padding: var(--sp-4);
}
.stub-chart__title { font-size: var(--fs-sm); color: var(--c-text-muted); margin-bottom: var(--sp-3); }
.stub-chart__bars {
  display: flex;
  align-items: flex-end;
  gap: var(--sp-2);
  height: 120px;
}
.stub-chart__bars div {
  flex: 1;
  background: var(--c-accent);
  border-radius: var(--r-sm) var(--r-sm) 0 0;
}
.stub-stats {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-3);
}
.stub-stat {
  padding: var(--sp-3);
  background: var(--c-bg-soft);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
}
.stub-stat__num { font-size: var(--fs-xl); font-weight: 700; margin-bottom: 2px; }

/* ---------- Toast ---------- */

.toast-container {
  position: fixed;
  bottom: var(--sp-5);
  right: var(--sp-5);
  z-index: var(--z-toast);
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  pointer-events: none;
}
.toast {
  background: var(--c-text);
  color: var(--c-text-on-accent);
  padding: var(--sp-3) var(--sp-4);
  border-radius: var(--r-md);
  font-size: var(--fs-sm);
  max-width: 360px;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 180ms, transform 180ms;
}
.toast--visible { opacity: 1; transform: translateY(0); }
.toast--success { background: var(--c-ok); }

/* ---------- Adaptive (узкие десктопы) ---------- */

@media (max-width: 1024px) {
  .layout { grid-template-columns: 200px 1fr; }
  .content { padding: var(--sp-5) var(--sp-5); }
  .row {
    grid-template-columns: 80px 1fr auto;
  }
  .row__artifacts { grid-column: 2; grid-row: 2; margin-top: var(--sp-2); }
  .row__actions { grid-column: 3; grid-row: 1 / 3; align-self: center; }
}

@media (max-width: 760px) {
  /* На очень узких просим открыть мобильную версию */
  body::before {
    content: 'Откройте mobile.html для мобильной версии';
    display: block;
    background: var(--c-warn-soft);
    color: var(--c-warn);
    padding: var(--sp-2);
    text-align: center;
    font-size: var(--fs-xs);
    font-weight: 600;
  }
}
