/* ============================================================
   KO Učebnice — hlavní styl
   Světlé téma default, tmavé přes [data-theme="dark"] na <html>
   ============================================================ */

:root {
  --bg: #fafbfc;
  --bg-card: #ffffff;
  --bg-soft: #f1f4f8;
  --ink: #1c2733;
  --ink-soft: #51606f;
  --line: #dde4ec;
  --accent: #0969da;
  --accent-soft: #ddeafe;
  --good: #1a7f37;
  --good-soft: #dcf2e3;
  --warn: #9a6700;
  --warn-soft: #fff3d1;
  --bad: #cf222e;
  --bad-soft: #ffe0e3;
  --purple: #8250df;
  --purple-soft: #ece3fb;
  --code-bg: #eef1f5;
  --shadow: 0 1px 3px rgba(20,30,45,.08), 0 4px 14px rgba(20,30,45,.05);
  --radius: 12px;
}

[data-theme="dark"] {
  --bg: #0e1419;
  --bg-card: #161d24;
  --bg-soft: #1d2630;
  --ink: #e6edf3;
  --ink-soft: #9baab8;
  --line: #2c3845;
  --accent: #58a6ff;
  --accent-soft: #122b4d;
  --good: #3fb950;
  --good-soft: #11301b;
  --warn: #d29922;
  --warn-soft: #332608;
  --bad: #f85149;
  --bad-soft: #3d1418;
  --purple: #bc8cff;
  --purple-soft: #271b3d;
  --code-bg: #1d2630;
  --shadow: 0 1px 3px rgba(0,0,0,.4);
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: "Segoe UI", -apple-system, Roboto, "Helvetica Neue", Arial, sans-serif;
  font-size: 17px;
  line-height: 1.65;
}

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

/* ---------- horní lišta ---------- */
.topbar {
  position: sticky; top: 0; z-index: 50;
  background: color-mix(in srgb, var(--bg) 88%, transparent);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--line);
}
.topbar-inner {
  max-width: 880px; margin: 0 auto; padding: 10px 20px;
  display: flex; align-items: center; gap: 12px;
}
.topbar a { color: var(--ink-soft); text-decoration: none; font-size: 14px; }
.topbar a:hover { color: var(--accent); }
.topbar .crumb-sep { color: var(--line); }
.topbar .spacer { flex: 1; }
.btn-icon {
  background: none; border: 1px solid var(--line); border-radius: 8px;
  width: 34px; height: 34px; cursor: pointer; color: var(--ink-soft);
  display: inline-flex; align-items: center; justify-content: center;
}
.btn-icon:hover { border-color: var(--accent); color: var(--accent); }
.btn-icon svg { width: 18px; height: 18px; }

/* tlačítko zpět odkud jsem přišel */
.btn-back {
  display: inline-flex; align-items: center; gap: 6px;
  background: none; border: 1px solid var(--line); border-radius: 8px;
  padding: 5px 12px; cursor: pointer; color: var(--ink-soft); font-size: 14px;
}
.btn-back:hover { border-color: var(--accent); color: var(--accent); }
.btn-back svg { width: 15px; height: 15px; }

/* ---------- typografie ---------- */
h1 { font-size: 31px; line-height: 1.25; margin: 28px 0 6px; }
h2 { font-size: 23px; margin: 40px 0 12px; padding-bottom: 6px; border-bottom: 2px solid var(--line); }
h3 { font-size: 19px; margin: 28px 0 8px; }
h4 { font-size: 16.5px; margin: 20px 0 6px; color: var(--ink-soft); }
p { margin: 10px 0; }
a { color: var(--accent); }
hr { border: none; border-top: 1px solid var(--line); margin: 34px 0; }
ul, ol { padding-left: 26px; }
li { margin: 5px 0; }
strong { font-weight: 650; }

.lesson-meta { color: var(--ink-soft); font-size: 14.5px; margin-bottom: 4px; }
.lesson-meta .chip {
  display: inline-block; background: var(--accent-soft); color: var(--accent);
  border-radius: 14px; padding: 1px 11px; font-weight: 600; font-size: 13px; margin-right: 6px;
}
.one-new-thing {
  background: var(--purple-soft); border-left: 4px solid var(--purple);
  border-radius: 0 10px 10px 0; padding: 12px 18px; margin: 18px 0; font-size: 16.5px;
}
.one-new-thing .lbl {
  display: block; font-size: 12px; font-weight: 700; letter-spacing: .06em;
  text-transform: uppercase; color: var(--purple); margin-bottom: 3px;
}

code, .mono {
  font-family: "Cascadia Code", Consolas, ui-monospace, monospace;
  background: var(--code-bg); border-radius: 6px; padding: 1px 6px; font-size: 14.5px;
}
pre { background: var(--code-bg); border-radius: 10px; padding: 14px 18px; overflow-x: auto; }
pre code { background: none; padding: 0; }

table { border-collapse: collapse; width: 100%; margin: 14px 0; font-size: 15px; }
th, td { border: 1px solid var(--line); padding: 8px 12px; text-align: left; vertical-align: top; }
th { background: var(--bg-soft); }
tr:nth-child(even) td { background: color-mix(in srgb, var(--bg-soft) 40%, transparent); }

/* ---------- boxy ---------- */
.box {
  background: var(--bg-card); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 16px 20px; margin: 18px 0;
  box-shadow: var(--shadow);
}
.box-title {
  display: flex; align-items: center; gap: 8px;
  font-weight: 700; font-size: 15px; margin-bottom: 8px;
}
.box-title svg, .box-title img { width: 18px; height: 18px; }

.box.takeaways { border-left: 4px solid var(--good); }
.box.takeaways .box-title { color: var(--good); }
.box.warning { border-left: 4px solid var(--warn); background: var(--warn-soft); }
.box.warning .box-title { color: var(--warn); }
.box.danger { border-left: 4px solid var(--bad); background: var(--bad-soft); }
.box.danger .box-title { color: var(--bad); }
.box.info { border-left: 4px solid var(--accent); }
.box.info .box-title { color: var(--accent); }
.box.foto { border-left: 4px solid var(--purple); }
.box.foto .box-title { color: var(--purple); }

/* ---------- interaktivní „zkus sám" ---------- */
details.try {
  background: var(--bg-card); border: 1px dashed var(--accent);
  border-radius: 10px; padding: 0; margin: 14px 0;
}
details.try > summary {
  cursor: pointer; padding: 11px 16px; font-weight: 600; color: var(--accent);
  list-style: none; display: block;
}
details.try > summary::before { content: "🤔 "; }
details.try[open] > summary { border-bottom: 1px dashed var(--accent); }
details.try > .inner { padding: 12px 16px; }

details.solution {
  background: var(--bg-card); border: 1px solid var(--good);
  border-radius: 10px; margin: 14px 0;
}
details.solution > summary {
  cursor: pointer; padding: 11px 16px; font-weight: 600; color: var(--good); list-style: none;
}
details.solution > summary::before { content: "✅ "; }
details.solution[open] > summary { border-bottom: 1px solid var(--good); }
details.solution > .inner { padding: 12px 16px; }

summary::-webkit-details-marker { display: none; }

/* ---------- úloha 4-dílný formát ---------- */
.task {
  background: var(--bg-card); border: 1px solid var(--line);
  border-radius: var(--radius); margin: 26px 0; box-shadow: var(--shadow);
  overflow: hidden;
}
.task-head {
  background: var(--bg-soft); padding: 13px 20px;
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
}
.task-head .task-id {
  background: var(--accent); color: #fff; font-weight: 700; font-size: 13px;
  border-radius: 8px; padding: 2px 10px;
}
.task-head .task-src { color: var(--ink-soft); font-size: 13px; margin-left: auto; }
.task-head.foto { background: var(--purple-soft); }
.task-head .foto-badge {
  display: inline-flex; align-items: center; gap: 5px;
  background: var(--purple); color: #fff; font-weight: 700; font-size: 12px;
  border-radius: 8px; padding: 2px 10px;
}
.task-body { padding: 6px 20px 16px; }
.task .assignment {
  background: var(--bg-soft); border-radius: 10px; padding: 14px 18px;
  font-size: 16px; margin: 12px 0;
  border-left: 4px solid var(--ink-soft);
}
.task .assignment .lbl {
  display: block; font-size: 11.5px; font-weight: 700; letter-spacing: .06em;
  text-transform: uppercase; color: var(--ink-soft); margin-bottom: 6px;
}

/* ---------- navigace prev/next ---------- */
.pager { display: flex; gap: 14px; margin-top: 50px; }
.pager a {
  flex: 1; border: 1px solid var(--line); border-radius: var(--radius);
  padding: 13px 18px; text-decoration: none; background: var(--bg-card);
  color: var(--ink); box-shadow: var(--shadow);
}
.pager a:hover { border-color: var(--accent); }
.pager .dir { font-size: 12.5px; color: var(--ink-soft); display: block; }
.pager .next { text-align: right; }

/* ---------- index stránky ---------- */
.chapter-card {
  background: var(--bg-card); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 18px 22px; margin: 14px 0; box-shadow: var(--shadow);
}
.chapter-card h3 { margin: 0 0 4px; }
.chapter-card .meta { color: var(--ink-soft); font-size: 14px; }
.chapter-card .chapter-intro {
  margin: 10px 0 2px; font-size: 14.5px; line-height: 1.55; color: var(--ink);
  border-left: 3px solid var(--accent); padding: 2px 0 2px 12px;
}
.lesson-list { list-style: none; padding: 0; margin: 10px 0 0; }
.lesson-list li {
  display: flex; align-items: center; gap: 10px; padding: 7px 4px;
  border-bottom: 1px dashed var(--line);
}
.lesson-list li:last-child { border-bottom: none; }
.lesson-list a { text-decoration: none; flex: 1; }
.lesson-list a:hover { text-decoration: underline; }
.lesson-list .done { color: var(--good); font-weight: 700; }
.lesson-list .lid { font-family: Consolas, monospace; font-size: 13px; color: var(--ink-soft); min-width: 46px; }
.tag-foto {
  background: var(--purple-soft); color: var(--purple); font-size: 11.5px;
  font-weight: 700; border-radius: 9px; padding: 1px 8px;
}
.tag-nice {
  background: var(--bg-soft); color: var(--ink-soft); font-size: 11.5px;
  font-weight: 700; border-radius: 9px; padding: 1px 8px;
}

/* checkbox hotovo */
.done-toggle {
  display: inline-flex; align-items: center; gap: 8px; cursor: pointer;
  border: 1px solid var(--line); border-radius: 10px; padding: 8px 16px;
  background: var(--bg-card); font-size: 15px; user-select: none; margin-top: 30px;
}
.done-toggle input { width: 17px; height: 17px; accent-color: var(--good); }
.done-toggle.is-done { border-color: var(--good); color: var(--good); }

/* ---------- checklist (stránka „co chtějí u zkoušky") ---------- */
.check-progress-wrap {
  position: sticky; top: 8px; z-index: 5; background: var(--bg-card);
  border: 1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow);
  padding: 12px 16px; margin: 14px 0 22px; display: flex; align-items: center; gap: 14px;
}
.check-progress-wrap .count { font-weight: 700; white-space: nowrap; }
.check-bar { flex: 1; height: 10px; background: var(--bg-soft); border-radius: 6px; overflow: hidden; }
.check-bar > i { display: block; height: 100%; width: 0; background: var(--good); transition: width .2s; }
.checklist { list-style: none; padding: 0; margin: 0 0 10px; }
.check-item {
  display: flex; align-items: flex-start; gap: 11px; padding: 11px 8px;
  border-bottom: 1px dashed var(--line);
}
.check-item:last-child { border-bottom: none; }
.check-item > input[type=checkbox] {
  width: 19px; height: 19px; margin-top: 2px; flex: none; cursor: pointer; accent-color: var(--good);
}
.check-item .ci-body { flex: 1; }
.check-item .ci-task { font-weight: 600; }
.check-item.is-done .ci-task { color: var(--good); text-decoration: line-through; text-decoration-color: var(--good); }
.check-item .ci-links { font-size: 13.5px; color: var(--ink-soft); margin-top: 3px; }
.check-item .ci-links a { color: var(--accent); text-decoration: none; }
.check-item .ci-links a:hover { text-decoration: underline; }
.ci-kind {
  font-size: 11px; font-weight: 700; border-radius: 8px; padding: 1px 7px; margin-left: 7px;
  vertical-align: 1px; white-space: nowrap;
}
.ci-kind.run { background: var(--accent-soft); color: var(--accent); }
.ci-kind.prove { background: var(--bad-soft); color: var(--bad); }
.ci-kind.oral { background: var(--warn-soft); color: var(--warn); }

/* ---------- vizualizace ---------- */
.viz {
  background: var(--bg-card); border: 1px solid var(--line); border-radius: var(--radius);
  margin: 18px 0; box-shadow: var(--shadow); overflow: hidden;
}
.viz-canvas { display: block; width: 100%; }
.viz-caption {
  border-top: 1px solid var(--line); padding: 9px 16px;
  font-size: 13.5px; color: var(--ink-soft); background: var(--bg-soft);
}
.viz-controls {
  display: flex; align-items: center; gap: 8px; padding: 9px 14px;
  border-top: 1px solid var(--line); flex-wrap: wrap;
}
.viz-controls .vbtn {
  border: 1px solid var(--line); background: var(--bg-card); color: var(--ink);
  border-radius: 8px; padding: 5px 11px; cursor: pointer; font-size: 14px;
  display: inline-flex; align-items: center; gap: 5px;
}
.viz-controls .vbtn:hover { border-color: var(--accent); color: var(--accent); }
.viz-controls .vbtn svg { width: 14px; height: 14px; }
.viz-controls .vstate { font-size: 13.5px; color: var(--ink-soft); margin-left: auto; }
.viz-controls input[type=range] { flex: 1; min-width: 100px; accent-color: var(--accent); }

/* SVG prvky grafů — barvy přes CSS proměnné */
.viz svg .node circle { fill: var(--bg-card); stroke: var(--ink-soft); stroke-width: 2; }
.viz svg .node text { fill: var(--ink); font-weight: 600; }
.viz svg .node .subtext { paint-order: stroke; stroke: var(--bg-card); stroke-width: 4px; stroke-linejoin: round; }
.viz svg .node.hl circle { fill: var(--accent-soft); stroke: var(--accent); stroke-width: 2.6; }
.viz svg .node.good circle { fill: var(--good-soft); stroke: var(--good); }
.viz svg .node.bad circle { fill: var(--bad-soft); stroke: var(--bad); }
.viz svg .edge path, .viz svg .edge line { stroke: var(--ink-soft); stroke-width: 1.8; fill: none; }
.viz svg .edge.hl path, .viz svg .edge.hl line { stroke: var(--accent); stroke-width: 3; }
.viz svg .edge.good path, .viz svg .edge.good line { stroke: var(--good); stroke-width: 3; }
.viz svg .edge.bad path, .viz svg .edge.bad line { stroke: var(--bad); stroke-width: 2.6; }
.viz svg .edge.dim path, .viz svg .edge.dim line { stroke: var(--line); }
.viz svg .edge text { fill: var(--ink); font-size: 13px; font-weight: 600; }
.viz svg .edge .wbg { fill: var(--bg-card); opacity: .92; }

/* inline ikonka — SVG přes <img> nedědí currentColor, v dark tématu invertujeme */
.ico { display: inline-block; width: 17px; height: 17px; vertical-align: -3px; }
[data-theme="dark"] img.ico { filter: invert(0.85); }
.foto-badge img.ico { filter: invert(1); } /* bílá na fialovém badge v obou tématech */

/* Gantt (KOViz.gantt) — bloky úloh a svislé značky */
.viz svg .gblock rect { fill: var(--accent-soft); stroke: var(--accent); stroke-width: 1.6; }
.viz svg .gblock text { fill: var(--ink); font-size: 13px; font-weight: 600; }
.viz svg .gblock.hl rect { fill: var(--accent); fill-opacity: .42; stroke: var(--accent); stroke-width: 2.4; }
.viz svg .gblock.good rect { fill: var(--good-soft); stroke: var(--good); }
.viz svg .gblock.bad rect { fill: var(--bad-soft); stroke: var(--bad); }
.viz svg .gblock.p rect { fill: var(--purple-soft); stroke: var(--purple); }
.viz svg .gblock.dim rect { fill: var(--bg-soft); stroke: var(--line); }
.viz svg .gblock.dim text { fill: var(--ink-soft); }
.viz svg .gblock.idle rect { fill: none; stroke: var(--line); stroke-dasharray: 4 4; }
.viz svg .gblock.idle text { fill: var(--ink-soft); font-weight: 400; }
.viz svg .gmark line { stroke: var(--bad); stroke-width: 1.6; }
.viz svg .gmark text { fill: var(--bad); font-size: 12px; font-weight: 600; }
.viz svg .gmark.soft line { stroke: var(--ink-soft); }
.viz svg .gmark.soft text { fill: var(--ink-soft); }
.viz svg .gmark.good line { stroke: var(--good); }
.viz svg .gmark.good text { fill: var(--good); }

/* DP tabulka (KOViz.dpTable) */
.dptab-wrap { overflow-x: auto; padding: 12px 12px 4px; }
.dptab { border-collapse: collapse; margin: 0 auto; font-size: 14.5px; }
.dptab th, .dptab td {
  border: 1px solid var(--line); min-width: 46px; padding: 5px 9px;
  text-align: center; font-family: Consolas, "Courier New", monospace;
}
.dptab th { background: var(--bg-soft); color: var(--ink-soft); font-weight: 600; font-size: 13.5px; }
.dptab th.hl { color: var(--accent); }
.dptab th.good { color: var(--good); }
.dptab td { color: var(--ink); background: var(--bg-card); }
.dptab td.empty { background: var(--bg-soft); }
.dptab td.hl { background: var(--accent-soft); color: var(--accent); font-weight: 700; outline: 2px solid var(--accent); outline-offset: -2px; }
.dptab td.src { outline: 2px dashed var(--accent); outline-offset: -2px; }
.dptab td.good { background: var(--good-soft); color: var(--good); font-weight: 700; }
.dptab td.bad { background: var(--bad-soft); color: var(--bad); font-weight: 700; }
.dptab td.dim { color: var(--ink-soft); }

/* mřížka LP regionu */
.viz svg .grid line { stroke: var(--line); stroke-width: 1; }
.viz svg .axis line, .viz svg .axis path { stroke: var(--ink-soft); stroke-width: 1.6; }
.viz svg .axis text { fill: var(--ink-soft); font-size: 12px; }
.viz svg .region { fill: var(--accent); opacity: .14; stroke: var(--accent); stroke-width: 1.6; }
.viz svg .latpt { fill: var(--ink-soft); }
.viz svg .latpt.feas { fill: var(--good); }
.viz svg .latpt.opt { fill: var(--bad); }

@media (max-width: 640px) {
  body { font-size: 16px; }
  h1 { font-size: 25px; }
  .pager { flex-direction: column; }
}

/* tisk */
@media print {
  .topbar, .pager, .done-toggle, .viz-controls { display: none; }
  body { background: #fff; color: #000; }
}
