/* ============================================================
   Дизайн-система курса подготовки к вступительным МИРЭА
   Палитра валидирована (CVD-safe). Светлая + тёмная темы.
   ============================================================ */

:root {
  --page:        #f9f9f7;
  --surface:     #fcfcfb;
  --ink:         #0b0b0b;
  --ink-2:       #52514e;
  --muted:       #898781;
  --grid:        #e1e0d9;
  --axis:        #c3c2b7;
  --border:      rgba(11,11,11,0.10);

  --blue:        #2a78d6;
  --blue-soft:   #e7f0fb;
  --aqua:        #1baf7a;
  --aqua-soft:   #e4f5ee;
  --yellow:      #eda100;
  --yellow-soft: #fdf3dd;
  --violet:      #4a3aa7;
  --violet-soft: #edebf8;
  --red:         #e34948;
  --red-soft:    #fbe9e9;
  --green:       #008300;

  --radius: 12px;
  --shadow: 0 1px 3px rgba(11,11,11,0.06), 0 4px 14px rgba(11,11,11,0.05);
  --sans: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --mono: ui-monospace, "Cascadia Code", Consolas, monospace;
}

@media (prefers-color-scheme: dark) {
  :root {
    --page:        #0d0d0d;
    --surface:     #1a1a19;
    /* тёплый офф-уайт вместо чистого белого — меньше «звона», легче читать длинные тексты */
    --ink:         #eae8e1;
    --ink-2:       #c3c2b7;
    --muted:       #898781;
    --grid:        #2c2c2a;
    --axis:        #383835;
    --border:      rgba(255,255,255,0.10);

    --blue:        #3987e5;
    --blue-soft:   #16233a;
    --aqua:        #199e70;
    --aqua-soft:   #12281f;
    --yellow:      #c98500;
    --yellow-soft: #2c2410;
    --violet:      #9085e9;
    --violet-soft: #211d3a;
    --red:         #e66767;
    --red-soft:    #331616;
    --green:       #0ca30c;

    --shadow: 0 1px 3px rgba(0,0,0,0.4), 0 4px 14px rgba(0,0,0,0.3);
  }
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  background: var(--page);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 17px;
  line-height: 1.65;
}

/* ---------- Каркас страницы ---------- */

.wrap {
  max-width: 880px;
  margin: 0 auto;
  padding: 0 20px 80px;
}

.wrap-wide { max-width: 1100px; }

/* ---------- Шапка / навигация ---------- */

.topnav {
  position: sticky;
  top: 0;
  z-index: 50;
  background: color-mix(in srgb, var(--page) 88%, transparent);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--border);
  margin-bottom: 32px;
}

.topnav-inner {
  max-width: 880px;
  margin: 0 auto;
  padding: 10px 20px;
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
  font-size: 14.5px;
}

.topnav a { color: var(--ink-2); text-decoration: none; padding: 4px 2px; }
.topnav a:hover { color: var(--blue); }
.topnav a.home { font-weight: 700; color: var(--ink); }
.topnav .sep { color: var(--muted); }

h1 {
  font-size: 34px;
  line-height: 1.2;
  letter-spacing: -0.02em;
  margin: 8px 0 4px;
}

.subtitle { color: var(--ink-2); font-size: 18px; margin: 0 0 28px; }

h2 {
  font-size: 24px;
  letter-spacing: -0.01em;
  margin: 48px 0 14px;
  padding-top: 14px;
  border-top: 1px solid var(--grid);
}

/* цветной маркер у заголовка секции — страница сканируется глазами по «вехам» */
h2::before {
  content: "";
  display: inline-block;
  width: 6px;
  height: 0.85em;
  border-radius: 4px;
  background: linear-gradient(180deg, var(--blue), var(--aqua));
  margin-right: 12px;
  vertical-align: -0.08em;
}

h2:first-of-type { border-top: none; }

h3 { font-size: 19px; margin: 32px 0 8px; }

a { color: var(--blue); }

.pill {
  display: inline-block;
  font-size: 12.5px;
  font-weight: 600;
  padding: 2px 10px;
  border-radius: 999px;
  background: var(--blue-soft);
  color: var(--blue);
  margin-right: 6px;
  vertical-align: middle;
}
.pill.aqua   { background: var(--aqua-soft);   color: var(--aqua); }
.pill.yellow { background: var(--yellow-soft); color: var(--yellow); }
.pill.violet { background: var(--violet-soft); color: var(--violet); }
.pill.red    { background: var(--red-soft);    color: var(--red); }

/* ---------- Карточки (главная, план) ---------- */

.cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  gap: 14px;
  margin: 20px 0;
}

.card {
  --acc: var(--blue);
  --acc-soft: var(--blue-soft);
  position: relative;
  display: block;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 16px 18px;
  text-decoration: none;
  color: var(--ink);
  box-shadow: var(--shadow);
  transition: transform 0.12s ease, border-color 0.12s ease;
  overflow: hidden;
}
/* цветная полоса сверху — тип карточки читается издалека */
.card::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--acc);
  opacity: 0.85;
}

.card:hover { transform: translateY(-2px); border-color: var(--acc); }
.card .num {
  display: inline-block;
  font-size: 11.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--acc);
  background: var(--acc-soft);
  padding: 3px 9px;
  border-radius: 999px;
  margin-bottom: 4px;
}
.card h3 { margin: 6px 0 6px; font-size: 17px; }
.card p { margin: 0; font-size: 14px; line-height: 1.55; color: var(--ink-2); }

/* цветовые типы карточек */
.card.c-blue   { --acc: var(--blue);   --acc-soft: var(--blue-soft); }
.card.c-aqua   { --acc: var(--aqua);   --acc-soft: var(--aqua-soft); }
.card.c-violet { --acc: var(--violet); --acc-soft: var(--violet-soft); }
.card.c-yellow { --acc: var(--yellow); --acc-soft: var(--yellow-soft); }
.card.c-red    { --acc: var(--red);    --acc-soft: var(--red-soft); }

/* иконка-плашка на карточках «начни отсюда» */
.card .card-ico {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 11px;
  background: var(--acc-soft);
  font-size: 20px;
  margin-bottom: 10px;
}

/* карточка модуля: крупный номер слева + контент */
.card.mod { display: flex; gap: 14px; align-items: flex-start; }
.card.mod .mod-badge {
  flex: 0 0 auto;
  width: 46px;
  height: 46px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  background: var(--acc-soft);
  color: var(--acc);
  font-size: 22px;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}
.card.mod .mod-body { min-width: 0; }
.card.mod h3 { margin-top: 2px; }

/* чип-отсылка к билету внутри карточки */
.tix {
  display: inline-block;
  font-size: 11.5px;
  font-weight: 700;
  padding: 1px 8px;
  border-radius: 999px;
  background: var(--acc-soft);
  color: var(--acc);
  white-space: nowrap;
  margin: 6px 6px 0 0;
}

/* ---------- Смысловые блоки ---------- */

.box {
  border-radius: var(--radius);
  padding: 16px 20px;
  margin: 18px 0;
  border: 1px solid var(--border);
  border-left: 4px solid var(--axis);
  background: var(--surface);
  box-shadow: var(--shadow);
}

.box > .box-title {
  display: block;
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 6px;
}

.box p:first-of-type { margin-top: 0; }
.box p:last-child { margin-bottom: 0; }

/* Ключевые термины <b> — лёгкий «маркер» снизу: структура текста видна при беглом
   чтении, но не спорит со ссылками. В цветных боксах маркер в цвет бокса. */
p b, li b {
  background: linear-gradient(transparent 64%, var(--blue-soft) 0);
  border-radius: 3px;
  padding: 0 2px;
}
.box.thm p b, .box.thm li b { background: linear-gradient(transparent 64%, var(--violet-soft) 0); }
.box.ex p b, .box.ex li b   { background: linear-gradient(transparent 64%, var(--aqua-soft) 0); }
.box.warn p b, .box.warn li b { background: linear-gradient(transparent 64%, color-mix(in srgb, var(--yellow) 22%, transparent) 0); }
.box.exam p b, .box.exam li b { background: linear-gradient(transparent 64%, var(--red-soft) 0); }

.box.def  { border-left-color: var(--blue); }
.box.def  > .box-title { color: var(--blue); }
.box.thm  { border-left-color: var(--violet); }
.box.thm  > .box-title { color: var(--violet); }
.box.ex   { border-left-color: var(--aqua); }
.box.ex   > .box-title { color: var(--aqua); }
.box.warn { border-left-color: var(--yellow); background: var(--yellow-soft); }
.box.warn > .box-title { color: var(--yellow); }
.box.exam { border-left-color: var(--red); }
.box.exam > .box-title { color: var(--red); }

/* Крупная ключевая формула */
.formula-hero {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 20px 24px;
  margin: 20px 0;
  text-align: center;
  font-size: 20px;
  overflow-x: auto;
}

/* ---------- Решения в details ---------- */

details.solution {
  margin: 12px 0 20px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface);
  overflow: hidden;
}

details.solution > summary {
  cursor: pointer;
  padding: 12px 18px;
  font-weight: 600;
  color: var(--blue);
  user-select: none;
  list-style: none;
}

details.solution > summary::before { content: "▸ "; }
details.solution[open] > summary::before { content: "▾ "; }
details.solution[open] > summary { border-bottom: 1px solid var(--grid); }
details.solution > .body { padding: 6px 20px 16px; }

.answer {
  display: inline-block;
  background: var(--aqua-soft);
  color: var(--ink);
  border: 1px solid var(--aqua);
  border-radius: 8px;
  padding: 4px 14px;
  font-weight: 600;
  margin-top: 8px;
}

/* ---------- Таблицы ---------- */

.table-scroll { overflow-x: auto; }

table.nice {
  border-collapse: collapse;
  width: 100%;
  margin: 16px 0;
  font-size: 15.5px;
  background: var(--surface);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}

table.nice th, table.nice td {
  padding: 10px 14px;
  border-bottom: 1px solid var(--grid);
  text-align: left;
  vertical-align: top;
}

table.nice th {
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--ink-2);
}

table.nice tr:last-child td { border-bottom: none; }

/* ---------- SVG-графики ---------- */

figure.plot {
  margin: 24px 0;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 16px;
  text-align: center;
}

figure.plot svg { max-width: 100%; height: auto; }

figure.plot figcaption {
  font-size: 14px;
  color: var(--ink-2);
  margin-top: 8px;
  text-align: left;
}

/* стандартные роли внутри SVG */
.svg-grid   { stroke: var(--grid); stroke-width: 1; }
.svg-axis   { stroke: var(--axis); stroke-width: 1.5; }
.svg-tick   { fill: var(--muted); font-size: 12px; font-family: var(--sans); }
.svg-label  { fill: var(--ink-2); font-size: 13px; font-family: var(--sans); }
.svg-c1     { stroke: var(--blue);   fill: none; stroke-width: 2.5; stroke-linecap: round; }
.svg-c2     { stroke: var(--aqua);   fill: none; stroke-width: 2.5; stroke-linecap: round; }
.svg-c3     { stroke: var(--yellow); fill: none; stroke-width: 2.5; stroke-linecap: round; }
.svg-c4     { stroke: var(--violet); fill: none; stroke-width: 2.5; stroke-linecap: round; }
.svg-fill1  { fill: var(--blue); opacity: 0.18; stroke: none; }
.svg-fill2  { fill: var(--aqua); opacity: 0.18; stroke: none; }
.svg-dot    { fill: var(--blue); stroke: var(--surface); stroke-width: 2; }

/* ---------- Чек-листы с прогрессом ---------- */

.checklist { list-style: none; padding: 0; margin: 16px 0; }

.checklist li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 8px 14px;
  border-radius: 8px;
  margin: 4px 0;
  background: var(--surface);
  border: 1px solid var(--border);
}

.checklist input[type="checkbox"] {
  width: 18px; height: 18px;
  margin-top: 4px;
  accent-color: var(--blue);
  flex-shrink: 0;
}

.checklist li:has(input:checked) { opacity: 0.55; }
.checklist li:has(input:checked) label { text-decoration: line-through; }
.checklist label { cursor: pointer; }

.progressbar {
  height: 10px;
  background: var(--grid);
  border-radius: 999px;
  overflow: hidden;
  margin: 8px 0 24px;
}

.progressbar > div {
  height: 100%;
  background: linear-gradient(90deg, var(--blue), var(--aqua));
  border-radius: 999px;
  width: 0%;
  transition: width 0.3s ease;
}

/* ---------- Навигация снизу ---------- */

.pagenav {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin-top: 56px;
  padding-top: 20px;
  border-top: 1px solid var(--grid);
  font-size: 15px;
}

.pagenav a {
  text-decoration: none;
  color: var(--blue);
  padding: 10px 16px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface);
}

.pagenav a:hover { border-color: var(--blue); }

/* ---------- Мелочи ---------- */

code {
  font-family: var(--mono);
  font-size: 0.9em;
  background: var(--grid);
  padding: 1px 6px;
  border-radius: 6px;
}

.small { font-size: 14px; color: var(--ink-2); }

mjx-container { overflow-x: auto; overflow-y: hidden; max-width: 100%; }
