/* public/css/monitor.css */
/* 2026-06-17 - стили страницы /monitor: мульти-терминалы, фильтры, контекстное меню (ТЗ 9.3) */
/* Поверх tokens.css. Сигнатура — терминальные окна в стиле .terminal лендинга FMOTC. */

/* ── Хедер монитора: фильтры активного терминала ───────────────────────────── */
.monitor-header {
  display: flex; align-items: center; gap: var(--sp-3);
  padding: var(--sp-2) var(--sp-5); min-height: 48px;
  border-bottom: 1px solid var(--c-border); background: var(--c-surface);
}
.monitor-header .hdr-label {
  font-family: var(--font-display); font-size: var(--fs-xs);
  letter-spacing: 0.08em; text-transform: uppercase; color: var(--c-text-dim);
}
.filters-row { display: flex; align-items: center; gap: var(--sp-2); flex-wrap: wrap; }
.filter-chip {
  display: inline-flex; align-items: center; gap: var(--sp-1);
  padding: 3px var(--sp-3); border-radius: var(--radius-sm); cursor: pointer;
  font-size: var(--fs-xs); border: 1px solid var(--c-border);
  background: var(--c-surface-2); color: var(--c-text-dim); user-select: none;
  transition: border-color .15s, color .15s;
}
.filter-chip .swatch { width: 8px; height: 8px; border-radius: 2px; }
.filter-chip.active { color: var(--c-text); border-color: currentColor; }
.filter-chip .rm { margin-left: 2px; opacity: 0.5; }
.filter-chip .rm:hover { opacity: 1; }
.filter-chip.add { border-style: dashed; color: var(--c-text-dim); }
.filters-hint { color: var(--c-text-dim); font-size: var(--fs-xs); font-style: italic; }

/* ── Рабочее поле с терминалами ────────────────────────────────────────────── */
.workspace {
  position: relative; flex: 1; overflow: hidden;
  background:
    linear-gradient(var(--c-bg) 0 0) padding-box,
    repeating-linear-gradient(0deg, transparent, transparent 31px, var(--c-surface) 31px, var(--c-surface) 32px),
    repeating-linear-gradient(90deg, transparent, transparent 31px, var(--c-surface) 31px, var(--c-surface) 32px);
}
.workspace .empty {
  position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
  color: var(--c-text-dim); font-size: var(--fs-lg); text-align: center; padding: var(--sp-8);
  pointer-events: none;
}

/* Окно терминала — draggable/resizable */
.term-window {
  position: absolute; display: flex; flex-direction: column;
  min-width: 280px; min-height: 180px;
  background: #050505; border: 1px solid var(--c-border); border-radius: var(--radius);
  box-shadow: 0 8px 28px rgba(0,0,0,0.55); overflow: hidden; resize: both;
}
.term-window.focused { border-color: var(--c-accent); box-shadow: 0 0 0 1px var(--c-accent), 0 8px 28px rgba(0,0,0,0.6); }
.term-window.maximized {
  inset: var(--sp-3) !important; width: auto !important; height: auto !important; resize: none;
}
.term-titlebar {
  display: flex; align-items: center; gap: var(--sp-2); cursor: move;
  padding: var(--sp-2) var(--sp-3); background: var(--c-surface);
  border-bottom: 1px solid var(--c-border);
  font-family: var(--font-display); font-size: var(--fs-xs);
  letter-spacing: 0.06em; text-transform: uppercase; color: var(--c-text-dim);
}
.term-titlebar .t-name { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--c-text); }
.term-titlebar .t-btn {
  border: none; background: none; color: var(--c-text-dim); cursor: pointer;
  padding: 0 var(--sp-1); font-size: var(--fs-base); line-height: 1;
}
.term-titlebar .t-btn:hover { color: var(--c-accent); }
.term-body {
  flex: 1; padding: var(--sp-3); overflow-y: auto;
  font-family: var(--font-mono); font-size: var(--fs-sm);
}
.term-line { white-space: pre-wrap; word-break: break-word; padding: 1px 0; }
.term-line .ts { color: var(--c-text-dim); margin-right: var(--sp-2); }
.term-line.hidden-by-filter { display: none; }
.term-cmd { display: flex; gap: var(--sp-2); padding: var(--sp-2); border-top: 1px solid var(--c-border); background: var(--c-surface); }
.term-cmd input { flex: 1; font-family: var(--font-mono); font-size: var(--fs-sm); }

/* счётчик открытых терминалов / лимит */
.term-count { margin-left: auto; font-size: var(--fs-xs); color: var(--c-text-dim); }
.term-count.limit { color: var(--c-warning); }

/* ── Левая панель: drag-resize ширины ──────────────────────────────────────── */
.devices-panel { position: relative; }
.panel-resizer {
  position: absolute; top: 0; right: -3px; width: 6px; height: 100%;
  cursor: col-resize; z-index: 5;
}
.panel-resizer:hover { background: var(--c-accent); opacity: 0.4; }
.group-header {
  display: flex; align-items: center; gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-4); font-size: var(--fs-xs);
  color: var(--c-text-dim); text-transform: uppercase; letter-spacing: 0.06em;
  cursor: pointer; user-select: none;
}
.group-header .chevron { transition: transform .15s; }
.group-header.collapsed .chevron { transform: rotate(-90deg); }
.group-devices.collapsed { display: none; }

/* Шапка панели с кнопкой создания группы */
.panel-head { display: flex; align-items: center; justify-content: space-between; }
.panel-add {
  border: 1px solid var(--c-border); background: var(--c-surface-2); color: var(--c-text-dim);
  width: 22px; height: 22px; line-height: 1; padding: 0; border-radius: var(--radius-sm); font-size: 16px;
}
.panel-add:hover { border-color: var(--c-accent); color: var(--c-accent); }
.group-header .grp-name { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.group-header .grp-dots {
  margin-left: auto; opacity: 0; color: var(--c-text-dim); cursor: pointer;
  font-size: var(--fs-md); padding: 0 4px; line-height: 1; user-select: none;
}
.group-header:hover .grp-dots { opacity: 0.6; }
.group-header .grp-dots:hover { opacity: 1; color: var(--c-accent); }

/* Кнопка-опасность в модалках (удаление, заморозка) */
button.danger { border-color: var(--c-error); color: var(--c-error); }
button.danger:hover:not(:disabled) { background: var(--c-error); color: #000; border-color: var(--c-error); }
button:disabled { opacity: 0.4; cursor: not-allowed; }

/* Кошелёк в хедере (как в ЛК Gateway) */
.wallet-badge {
  display: inline-flex; align-items: center; gap: 6px; margin-left: var(--sp-3);
  padding: 4px 10px; border: 1px solid var(--c-border); border-radius: 6px;
  background: var(--c-surface-2); color: var(--c-text); font-size: var(--fs-sm); cursor: pointer;
}
.wallet-badge:hover { border-color: var(--c-accent); }
.wallet-badge .wallet-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 16px; height: 16px; color: var(--c-text-dim);
}
.wallet-badge:hover .wallet-icon { color: var(--c-accent); }
.wallet-badge .wallet-icon svg { width: 16px; height: 16px; display: block; }
.wallet-badge .wallet-addr { font-family: var(--font-mono, monospace); letter-spacing: 0.02em; }


/* ── Контекстное меню (расширенное) ────────────────────────────────────────── */
.ctx-menu .ctx-toggle { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-3); }
.ctx-menu .reason { padding: var(--sp-2) var(--sp-3); font-size: var(--fs-xs); color: var(--c-warning); }

/* ── Модалки экспорта/группы ───────────────────────────────────────────────── */
.modal .field { display: flex; flex-direction: column; gap: var(--sp-1); margin-bottom: var(--sp-3); }
.modal .field label { font-size: var(--fs-xs); color: var(--c-text-dim); text-transform: uppercase; letter-spacing: 0.05em; }
.modal .seg { display: flex; gap: var(--sp-1); }
.modal .seg button { flex: 1; }
.modal .seg button.active { background: var(--c-accent); color: #000; border-color: var(--c-accent); }

/* ── Кастомный скроллбар: полупрозрачный серый, не режет глаз ─────────────────── */
.modal, .term-body, .terminal-body, .trigger-preview, #deviceList, .workspace {
  scrollbar-width: thin;
  scrollbar-color: rgba(255, 255, 255, 0.12) transparent;
}
.modal::-webkit-scrollbar,
.term-body::-webkit-scrollbar,
.terminal-body::-webkit-scrollbar,
#deviceList::-webkit-scrollbar,
.workspace::-webkit-scrollbar { width: 8px; height: 8px; }
.modal::-webkit-scrollbar-track,
.term-body::-webkit-scrollbar-track,
.terminal-body::-webkit-scrollbar-track,
#deviceList::-webkit-scrollbar-track,
.workspace::-webkit-scrollbar-track { background: transparent; }
.modal::-webkit-scrollbar-thumb,
.term-body::-webkit-scrollbar-thumb,
.terminal-body::-webkit-scrollbar-thumb,
#deviceList::-webkit-scrollbar-thumb,
.workspace::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.12);
  border-radius: 4px;
}
.modal::-webkit-scrollbar-thumb:hover,
.term-body::-webkit-scrollbar-thumb:hover,
.terminal-body::-webkit-scrollbar-thumb:hover,
#deviceList::-webkit-scrollbar-thumb:hover,
.workspace::-webkit-scrollbar-thumb:hover {
  background: rgba(255, 255, 255, 0.2);
}

/* Индикаторы безопасности устройства (Приложение C 7) */
.device-item .sec-badge {
  margin-left: 4px; cursor: default; font-size: var(--fs-sm); line-height: 1;
}
.device-item .sec-badge.sec-mismatch { color: var(--c-warning); cursor: pointer; }
.device-item .sec-badge.sec-mismatch:hover { filter: brightness(1.3); }
.device-item .sec-badge.sec-freezing { color: var(--c-info); }
