:root{
  --bg:#0f1420; --panel:#161d2e; --panel2:#1b2336; --ink:#e8edf6; --muted:#94a2bd;
  --line:#28324c; --accent:#3b6ef0; --err:#e06a6a; --ok:#44d4b6;
}
*{box-sizing:border-box}
html,body{margin:0;background:var(--bg);color:var(--ink);
  font:16px/1.6 system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;overflow-x:hidden}
[v-cloak]{display:none}
a{color:var(--accent);cursor:pointer;text-decoration:none}
h1{font-size:26px;font-weight:800;letter-spacing:-.02em;margin:0 0 12px}
.muted{color:var(--muted)}
.err{color:var(--err);margin-top:12px}
button{font:inherit;cursor:pointer;border-radius:10px;border:1px solid var(--line);
  background:var(--panel);color:var(--ink);padding:11px 18px;transition:.15s}
button:hover:not(:disabled){border-color:var(--accent)}
button:disabled{opacity:.5;cursor:default}
button.primary{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600;width:100%}
button.ghost{background:transparent}
input{width:100%;background:var(--bg);border:1px solid var(--line);border-radius:10px;
  color:var(--ink);font:inherit;padding:13px 15px;margin:10px 0}
input:focus{outline:none;border-color:var(--accent)}

/* ВХОД */
.auth{max-width:380px;margin:12vh auto;padding:28px;background:var(--panel);
  border:1px solid var(--line);border-radius:16px}
.code-input{text-align:center;letter-spacing:.5em;font-size:24px;font-family:ui-monospace,monospace}

/* КАТАЛОГ / КУРС */
.wrap{max-width:860px;margin:0 auto;padding:24px 16px 60px}
.top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px}
.top h1{margin:0}
.who{color:var(--muted);font-size:14px;white-space:nowrap}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}
.ccard{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:18px;
  cursor:pointer;transition:.18s}
.ccard:hover{border-color:var(--accent);transform:translateY(-2px);background:var(--panel2)}
.ccard h3{margin:0 0 8px;font-size:17px;letter-spacing:-.01em}
.cmeta{color:var(--muted);font-size:13px;margin-bottom:10px}
.cat{display:inline-block;background:var(--bg);color:var(--accent);border-radius:6px;
  padding:1px 7px;margin-right:6px}
.ctags{display:flex;flex-wrap:wrap;gap:6px}
.ctags span{font-size:11px;color:#b9c3d2;border:1px solid var(--line);border-radius:999px;padding:2px 9px}

.sec{margin:22px 0}
.sec h2{font-size:19px;display:flex;align-items:center;gap:10px}
.snum{flex:none;width:26px;height:26px;border-radius:50%;background:var(--panel2);color:var(--accent);
  display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700}
.sub{background:var(--panel);border:1px solid var(--line);border-radius:12px;margin:8px 0;overflow:hidden}
.sub>summary{padding:14px 16px;cursor:pointer;font-weight:600;list-style:none}
.sub>summary::-webkit-details-marker{display:none}
.sub>summary:hover{background:var(--panel2)}
.sub[open]>summary{border-bottom:1px solid var(--line)}
.block{padding:6px 18px 14px}
.block h4{margin:14px 0 6px;color:var(--accent);font-size:14px;text-transform:uppercase;letter-spacing:.04em}
.md{color:#dbe2ee}
.md :is(h1,h2,h3){font-size:1.05em;margin:.6em 0 .3em}
.md p{margin:.5em 0}
.md ul,.md ol{margin:.4em 0;padding-left:1.4em}
.md code{background:var(--bg);border:1px solid var(--line);border-radius:5px;padding:1px 5px;font-size:.9em}
.md pre{background:var(--bg);border:1px solid var(--line);border-radius:8px;padding:12px;overflow:auto}
.md strong{color:var(--ink)}
.md blockquote{border-left:3px solid var(--accent);margin:.5em 0;padding:2px 0 2px 14px;color:var(--muted)}
.md table{border-collapse:collapse;margin:.5em 0}
.md td,.md th{border:1px solid var(--line);padding:5px 10px}
