/* Convicta Mini App — палитра из брендового лого:
   кремовый #F2ECDC · тёмно-синий #1E2A4A · оранжевый #E0822B.
   Темы: light/dark по Telegram colorScheme (data-theme на <html>). */

:root {
  --bg: #F2ECDC;
  --card: #FBF7EC;
  --ink: #1E2A4A;
  --muted: #6A7088;
  --accent: #E0822B;
  --accent-ink: #FFFFFF;
  --line: #D9D2BE;
  --logo-ink: #1E2A4A;
  --logo-accent: #E0822B;
}
[data-theme="dark"] {
  --bg: #141A2E;
  --card: #1E2A4A;
  --ink: #F2ECDC;
  --muted: #9AA3BD;
  --accent: #E0822B;
  --accent-ink: #141A2E;
  --line: #2C3A5E;
  --logo-ink: #F2ECDC;
  --logo-accent: #E0822B;
}

* { box-sizing: border-box; }
html, body {
  margin: 0; padding: 0;
  background: var(--bg); color: var(--ink);
  font: 16px/1.45 -apple-system, "SF Pro Text", Roboto, "Segoe UI", sans-serif;
}

.topbar {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 16px 8px;
}
.topback {
  width: 36px; height: 36px; border-radius: 12px; flex: none;
  border: 1.5px solid var(--line); background: var(--card);
  color: var(--ink); font-size: 18px; cursor: pointer; line-height: 1;
}
.topback.hidden { display: none; }
/* RTL-языки (fa/ar): направление текста по контенту */
h1.title, p.hint, .info, .opt .lb, .toggle-row .lb, .ta-label,
textarea.ta { unicode-bidi: plaintext; }
.logo { width: 34px; height: 34px; }
.brand { font-weight: 700; letter-spacing: .04em; font-size: 18px; }
.progress { margin-left: auto; font-size: 12.5px; color: var(--muted); text-align: right; }

.screen { padding: 4px 16px 96px; max-width: 560px; margin: 0 auto; }

h1.title { font-size: 21px; margin: 10px 0 4px; }
p.hint { margin: 0 0 14px; color: var(--muted); font-size: 14.5px; }

.info {
  background: var(--card); border: 1px solid var(--line);
  border-radius: 14px; padding: 14px 16px; margin: 10px 0;
  white-space: pre-wrap; font-size: 15px;
}

.options { display: flex; flex-direction: column; gap: 8px; margin: 10px 0; }
.opt {
  display: flex; align-items: center; gap: 10px;
  background: var(--card); border: 1.5px solid var(--line);
  border-radius: 14px; padding: 12px 14px; cursor: pointer;
  user-select: none; transition: border-color .12s, background .12s;
}
.opt .ic { width: 24px; text-align: center; }
.opt .lb { flex: 1; }
.opt .desc { display: block; font-size: 13px; color: var(--muted); }
.opt .mark {
  width: 22px; height: 22px; border-radius: 7px;
  border: 2px solid var(--line); display: inline-flex;
  align-items: center; justify-content: center;
  font-size: 14px; color: var(--accent-ink); flex: none;
}
.opt.sel { border-color: var(--accent); }
.opt.sel .mark { background: var(--accent); border-color: var(--accent); }
.opt.disabled { opacity: .45; cursor: default; }
.opt .tag {
  font-size: 11px; padding: 2px 8px; border-radius: 999px;
  background: var(--line); color: var(--ink);
}

.toggle-row {
  display: flex; align-items: center; gap: 12px;
  background: var(--card); border: 1.5px solid var(--line);
  border-radius: 14px; padding: 14px 16px; margin: 10px 0; cursor: pointer;
}
.toggle-row .lb { flex: 1; }
.toggle-row .desc { display: block; font-size: 13px; color: var(--muted); }
.switch {
  width: 50px; height: 30px; border-radius: 999px; flex: none;
  background: var(--line); position: relative; transition: background .15s;
}
.switch::after {
  content: ""; position: absolute; top: 3px; left: 3px;
  width: 24px; height: 24px; border-radius: 50%;
  background: #fff; transition: left .15s;
  box-shadow: 0 1px 3px rgba(0,0,0,.25);
}
.toggle-row.on .switch { background: var(--accent); }
.toggle-row.on .switch::after { left: 23px; }

.fallback-nav {
  position: fixed; bottom: 0; left: 0; right: 0;
  display: flex; gap: 10px; padding: 12px 16px calc(12px + env(safe-area-inset-bottom));
  background: var(--bg); border-top: 1px solid var(--line);
}
.fallback-nav.hidden { display: none; }
.btn {
  flex: 1; border: none; border-radius: 12px; padding: 13px;
  font-size: 16px; font-weight: 600; cursor: pointer;
}
.btn.primary { background: var(--accent); color: var(--accent-ink); }
.btn.ghost { background: transparent; color: var(--muted); border: 1.5px solid var(--line); }
.btn:disabled { opacity: .5; }

/* 👁 вложенность группы: кнопка + панель участников с галочками */
.opt .peek {
  width: 34px; height: 34px; border-radius: 10px; flex: none;
  display: inline-flex; align-items: center; justify-content: center;
  border: 1.5px solid var(--line); background: transparent;
  font-size: 16px; cursor: pointer;
}
.members {
  margin: 4px 0 6px 14px; padding: 8px 10px;
  border-left: 2px solid var(--line); border-radius: 0 10px 10px 0;
  background: color-mix(in srgb, var(--card) 60%, transparent);
}
.members.hidden { display: none; }
.members-title { font-size: 12.5px; color: var(--muted); margin: 2px 0 8px; }
.member {
  display: flex; align-items: center; gap: 10px;
  padding: 7px 6px; cursor: pointer; border-radius: 8px;
  opacity: .45;
}
.member.on { opacity: 1; }
.member .mark {
  width: 18px; height: 18px; border-radius: 6px; flex: none;
  border: 2px solid var(--line);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 11px; color: var(--accent-ink);
}
.member.on .mark { background: var(--accent); border-color: var(--accent); }
.member .lb { font-size: 14px; }
.member .desc { display: block; font-size: 12px; color: var(--muted); }
.member .stbtn, .opt .gstbtn {
  width: 30px; height: 30px; border-radius: 9px; flex: none;
  display: inline-flex; align-items: center; justify-content: center;
  border: 1.5px solid var(--line); font-size: 13px; cursor: pointer;
  opacity: 1;
}
.stform { margin: 2px 0 8px 30px; }
.stform.hidden { display: none; }
.stform textarea.ta { min-height: 38px; margin-bottom: 4px; }

.segment { display: flex; gap: 8px; margin: 4px 0 10px; }
.segbtn {
  flex: 1; padding: 11px; border-radius: 12px; font-size: 14px;
  border: 1.5px solid var(--line); background: var(--card);
  color: var(--ink); cursor: pointer;
}
.segbtn.on { border-color: var(--accent); background: var(--accent);
             color: var(--accent-ink); font-weight: 600; }

.bulkbar { display: flex; gap: 8px; margin: 4px 0 8px; }
.bulkbar .mini {
  padding: 7px 12px; border-radius: 10px; font-size: 13px;
  border: 1.5px solid var(--line); background: var(--card);
  color: var(--ink); cursor: pointer;
}

.ta-label { margin: 12px 0 6px; font-weight: 600; font-size: 15px; }
textarea.ta {
  width: 100%; min-height: 76px; resize: vertical;
  background: var(--card); color: var(--ink);
  border: 1.5px solid var(--line); border-radius: 14px;
  padding: 12px 14px; font: inherit; font-size: 15px;
}
textarea.ta:focus { outline: none; border-color: var(--accent); }
.btn.block { display: block; width: 100%; margin: 14px 0 6px; }

.err { color: #C0392B; font-size: 14px; margin: 8px 0; }
.center { text-align: center; }
.done-logo { width: 84px; height: 84px; margin: 24px auto 6px; display: block; }

/* 🔎 глобальный поиск (ТЗ UX §1, 25/ 10.06) */
.searchbox { margin: 4px 0 10px; }
.search-inp {
  width: 100%; background: var(--card); color: var(--ink);
  border: 1.5px solid var(--line); border-radius: 14px;
  padding: 12px 14px; font: inherit; font-size: 15px;
}
.search-inp:focus { outline: none; border-color: var(--accent); }
.search-res { max-height: 46vh; overflow-y: auto; margin-top: 8px; }
.search-res .opt { margin-bottom: 6px; }
.search-row .desc { display: block; font-size: 12px; color: var(--muted); }

/* 55+60/ 11.06: ⚙️ Конфигурация — крупные секции, компактные nested-опции */
.section {
  font-weight: 800; font-size: 17.5px; margin: 24px 2px 8px;
  padding-bottom: 5px; border-bottom: 2px solid var(--line);
}
.toggle-row.nested, .segment.nested, .ta-label.nested {
  margin-left: 12px; border-left: 3px solid var(--line); padding-left: 12px;
}
.toggle-row.nested { padding-top: 11px; padding-bottom: 11px; margin: 6px 0 6px 12px; }
.toggle-row.nested .lb { font-size: 14.5px; }
/* 60/ 🏷 слова категории: компактная кнопка + низкие поля */
.btn.wordsbtn {
  display: inline-block; width: auto; padding: 9px 14px;
  font-size: 14px; margin: 6px 0 4px;
}
.btn.wordsbtn.nested { margin-left: 12px; }
.ta-label.small { margin: 8px 0 4px; font-size: 13.5px; }
textarea.ta.small { min-height: 40px; padding: 9px 12px; font-size: 14px; }
div.nested { margin-left: 12px; border-left: 3px solid var(--line); padding-left: 12px; }

/* 66/ 12.06: версия сборки внизу каждой страницы */
.buildtag { margin: 28px auto 10px; text-align: center;
  font-size: 10px; line-height: 1.6; color: #888; opacity: .4; }

/* 67/ 12.06: шаги мастера категорий в стиле ⚙️ Конфигурации */
.screen.wizard h1.title {
  font-weight: 800; font-size: 17.5px; margin: 18px 2px 8px;
  padding-bottom: 5px; border-bottom: 2px solid var(--line);
}
.screen.wizard p.hint, .screen.wizard .options, .screen.wizard .bulkbar,
.screen.wizard .toggle-row, .screen.wizard .segment, .screen.wizard .ta-label,
.screen.wizard textarea.ta, .screen.wizard .info {
  margin-left: 12px; border-left: 3px solid var(--line); padding-left: 12px;
}
.screen.wizard .toggle-row { padding-top: 11px; padding-bottom: 11px; }

/* 68/ 12.06: разделители источников по фокусу внутри шага */
.optsec {
  font-weight: 700; font-size: 13.5px; color: var(--muted);
  margin: 12px 2px 0; padding-bottom: 3px;
  border-bottom: 1px solid var(--line);
}
.optsec:first-child { margin-top: 2px; }
