/* Vyper — Entrenamiento. Limpio, neutro, estilo documentación (referencia: ChatGPT). */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#ffffff;--soft:#f7f7f8;--hover:#f0f0f3;
  --text:#0d0d0d;--text-2:#3d3d46;--muted:#8e8e9a;--faint:#b4b4bd;
  --line:#ececef;--line-2:#e2e2e7;
  --accent:#6d4aff;--accent-soft:#f3f0ff;
  --font:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,"Apple Color Emoji",sans-serif;
  --mono:"SFMono-Regular",Consolas,"Liberation Mono",Menlo,monospace;
}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--font);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:var(--accent);text-decoration:none}
::selection{background:var(--accent-soft)}

/* ── header ── */
.t-top{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;
  height:56px;padding:0 22px;background:rgba(255,255,255,.9);backdrop-filter:saturate(160%) blur(10px);border-bottom:1px solid var(--line)}
.t-brand{display:flex;align-items:center;gap:9px;color:var(--text)}
.t-brand img{border-radius:7px;display:block}
.t-brand b{font-weight:600;font-size:16px}
.t-brand span{color:var(--muted);font-weight:400;font-size:15px}
.t-back{display:inline-flex;align-items:center;gap:7px;font-size:14px;font-weight:500;color:var(--text-2);
  border:1px solid var(--line-2);border-radius:8px;padding:7px 13px;transition:background .15s}
.t-back:hover{background:var(--hover)}

/* ── layout ── */
.wrap{max-width:940px;margin:0 auto;padding:46px 24px 100px}

/* ═══ HUB ═══ */
.hub-eyebrow{font-family:var(--mono);font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);margin-bottom:14px}
.hub-h1{font-size:clamp(30px,5vw,40px);font-weight:700;letter-spacing:-1px;line-height:1.08;max-width:620px}
.hub-lead{font-size:17.5px;color:var(--text-2);margin-top:14px;max-width:600px;line-height:1.55}
.hub-stats{display:flex;gap:22px;margin-top:18px;font-size:13.5px;color:var(--muted)}
.hub-stats b{color:var(--text);font-weight:600}
.note{display:flex;gap:10px;align-items:flex-start;background:var(--soft);border:1px solid var(--line);border-radius:12px;
  padding:13px 15px;margin:30px 0 40px;font-size:13.5px;color:var(--text-2);line-height:1.5}
.note svg{flex-shrink:0;margin-top:1px;color:var(--muted)}
.note b{color:var(--text);font-weight:600}

.block{margin-bottom:40px}
.block-head{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.block-tag{flex-shrink:0;width:30px;height:30px;display:grid;place-items:center;font-family:var(--mono);font-size:14px;
  font-weight:600;color:var(--text-2);background:var(--soft);border:1px solid var(--line-2);border-radius:8px}
.block-head h2{font-size:18px;font-weight:650;font-weight:600;letter-spacing:-.2px;flex:1}
.block-head .count{font-size:13px;color:var(--faint);font-weight:500}

.modlist{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--line-2);border-radius:14px;overflow:hidden}
.mod{display:flex;align-items:center;gap:14px;padding:16px 18px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);
  transition:background .13s;position:relative}
.mod:nth-child(2n){border-right:0}
.mod:hover{background:var(--soft)}
.mod .n{flex-shrink:0;font-family:var(--mono);font-size:12.5px;font-weight:600;color:var(--muted);width:22px}
.mod .b{flex:1;min-width:0}
.mod .b h3{font-size:14.5px;font-weight:550;font-weight:500;color:var(--text);line-height:1.35}
.mod .b p{font-size:12.5px;color:var(--muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mod .arrow{flex-shrink:0;color:var(--faint);opacity:0;transform:translateX(-3px);transition:opacity .13s,transform .13s}
.mod:hover .arrow{opacity:1;transform:none;color:var(--accent)}
/* bordes inferiores limpios en la última fila */
.modlist .mod:last-child,.modlist .mod:nth-last-child(2):nth-child(odd){border-bottom:0}
@media(max-width:680px){
  .modlist{grid-template-columns:1fr}
  .mod{border-right:0}
  .modlist .mod:nth-last-child(2):nth-child(odd){border-bottom:1px solid var(--line)}
}

/* ═══ LECCIÓN ═══ */
.lesson-head{max-width:760px}
.crumb{display:flex;align-items:center;gap:7px;font-size:13px;color:var(--muted);margin-bottom:16px}
.crumb a{color:var(--muted)}.crumb a:hover{color:var(--text)}
.crumb .sep{color:var(--faint)}
.lesson-head h1{font-size:clamp(26px,4.5vw,34px);font-weight:700;letter-spacing:-.7px;line-height:1.14}
.lesson-meta{display:flex;flex-wrap:wrap;gap:7px;margin-top:15px}
.lesson-meta .chip{font-size:12.5px;color:var(--text-2);background:var(--soft);border:1px solid var(--line-2);border-radius:7px;padding:4px 10px}
.lesson-rule{height:1px;background:var(--line);margin:26px 0}

.lesson{display:grid;grid-template-columns:minmax(0,1fr) 218px;gap:48px;align-items:start}
@media(max-width:980px){.lesson{grid-template-columns:1fr}.toc{display:none}}

/* TOC */
.toc{position:sticky;top:80px}
.toc-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:12px}
.toc ul{list-style:none}
.toc li{margin:0}
.toc a{display:block;font-size:13.5px;line-height:1.4;color:var(--muted);padding:6px 0 6px 13px;border-left:2px solid var(--line-2);transition:color .12s,border-color .12s}
.toc a:hover{color:var(--text)}
.toc a.active{color:var(--accent);border-left-color:var(--accent);font-weight:500}

/* ── markdown ── */
.md{font-size:16.5px;line-height:1.75;color:var(--text-2);max-width:740px}
.md>*:first-child{margin-top:0}
.md p{margin:0 0 1.05em}
.md h2{font-size:1.4em;font-weight:650;font-weight:700;color:var(--text);letter-spacing:-.3px;margin:1.9em 0 .65em;scroll-margin-top:78px}
.md h3{font-size:1.16em;font-weight:600;color:var(--text);margin:1.5em 0 .5em}
.md h4{font-size:1.02em;font-weight:600;color:var(--text);margin:1.3em 0 .4em}
.md a{color:var(--accent);text-decoration:underline;text-underline-offset:2px;overflow-wrap:anywhere}
.md strong{color:var(--text);font-weight:600}
.md ul,.md ol{margin:.6em 0 1.1em;padding-left:1.4em}
.md li{margin:.4em 0;padding-left:.15em}
.md ul li::marker{color:var(--faint)}
.md ol li::marker{color:var(--muted);font-variant-numeric:tabular-nums}
.md code{font-family:var(--mono);font-size:.85em;background:var(--soft);border:1px solid var(--line-2);padding:.08em .4em;border-radius:5px;color:var(--text)}
.md pre{margin:1.1em 0;background:#1a1a1e;border-radius:10px;overflow:auto}
.md pre code{display:block;background:transparent;border:0;color:#ededf2;padding:14px 16px;font-size:13.5px;line-height:1.6}
.md blockquote{background:var(--soft);border:1px solid var(--line-2);border-radius:10px;margin:1.3em 0;padding:13px 16px;color:var(--text-2)}
.md blockquote p{margin:.3em 0}
.md blockquote p:first-child{margin-top:0}.md blockquote p:last-child{margin-bottom:0}
.md hr{border:0;height:1px;background:var(--line);margin:2em 0}
.md table{border-collapse:collapse;width:100%;margin:1.3em 0;font-size:14px;display:block;overflow-x:auto}
.md thead th{background:var(--soft);font-weight:600;color:var(--text);text-align:left;white-space:nowrap}
.md th,.md td{border:1px solid var(--line-2);padding:9px 13px;vertical-align:top}
.md tbody tr:hover{background:#fafafb}

/* ── CTA + pager ── */
.cta{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:14px;
  background:var(--soft);border:1px solid var(--line-2);border-radius:14px;padding:18px 20px;margin:38px 0 24px;max-width:740px}
.cta .tx b{display:block;font-size:15.5px;color:var(--text);font-weight:600}
.cta .tx span{font-size:13.5px;color:var(--muted)}
.cta a.ask{flex-shrink:0;display:inline-flex;align-items:center;gap:7px;background:var(--accent);color:#fff;
  font-weight:600;font-size:14px;border-radius:9px;padding:10px 17px;transition:background .15s}
.cta a.ask:hover{background:#5a37e0}
.pager{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:8px;max-width:740px}
.pager a{display:flex;flex-direction:column;gap:3px;border:1px solid var(--line-2);border-radius:11px;padding:13px 16px;transition:background .14s}
.pager a:hover{background:var(--soft)}
.pager .lbl{font-size:12px;color:var(--muted);font-weight:500}
.pager .ttl{font-size:14px;color:var(--text);font-weight:500;line-height:1.3}
.pager .nx{text-align:right}
.pager .off{visibility:hidden}
@media(max-width:560px){.pager{grid-template-columns:1fr}.pager .nx{text-align:left}}

footer.t-foot{border-top:1px solid var(--line);margin-top:48px;padding:24px;text-align:center;color:var(--muted);font-size:13px}
footer.t-foot a{color:var(--muted);text-decoration:underline}
