:root{
  /* Светлая, спокойная палитра */
  --bg:#f7f8fb;
  --panel:#ffffff;
  --panel-2:#fafbff;
  --text:#1f2937;      /* графит */
  --muted:#6b7280;     /* серый подписи */
  --accent:#3b82f6;    /* мягкий синий для слов */
  --danger:#ef4444;    /* красный для строк */
  --warn:#f59e0b;      /* янтарь для ручного выделения */
  --chip:#eef2ff;      /* нежно-лавандовый фон чипов */
  --border:#e5e7eb;    /* светлая граница */
  --ok:#10b981;        /* зеленый успех */
  --shadow-sm: 0 1px 2px rgba(15,23,42,.06);
  --shadow-md: 0 6px 16px rgba(15,23,42,.08);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font:16px/1.5 system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
}

/* ====== Шапка ====== */
.app-header{
  position:sticky; top:0; z-index:10;
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 16px;
  background:rgba(255,255,255,.9);
  backdrop-filter: blur(8px);
  border-bottom:1px solid var(--border);
}
.app-header h1{font-size:18px; margin:0 12px 0 0; white-space:nowrap}
.header-left{display:flex; align-items:center; gap:12px}
.header-right{display:flex; gap:12px; align-items:center}
.counter{
  padding:6px 10px; border:1px solid var(--border); border-radius:10px;
  color:var(--muted); background:var(--panel);
  box-shadow: var(--shadow-sm);
}

/* ====== Файл ====== */
.file-input{display:inline-flex; align-items:center; gap:8px; cursor:pointer}
.file-input input{display:none}
.file-input span{
  display:inline-flex; align-items:center; gap:8px;
  background:var(--panel); border:1px solid var(--border);
  padding:8px 12px; border-radius:10px;
  box-shadow: var(--shadow-sm);
  transition: border-color .15s, transform .05s, background .15s;
}
.file-input span:hover{border-color:#c7cdd8; background:#fbfbfe}

/* ====== Макет ====== */
.app-main{
  display:grid; gap:16px; padding:16px; max-width:1200px; margin:0 auto;
  grid-template-columns: 1.2fr .8fr;
}
@media (max-width: 980px){
  .app-main{grid-template-columns: 1fr}
}

.col{
  min-height:60vh; background:var(--panel);
  border:1px solid var(--border); border-radius:16px; padding:12px;
  box-shadow: var(--shadow-sm);
}
.col-right{background:var(--panel-2)}

/* ====== Панель инструментов ====== */
.toolbar{display:flex; flex-direction:column; gap:12px; margin-bottom:8px}
.search{
  width:100%; border:1px solid var(--border); border-radius:10px;
  background:#ffffff; color:var(--text); padding:10px 12px;
  box-shadow: inset 0 1px 0 rgba(0,0,0,.02);
}
.search::placeholder{color:#9aa3b2}

.btn-row{display:flex; flex-wrap:wrap; gap:8px}
.btn{
  border:1px solid var(--border); background:#ffffff; color:var(--text);
  padding:8px 12px; border-radius:10px; cursor:pointer;
  box-shadow: var(--shadow-sm);
  transition: border-color .15s, transform .05s, background .15s;
}
.btn:hover{border-color:#cbd5e1; background:#f9fafb}
.btn:active{transform: translateY(1px)}
.btn-warn{background:#fff7ed; border-color:#fde68a}
.btn-danger{background:#fff1f2; border-color:#fecaca}

/* ====== Список фраз ====== */
.list{
  display:flex; flex-direction:column; gap:8px;
  max-height:72vh; overflow:auto; padding-right:4px
}
.phrases-list .row{
  padding:10px 12px; border:1px solid var(--border); border-radius:12px;
  background:#ffffff; cursor:default; transition:background .15s, border-color .15s, transform .05s, box-shadow .15s;
  user-select:none; box-shadow: var(--shadow-sm);
}
.phrases-list .row:hover{border-color:#d7dbe5; box-shadow: var(--shadow-md)}
.phrases-list .row.hidden{display:none}

/* Автовыделение строк, содержащих минус-слово */
.row.selected-line{
  background:#fff5f5;
  border-color:#fecaca;
}

/* Ручное выделение пользователем */
.row.selected-manual{
  outline:2px dashed var(--warn);
  outline-offset:2px;
}

/* ====== Слова внутри фразы ====== */
.words{display:flex; flex-wrap:wrap; gap:6px}
.word{
  padding:2px 6px; border-radius:8px; border:1px solid transparent;
  background:#f3f6ff; color:#0f172a; font-weight:500;
  transition:transform .05s, background .15s, border-color .15s;
}
.word:hover{background:#eaf0ff; border-color:#dbe4ff}
.word.selected{
  background:#e0ecff;
  border-color:#bfd7ff;
}

/* ====== Правая колонка ====== */
.right-block{
  border:1px solid var(--border); border-radius:16px; padding:12px;
  background:#ffffff; margin-bottom:12px; box-shadow: var(--shadow-sm);
}
.right-block h2{margin:4px 0 12px; font-size:16px; color:var(--muted)}

/* Чипы минус-слов */
.chips{display:flex; flex-wrap:wrap; gap:8px}
.chip{
  display:inline-flex; align-items:center; gap:6px;
  background:var(--chip); border:1px solid #e0e7ff; border-radius:999px;
  padding:6px 10px; font-weight:600; color:#1e293b;
}
.chip button{
  background:transparent; border:none; color:#64748b; cursor:pointer; padding:0 2px;
}
.chip button:hover{color:#0f172a}

/* История */
.history{margin:0; padding-left:20px; color:var(--muted)}
.history li{margin:2px 0}

/* ====== Подвал ====== */
.app-footer{
  padding:16px; text-align:center; color:var(--muted);
}

/* ====== Ссылки/фокусы (доступность) ====== */
:focus-visible{
  outline: 3px solid rgba(59,130,246,.5);
  outline-offset: 2px;
  border-radius: 8px;
}
