:root{
  --primary:#217346; --primary-d:#195936; --secondary:#1a5c38;
  --ink:#1f2430; --muted:#5b6b86; --line:#e6ecf3; --bg:#f4f7fb; --ok:#15803d; --bad:#b91c1c;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{font-family:'Segoe UI',system-ui,-apple-system,Roboto,Arial,sans-serif;color:var(--ink);background:var(--bg);line-height:1.65}
button{font-family:inherit}
/* header */
.vn-top{position:sticky;top:0;z-index:30;background:linear-gradient(135deg,var(--primary),var(--primary-d));color:#fff}
.vn-top .bar{display:flex;align-items:center;gap:14px;padding:12px 18px}
.vn-top .burger{display:none;background:rgba(255,255,255,.18);border:0;color:#fff;font-size:20px;border-radius:8px;width:40px;height:40px;cursor:pointer}
.vn-top .ttl{flex:1;min-width:0}
.vn-top .ttl b{display:block;font-size:1.02rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vn-top .ttl span{font-size:.8rem;opacity:.9}
.vn-top .dl{display:inline-flex;align-items:center;gap:7px;background:#fff;color:var(--primary-d);font-weight:700;font-size:.85rem;padding:9px 14px;border-radius:999px;text-decoration:none;white-space:nowrap}
.vn-top .vn-fs{display:inline-grid;place-items:center;background:rgba(255,255,255,.18);border:0;color:#fff;font-size:18px;line-height:1;border-radius:8px;width:40px;height:40px;cursor:pointer;flex-shrink:0}
.vn-top .vn-fs:hover{background:rgba(255,255,255,.30)}
.vn-top .dl:hover{background:#f0f4ff}
.vn-prog{height:6px;background:rgba(255,255,255,.25)}
.vn-prog>i{display:block;height:100%;width:0;background:#fff;transition:width .35s ease}
/* layout */
.vn-wrap{display:flex;min-height:calc(100vh - 60px)}
.vn-toc{width:300px;flex-shrink:0;background:#fff;border-right:1px solid var(--line);padding:16px 0;overflow-y:auto}
.vn-toc h4{margin:0 0 8px;padding:0 18px;font-size:.72rem;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}
.vn-toc-pct{padding:2px 18px 12px;margin-bottom:6px;border-bottom:1px solid var(--line)}
.vn-toc-pct-bar{height:7px;background:var(--line);border-radius:999px;overflow:hidden;margin-bottom:5px}
.vn-toc-pct-bar>i{display:block;height:100%;width:0;background:var(--primary);transition:width .35s ease;border-radius:999px}
.vn-toc-pct span{font-size:.74rem;color:var(--muted);font-weight:700}
.vn-toc a{display:flex;gap:10px;align-items:flex-start;padding:11px 18px;color:var(--ink);text-decoration:none;font-size:.92rem;border-left:3px solid transparent;cursor:pointer}
.vn-toc a:hover{background:#f6f9fc}
.vn-toc a.active{background:#eef6f8;border-left-color:var(--secondary);font-weight:600}
.vn-toc a .ic{flex-shrink:0;width:20px;height:20px;border-radius:50%;border:2px solid #cdd7e5;display:grid;place-items:center;font-size:12px;color:#cdd7e5;margin-top:1px}
.vn-toc a.done .ic{background:var(--ok);border-color:var(--ok);color:#fff}
.vn-toc a.active .ic{border-color:var(--secondary);color:var(--secondary)}
.vn-toc a.locked{opacity:.5}
/* main */
.vn-main{flex:1;min-width:0;display:flex;flex-direction:column}
.vn-stage{flex:1;max-width:860px;width:100%;margin:0 auto;padding:30px 28px 40px}
.vn-screen{display:none;animation:fade .35s ease}
.vn-screen.show{display:block}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.vn-kicker{display:inline-block;background:#eef6f8;color:var(--secondary);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:4px 11px;border-radius:999px;margin-bottom:10px}
.vn-screen h2{font-size:1.6rem;margin:.1em 0 .5em;color:#0f172a}
/* storytelling callout */
.vn-story{display:flex;gap:14px;background:linear-gradient(135deg,#fff7e6,#eef6f8);border:1px solid #ffe6ad;border-radius:14px;padding:16px 18px;margin:0 0 22px;align-items:flex-start}
.vn-story .av{position:relative;flex-shrink:0;width:66px;height:66px;border-radius:50%;overflow:hidden;background:#eef0f3;color:#fff;display:grid;place-items:center;font-weight:700;font-size:1.3rem;box-shadow:0 2px 8px rgba(20,35,59,.12)}
/* poses apiladas como capas: solo cambia cuál es visible (sin tocar src) → sin flash */
.vn-story .av .pose{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;opacity:0;transition:opacity .6s ease}
.vn-story .av .pose.active{opacity:1}
.vn-story .tx{font-size:.97rem;color:#33425c;flex:1;min-width:0}
.vn-story .gname{font-weight:700;color:var(--primary-d);margin-bottom:2px}
.vn-story .tx b{color:var(--primary-d)}
.vn-narr{display:block;width:100%;margin-top:11px;height:40px}
/* avatar: SOLO transición de poses (fade al cambiar de gesto). Sin cabeceo ni inclinación. */
.vn-story .av.talking{box-shadow:0 0 0 3px rgba(40,134,134,.18),0 2px 10px rgba(20,35,59,.14)}
.vn-story .avwrap{position:relative;flex-shrink:0}
.vn-eq{position:absolute;bottom:-3px;left:50%;transform:translateX(-50%);display:none;gap:2px;align-items:flex-end;height:12px}
.vn-eq.on{display:flex}
.vn-eq i{width:3px;background:var(--secondary);border-radius:2px;height:4px;animation:vneq .5s ease-in-out infinite}
.vn-eq i:nth-child(2){animation-delay:.12s}.vn-eq i:nth-child(3){animation-delay:.24s}.vn-eq i:nth-child(4){animation-delay:.36s}
@keyframes vneq{0%,100%{height:3px}50%{height:12px}}
/* video */
.vn-video{position:relative;aspect-ratio:16/9;background:#000;border-radius:12px;overflow:hidden;margin:0 0 22px}
.vn-video video{width:100%;height:100%;display:block}
/* actividad embebida (biblioteca: storytelling / gamificada) */
.vn-embed{position:relative;width:100%;height:calc(100vh - 150px);min-height:680px;border-radius:12px;overflow:hidden;border:1px solid var(--line);background:#000;margin:6px 0 4px}
.vn-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.vn-stage.embed{max-width:1180px}
/* content */
.vn-content h3{font-size:1.18rem;margin:22px 0 8px;color:#1e293b}
.vn-content p{margin:10px 0}
.vn-content ul,.vn-content ol{margin:10px 0 14px 26px}.vn-content li{margin:5px 0}
.vn-content img{max-width:100%;height:auto;border-radius:8px;display:block;margin:12px auto}
.vn-content table{border-collapse:collapse;width:100%;margin:14px 0}
.vn-content th,.vn-content td{border:1px solid var(--line);padding:8px 10px;text-align:left}
.vn-content th{background:#f1f5f9}
.vn-content blockquote{border-left:4px solid var(--primary);background:#fff8ec;padding:10px 16px;margin:14px 0;border-radius:0 8px 8px 0}
.vn-content kbd{background:#eef2f7;border:1px solid #cdd7e5;border-bottom-width:2px;border-radius:5px;padding:1px 6px;font-size:.85em}
/* check */
.vn-check{border:1px solid var(--line);border-radius:14px;background:#fff;padding:18px 20px;margin:26px 0 6px;box-shadow:0 4px 16px rgba(20,35,59,.05)}
.vn-check .q{font-weight:600;margin:0 0 12px;display:flex;gap:8px}
.vn-check .q .qic{color:var(--secondary)}
.vn-opt{display:block;width:100%;text-align:left;border:1.5px solid var(--line);background:#fff;border-radius:10px;padding:12px 14px;margin:8px 0;cursor:pointer;font-size:.95rem;transition:.15s}
.vn-opt:hover:not([disabled]){border-color:var(--secondary);background:#f6fbfc}
.vn-opt.correct{border-color:var(--ok);background:#f0fdf4}
.vn-opt.wrong{border-color:var(--bad);background:#fef2f2}
.vn-opt[disabled]{cursor:default}
.vn-fb{margin-top:12px;padding:12px 14px;border-radius:10px;font-size:.92rem;display:none}
.vn-fb.show{display:block}
.vn-fb.ok{background:#f0fdf4;color:#14532d;border:1px solid #bbf7d0}
.vn-fb.no{background:#fef2f2;color:#7f1d1d;border:1px solid #fecaca}
/* nav */
.vn-nav{border-top:1px solid var(--line);background:#fff;padding:14px 28px;display:flex;justify-content:space-between;max-width:860px;width:100%;margin:0 auto}
.vn-btn{display:inline-flex;align-items:center;gap:8px;border:0;border-radius:999px;padding:11px 22px;font-weight:700;font-size:.92rem;cursor:pointer}
.vn-btn.prev{background:#eef2f7;color:var(--ink)}
.vn-btn.next{background:var(--primary);color:#fff}
.vn-btn:disabled{opacity:.45;cursor:not-allowed}
/* done */
.vn-done{text-align:center;padding:30px 10px}
.vn-done .medal{font-size:3rem}
.vn-done .medal.spin{display:inline-block;animation:vnpop .6s ease, vnfloat 2.6s ease-in-out .6s infinite}
.vn-done h2{border:0}
@keyframes vnpop{0%{transform:scale(0) rotate(-25deg);opacity:0}60%{transform:scale(1.25) rotate(8deg)}100%{transform:scale(1) rotate(0);opacity:1}}
@keyframes vnfloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
.vn-stats{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin:22px auto 6px;max-width:520px}
.vn-stats .st{background:#f4f7fb;border:1px solid var(--line);border-radius:14px;padding:13px 18px;min-width:96px}
.vn-stats .st b{display:block;font-size:1.5rem;color:var(--primary-d);line-height:1.1}
.vn-stats .st span{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}
.vn-cta{margin-top:10px;font-size:1.02rem}
.vn-opt.pop{animation:vnpop .45s ease}
.vn-try{display:inline-block;margin-left:6px;background:var(--ok);color:#fff;font-size:.7rem;font-weight:700;padding:1px 9px;border-radius:999px;vertical-align:middle}
.vn-try.no{background:var(--bad)}
.vn-toc-pct .crs{display:block;font-size:.7rem;color:var(--secondary);font-weight:700;margin-top:3px}
.vn-toc h4 .dur{font-weight:600;color:var(--muted);text-transform:none;letter-spacing:0}
.vn-toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(20px);background:#1f2430;color:#fff;padding:11px 20px;border-radius:999px;font-size:.9rem;box-shadow:0 8px 30px rgba(0,0,0,.25);opacity:0;transition:.3s;z-index:60;max-width:90vw;text-align:center}
.vn-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
@media(max-width:820px){
  .vn-toc{position:fixed;left:0;top:60px;bottom:0;z-index:25;transform:translateX(-100%);transition:transform .25s;box-shadow:4px 0 20px rgba(0,0,0,.12)}
  .vn-toc.open{transform:none}
  .vn-top .burger{display:grid;place-items:center}
  .vn-top .ttl b{white-space:normal}
}
/* marca de agua de licencia (disuasivo + trazable) */
.vn-wm{position:fixed;right:10px;bottom:8px;z-index:40;font-size:11px;color:rgba(31,36,48,.45);background:rgba(255,255,255,.6);border:1px solid rgba(0,0,0,.06);border-radius:6px;padding:3px 8px;pointer-events:none;user-select:none;backdrop-filter:blur(2px)}
.vn-foot-lic{margin:30px 0 0;padding-top:12px;border-top:1px dashed var(--line);font-size:.78rem;color:var(--muted)}
.vn-video .vn-vwm{position:absolute;bottom:8px;right:10px;z-index:5;font-size:11px;color:rgba(255,255,255,.7);background:rgba(0,0,0,.25);border-radius:5px;padding:2px 7px;pointer-events:none}
