/* Палитра: светлая тема по умолчанию, тёмная — через data-theme="dark" */
:root {
  --background-color: #faf7f2;
  --surface-color: #ffffff;
  --text-color: #2b2a27;
  --muted-text-color: #8a857c;
  --border-color: #e3ddd2;
  --accent-color: #2f6f6a;
  --accent-text-color: #ffffff;
  --danger-color: #b3402f;
}

:root[data-theme="dark"] {
  --background-color: #1e1d1b;
  --surface-color: #282623;
  --text-color: #e8e4dc;
  --muted-text-color: #97917f;
  --border-color: #3b382f;
  --accent-color: #5fa8a0;
  --accent-text-color: #14211f;
  --danger-color: #d97862;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  background: var(--background-color);
  color: var(--text-color);
}

.loading-placeholder { padding: 3rem; text-align: center; color: var(--muted-text-color); }

.application-layout { display: flex; min-height: 100vh; }

/* Боковая панель: прилипает к экрану, все действия — сверху */
.characters-sidebar {
  width: 270px;
  flex-shrink: 0;
  padding: 1rem;
  border-right: 1px solid var(--border-color);
  display: flex;
  flex-direction: column;
  gap: 0.9rem;
  position: sticky;
  top: 0;
  height: 100vh;
}

.sidebar-header { display: flex; align-items: center; justify-content: space-between; }
.application-title { font-size: 1.2rem; margin: 0; letter-spacing: 0.02em; }
.theme-toggle-button { background: none; border: none; font-size: 1.1rem; cursor: pointer; }

.sidebar-actions { display: flex; flex-direction: column; gap: 6px; }
.action-buttons-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; }
.action-buttons-grid > * { min-width: 0; }

.characters-list {
  list-style: none; margin: 0; padding: 0;
  flex: 1; overflow-y: auto;
  border-top: 1px solid var(--border-color);
  padding-top: 0.6rem;
}
.character-item { margin-bottom: 4px; }
.character-select-button {
  width: 100%; text-align: left; padding: 8px 10px;
  background: none; border: 1px solid transparent; border-radius: 8px;
  color: var(--text-color); font: inherit; cursor: pointer;
}
.character-item.selected .character-select-button {
  background: var(--surface-color); border-color: var(--border-color); font-weight: bold;
}

.primary-button, .secondary-button, .danger-button {
  padding: 8px 10px; border-radius: 8px; font: inherit; font-size: 0.92rem;
  cursor: pointer; text-align: center;
}
.primary-button { background: var(--accent-color); color: var(--accent-text-color); border: none; }
.secondary-button { background: var(--surface-color); color: var(--text-color); border: 1px solid var(--border-color); }
.secondary-button:disabled, .danger-button:disabled { opacity: 0.45; cursor: default; }
.danger-button { background: none; color: var(--danger-color); border: 1px solid var(--danger-color); }

.import-label { display: block; cursor: pointer; }
.hidden-file-input { display: none; }

/* Редактор анкеты */
.questionnaire-editor { flex: 1; max-width: 880px; padding: 1.5rem 2rem; }
.empty-state-message { color: var(--muted-text-color); }

.character-name-input {
  width: 100%; font: inherit; font-size: 1.6rem; font-weight: bold;
  background: none; border: none; border-bottom: 2px solid var(--border-color);
  color: var(--text-color); padding: 6px 2px; margin-bottom: 1.25rem; outline: none;
}

.questionnaire-section {
  background: var(--surface-color); border: 1px solid var(--border-color);
  border-radius: 12px; padding: 1rem 1.25rem; margin-bottom: 1rem;
}

.section-header { display: flex; align-items: center; gap: 8px; }

/* Значок раздела: фиксированная ширина и центрирование — всегда выровнен, всегда редактируем */
.section-icon-input {
  width: 2.2em; text-align: center; font: inherit; font-size: 1.05rem;
  background: var(--background-color); border: 1px solid transparent; border-radius: 8px;
  color: var(--text-color); padding: 4px 0; outline: none;
}
.section-icon-input:hover, .section-icon-input:focus { border-color: var(--border-color); }

.section-title-input {
  flex: 1; font: inherit; font-size: 1.1rem; font-weight: bold;
  background: none; border: none; color: var(--text-color); outline: none;
}
.section-hint { color: var(--muted-text-color); font-style: italic; font-size: 0.9rem; margin: 6px 0 10px; }

.row-controls { display: flex; gap: 2px; align-items: center; }

.paired-columns-header {
  display: grid; grid-template-columns: 160px 1fr 1fr 76px; gap: 8px;
  color: var(--muted-text-color); font-size: 0.85rem; margin-top: 10px;
}

.field-row { display: grid; grid-template-columns: 160px 1fr 76px; gap: 8px; align-items: start; margin-top: 8px; }
.field-row.paired { grid-template-columns: 160px 1fr 1fr 76px; }

.field-label-input {
  font: inherit; font-size: 0.9rem; color: var(--muted-text-color);
  background: none; border: none; outline: none; padding-top: 8px;
}

/* Все поля многострочные и растут под содержимое (field-sizing), min-height — запасной вариант */
.field-value-textarea {
  font: inherit; width: 100%; padding: 7px 9px;
  background: var(--background-color); color: var(--text-color);
  border: 1px solid var(--border-color); border-radius: 8px; outline: none;
  resize: vertical; min-height: 2.5em; field-sizing: content;
}
.field-value-textarea:focus { border-color: var(--accent-color); }

.icon-button {
  background: none; border: none; color: var(--muted-text-color);
  cursor: pointer; padding: 8px 3px 0; font-size: 0.95rem;
}
.icon-button:hover:not(:disabled) { color: var(--danger-color); }
.icon-button:disabled { opacity: 0.25; cursor: default; }

.add-field-button, .add-section-button {
  margin-top: 10px; background: none; border: 1px dashed var(--border-color);
  border-radius: 8px; color: var(--muted-text-color); font: inherit;
  padding: 7px 12px; cursor: pointer;
}
.add-section-button { width: 100%; padding: 12px; }
.add-field-button:hover, .add-section-button:hover { color: var(--accent-color); border-color: var(--accent-color); }

/* Телефон: панель сверху, анкета под ней */
@media (max-width: 720px) {
  .application-layout { flex-direction: column; }
  .characters-sidebar { width: 100%; height: auto; position: static; border-right: none; border-bottom: 1px solid var(--border-color); }
  .questionnaire-editor { padding: 1rem; }
  .field-row, .field-row.paired, .paired-columns-header { grid-template-columns: 1fr; }
  .row-controls { justify-content: flex-end; }
}

/* Печатная версия: только содержимое анкеты, без панелей, кнопок и пустых полей */
@media print {
  :root {
    --background-color: #ffffff;
    --surface-color: #ffffff;
    --text-color: #000000;
    --muted-text-color: #555555;
    --border-color: #bbbbbb;
  }

  .characters-sidebar, .row-controls, .add-field-button, .add-section-button { display: none !important; }
  .field-row.empty-field { display: none !important; }

  .application-layout { display: block; }
  .questionnaire-editor { max-width: none; padding: 0; }

  .character-name-input { border-bottom: 2px solid #000; font-size: 1.8rem; }

  .questionnaire-section {
    border: none; border-radius: 0; padding: 0.4rem 0 0.8rem;
    border-bottom: 1px solid var(--border-color);
    break-inside: avoid;
  }

  .section-icon-input { background: none; border: none; }
  .section-hint { display: none; }

  .field-row { grid-template-columns: 170px 1fr; }
  .field-row.paired { grid-template-columns: 170px 1fr 1fr; }
  .paired-columns-header { grid-template-columns: 170px 1fr 1fr; }

  .field-value-textarea {
    border: none; background: none; padding: 4px 0;
    resize: none; min-height: 0; field-sizing: content;
  }
}

/* --- Дополнения: иконки, выбор иконки, граф связей --- */

.application-icon { display: block; }

.view-switch { display: flex; gap: 6px; }
.view-switch-button {
  flex: 1; padding: 7px 0; border-radius: 8px; font: inherit; font-size: 0.92rem;
  background: none; border: 1px solid var(--border-color); color: var(--muted-text-color); cursor: pointer;
}
.view-switch-button.active {
  background: var(--surface-color); color: var(--text-color); font-weight: bold;
  border-color: var(--accent-color);
}

.theme-toggle-button { color: var(--text-color); padding: 4px; border-radius: 6px; }
.theme-toggle-button:hover { background: var(--surface-color); }

.icon-picker-anchor { position: relative; display: inline-flex; }
.section-icon-button {
  background: var(--background-color); border: 1px solid transparent; border-radius: 8px;
  color: var(--text-color); cursor: pointer; padding: 6px; display: inline-flex;
}
.section-icon-button:hover { border-color: var(--border-color); }

.icon-picker-popup {
  position: absolute; top: 110%; left: 0; z-index: 10;
  display: grid; grid-template-columns: repeat(6, 1fr); gap: 4px;
  background: var(--surface-color); border: 1px solid var(--border-color);
  border-radius: 10px; padding: 8px; box-shadow: 0 6px 24px rgba(0,0,0,0.18);
}
.icon-picker-option {
  background: none; border: 1px solid transparent; border-radius: 6px;
  color: var(--text-color); cursor: pointer; padding: 6px; display: inline-flex;
}
.icon-picker-option:hover { border-color: var(--accent-color); color: var(--accent-color); }

/* Подписи полей — многострочные и растут под содержимое: длинные фразы видны целиком */
.field-label-input {
  font: inherit; font-size: 0.9rem; color: var(--muted-text-color);
  background: none; border: none; outline: none; padding-top: 8px;
  resize: none; min-height: 0; field-sizing: content; width: 100%; overflow: hidden;
}

.column-label-input {
  font: inherit; font-size: 0.85rem; color: var(--muted-text-color);
  background: none; border: none; outline: none; width: 100%;
}
.column-label-input:focus { color: var(--text-color); }

.field-row { grid-template-columns: 190px 1fr 76px; }
.field-row.paired { grid-template-columns: 190px 1fr 1fr 76px; }
.paired-columns-header { grid-template-columns: 190px 1fr 1fr 76px; }

.add-section-row { display: flex; gap: 8px; }
.add-section-row .add-section-button { flex: 1; }

/* Вид «Связи» */
.relationships-view { flex: 1; max-width: 920px; padding: 1.5rem 2rem; }
.view-heading { margin: 0 0 1rem; }

.relationship-form { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; margin-bottom: 0.6rem; }
.relationship-select, .relationship-label-input {
  font: inherit; font-size: 0.92rem; padding: 8px 9px;
  background: var(--surface-color); color: var(--text-color);
  border: 1px solid var(--border-color); border-radius: 8px; outline: none;
}
.relationship-label-input { flex: 1; min-width: 140px; }
.form-message { color: var(--danger-color); font-size: 0.9rem; margin: 0 0 0.6rem; }

.relationships-graph {
  display: block; width: 100%; aspect-ratio: 800 / 520;
  background: var(--surface-color);
  border: 1px solid var(--border-color); border-radius: 12px;
}

.relationships-list { list-style: none; margin: 1rem 0 0; padding: 0; }
.relationship-item {
  display: flex; align-items: center; gap: 10px; padding: 8px 4px;
  border-bottom: 1px solid var(--border-color);
  transition: background 0.15s ease, box-shadow 0.15s ease;
}
.relationship-item[draggable="true"] { cursor: default; }
.relationship-item.drag-over {
  background: var(--surface-color);
  box-shadow: inset 0 2px 0 var(--accent-color);
}
.drag-handle {
  color: var(--muted-text-color); cursor: grab; user-select: none;
  font-size: 0.95rem; padding: 0 2px; flex-shrink: 0;
}
.drag-handle:active { cursor: grabbing; }
.context-menu-backdrop { position: fixed; inset: 0; z-index: 49; }
.relationship-item.dragging { opacity: 0.55; }
.node-context-menu-item.danger { color: var(--danger-color); }
.node-context-menu-item.danger:hover { background: var(--background-color); color: var(--danger-color); }
.relationship-color-dot { flex-shrink: 0; display: block; }
.relationship-item .icon-button { margin-left: auto; padding: 0 4px; }

@media print {
  .view-switch, .relationships-view { display: none !important; }
  .icon-picker-popup { display: none !important; }
  .field-row { grid-template-columns: 190px 1fr; }
  .field-row.paired { grid-template-columns: 190px 1fr 1fr; }
  .paired-columns-header { grid-template-columns: 190px 1fr 1fr; }
  .column-label-input { border-bottom: none; }
}

/* --- Категории героев в боковой панели --- */
.category-item { margin: 6px 0 2px; }
.category-toggle-button {
  width: 100%; display: flex; align-items: center; gap: 6px;
  background: none; border: none; cursor: pointer; padding: 4px 6px;
  color: var(--muted-text-color); font: inherit; font-size: 0.85rem;
  text-transform: uppercase; letter-spacing: 0.05em;
}
.category-toggle-arrow { width: 1em; }
.category-toggle-name { flex: 1; text-align: left; }
.category-toggle-count {
  display: grid; place-items: center;
  background: var(--surface-color); border: 1px solid var(--border-color);
  border-radius: 10px; min-width: 1.8em; height: 1.6em;
  padding: 0 6px; font-size: 0.78rem; line-height: 1;
  /* У Georgia «старостильные» цифры с выносами ниже базовой линии —
     для счётчика берётся шрифт с обычными цифрами */
  font-family: "Segoe UI", Tahoma, Arial, sans-serif;
  font-variant-numeric: lining-nums;
}

.category-row { display: flex; align-items: center; gap: 8px; margin-bottom: 1.1rem; }
.category-row-label { color: var(--muted-text-color); font-size: 0.9rem; }
.category-input {
  font: inherit; font-size: 0.9rem; padding: 5px 9px; flex: 1; max-width: 300px;
  background: var(--surface-color); color: var(--text-color);
  border: 1px solid var(--border-color); border-radius: 8px; outline: none;
}
.category-input:focus { border-color: var(--accent-color); }

/* --- Граф: перетаскивание, меню, фильтр --- */
.relationships-graph { touch-action: none; }
.graph-hint { color: var(--muted-text-color); font-size: 0.85rem; margin-top: 6px; }

/* Переключатель «односторонняя связь» в стиле приложения */
.direction-toggle {
  display: inline-flex; align-items: center; gap: 7px;
  cursor: pointer; user-select: none; white-space: nowrap;
}
.direction-toggle input { position: absolute; opacity: 0; width: 0; height: 0; }
.direction-toggle-track {
  width: 34px; height: 19px; border-radius: 10px; flex-shrink: 0;
  background: var(--background-color); border: 1px solid var(--border-color);
  position: relative; transition: background 0.18s ease, border-color 0.18s ease;
}
.direction-toggle-thumb {
  position: absolute; top: 2px; left: 2px; width: 13px; height: 13px;
  border-radius: 50%; background: var(--muted-text-color);
  transition: left 0.18s ease, background 0.18s ease;
}
.direction-toggle input:checked + .direction-toggle-track {
  background: var(--accent-color); border-color: var(--accent-color);
}
.direction-toggle input:checked + .direction-toggle-track .direction-toggle-thumb {
  left: 17px; background: var(--accent-text-color);
}
.direction-toggle input:focus-visible + .direction-toggle-track {
  outline: 2px solid var(--accent-color); outline-offset: 2px;
}
.direction-toggle-text { color: var(--muted-text-color); font-size: 0.9rem; }

.filter-banner { color: var(--muted-text-color); font-size: 0.92rem; margin: 0 0 0.6rem; }
.link-button {
  background: none; border: none; color: var(--accent-color);
  font: inherit; font-size: 0.92rem; cursor: pointer; text-decoration: underline; padding: 0;
}

.node-context-menu {
  position: fixed; z-index: 50; min-width: 210px; visibility: hidden;
  background: var(--surface-color); border: 1px solid var(--border-color);
  border-radius: 10px; padding: 6px; box-shadow: 0 8px 28px rgba(0,0,0,0.22);
}
.node-context-menu-title {
  font-weight: bold; padding: 6px 10px; border-bottom: 1px solid var(--border-color); margin-bottom: 4px;
}
.node-context-menu-item {
  display: block; width: 100%; text-align: left;
  background: none; border: none; border-radius: 6px;
  color: var(--text-color); font: inherit; font-size: 0.92rem;
  padding: 7px 10px; cursor: pointer;
}
.node-context-menu-item:hover { background: var(--background-color); color: var(--accent-color); }

@media print {
  .node-context-menu, .category-row { display: none !important; }
}

/* --- Заготовки связей: выбор и редактор --- */
.preset-picker { display: inline-flex; align-items: center; gap: 6px; }
.preset-color-dot { flex-shrink: 0; display: block; }
.preset-settings-button {
  background: var(--surface-color); border: 1px solid var(--border-color); border-radius: 8px;
  color: var(--muted-text-color); cursor: pointer; font-size: 0.95rem;
  padding: 6px 9px; line-height: 1;
}
.preset-settings-button:hover { color: var(--accent-color); border-color: var(--accent-color); }

.preset-editor {
  background: var(--surface-color); border: 1px solid var(--border-color);
  border-radius: 12px; padding: 10px 12px; margin-bottom: 0.8rem; max-width: 420px;
}
.preset-editor-title { font-weight: bold; font-size: 0.92rem; margin-bottom: 8px; }
.preset-editor-row { display: flex; align-items: center; gap: 8px; margin-bottom: 6px; }
.preset-color-input {
  width: 34px; height: 28px; padding: 1px; flex-shrink: 0;
  background: none; border: 1px solid var(--border-color); border-radius: 6px; cursor: pointer;
}
.preset-name-input {
  flex: 1; font: inherit; font-size: 0.92rem; padding: 6px 9px;
  background: var(--background-color); color: var(--text-color);
  border: 1px solid var(--border-color); border-radius: 8px; outline: none;
}
.preset-name-input:focus { border-color: var(--accent-color); }
.preset-editor .add-field-button { margin-top: 4px; }
.preset-editor .icon-button { padding: 0 4px; }
