:root{--green: #58cc02;--green-dark: #46a302;--red: #ff4b4b;--red-dark: #d63a3a;--blue: #1cb0f6;--blue-dark: #1899d6;--yellow: #ffc800;--orange: #ff9600;--text: #3c3c3c;--muted: #777;--border: #e5e5e5;--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-in-out: cubic-bezier(.77, 0, .175, 1);--ease-pop: cubic-bezier(.34, 1.56, .64, 1);--ease-drawer: cubic-bezier(.32, .72, 0, 1)}*{box-sizing:border-box}body{margin:0;font-family:Nunito,Segoe UI,system-ui,sans-serif;background:#fff;color:var(--text);-webkit-font-smoothing:antialiased}button{font-family:inherit}@keyframes view-enter{0%{opacity:0;transform:translateY(6px)}}@keyframes fade-in{0%{opacity:0}}@keyframes rise{0%{opacity:0;transform:translateY(10px)}}.home{max-width:640px;margin:0 auto;padding:0 16px 60px;animation:view-enter .16s var(--ease-out)}.topbar{position:sticky;top:0;z-index:10;display:flex;justify-content:space-between;align-items:center;padding:calc(14px + env(safe-area-inset-top,0px)) 4px 14px;background:#fffffff2;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-bottom:2px solid var(--border)}.logo{font-weight:900;font-size:22px;color:var(--green)}.stats{display:flex;gap:14px;font-weight:800;font-size:15px}.stat.streak{color:var(--orange)}.stat.xp{color:var(--blue)}.stat.lessons{color:var(--muted)}.daily{display:flex;align-items:center;gap:10px;margin:14px 2px 6px;font-size:13px;font-weight:700;color:var(--muted)}.daily-bar{flex:1;height:12px;background:#ddd;border-radius:8px;overflow:hidden}.daily-bar>div{height:100%;background:var(--orange);border-radius:8px;transition:width .4s var(--ease-out)}.review-banner{display:block;width:100%;margin:14px 0 4px;padding:14px;font-size:15px;font-weight:800;color:#fff;background:var(--blue);border:none;border-radius:14px;box-shadow:0 4px 0 var(--blue-dark);cursor:pointer;transition:transform 80ms var(--ease-out),box-shadow 80ms var(--ease-out)}.review-banner:active{transform:translateY(4px);box-shadow:none}.unit{margin-top:28px}.unit-banner{border-radius:16px;padding:16px 20px;color:#fff;box-shadow:0 4px #0000002e}.unit-banner.dark-text{color:#3c3c3c}.unit-label{font-size:11px;font-weight:800;letter-spacing:1px;opacity:.85}.unit-banner h2{margin:4px 0;font-size:20px;font-weight:900}.unit-banner p{margin:0;font-size:13px;opacity:.92}.nodes{display:flex;flex-direction:column;align-items:center;gap:44px;padding:52px 0 6px}.node-wrap{display:flex;flex-direction:column;align-items:center;position:relative}.node{width:74px;height:74px;border-radius:50%;border:none;font-size:32px;cursor:pointer;display:flex;align-items:center;justify-content:center;background:var(--c, #e5e5e5);box-shadow:0 7px #0000004d;box-shadow:0 7px color-mix(in srgb,var(--c, #e5e5e5) 60%,black);transition:transform 90ms var(--ease-out),box-shadow 90ms var(--ease-out),filter .15s ease}.node:active:not(:disabled){transform:translateY(6px);box-shadow:0 1px #0000004d}.node.locked{background:#e5e5e5;box-shadow:0 7px #c7c7c7;cursor:not-allowed;font-size:26px}.node.current{animation:pulse 1.6s var(--ease-in-out) infinite;outline:4px solid rgba(0,0,0,.12);outline:4px solid color-mix(in srgb,var(--c) 35%,white);outline-offset:4px}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.06)}}.start-bubble{position:absolute;top:-38px;z-index:2;background:#fff;border:2px solid var(--border);border-radius:10px;padding:5px 12px;font-size:12px;font-weight:900;color:var(--green);animation:bob 1.2s var(--ease-in-out) infinite;white-space:nowrap}@keyframes bob{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.node-stars{height:18px;margin-top:6px;font-size:15px;letter-spacing:2px}.node-stars span{color:#d8d8d8}.node-stars span.on{color:#e6a800;text-shadow:0 1px 0 rgba(0,0,0,.2)}.node-title{font-size:12.5px;font-weight:700;color:var(--muted);max-width:150px;text-align:center}.foot{text-align:center;margin-top:40px;color:#bbb;font-size:13px;font-weight:700}.lesson{max-width:640px;margin:0 auto;padding:0 16px calc(26vh + 180px);min-height:100vh;animation:view-enter .18s var(--ease-out)}.lesson-top{display:flex;align-items:center;gap:14px;padding:calc(18px + env(safe-area-inset-top,0px)) 0 8px}.quit{border:none;background:none;font-size:22px;color:#afafaf;cursor:pointer;font-weight:800;transition:color .15s ease,transform .1s var(--ease-out)}.quit:active{transform:scale(.9)}.bar{flex:1;height:16px;background:#e5e5e5;border-radius:10px;overflow:hidden}.bar-fill{height:100%;background:var(--green);border-radius:10px;transition:width .4s var(--ease-out);position:relative}.bar-fill:after{content:"";position:absolute;top:3px;left:8px;right:8px;height:4px;border-radius:4px;background:#ffffff59}.lesson-name{font-size:13px;font-weight:800;color:var(--muted);letter-spacing:.5px}.question-area{animation:rise .18s var(--ease-out)}.q-text{font-size:20px;font-weight:800;line-height:1.45;margin:18px 0 22px}.q-text.scenario{background:#f7f7f7;border:2px solid var(--border);border-radius:14px;padding:14px 16px;font-size:16.5px;font-weight:700}.chip-caso,.chip-tf{display:inline-block;margin-top:16px;font-size:11px;font-weight:900;letter-spacing:1px;color:var(--blue);border:2px solid var(--blue);padding:3px 10px;border-radius:8px}.options{display:flex;flex-direction:column;gap:10px}.option,.tf-btn,.match-btn{text-align:left;background:#fff;border:2px solid var(--border);border-bottom-width:4px;border-radius:12px;padding:13px 16px;font-size:15.5px;font-weight:700;color:var(--text);cursor:pointer;transition:background .12s ease,border-color .12s ease,color .12s ease,transform .1s var(--ease-out)}.option:active:not(.done),.tf-btn:active:not(.done),.match-btn:active:not(.matched){transform:scale(.98)}.option.selected,.tf-btn.selected,.match-btn.selected{border-color:var(--blue);background:#eaf6ff;color:var(--blue-dark)}.option.right,.tf-btn.right{border-color:var(--green);background:#e8ffd6;color:#58a700}.option.wrong,.tf-btn.wrong{border-color:var(--red);background:#ffebeb;color:#ea2b2b}.option.done,.tf-btn.done{cursor:default}.tf-row{display:flex;gap:12px}.tf-btn{flex:1;text-align:center;padding:18px 10px;font-weight:800}.match-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 14px}.match-col{display:flex;flex-direction:column;gap:10px}.match-btn{text-align:center;min-height:58px;display:flex;align-items:center;justify-content:center;font-size:14.5px}.match-btn.matched{opacity:.45;border-color:var(--green);background:#e8ffd6;cursor:default;animation:match-settle .26s var(--ease-pop)}@keyframes match-settle{50%{transform:scale(1.05)}}.match-btn.shake:not(.matched){animation:shake .35s var(--ease-in-out);border-color:var(--red)!important;background:#ffebeb!important}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-6px)}50%{transform:translate(6px)}75%{transform:translate(-4px)}}.feedback{position:fixed;left:0;right:0;bottom:0;z-index:50;padding:18px 16px calc(22px + env(safe-area-inset-bottom,0px));animation:feedback-enter .3s var(--ease-drawer)}@keyframes feedback-enter{0%{transform:translateY(100%)}}.feedback.ok{background:#d7ffb8}.feedback.ko{background:#ffdfe0}.feedback-inner{max-width:640px;margin:0 auto}.feedback-title{font-size:19px;font-weight:900}.feedback.ok .feedback-title{color:#58a700}.feedback.ko .feedback-title{color:#ea2b2b}.feedback-expl{font-size:14.5px;line-height:1.5;margin:8px 0 14px;color:#444;max-height:26vh;overflow-y:auto}.btn{width:100%;padding:14px;border:none;border-radius:14px;font-size:15px;font-weight:900;letter-spacing:.8px;color:#fff;cursor:pointer;transition:transform 80ms var(--ease-out),box-shadow 80ms var(--ease-out)}.btn-green{background:var(--green);box-shadow:0 4px 0 var(--green-dark)}.btn-red{background:var(--red);box-shadow:0 4px 0 var(--red-dark)}.btn:active{transform:translateY(4px);box-shadow:none}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:24px;background:#3c3c3c73;animation:fade-in .18s ease}.modal{background:#fff;border-radius:20px;padding:26px 22px 20px;max-width:360px;width:100%;text-align:center;animation:modal-enter .22s var(--ease-out)}@keyframes modal-enter{0%{opacity:0;transform:scale(.95)}}.modal-emoji{font-size:44px}.modal h3{margin:10px 0 4px;font-size:19px;font-weight:900}.modal p{margin:0 0 18px;font-size:14.5px;color:var(--muted);font-weight:700}.btn-ghost{width:100%;margin-top:10px;padding:12px;background:none;border:none;border-radius:12px;color:var(--red);font-size:14px;font-weight:900;letter-spacing:.8px;cursor:pointer;transition:background .12s ease,transform .1s var(--ease-out)}.btn-ghost:active{transform:scale(.97)}.results{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.results-card{text-align:center;max-width:440px;width:100%;animation:view-enter .2s var(--ease-out)}.stars-row{font-size:64px;line-height:1}.star{color:#e5e5e5;display:inline-block;margin:0 6px}.star.on{color:var(--yellow);animation:star-pop .48s var(--ease-pop) backwards;text-shadow:0 3px 0 rgba(0,0,0,.12)}@keyframes star-pop{0%{transform:scale(.4) rotate(-12deg);opacity:0}}.review-done{font-size:64px;animation:star-pop .48s var(--ease-pop) backwards}.results-card h1{font-weight:900;margin:14px 0 6px;animation:rise .3s var(--ease-out) .3s backwards}.results-chips{display:flex;gap:12px;justify-content:center;margin:22px 0 28px}.chip{border:2px solid var(--border);border-radius:14px;padding:10px 16px;min-width:96px;animation:rise .32s var(--ease-out) backwards}.results-chips .chip:nth-child(1){animation-delay:.42s}.results-chips .chip:nth-child(2){animation-delay:.48s}.results-chips .chip:nth-child(3){animation-delay:.54s}.chip span{display:block;font-size:11px;font-weight:900;letter-spacing:1px;color:var(--muted)}.chip strong{font-size:20px;font-weight:900}.chip-xp strong{color:var(--orange)}.chip-acc strong{color:var(--green)}.chip-streak strong{color:var(--orange)}.btn.big{max-width:320px;margin:0 auto;display:block;animation:rise .3s var(--ease-out) .64s backwards}@media (hover: hover) and (pointer: fine){.node:hover:not(:disabled){filter:brightness(1.08)}.quit:hover{color:var(--text)}.option:hover:not(.done),.tf-btn:hover:not(.done),.match-btn:hover:not(.matched){background:#f7f7f7}.option.selected:hover,.tf-btn.selected:hover,.match-btn.selected:hover{background:#eaf6ff}.btn-ghost:hover{background:#ffefef}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-delay:0s!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media (max-width: 480px){.stats{gap:9px;font-size:13.5px}.logo{font-size:18px}.tf-row{flex-direction:column}}
