:root {
  --bg: #0f1226; --bg2: #1b2048; --panel: #171a35; --fg: #eef0ff; --muted: #9aa0c7;
  --accent: #6c7bff; --ok: #3ddc84; --err: #ff5c7a; --line: #2a2f55;
}
* { box-sizing: border-box; }
body {
  margin: 0; font-family: -apple-system, "Segoe UI", Roboto, sans-serif;
  background: var(--bg); color: var(--fg); min-height: 100vh; min-height: 100dvh;
}
header {
  display: flex; align-items: center; justify-content: center; gap: 14px;
  padding: 16px 24px; border-bottom: 1px solid var(--line);
}
header h1 { font-size: 20px; margin: 0; display: flex; align-items: center; gap: 10px; }
.brand-logo { width: 92px; height: auto; object-fit: contain; }
.brand-abbr { color: var(--muted); font-weight: 400; font-size: 16px; }
.badge { font-size: 13px; padding: 4px 10px; border-radius: 999px; background: var(--panel); color: var(--muted); }
.badge.ok { color: var(--ok); } .badge.err { color: var(--err); }

.tabs { display: flex; flex-wrap: wrap; justify-content: center; gap: 6px; padding: 12px 24px; border-bottom: 1px solid var(--line); }
.tab {
  background: var(--panel); color: var(--muted); border: 1px solid var(--line);
  border-radius: 8px; padding: 8px 14px; cursor: pointer; font-size: 14px;
}
.tab.active { color: var(--fg); border-color: var(--accent); background: #232853; }

main { padding: 24px; max-width: 900px; margin: 0 auto; }
.panel { display: none; }
.panel.active { display: block; }
h2 { font-size: 17px; margin: 0 0 16px; }

.row { display: flex; flex-wrap: wrap; align-items: center; gap: 12px; margin: 12px 0; }
label { font-size: 14px; color: var(--muted); display: flex; align-items: center; gap: 6px; }
select, textarea, input {
  background: var(--bg); color: var(--fg); border: 1px solid var(--line);
  border-radius: 8px; padding: 8px 10px; font-size: 14px; font-family: inherit;
  max-width: 100%; min-width: 0;
}
textarea { width: 100%; min-height: 70px; resize: vertical; }
.btn {
  background: linear-gradient(160deg, var(--accent), #4a59e0); color: #fff;
  border: none; border-radius: 8px; padding: 9px 16px; cursor: pointer; font-size: 14px; font-weight: 600;
  max-width: 100%; white-space: normal;
}
.btn:active { transform: scale(.97); }
.btn.rec { background: linear-gradient(160deg, var(--err), #d23a59); }

.result { background: var(--panel); border: 1px solid var(--line); border-radius: 10px;
  padding: 16px; font-size: 18px; min-height: 30px; margin-top: 10px; word-break: break-word; }
.muted { color: var(--muted); font-size: 13px; }
audio { width: 100%; margin-top: 12px; }

.grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 12px; }
.stat { background: var(--panel); border: 1px solid var(--line); border-radius: 10px; padding: 14px; }
.stat .num { font-size: 24px; font-weight: 700; }
.stat .lbl { font-size: 12px; color: var(--muted); margin-top: 4px; }

.list { background: var(--panel); border: 1px solid var(--line); border-radius: 10px; padding: 8px 0; max-height: 60vh; overflow: auto; }
.list .item { padding: 8px 16px; border-bottom: 1px solid var(--line); font-size: 14px; }
.list .item:last-child { border: none; }
.list .en { color: var(--fg); } .list .ru { color: var(--muted); }

.card { background: var(--panel); border: 1px solid var(--line); border-radius: 12px; padding: 20px; overflow-wrap: break-word; }
.tagline { display: flex; gap: 8px; margin-bottom: 12px; }
.chip { font-size: 12px; padding: 3px 9px; border-radius: 999px; background: #232853; color: var(--accent); }
.exprompt { font-size: 15px; color: var(--muted); margin-bottom: 8px; }
.exshow { font-size: 22px; font-weight: 600; margin-bottom: 14px; }
.opt { display: block; width: 100%; text-align: left; margin: 6px 0; background: var(--bg);
  border: 1px solid var(--line); color: var(--fg); border-radius: 8px; padding: 10px; cursor: pointer; }
.opt.correct { border-color: var(--ok); color: var(--ok); }
.opt.wrong { border-color: var(--err); color: var(--err); }
.feedback { margin-top: 12px; font-weight: 600; }
.feedback.ok { color: var(--ok); } .feedback.err { color: var(--err); }

/* подсказка в упражнении */
.hint-wrap { margin: 8px 0 12px; }
.hint-btn { background: none; border: 1px solid var(--line); color: var(--muted);
  border-radius: 8px; padding: 6px 12px; cursor: pointer; font-size: 13px; }
.hint-btn:hover { color: var(--accent); border-color: var(--accent); }
.hint-body { margin-top: 8px; color: var(--ok); font-size: 14px; }
.hint-words { color: var(--ok); font-size: 16px; font-weight: 600; }
.ans-count { font-size: 13px; color: var(--muted); margin-bottom: 8px; }

/* «Собери предложение» — слова-кнопки */
.wb-bank { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 12px; }
.wbuild { background: var(--bg); border: 1px solid var(--line); border-radius: 8px;
  padding: 8px 14px; cursor: pointer; font-size: 16px; user-select: none; }
.wbuild:hover { border-color: var(--accent); color: var(--accent); }
.wbuild.used { text-decoration: line-through; color: var(--muted); opacity: .5; cursor: default; }
.wb-input { width: 100%; }

/* плавающий ИИ-ассистент (глобальный) */
.ai-fab { position: fixed; right: 20px; bottom: 20px; z-index: 4000;
  width: 56px; height: 56px; border-radius: 50%; border: none; cursor: pointer;
  background: linear-gradient(160deg, var(--accent), #4a59e0); color: #fff; font-size: 26px;
  box-shadow: 0 8px 24px rgba(0,0,0,.45); }
.ai-fab:active { transform: scale(.95); }
.ai-panel { position: fixed; right: 20px; bottom: 88px; z-index: 4000;
  width: min(420px, calc(100vw - 40px)); background: var(--panel);
  border: 1px solid var(--accent); border-radius: 14px; padding: 14px;
  box-shadow: 0 16px 44px rgba(0,0,0,.55); display: flex; flex-direction: column; gap: 10px;
  max-height: calc(100vh - 110px); max-height: calc(100dvh - 110px); overflow: auto; }
.ai-head { display: flex; align-items: center; justify-content: space-between; font-size: 14px; }
.ai-head .btn { padding: 4px 12px; }
.ai-panel .chat { min-height: 200px; max-height: 50vh; margin-bottom: 0; }

/* кликабельные слова + всплывающий перевод */
.interactive .w { cursor: pointer; border-bottom: 1px dotted transparent; }
.interactive .w:hover { border-bottom-color: var(--accent); color: var(--accent); }
.interactive .w.hl { background: var(--accent); color: #11132b; border-radius: 4px; padding: 0 3px; }

/* Крупные иероглифы: для китайского/японского текст НА ИЗУЧАЕМОМ языке показываем
   большим (data-learn ставится в dashboard.js при выборе языка обучения). Русские
   подсказки/промпты (.exprompt, .muted, .hint-*) не трогаем — они остаются мелкими. */
html[data-learn="chinese"] .exshow,
html[data-learn="japanese"] .exshow { font-size: 40px; line-height: 1.4; }
html[data-learn="chinese"] .opt,
html[data-learn="japanese"] .opt { font-size: 26px; }
html[data-learn="chinese"] .wbuild,
html[data-learn="japanese"] .wbuild { font-size: 28px; padding: 10px 18px; }
html[data-learn="chinese"] .list .en,
html[data-learn="japanese"] .list .en { font-size: 30px; }
html[data-learn="chinese"] .en.interactive,
html[data-learn="japanese"] .en.interactive,
html[data-learn="chinese"] .exprompt.interactive,
html[data-learn="japanese"] .exprompt.interactive { font-size: 32px; line-height: 1.45; }
.btn.sub.on { background: var(--accent); color: #11132b; }
.subtabs { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 14px; border-bottom: 1px solid var(--line); padding-bottom: 10px; }
.subtab { background: var(--panel); color: var(--muted); border: 1px solid var(--line); border-radius: 8px; padding: 8px 14px; cursor: pointer; font-size: 14px; }
.subtab.active { color: var(--fg); border-color: var(--accent); background: #232853; }
.subpanel { display: none; }
.subpanel.active { display: block; }
#wordPopup {
  position: fixed; z-index: 5000; background: #1d2147; color: var(--fg);
  border: 1px solid var(--accent); border-radius: 12px; padding: 12px 16px;
  box-shadow: 0 12px 30px rgba(0,0,0,.5); pointer-events: auto;
  max-width: min(320px, calc(100vw - 16px));
}
#wordPopup .wp-emoji { font-size: 34px; text-align: center; margin-bottom: 4px; }
#wordPopup .wp-src { font-size: 15px; font-weight: 600; }
#wordPopup .wp-ipa { font-size: 13px; color: var(--muted); margin-top: 1px; }
#wordPopup .wp-tr { font-size: 16px; color: var(--ok); margin-top: 2px; }
#wordPopup .wp-words { margin-top: 8px; display: flex; flex-direction: column; gap: 3px; font-size: 13px; color: var(--muted); }
#wordPopup .wp-load { color: var(--muted); }
#wordPopup .wp-listen { background: none; border: none; cursor: pointer; font-size: 16px; padding: 0 4px; }
/* подсветка проверки произношения */
.sp-word { padding: 1px 3px; border-radius: 4px; }
.sp-word.ok { color: var(--ok); }
.sp-word.bad { color: var(--err); text-decoration: underline wavy var(--err); }
.sp-word.weak { color: #ffb454; }
.sp-score { font-size: 22px; font-weight: 700; margin: 6px 0; }

/* чат-урок */
.chat { background: var(--panel); border: 1px solid var(--line); border-radius: 12px;
  padding: 12px; min-height: 260px; max-height: 55vh; max-height: 55dvh;
  overflow: auto; margin-bottom: 12px;
  display: flex; flex-direction: column; gap: 10px; }
.msg { max-width: 85%; padding: 10px 14px; border-radius: 14px; font-size: 12px; line-height: 1.45; }
.msg.user { align-self: flex-end; background: #2b3170; color: var(--fg); font-size: 12px; }
.msg.bot { align-self: flex-start; background: var(--bg); border: 1px solid var(--line); font-size: 12px; }
.msg .act-btn { margin-top: 10px; width: 100%; }
.testres { font-size: 20px; font-weight: 700; margin: 10px 0; color: var(--ok); }

/* прогресс по навыкам (проценты) */
.skills { display: flex; flex-direction: column; gap: 10px; margin-bottom: 12px; }
.lvltag { font-size: 15px; margin-bottom: 4px; }
.skillbar { background: var(--panel); border: 1px solid var(--line); border-radius: 10px; padding: 10px 12px; }
.sb-top { display: flex; justify-content: space-between; font-size: 13px; margin-bottom: 6px; text-transform: capitalize; }
.sb-track { height: 10px; background: var(--bg); border-radius: 6px; overflow: hidden; }
.sb-fill { height: 100%; background: linear-gradient(90deg, var(--accent), #4a59e0); border-radius: 6px; transition: width .4s ease; }
.sb-fill.done { background: linear-gradient(90deg, var(--ok), #2bb56a); }

/* пояснение от ИИ под запущенным заданием (из чата) */
.ws-note { margin-top: 14px; background: var(--panel); border: 1px solid var(--accent);
  border-radius: 12px; padding: 12px 16px; overflow-wrap: break-word; }
.ws-note .wsn-head { font-size: 13px; color: var(--muted); display: block; margin-bottom: 6px; }

/* чип грамматики + модалка с правилами */
.chip.gram { cursor: pointer; background: #34284f; color: #c9a8ff; border: 1px solid #5a3f8a; }
.chip.gram:hover { background: #43356a; }
.modal { position: fixed; inset: 0; background: rgba(0,0,0,.6); z-index: 2000;
  display: flex; align-items: center; justify-content: center; padding: 16px; }
.modal-box { background: var(--bg2); border: 1px solid var(--accent); border-radius: 14px;
  width: 100%; max-width: 640px; max-height: 85vh; max-height: 85dvh;
  display: flex; flex-direction: column; }
.modal-head { display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px; border-bottom: 1px solid var(--line); }
.modal-head h3 { margin: 0; }
.modal-head .btn { padding: 4px 12px; }
.modal-body { padding: 14px 18px; overflow: auto; }
.gm-topic { padding: 12px 0; border-bottom: 1px solid var(--line); }
.gm-topic:last-child { border: none; }
.gm-h { font-size: 16px; font-weight: 600; margin-bottom: 4px; }
.gm-exp { font-size: 14px; margin: 6px 0; line-height: 1.5; }
.gm-topic .ex { font-size: 13px; margin-top: 4px; }
.gm-topic .ex .en.interactive { color: var(--fg); } .gm-topic .ex .ru { color: var(--muted); }

/* ===================== МОБИЛЬНАЯ ВЁРСТКА ===================== */
/* Ничто не должно создавать горизонтальную прокрутку (из-за неё вкладки
   «съезжали» за экран). Ограничиваем ширину и прячем горизонтальный скролл. */
html, body { max-width: 100%; overflow-x: hidden; }
img, video, canvas, iframe { max-width: 100%; height: auto; }

/* Вкладки: не режем — переносим на новые строки, помещаются всегда */
.tabs, .subtabs { flex-wrap: wrap; }

@media (max-width: 640px) {
  header { padding: 10px 12px; gap: 8px; flex-wrap: wrap; }
  header h1 { font-size: 16px; gap: 8px; }
  .brand-logo { width: 56px; }
  .badge { font-size: 12px; }

  .tabs { padding: 8px 8px; gap: 6px; }
  .tab { padding: 7px 10px; font-size: 13px; }
  .subtab { padding: 7px 10px; font-size: 13px; }

  main { padding: 14px 12px; }
  h2 { font-size: 16px; }
  .card { padding: 16px 14px; }
  .exshow { font-size: 20px; }
  .result { font-size: 16px; padding: 14px; }
  .msg { max-width: 92%; }

  /* плавающий ИИ-помощник ближе к краю; чат раскрывается НА ВЕСЬ ЭКРАН */
  .ai-fab { right: 14px; bottom: 14px; }
  .ai-panel { top: 0; right: 0; bottom: 0; left: 0; width: auto;
    max-height: none; border-radius: 0; border: none;
    padding: 12px;
    padding-top: max(12px, env(safe-area-inset-top));
    padding-bottom: max(12px, env(safe-area-inset-bottom)); }
  .ai-panel .chat { flex: 1; max-height: none; min-height: 0; }

  /* Кнопки и селекты растягиваются по ширине ряда — ничего не вылезает,
     не остаётся обрезанных элементов на узком экране */
  .row .btn { flex: 1 1 auto; min-width: 0; }
  .row label { flex: 1 1 auto; min-width: 0; }
  .row label select { flex: 1; min-width: 0; }
  .row input[type="file"] { max-width: 100%; min-width: 0; }

  /* видео не выше половины экрана, чтобы кнопки под ним оставались видны */
  video { max-height: 50dvh !important; }
}

/* Безопасные зоны на телефонах с «чёлкой»/жестовой полосой (viewport-fit=cover) */
@supports (padding: max(0px)) {
  header { padding-top: max(10px, env(safe-area-inset-top)); }
  main { padding-bottom: max(24px, env(safe-area-inset-bottom)); }
  .ai-fab { bottom: max(14px, env(safe-area-inset-bottom)); }
}

/* --- «Сообщить об ошибке»: кнопка + модальное окно --- */
.report-wrap { margin: 8px 0; }
.report-btn {
  background: transparent; border: 1px solid #d9736b; color: #d9736b;
  border-radius: 8px; padding: 4px 10px; font-size: .82em; cursor: pointer;
}
.report-btn:hover { background: #d9736b; color: #fff; }
.report-modal {
  position: fixed; inset: 0; background: rgba(0, 0, 0, .55);
  display: flex; align-items: center; justify-content: center; z-index: 2000; padding: 16px;
}
.report-box {
  background: #fff; color: #222; width: 100%; max-width: 440px;
  border-radius: 14px; padding: 20px; box-shadow: 0 20px 60px rgba(0, 0, 0, .4);
}
.report-title { font-weight: 700; font-size: 1.1em; margin-bottom: 14px; }
.report-opt { display: flex; align-items: center; gap: 8px; padding: 7px 0; cursor: pointer; }
.report-comment {
  width: 100%; min-height: 64px; margin: 10px 0; padding: 8px; font: inherit;
  border: 1px solid #ccc; border-radius: 8px; resize: vertical; box-sizing: border-box;
}
.report-actions { display: flex; gap: 10px; justify-content: flex-end; }
.report-fb { margin-top: 10px; min-height: 1.2em; color: #2a8a5a; }
@media (prefers-color-scheme: dark) {
  .report-box { background: #23262b; color: #eee; }
  .report-comment { background: #1a1c20; color: #eee; border-color: #444; }
}

/* --- отрендеренный markdown в объяснениях ИИ --- */
.md p { margin: 5px 0; }
.md ul { margin: 5px 0; padding-left: 20px; }
.md li { margin: 2px 0; }
.md strong { font-weight: 700; }
.md code { background: rgba(127, 127, 127, .2); padding: 1px 5px; border-radius: 4px; font-size: .92em; }
