/* ============ Темы ============ */
/* Светлая по умолчанию + авто-тёмная через prefers-color-scheme */
:root{--bg:#FDFBF7;--tx:#2C2A25;--h:#1A1815;--mt:#8A8680;--ac:#C4553A;--al:#FDF0ED;--bd:#E8E4DD;--cd:#F7F4EE;--sb:#F2EFE8;--dn:#5B8C5A;--dl:#EFF6EF;--cb:#EFEAE0;--qb:#F2EDE2}
@media(prefers-color-scheme:dark){
  :root:not([data-theme="light"]){--bg:#1A1917;--tx:#D5D0C8;--h:#EDE8DF;--mt:#8A8680;--ac:#E07A5F;--al:#2D2220;--bd:#333028;--cd:#22211D;--sb:#1E1D1A;--dn:#7CB97B;--dl:#1E261E;--cb:#2A2823;--qb:#26241F}
}
/* Ручной override: тёмная независимо от системной */
:root[data-theme="dark"]{--bg:#1A1917;--tx:#D5D0C8;--h:#EDE8DF;--mt:#8A8680;--ac:#E07A5F;--al:#2D2220;--bd:#333028;--cd:#22211D;--sb:#1E1D1A;--dn:#7CB97B;--dl:#1E261E;--cb:#2A2823;--qb:#26241F}

/* ============ База ============ */
*{box-sizing:border-box;margin:0;padding:0}
[hidden]{display:none!important}
body{font-family:'Source Serif 4',Georgia,serif;background:var(--bg);color:var(--tx);overflow:hidden}
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--bd);border-radius:3px}
.dm{font-family:'DM Sans',sans-serif}
button{font:inherit}

/* ============ Каркас ============ */
.app{display:flex;height:100vh}
main#mn{flex:1;min-width:0;overflow-y:auto;height:100vh}

/* ============ Sidebar ============ */
.sidebar{display:none;width:300px;min-width:300px;background:var(--sb);border-right:1px solid var(--bd);overflow-y:auto;height:100vh;padding:20px 0}
body.sb-open .sidebar{display:block}
.backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.35);z-index:85;animation:fadeIn 0.18s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideIn{from{transform:translateX(-100%)}to{transform:translateX(0)}}

.sbhead{padding:0 20px 18px;border-bottom:1px solid var(--bd);position:relative}
.sbclose{display:none;position:absolute;top:-4px;right:14px;width:36px;height:36px;border:1px solid var(--bd);background:var(--bg);border-radius:8px;cursor:pointer;align-items:center;justify-content:center;color:var(--tx)}
.kicker{font-size:13px;font-weight:600;color:var(--ac);letter-spacing:0.06em;text-transform:uppercase}
.sbtitle{font-size:23px;font-weight:600;color:var(--h);line-height:1.3;margin-top:6px}
.sbcount{font-size:14px;color:var(--mt);margin-top:12px}
.pbar{height:4px;background:var(--bd);border-radius:2px;margin-top:8px;overflow:hidden}
.pfill{height:100%;width:0;background:var(--dn);border-radius:2px;transition:width 0.3s}

.modlist{padding:8px 0}
.mod{margin-bottom:2px}
.modhdr{cursor:pointer;user-select:none;display:flex;align-items:center;gap:8px;padding:10px 18px;border-radius:0;transition:background 0.15s}
.modhdr:hover{background:var(--cd)}
.caret{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;color:var(--mt);transition:transform 0.2s ease;flex-shrink:0;font-size:11px}
.caret.open{transform:rotate(90deg)}
.modnum{font-size:15px;color:var(--mt);min-width:20px}
.modtitle{flex:1;font-size:15.5px;font-weight:500;color:var(--tx);line-height:1.35}
.modtitle.cur{font-weight:600;color:var(--h)}
.modcount{font-size:13px;color:var(--mt)}
.modcount.full{color:var(--dn)}

.lessons{padding:4px 0 8px 38px}
.lmsg{font-size:14px;color:var(--mt);padding:8px 12px}
.lmsg.err-msg{color:var(--ac)}
.lesson{display:flex;align-items:flex-start;gap:10px;padding:9px 12px;border-radius:6px;cursor:pointer;margin-bottom:1px;margin-right:12px;background:transparent}
.lesson:hover{background:var(--cd)}
.lesson.active,.lesson.active:hover{background:var(--al)}
.lcheck{width:18px;height:18px;min-width:18px;border-radius:50%;margin-top:2px;border:1.5px solid var(--bd);background:transparent;display:flex;align-items:center;justify-content:center;font-size:11px;color:#fff;font-weight:700}
.lcheck.done{border:none;background:var(--dn)}
.lspacer{width:18px;min-width:18px}
.ltitle{flex:1;min-width:0;font-size:15px;font-weight:400;color:var(--tx);line-height:1.4}
.lesson.active .ltitle{font-weight:600;color:var(--ac)}

.sbfoot{padding:22px 20px 10px;margin-top:10px;border-top:1px solid var(--bd)}
.sbfoot-text{font-size:13px;color:var(--mt);line-height:1.5}

/* Мобильный sidebar — поверх контента */
@media(max-width:768px){
  .sidebar{position:fixed;top:0;left:0;width:min(320px,85vw);height:100vh;z-index:90;box-shadow:0 0 30px rgba(0,0,0,0.18);animation:slideIn 0.22s ease}
  body.sb-open .backdrop{display:block}
  .sbclose{display:flex}
  .sbtitle{padding-right:44px}
}

/* ============ Topbar ============ */
.topbar{position:sticky;top:0;z-index:70;background:var(--bg);border-bottom:1px solid var(--bd);padding:12px 24px;display:flex;align-items:center;gap:14px;min-height:60px}
.navbtn{background:var(--bg);border:1px solid var(--bd);cursor:pointer;display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:8px;color:var(--tx);transition:background 0.15s,border-color 0.15s,color 0.15s;flex-shrink:0}
.navbtn:hover{background:var(--cd);border-color:var(--ac);color:var(--ac)}
.crumb-mod{font-size:15px;color:var(--mt)}
.crumb-arrow{font-size:15px;color:var(--bd)}
.crumb-lesson{font-size:15px;color:var(--tx);font-weight:500;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.themesw{display:inline-flex;background:var(--cd);border:1px solid var(--bd);border-radius:8px;padding:3px;gap:0;margin-left:auto}
.themesw button{background:none;border:none;cursor:pointer;width:30px;height:28px;border-radius:5px;display:flex;align-items:center;justify-content:center;color:var(--mt);transition:background 0.15s,color 0.15s}
.themesw button:hover{color:var(--tx)}
.themesw button.active{background:var(--bg);color:var(--ac);box-shadow:0 1px 2px rgba(0,0,0,0.06)}

/* ============ Контент урока ============ */
.content{max-width:1180px;margin:0 auto;padding:40px 32px 100px;display:flex;gap:32px;align-items:flex-start}
.article{flex:1;min-width:0;max-width:820px}
.lesson-kicker{font-size:13px;color:var(--ac);font-weight:600;letter-spacing:0.04em;text-transform:uppercase;margin-bottom:10px}
.lesson-title{font-size:34px;font-weight:600;color:var(--h);line-height:1.2;margin-bottom:14px}
.lesson-meta{display:flex;gap:18px;font-size:14px;color:var(--mt);margin-bottom:32px;flex-wrap:wrap}

.done-wrap{margin-top:36px;padding-top:20px;border-top:1px solid var(--bd)}
.donebtn{background:var(--al);color:var(--ac);border:1px solid var(--ac);border-radius:7px;padding:11px 24px;font-size:14px;font-weight:600;cursor:pointer}
.donebtn.done{background:var(--dl);color:var(--dn);border-color:var(--dn)}

.pnrow{display:flex;justify-content:space-between;margin-top:28px;gap:14px;flex-wrap:wrap}
.pnbtn{background:var(--cd);border:1px solid var(--bd);border-radius:7px;padding:12px 18px;cursor:pointer;text-align:left;flex:1;min-width:200px;color:var(--tx)}
.pnbtn.next{text-align:right}
.pnlabel{font-size:11px;color:var(--mt);margin-bottom:4px}
.pnname{font-size:14px;font-weight:500}

/* ============ Markdown ============ */
.md{font-size:20px;line-height:1.75;color:var(--tx)}
.md h1{font-size:33px;font-weight:600;color:var(--h);line-height:1.25;margin:34px 0 16px}
.md h2{font-size:27px;font-weight:600;color:var(--h);line-height:1.3;margin:32px 0 14px;padding-bottom:7px;border-bottom:1px solid var(--bd)}
.md h3{font-size:22px;font-weight:600;color:var(--h);line-height:1.35;margin:28px 0 12px}
.md h4{font-size:19px;font-weight:600;color:var(--h);line-height:1.4;margin:24px 0 10px;font-family:'DM Sans',sans-serif;letter-spacing:.01em}
.md p{margin:14px 0}
.md strong{font-weight:600;color:var(--h)}
.md em{font-style:italic}
.md a{color:var(--ac);text-decoration:underline;text-decoration-color:var(--bd);text-underline-offset:3px}
.md a:hover{text-decoration-color:var(--ac)}
.md ul,.md ol{margin:14px 0 14px 4px;padding-left:26px}
.md li{margin:7px 0;line-height:1.7}
.md li>p{margin:5px 0}
.md ul li::marker{color:var(--ac)}
.md ol li::marker{color:var(--ac);font-weight:600}
.md blockquote{margin:20px 0;padding:16px 22px;background:var(--qb);border-left:3px solid var(--ac);border-radius:0 6px 6px 0;color:var(--tx);font-style:italic}
.md blockquote p{margin:7px 0}
.md hr{border:none;border-top:1px solid var(--bd);margin:34px 0}
.md code{font-family:'SF Mono','Monaco','Consolas',monospace;font-size:.9em;background:var(--cb);padding:2px 6px;border-radius:4px;color:var(--h)}
.md pre{background:var(--cb);padding:18px 20px;border-radius:8px;overflow-x:auto;margin:18px 0;font-size:16px;line-height:1.6}
.md pre code{background:none;padding:0;font-size:16px}
.md table{border-collapse:collapse;margin:20px 0;width:100%;font-size:17px;display:block;overflow-x:auto}
.md table thead{background:var(--cd)}
.md table th,.md table td{padding:11px 15px;text-align:left;border:1px solid var(--bd);vertical-align:top;line-height:1.55}
.md table th{font-weight:600;color:var(--h);font-family:'DM Sans',sans-serif;font-size:16px}
.md table tr:nth-child(even) td{background:var(--cd)}

/* ============ Состояния загрузки ============ */
.loading{display:flex;align-items:center;justify-content:center;height:60vh;color:var(--mt);font-family:'DM Sans',sans-serif;font-size:15px}
.spinner{width:26px;height:26px;border:2.5px solid var(--bd);border-top-color:var(--ac);border-radius:50%;animation:spin 0.8s linear infinite;margin-right:10px}
@keyframes spin{to{transform:rotate(360deg)}}
.err{padding:24px;background:var(--al);border-left:3px solid var(--ac);border-radius:0 6px 6px 0;color:var(--tx);font-family:'DM Sans',sans-serif;font-size:15px;line-height:1.6}
.err strong{color:var(--ac)}

/* ============ TOC урока (справа на десктопе) ============ */
.toc{position:sticky;top:80px;align-self:flex-start;width:240px;flex-shrink:0;font-family:'DM Sans',sans-serif;font-size:13px;line-height:1.5;max-height:calc(100vh - 100px);overflow-y:auto;padding:0 10px}
.toc-title{font-size:11px;font-weight:600;color:var(--mt);letter-spacing:0.06em;text-transform:uppercase;margin-bottom:10px;padding-left:10px}
.toc-list{list-style:none;padding:0;margin:0;border-left:1.5px solid var(--bd)}
.toc-list li{margin:0}
.toc-link{display:block;padding:6px 12px;color:var(--mt);cursor:pointer;border-left:2px solid transparent;margin-left:-1.5px;transition:color 0.15s,border-color 0.15s;text-decoration:none;font-weight:400}
.toc-link:hover{color:var(--ac)}
.toc-link.active{color:var(--ac);border-left-color:var(--ac);font-weight:500}
.toc-link.lvl-h4{padding-left:24px;font-size:12px}
@media(max-width:1100px){.toc{display:none!important}}

/* ============ Кнопка «наверх» ============ */
.totop{position:fixed;right:24px;bottom:24px;width:44px;height:44px;border-radius:50%;background:var(--ac);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(0,0,0,0.15);z-index:40;opacity:0;pointer-events:none;transform:translateY(10px);transition:opacity 0.2s,transform 0.2s,background 0.15s}
.totop.show{opacity:1;pointer-events:auto;transform:translateY(0)}
.totop:hover{background:var(--h)}

/* ============ Мобильная типографика ============ */
@media(max-width:768px){
  .md{font-size:18px}
  .md h1{font-size:27px}
  .md h2{font-size:23px}
  .md h3{font-size:20px}
  .md h4{font-size:17px}
  .md table{font-size:15px}
  .md pre{font-size:14px}
}
