/* ---------------- theme tokens ---------------- */
:root {
  color-scheme: light;
  --bg: #ffffff;
  --fg: #222;
  --fg-dim: #555;
  --fg-const: #555;
  --surface-1: #f5f5f5;
  --surface-2: #eee;
  --surface-3: #ddd;           /* th hover */
  --zebra: #fafafa;
  --border: #ddd;
  --border-strong: #ccc;
  --accent: #36f;              /* focus / sort arrow */
  --hover-row: #fff8c0;
  --pending: #c00;
  --orphan: #888;
  --input-bg: #fff;

  --banner-bg: #ffe6e6;
  --banner-fg: #900;
  --banner-border: #c22;

  --btn-bg: #fff;
  --btn-hover-bg: #eaeaea;
  --btn-border: #888;
  --btn-danger-bg: #ffd9d9;

  --deepl-bg: #eef4ff;
  --deepl-hover-bg: #d9e6ff;
  --deepl-border: #69c;
  --deepl-fg: #036;

  --add-bg: #e6f5ea;
  --add-hover-bg: #cfeed7;
  --add-border: #396;
  --add-fg: #062;

  --td1-bg: #eef4ff;  --td1-border: #69c;
  --td2-bg: #fff4dc;  --td2-border: #c96;

  --pre-bg: #111;
  --pre-fg: #dfe;
  --pre-err-fg: #fdd;

  --toast-bg: #333;
  --toast-fg: #fff;
  --toast-err-bg: #a00;
}

[data-theme="dark"] {
  color-scheme: dark;
  --bg: #1a1a1a;
  --fg: #e1e1e1;
  --fg-dim: #9a9a9a;
  --fg-const: #c0b090;
  --surface-1: #232323;
  --surface-2: #2e2e2e;
  --surface-3: #3a3a3a;
  --zebra: #1f1f1f;
  --border: #3a3a3a;
  --border-strong: #444;
  --accent: #6ae;
  --hover-row: #3a3a20;
  --pending: #ff8b8b;
  --orphan: #999;
  --input-bg: #2a2a2a;

  --banner-bg: #3a1a1a;
  --banner-fg: #ff9a9a;
  --banner-border: #c55;

  --btn-bg: #2a2a2a;
  --btn-hover-bg: #353535;
  --btn-border: #555;
  --btn-danger-bg: #4a1818;

  --deepl-bg: #13243a;
  --deepl-hover-bg: #1e3557;
  --deepl-border: #4a8;
  --deepl-fg: #9cd0ff;

  --add-bg: #143020;
  --add-hover-bg: #1c4030;
  --add-border: #4a8;
  --add-fg: #9fe0b8;

  --td1-bg: #15243a;  --td1-border: #4a7;
  --td2-bg: #3a2a12;  --td2-border: #c96;

  --pre-bg: #0d0d0d;
  --pre-fg: #dfe;
  --pre-err-fg: #fdd;

  --toast-bg: #444;
  --toast-fg: #fff;
  --toast-err-bg: #c00;
}

/* ---------------- base ---------------- */
* { box-sizing: border-box; }
html, body {
  margin: 0; padding: 0;
  font-family: -apple-system, system-ui, sans-serif;
  font-size: 15px; font-weight: 700;
  background: var(--bg); color: var(--fg);
}

header {
  position: sticky; top: 0; z-index: 10;
  background: var(--surface-1); border-bottom: 1px solid var(--border-strong);
  padding: 6px 16px; display: flex; flex-direction: column; gap: 4px;
}
header h1 { font-size: 18px; margin: 0 4px 0 0; }
.controls { display: flex; flex-wrap: wrap; align-items: center; gap: 12px; }
.controls label { display: flex; align-items: center; gap: 4px; }
.controls select, .controls input {
  font-size: 15px; font-weight: 700; padding: 2px 4px;
  background: var(--input-bg); color: var(--fg); border: 1px solid var(--border-strong); border-radius: 3px;
}

.stats { display: flex; flex-wrap: wrap; align-items: center; gap: 18px; color: var(--fg-dim); font-variant-numeric: tabular-nums; }
.stats > span { white-space: nowrap; }
.search-group { display: flex; gap: 6px; margin-left: auto; }
.search-group input { font-size: 15px; font-weight: 700; padding: 2px 6px; width: 600px; max-width: 60vw; }
.search-group select { font-size: 15px; font-weight: 700; padding: 2px 4px; }

main { padding: 0 16px 60px; }

/* ---------------- table ---------------- */
table { width: 100%; border-collapse: collapse; margin-top: 8px; table-layout: fixed; }
th, td { border: 1px solid var(--border); padding: 4px 6px; vertical-align: top; text-align: left; }
th { background: var(--surface-2); position: sticky; top: 108px; z-index: 5; font-weight: 700; white-space: nowrap; }
th[data-sort]          { cursor: pointer; user-select: none; }
th[data-sort]:hover    { background: var(--surface-3); }
th[data-dir="asc"]::after  { content: " ▲"; color: var(--accent); }
th[data-dir="desc"]::after { content: " ▼"; color: var(--accent); }
tbody tr:nth-child(even) { background: var(--zebra); }
tbody tr:hover { background: var(--hover-row); }

.c-id    { width: 60px;  text-align: right; font-variant-numeric: tabular-nums; color: var(--fg-dim); }
.c-mark  { width: 24px;  text-align: center; }
.c-const { width: 220px; overflow-wrap: anywhere; }
td.c-const .cell-const {
  font-family: ui-monospace, Menlo, monospace;
  font-size: 13px; font-weight: 600; color: var(--fg-const);
}

/* `original` lookup keys are stored UPPERCASE in the DB. Visual hint
   in the add-decode dialog; the actual `.value` is left as typed so
   the AI-suggest path receives natural case. Server normalizes on
   submit. */
#add-decode-original { text-transform: uppercase; }

/* inline textareas — always visible, native editing */
td .cell-ta {
  width: 100%; font: inherit; color: var(--fg);
  padding: 2px 4px; border: 1px solid transparent; background: transparent;
  resize: vertical; min-height: 2.4em; field-sizing: content;
  white-space: pre-wrap; overflow-wrap: anywhere;
}
td .cell-ta:hover  { border-color: var(--border-strong); background: var(--input-bg); }
td .cell-ta:focus  { border-color: var(--accent); background: var(--input-bg); outline: none; }
td .cell-ta.pending { color: var(--pending); }
/* noop: model said "untranslatable" (done_state=1). Muted + non-bold so
   these are visible but don't draw the eye the way pending does. */
td .cell-ta.noop    { color: var(--muted, #888); font-weight: 300; }
td .cell-ta.orphan  { font-style: italic; }
td.c-en .cell-ta    { font-weight: 500; }

/* Cyrillic-rejection highlight (EN cells, non-Russian translation cells,
   and Add EN modal textarea). Red border + tinted background. */
.cyr-error,
td .cell-ta.cyr-error,
#dlg-add-text.cyr-error { border-color: #d33 !important; background: rgba(221,51,51,0.08) !important; }

/* DeepL button */
.trans-wrap { display: flex; flex-direction: column; gap: 2px; }
button.deepl-btn {
  align-self: flex-start;
  padding: 1px 8px; font-size: 12px; font-weight: 700; line-height: 1.4;
  border: 1px solid var(--deepl-border); border-radius: 3px;
  background: var(--deepl-bg); color: var(--deepl-fg); cursor: pointer;
}
button.deepl-btn:hover     { background: var(--deepl-hover-bg); }
button.deepl-btn:disabled  { opacity: 0.4; cursor: wait; }

/* orphan flag on en cell */
td.c-en.orphan::before { content: "⚑ "; color: var(--orphan); }

.mark-cb { transform: scale(0.9); }

/* Add EN button */
button.add-btn {
  padding: 4px 12px; font-size: 14px; font-weight: 700;
  border: 1px solid var(--add-border); border-radius: 3px;
  background: var(--add-bg); color: var(--add-fg); cursor: pointer;
}
button.add-btn:hover:not(:disabled) { background: var(--add-hover-bg); }
button.add-btn:disabled {
  opacity: 0.45; cursor: not-allowed;
  background: var(--surface-2); color: var(--fg-dim); border-color: var(--border-strong);
}
/* Pulse the save button while it has pending edits so a new user sees it. */
button#save-btn:not(:disabled) {
  animation: pulse-save 1.6s ease-in-out infinite;
}
@keyframes pulse-save {
  0%, 100% { box-shadow: 0 0 0 0 rgba(70, 170, 90, 0.0); }
  50%      { box-shadow: 0 0 0 5px rgba(70, 170, 90, 0.35); }
}

/* theme toggle */
button.theme-toggle {
  padding: 2px 8px; font-size: 14px; line-height: 1;
  border: 1px solid var(--btn-border); border-radius: 3px;
  background: var(--btn-bg); color: var(--fg); cursor: pointer;
}
button.theme-toggle:hover { background: var(--btn-hover-bg); }

/* Service page link + locked banner */
a.svc-btn {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 4px 12px; font-size: 14px; font-weight: 700;
  border: 1px solid var(--btn-border); border-radius: 3px;
  background: var(--btn-bg); color: var(--fg); text-decoration: none; cursor: pointer;
}
a.svc-btn:hover { background: var(--btn-hover-bg); }
a.svc-btn.back  { background: var(--surface-1); }
.locked-banner {
  margin: 4px 0 0; padding: 6px 12px; font-weight: 700; font-size: 14px;
  background: var(--banner-bg); color: var(--banner-fg); border: 1px solid var(--banner-border); border-radius: 3px;
}

/* Service page */
body.service-body main.service-main { padding: 20px 28px 40px; max-width: 960px; }
.svc-actions { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 14px; }
.svc-actions button {
  padding: 6px 16px; font-size: 14px; font-weight: 700;
  border: 1px solid var(--btn-border); border-radius: 3px;
  background: var(--btn-bg); color: var(--fg); cursor: pointer;
}
.svc-actions button:hover   { background: var(--btn-hover-bg); }
.svc-actions button.danger  { border-color: var(--banner-border); color: var(--banner-fg); }
.svc-actions button.danger:hover { background: var(--btn-danger-bg); }
.svc-actions button:disabled { opacity: 0.5; cursor: wait; }
.svc-actions button .hint { font-weight: 500; color: var(--fg-dim); }
.lock-indicator { padding: 3px 10px; border-radius: 3px; background: var(--surface-2); color: var(--fg-dim); font-weight: 700; }
.lock-indicator.on { background: var(--banner-bg); color: var(--banner-fg); border: 1px solid var(--banner-border); }
#svc-out {
  margin: 0; padding: 12px;
  background: var(--pre-bg); color: var(--pre-fg);
  font-family: ui-monospace, Menlo, monospace; font-size: 12px; font-weight: 500;
  white-space: pre-wrap; word-break: break-word;
  border-radius: 3px; min-height: 200px; max-height: 60vh; overflow: auto;
}
#svc-out.has-err { color: var(--pre-err-fg); }
.service-main h3 { font-size: 14px; margin: 16px 0 6px; color: var(--fg-dim); }

/* Login page */
body.login-body { background: var(--surface-1); }
main.login-main {
  min-height: 100vh; display: flex; align-items: center; justify-content: center;
}
#login-form {
  width: 360px; max-width: 92vw;
  background: var(--bg); color: var(--fg);
  border: 1px solid var(--border-strong); border-radius: 6px;
  padding: 24px 28px; display: flex; flex-direction: column; gap: 14px;
}
#login-form h1 { margin: 0 0 4px; font-size: 20px; }
#login-form label { display: flex; flex-direction: column; gap: 4px; font-weight: 700; font-size: 13px; color: var(--fg-dim); }
#login-form input {
  font: inherit; font-weight: 700; color: var(--fg);
  padding: 6px 10px; background: var(--input-bg);
  border: 1px solid var(--border-strong); border-radius: 3px;
}
#login-form button {
  margin-top: 4px; padding: 8px 14px; font-size: 15px; font-weight: 700;
  border: 1px solid var(--add-border); border-radius: 3px;
  background: var(--add-bg); color: var(--add-fg); cursor: pointer;
}
#login-form button:hover { background: var(--add-hover-bg); }
.login-err {
  padding: 8px 12px; border-radius: 3px;
  background: var(--banner-bg); color: var(--banner-fg);
  border: 1px solid var(--banner-border); font-weight: 700; font-size: 13px;
}

/* Who-am-I + logout widget on main page header */
.user-box { display: inline-flex; align-items: center; gap: 6px; color: var(--fg-dim); font-weight: 700; }
.user-box .email { color: var(--fg); }
button.logout-btn {
  padding: 3px 10px; font-size: 13px; font-weight: 700;
  border: 1px solid var(--btn-border); border-radius: 3px;
  background: var(--btn-bg); color: var(--fg); cursor: pointer;
}
button.logout-btn:hover { background: var(--btn-hover-bg); }

/* Prompts/glossary edit pages */
body.edit-body main.edit-main { padding: 0; height: calc(100vh - 80px); }
body.edit-body #text {
  width: 100%; height: 100%;
  font: 13px/1.5 ui-monospace, Menlo, monospace; font-weight: 500;
  padding: 12px 16px;
  background: var(--bg); color: var(--fg);
  border: none; outline: none; resize: none;
  white-space: pre-wrap;
}
.status-tag { padding: 2px 8px; border-radius: 3px; font-size: 12px; font-weight: 700; }
.status-tag.ok      { background: var(--add-bg); color: var(--add-fg); border: 1px solid var(--add-border); }
.status-tag.missing { background: var(--banner-bg); color: var(--banner-fg); border: 1px solid var(--banner-border); }

/* Glossary add dialog (reuses add-decode styling where possible) */
#dlg-add label { display: flex; flex-direction: column; gap: 4px; font-weight: 700; font-size: 13px; color: var(--fg-dim); margin-bottom: 8px; }
#dlg-add label input { font: inherit; font-weight: 700; color: var(--fg); padding: 4px 8px; background: var(--input-bg); border: 1px solid var(--border-strong); border-radius: 3px; }

/* Translate (bulk-translate) bar */
.translate-bar {
  display: flex; flex-wrap: wrap; align-items: center; gap: 10px;
  padding-top: 4px; border-top: 1px dashed var(--border);
}
.translate-bar > label { display: flex; align-items: center; gap: 6px; font-weight: 700; }
.translate-bar select { font-size: 15px; font-weight: 700; padding: 2px 6px;
  min-width: 520px; max-width: 90vw;
  background: var(--input-bg); color: var(--fg); border: 1px solid var(--border-strong); border-radius: 3px; }

/* Translate run progress dialog */
#dlg-run { border: none; border-radius: 6px; padding: 0; width: 560px; max-width: 92vw; background: var(--bg); color: var(--fg); }
#dlg-run::backdrop { background: rgba(0,0,0,0.55); }
#dlg-run form { display: flex; flex-direction: column; gap: 12px; padding: 20px; }
#dlg-run h3 { margin: 0; font-size: 15px; }
#dlg-run #run-progress { display: flex; align-items: center; gap: 12px; font-size: 14px; }
#dlg-run #run-state { flex: 1; }
#dlg-run #run-timer { color: var(--fg-dim); font-variant-numeric: tabular-nums; }
#dlg-run pre {
  margin: 0; padding: 10px; background: var(--pre-bg); color: var(--pre-fg);
  font-family: ui-monospace, Menlo, monospace; font-size: 12px; font-weight: 500;
  white-space: pre-wrap; border-radius: 3px; max-height: 55vh; overflow: auto;
}
#dlg-run pre.has-err { color: var(--pre-err-fg); }
#dlg-run .dlg-actions { display: flex; justify-content: flex-end; }
#dlg-run button { padding: 5px 14px; font-size: 14px; font-weight: 700; border-radius: 3px; border: 1px solid var(--btn-border); background: var(--btn-bg); color: var(--fg); cursor: pointer; }
#dlg-run button:disabled { opacity: 0.4; cursor: not-allowed; }

.spinner {
  width: 18px; height: 18px; flex: 0 0 auto;
  border: 2px solid var(--border-strong); border-top-color: var(--accent);
  border-radius: 50%; animation: spin .8s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* Translate-configs JSON dialog */
#dlg-translate-config { border: none; border-radius: 6px; padding: 0; width: 720px; max-width: 94vw; background: var(--bg); color: var(--fg); }
#dlg-translate-config::backdrop { background: rgba(0,0,0,0.5); }
#dlg-translate-config form { display: flex; flex-direction: column; gap: 10px; padding: 18px; }
#dlg-translate-config h3 { margin: 0; font-size: 15px; }
#dlg-translate-config p { margin: 0; color: var(--fg-dim); font-weight: 500; font-size: 13px; }
#dlg-translate-config p code { font-family: ui-monospace, Menlo, monospace; font-size: 12px; color: var(--fg); }
#dlg-translate-config textarea {
  font: 13px/1.45 ui-monospace, Menlo, monospace; padding: 8px 10px;
  background: var(--input-bg); color: var(--fg); border: 1px solid var(--border-strong); border-radius: 3px;
  resize: vertical; min-height: 320px; white-space: pre;
}
#dlg-translate-config .dlg-actions { display: flex; justify-content: flex-end; gap: 8px; }
#dlg-translate-config button { padding: 5px 14px; font-size: 14px; font-weight: 700; border-radius: 3px; border: 1px solid var(--btn-border); background: var(--btn-bg); color: var(--fg); cursor: pointer; }
#dlg-translate-config #dlg-translate-config-save { border-color: var(--add-border); background: var(--add-bg); color: var(--add-fg); }

/* Decode (конверсия) view */
.c-decode-del { width: 30px; text-align: center; }
.c-decode-del button {
  padding: 1px 6px; border: 1px solid var(--banner-border); border-radius: 3px;
  background: var(--btn-bg); color: var(--banner-fg); cursor: pointer; font-weight: 700;
}
.c-decode-del button:hover { background: var(--btn-danger-bg); }
.c-decode-id     { width: 60px; text-align: right; color: var(--fg-dim); font-variant-numeric: tabular-nums; }
.c-decode-target .target-display {
  display: flex; align-items: baseline; gap: 6px; padding: 4px 2px;
}
.c-decode-target .target-id   { color: var(--fg-dim); font-variant-numeric: tabular-nums; white-space: nowrap; }
.c-decode-target .target-en   { flex: 1; overflow-wrap: anywhere; }
.c-decode-target .pick-btn {
  padding: 1px 6px; font-size: 12px; font-weight: 700;
  border: 1px solid var(--btn-border); border-radius: 3px;
  background: var(--btn-bg); color: var(--fg); cursor: pointer;
}
.c-decode-target .pick-btn:hover { background: var(--btn-hover-bg); }
.c-decode-target .target-missing { color: var(--pending); font-style: italic; }
.c-decode-add-row td { padding: 6px; background: var(--surface-1); }
.c-decode-add-row input, .c-decode-add-row textarea {
  font: inherit; padding: 2px 4px; background: var(--input-bg); color: var(--fg);
  border: 1px solid var(--border-strong); border-radius: 3px; width: 100%;
}

/* Add-decode dialog */
#dlg-add-decode { border: none; border-radius: 6px; padding: 0; width: 560px; max-width: 92vw; background: var(--bg); color: var(--fg); }
#dlg-add-decode::backdrop { background: rgba(0,0,0,0.5); }
#dlg-add-decode form { display: flex; flex-direction: column; gap: 10px; padding: 18px; }
#dlg-add-decode h3 { margin: 0; font-size: 15px; }
#dlg-add-decode label { display: flex; flex-direction: column; gap: 4px; font-weight: 700; font-size: 13px; color: var(--fg-dim); }
#dlg-add-decode input { font: inherit; font-weight: 700; color: var(--fg); padding: 4px 8px; background: var(--input-bg); border: 1px solid var(--border-strong); border-radius: 3px; }
#dlg-add-decode .add-decode-target { display: flex; align-items: center; gap: 8px; padding: 5px 8px; background: var(--input-bg); border: 1px solid var(--border-strong); border-radius: 3px; }
#dlg-add-decode #add-decode-target-display { flex: 1; font-weight: 700; color: var(--fg); }
#dlg-add-decode #add-decode-target-display.target-missing { color: var(--pending); font-style: italic; }
#dlg-add-decode .dlg-actions { display: flex; justify-content: flex-end; gap: 8px; margin-top: 6px; }
#dlg-add-decode button { padding: 5px 14px; font-size: 14px; font-weight: 700; border-radius: 3px; border: 1px solid var(--btn-border); background: var(--btn-bg); color: var(--fg); cursor: pointer; }
#dlg-add-decode #dlg-add-decode-submit { border-color: var(--add-border); background: var(--add-bg); color: var(--add-fg); }

/* Decode bulk-import dialog */
#dlg-decode-import { border: none; border-radius: 6px; padding: 0; width: 640px; max-width: 92vw; background: var(--bg); color: var(--fg); }
#dlg-decode-import::backdrop { background: rgba(0,0,0,0.5); }
#dlg-decode-import form { display: flex; flex-direction: column; gap: 10px; padding: 18px; }
#dlg-decode-import h3 { margin: 0; font-size: 15px; }
#dlg-decode-import .dlg-hint { margin: 0; font-size: 12px; color: var(--fg-dim); }
#dlg-decode-import textarea { font: 13px/1.4 ui-monospace, Menlo, Consolas, monospace; color: var(--fg); padding: 6px 8px; background: var(--input-bg); border: 1px solid var(--border-strong); border-radius: 3px; resize: vertical; }
#dlg-decode-import .dlg-decode-import-report { font-size: 13px; }
#dlg-decode-import .report-block { padding: 6px 8px; background: var(--input-bg); border: 1px solid var(--border-strong); border-radius: 3px; margin-bottom: 6px; }
#dlg-decode-import .report-warn { border-color: var(--pending); }
#dlg-decode-import .report-block ul { margin: 4px 0 0; padding-left: 20px; }
#dlg-decode-import .dlg-actions { display: flex; justify-content: flex-end; gap: 8px; margin-top: 6px; }
#dlg-decode-import button { padding: 5px 14px; font-size: 14px; font-weight: 700; border-radius: 3px; border: 1px solid var(--btn-border); background: var(--btn-bg); color: var(--fg); cursor: pointer; }
#dlg-decode-import button:disabled { opacity: 0.5; cursor: not-allowed; }
#dlg-decode-import #dlg-decode-import-apply { border-color: var(--add-border); background: var(--add-bg); color: var(--add-fg); }

/* Picker dialog */
#dlg-picker { border: none; border-radius: 6px; padding: 0; width: 620px; max-width: 92vw; background: var(--bg); color: var(--fg); }
#dlg-picker::backdrop { background: rgba(0,0,0,0.5); }
#dlg-picker form { display: flex; flex-direction: column; gap: 10px; padding: 18px; }
#dlg-picker h3 { margin: 0; font-size: 15px; }
#dlg-picker input { font: inherit; padding: 5px 8px; background: var(--input-bg); color: var(--fg); border: 1px solid var(--border-strong); border-radius: 3px; }
#dlg-picker ul { list-style: none; margin: 0; padding: 0; max-height: 50vh; overflow: auto; border: 1px solid var(--border); border-radius: 3px; }
#dlg-picker li { padding: 6px 10px; cursor: pointer; border-bottom: 1px solid var(--border); display: flex; gap: 8px; }
#dlg-picker li:last-child { border-bottom: none; }
#dlg-picker li:hover { background: var(--hover-row); }
#dlg-picker li .id { color: var(--fg-dim); font-variant-numeric: tabular-nums; min-width: 80px; text-align: right; }
#dlg-picker li .en { flex: 1; }
#dlg-picker li .sim { color: var(--fg-dim); font-variant-numeric: tabular-nums; min-width: 60px; text-align: right; font-size: 12px; }
#dlg-picker li.picked { background: var(--hover-row); outline: 2px solid var(--add-border); outline-offset: -2px; }
#dlg-picker .dlg-actions { display: flex; justify-content: flex-end; }
#dlg-picker button { padding: 5px 14px; font-size: 14px; font-weight: 700; border-radius: 3px; border: 1px solid var(--btn-border); background: var(--btn-bg); color: var(--fg); cursor: pointer; }
#dlg-picker .picker-search-row { display: flex; gap: 8px; align-items: stretch; }
#dlg-picker .picker-search-row input { flex: 1; }
#dlg-picker .picker-suggest-btn { padding: 5px 10px; }
#dlg-picker .picker-suggest-btn:disabled { opacity: 0.4; cursor: not-allowed; }
#dlg-picker .picker-suggest-status { font-size: 12px; color: var(--fg-dim); }
#dlg-picker .picker-suggest-banner { border: 1px solid var(--add-border); background: var(--add-bg); color: var(--add-fg); border-radius: 3px; padding: 10px 12px; display: flex; flex-direction: column; gap: 6px; }
#dlg-picker .picker-suggest-banner .banner-head { font-size: 12px; opacity: 0.8; }
#dlg-picker .picker-suggest-banner .banner-en { font-weight: 700; font-size: 14px; }
#dlg-picker .picker-suggest-banner .banner-reason { font-size: 12px; opacity: 0.85; }
#dlg-picker .picker-suggest-banner .banner-actions { display: flex; gap: 8px; justify-content: flex-end; }

/* Add-rows dialog */
#dlg-add { border: none; border-radius: 6px; padding: 0; width: 600px; max-width: 90vw; background: var(--bg); color: var(--fg); }
#dlg-add::backdrop { background: rgba(0,0,0,0.5); }
#dlg-add form { display: flex; flex-direction: column; gap: 12px; padding: 20px; }
#dlg-add h3 { margin: 0; font-size: 16px; }
#dlg-add p { margin: 0; color: var(--fg-dim); font-weight: 500; }
#dlg-add textarea {
  font: inherit; padding: 6px 8px;
  background: var(--input-bg); color: var(--fg);
  border: 1px solid var(--border-strong); border-radius: 3px;
  resize: vertical; min-height: 160px;
}
#dlg-add .dlg-actions { display: flex; justify-content: flex-end; gap: 8px; }
#dlg-add button {
  padding: 5px 14px; font-size: 14px; font-weight: 700; border-radius: 3px;
  border: 1px solid var(--btn-border); background: var(--btn-bg); color: var(--fg); cursor: pointer;
}
#dlg-add #dlg-add-submit { border-color: var(--add-border); background: var(--add-bg); color: var(--add-fg); }

/* footer pager */
#pager {
  position: fixed; bottom: 0; left: 0; right: 0;
  background: var(--surface-1); border-top: 1px solid var(--border-strong);
  padding: 6px 16px; display: flex; align-items: center; gap: 10px;
}
#pager button {
  padding: 4px 10px;
  background: var(--btn-bg); color: var(--fg); border: 1px solid var(--btn-border); border-radius: 3px;
}
#pager button:hover    { background: var(--btn-hover-bg); }
#pager button:disabled { opacity: 0.4; cursor: not-allowed; }
.page-jump { font-variant-numeric: tabular-nums; display: flex; align-items: center; gap: 6px; }
.page-jump input { width: 70px; font-size: 13px; padding: 2px 4px; text-align: right; }

#status {
  position: fixed; bottom: 50px; right: 16px;
  padding: 6px 12px; border-radius: 4px;
  background: var(--toast-bg); color: var(--toast-fg);
  font-size: 12px; opacity: 0; transition: opacity .2s;
  pointer-events: none;
}
#status.show  { opacity: 1; }
#status.error { background: var(--toast-err-bg); }
