.cs-page{max-width:600px;margin:0 auto;padding:0 0 80px;min-height:100vh;position:relative;font-family:inherit}.cs-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:16px;color:var(--fg-3)}.cs-loading-spinner{width:36px;height:36px;border:3px solid var(--border-2);border-top-color:var(--primary);border-radius:50%;animation:cs-spin .8s linear infinite}@keyframes cs-spin{to{transform:rotate(360deg)}}.cs-header{position:sticky;top:0;z-index:10;background:var(--bg);border-bottom:1px solid var(--border-2);padding:10px 16px 8px;display:flex;align-items:center;gap:10px}.cs-back{background:none;border:none;color:var(--primary);font-size:14px;cursor:pointer;padding:4px 8px;border-radius:6px;white-space:nowrap;flex-shrink:0}.cs-back:hover{background:var(--primary-soft)}.cs-lesson-num{font-size:13px;font-weight:600;color:var(--fg-2);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cs-checkpoint-badge{font-size:13px;font-weight:700;color:var(--hoang-kim);flex:1}.cs-progress-wrap{width:80px;height:6px;background:var(--border-2);border-radius:3px;overflow:hidden;flex-shrink:0}.cs-progress-bar{height:100%;background:var(--primary);border-radius:3px;transition:width .4s ease}@keyframes cs-breathe{0%,to{transform:scaleY(1) scaleX(1)}50%{transform:scaleY(1.025) scaleX(.98) translateY(-2px)}}@keyframes cs-bounce-in{0%{transform:translateY(24px) scaleY(.85) scaleX(1.05);opacity:0}60%{transform:translateY(-6px) scaleY(1.04) scaleX(.97);opacity:1}80%{transform:translateY(3px) scaleY(.98) scaleX(1.01)}to{transform:translateY(0) scaleY(1) scaleX(1);opacity:1}}@keyframes cs-pop-in{0%{transform:scale(.88);opacity:0}70%{transform:scale(1.04);opacity:1}to{transform:scale(1)}}.cs-vn-choice-box{background:var(--bg);border-top:1px solid var(--border-2);padding:20px 16px;margin:0}.cs-vn-choice-q{font-size:15px;font-weight:600;color:var(--fg-1);margin-bottom:16px;line-height:1.5}.cs-vn-choice-opts{display:flex;flex-direction:column;gap:10px;margin-bottom:12px}.cs-vn-choice-row,.cs-opt-row{display:flex;align-items:stretch;gap:8px}.cs-vn-choice-row>.cs-vn-choice-opt,.cs-opt-row>.cs-opt{flex:1;min-width:0}.cs-spk{flex:0 0 auto;align-self:center;background:var(--bg-2);border:1px solid var(--border-2);border-radius:8px;padding:6px 10px;font-size:15px;line-height:1;cursor:pointer;font-family:inherit;transition:background .15s ease,border-color .15s ease,transform .15s ease}.cs-spk:hover{background:var(--primary-soft);border-color:var(--primary);transform:scale(1.06)}.cs-q-text .cs-spk,.cs-vn-choice-q .cs-spk{padding:2px 8px;font-size:13px;margin-right:6px;vertical-align:middle}.cs-vn-choice-opt{background:var(--bg-2);border:2px solid var(--border-2);border-radius:10px;padding:12px 14px;text-align:left;cursor:pointer;transition:all .2s ease;font-family:inherit}.cs-vn-choice-opt:hover:not(:disabled){background:var(--bg-3);border-color:var(--primary);transform:translateY(-1px)}.cs-vn-choice-hanzi{font-size:16px;font-weight:600;color:var(--fg-1);margin-bottom:4px}.cs-vn-choice-py{font-size:13px;color:var(--fg-3);font-style:italic}.cs-vn-choice-opt.is-correct{background:var(--thuy-luc-soft);border-color:var(--thuy-luc);animation:cs-pop-in .3s ease}.cs-vn-choice-opt.is-wrong{background:var(--chau-hong-soft);border-color:var(--chau-hong);animation:cs-shake .4s ease}@keyframes cs-shake{0%,to{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}}.cs-vn-choice-feedback{background:var(--hoang-kim-soft);border-left:3px solid var(--hoang-kim);padding:10px 12px;border-radius:6px;font-size:14px;color:var(--fg-2);line-height:1.5;margin-top:12px}} .cs-controls{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:600px;background:var(--bg);border-top:1px solid var(--border-2);padding:10px 16px;display:flex;gap:10px;align-items:center;justify-content:flex-end;z-index:20;box-sizing:border-box}.cs-btn-icon{background:var(--surface-3);border:1px solid var(--border-2);border-radius:8px;padding:8px 12px;font-size:18px;cursor:pointer;line-height:1;flex-shrink:0}.cs-btn-icon:hover{background:var(--border-2)}.cs-btn-primary{background:var(--primary);color:var(--me-bach);border:none;border-radius:10px;padding:10px 22px;font-size:15px;font-weight:600;cursor:pointer;transition:background .2s}.cs-btn-primary:hover{background:var(--chau-hong-2)}.cs-btn-primary:disabled{background:var(--fg-4);cursor:not-allowed}.cs-btn-secondary{background:var(--surface-3);color:var(--fg-2);border:1px solid var(--border-2);border-radius:10px;padding:10px 18px;font-size:15px;font-weight:500;cursor:pointer}.cs-btn-secondary:hover{background:var(--border-2)}.cs-btn-secondary:disabled{opacity:.4;cursor:not-allowed}.cs-speak-btn{border-color:var(--success);color:var(--success)}.cs-speak-btn:hover{background:color-mix(in srgb,var(--success) 12%,transparent)}.cs-btn-sm{background:var(--primary);color:var(--me-bach);border:none;border-radius:8px;padding:7px 14px;font-size:13px;font-weight:600;cursor:pointer;margin-top:8px}.cs-btn-sm:hover{background:var(--chau-hong-2)}.cs-intro{padding:0 16px 100px;text-align:center}.cs-intro-scene{position:relative;height:220px;display:flex;align-items:flex-end;justify-content:center;overflow:hidden;background:linear-gradient(135deg,var(--hoang-kim-soft) 0%,var(--hoang-kim-3) 100%);background-size:cover;background-position:center 35%;border-radius:0 0 20px 20px;margin-bottom:20px}.cs-intro-scene:after{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,#0000000f,#0000 35%,#00000038);pointer-events:none}.cs-mai-img{position:relative;z-index:1;height:196px;width:auto;object-fit:contain;object-position:bottom center;filter:drop-shadow(0 6px 14px rgba(0,0,0,.22));transform-origin:bottom center;animation:cs-bounce-in .5s cubic-bezier(.34,1.56,.64,1) both,cs-breathe 3.2s ease-in-out .5s infinite}.cs-intro-title{font-size:22px;font-weight:800;color:var(--fg);margin:0 0 8px}.cs-intro-context{font-size:15px;color:var(--fg-2);line-height:1.6;margin:0 0 20px}.cs-intro-vocab{margin-bottom:28px}.cs-intro-vocab-label{font-size:12px;font-weight:700;color:var(--fg-3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}.cs-vocab-chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.cs-vocab-chip{background:var(--primary-soft, rgba(220,38,38,.1));color:var(--primary);border-radius:20px;padding:6px 14px;font-size:18px;font-weight:700}.cs-start-btn{width:100%;max-width:280px;padding:14px;font-size:17px}.cs-handout-btn,.cs-grammar-btn{display:block;width:100%;max-width:280px;margin:10px auto 0;padding:12px;font-size:15px}.cs-pinyin-link-card{background:var(--hoang-kim-soft);border:1px solid var(--hoang-kim);border-radius:14px;padding:14px 14px 16px;margin:0 0 20px;text-align:center}.cs-plc-head{font-size:14px;font-weight:700;color:var(--fg-2);margin-bottom:12px}.cs-plc-btns{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.cs-plc-btn{background:var(--bg);color:var(--hoang-kim-2);border:1px solid var(--hoang-kim);border-radius:20px;padding:7px 16px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s,color .15s}.cs-plc-btn:hover{background:var(--hoang-kim);color:var(--me-bach)}.cs-objectives{background:var(--thuy-luc-soft);border-left:3px solid var(--thuy-luc);border-radius:10px;padding:14px 16px;margin:0 0 24px;text-align:left}.cs-objectives-label{font-size:13px;font-weight:700;color:var(--fg-2);margin-bottom:8px}.cs-objectives-list{margin:0;padding-left:20px;list-style:disc}.cs-objectives-list li{font-size:14px;color:var(--fg-2);line-height:1.6;margin-bottom:4px}.cs-grammar-block{text-align:left;margin:8px auto 24px;max-width:560px}.cs-grammar-title{font-size:16px;font-weight:800;color:var(--fg);margin:0 0 12px}.cs-grammar-note{background:var(--bg-2);border:1px solid var(--border-2);border-radius:12px;padding:14px 16px;margin-bottom:12px}.cs-vn-toggle--on{background:var(--primary);color:#fff;border-color:var(--primary)}.cs-vn-listen-ph{display:flex;flex-direction:column;align-items:center;gap:12px;padding:22px 16px;text-align:center}.cs-vn-listen-hint{margin:0;font-size:14px;color:var(--fg-2)}.cs-vn-reveal-btn{width:auto;min-width:140px}.cs-warmup-hint{font-size:14px;color:var(--fg-2);margin:0 0 14px;text-align:center}.cs-warmup-q{display:flex;align-items:center;gap:10px;justify-content:center;flex-wrap:wrap}.cs-warmup-hanzi{font-size:34px;font-weight:800;color:var(--fg)}.cs-warmup-py{font-size:16px;color:var(--fg-2)}.cs-gn-point{font-size:15px;font-weight:700;color:var(--primary);margin-bottom:6px}.cs-gn-pattern{display:inline-block;margin-left:6px;padding:1px 8px;font-size:12.5px;font-weight:600;color:var(--fg-2);background:var(--bg);border:1px solid var(--border-2);border-radius:999px;vertical-align:middle}.cs-gn-explain{font-size:14px;color:var(--fg-2);line-height:1.6;margin-bottom:10px}.cs-gn-examples{display:flex;flex-direction:column;gap:8px}.cs-gn-ex{background:var(--bg);border-radius:8px;padding:8px 12px;border:1px solid var(--border-2)}.cs-gn-ex-zh{display:block;font-size:16px;font-weight:700;color:var(--fg)}.cs-gn-ex-py{display:block;font-size:13px;color:var(--hoang-kim-2);margin-top:2px}.cs-gn-ex-vi{display:block;font-size:13px;color:var(--fg-3);margin-top:2px}.cs-grammar-modal{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;padding:16px;z-index:9000;animation:cs-gm-fade .18s ease both}@keyframes cs-gm-fade{0%{opacity:0}to{opacity:1}}.cs-grammar-modal-box{position:relative;background:var(--bg);border-radius:16px;padding:20px 18px 18px;max-width:560px;width:100%;max-height:85vh;overflow-y:auto;box-shadow:0 12px 40px #00000040}.cs-grammar-modal-box .cs-grammar-block{margin:0}.cs-grammar-modal-close{position:absolute;top:12px;right:12px;background:var(--surface-3);border:1px solid var(--border-2);color:var(--fg-2);width:32px;height:32px;border-radius:50%;font-size:15px;cursor:pointer;line-height:1}.cs-grammar-modal-close:hover{background:var(--border-2)}.cs-checkpoint{padding:16px 16px 100px}.cs-checkpoint-title{font-size:17px;font-weight:700;color:var(--fg);margin:0 0 16px}.cs-question{background:var(--me-bach);border-radius:12px;box-shadow:0 1px 8px #00000012;padding:16px;margin-bottom:12px}.cs-q-text{font-size:15px;font-weight:600;color:var(--fg);margin-bottom:12px;line-height:1.5}.cs-opts{display:flex;flex-direction:column;gap:8px}.cs-opt{background:var(--surface-3);color:var(--fg);border:1.5px solid var(--border-2);border-radius:8px;padding:10px 14px;font-size:14px;text-align:left;cursor:pointer;transition:background .15s,border-color .15s}.cs-opt:hover:not(:disabled){background:var(--primary-soft);border-color:var(--primary)}.cs-opt-correct{background:#10b9811f!important;border-color:var(--thuy-luc)!important;color:var(--thuy-luc-2);font-weight:700}.cs-opt-wrong{background:#dc26261a!important;border-color:var(--primary)!important;color:var(--primary);text-decoration:line-through}.cs-opt-sm{padding:7px 12px;font-size:13px}.cs-checkpoint-next{width:100%;margin-top:8px;padding:13px;font-size:16px}.cs-vocab-review{padding:16px 16px 100px}.cs-section-title{font-size:17px;font-weight:700;color:var(--fg);margin:0 0 16px}.cs-vocab-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:20px}.cs-vocab-card{background:var(--me-bach);border-radius:12px;box-shadow:0 1px 6px #00000012;padding:14px 12px;text-align:center}.cs-vc-hanzi{font-size:24px;font-weight:800;color:var(--fg);margin-bottom:4px}.cs-vc-pinyin{font-size:13px;color:var(--hoang-kim);font-weight:500;margin-bottom:4px}.cs-vc-meaning{font-size:12px;color:var(--fg-3)}.cs-vc-en{font-size:11px;color:var(--fg-4);opacity:.7;font-style:italic;margin-top:2px}.cs-vc-colloc{display:flex;flex-wrap:wrap;gap:4px;justify-content:center;margin-top:8px}.cs-vc-chip{font-size:11px;padding:2px 7px;border-radius:999px;background:var(--bg-2);border:1px solid var(--border-2);color:var(--fg-2)}.cs-vc-ex{margin-top:8px;padding-top:8px;border-top:1px dashed var(--border-2);text-align:left}.cs-vc-ex-zh{display:block;font-size:12.5px;font-weight:600;color:var(--fg);line-height:1.5}.cs-vc-ex-py,.cs-vc-ex-vi{display:block;font-size:10.5px;color:var(--fg-3)}.cs-vocab-next{width:100%;padding:13px;font-size:16px}.cs-workbook{padding:16px 16px 100px}.cs-diff-tabs{display:flex;gap:6px;margin-bottom:16px;background:var(--surface-3);border-radius:10px;padding:4px}.cs-diff-tab{flex:1;background:none;border:none;border-radius:8px;padding:8px;font-size:14px;font-weight:600;color:var(--fg-3);cursor:pointer;transition:background .15s,color .15s}.cs-diff-tab:hover{color:var(--fg);background:var(--border-2)}.cs-diff-active{background:var(--me-bach)!important;color:var(--primary)!important;box-shadow:0 1px 4px #00000014}.cs-exercises{display:flex;flex-direction:column;gap:12px}.cs-exercise{background:var(--me-bach);border-radius:12px;box-shadow:0 1px 8px #00000012;padding:16px}.cs-ex-num{font-size:11px;font-weight:700;color:var(--fg-4);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.cs-ex-sentence{font-size:18px;font-weight:600;color:var(--fg);margin-bottom:12px;line-height:1.6}.cs-blank{display:inline-block;width:48px;border-bottom:2.5px solid var(--primary);margin:0 4px;vertical-align:bottom}.cs-blank-filled{display:inline-block;min-width:40px;padding:0 6px;border-radius:4px;font-weight:800;margin:0 2px}.cs-blank-filled.cs-correct{background:#10b98126;color:var(--thuy-luc-2)}.cs-blank-filled.cs-wrong{background:#dc26261a;color:var(--primary);text-decoration:line-through}.cs-ex-label{font-size:13px;color:var(--fg-3);margin-bottom:8px}.cs-ex-prompt{font-size:16px;font-style:italic;color:var(--fg-2);margin-bottom:10px;line-height:1.5}.cs-word-btns{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}.cs-word-btn{background:var(--surface-3);color:var(--fg);border:1.5px solid var(--border-2);border-radius:8px;padding:8px 14px;font-size:16px;font-weight:600;cursor:pointer;transition:background .15s}.cs-word-btn:hover{background:var(--primary-soft);border-color:var(--primary)}.cs-word-selected{background:var(--primary)!important;color:var(--me-bach)!important;border-color:var(--primary)!important}.cs-order-result{font-size:16px;font-weight:700;color:var(--fg-2);min-height:28px;padding:4px 0}.cs-order-result.cs-correct{color:var(--thuy-luc)}.cs-order-result.cs-wrong{color:var(--primary)}.cs-translate-input{width:100%;border:1.5px solid var(--border-2);border-radius:8px;padding:10px 12px;font-size:16px;color:var(--fg);box-sizing:border-box;outline:none;margin-bottom:6px}.cs-translate-input:focus{border-color:var(--primary)}.cs-translate-ans{font-size:13px;color:var(--thuy-luc-2);margin-top:4px}.cs-translate-ans.cs-wrong{color:var(--primary)}.cs-translate-ans.cs-correct{color:var(--thuy-luc-2)}.cs-ex-explain{margin-top:10px;padding:8px 12px;font-size:13px;line-height:1.5;color:var(--fg-2);background:var(--bg-2, rgba(245,158,11,.08));border-left:3px solid var(--hoang-kim);border-radius:6px}.cs-wb-submit{width:100%;padding:13px;font-size:16px;margin-top:16px}.cs-ex-play{display:inline-flex;align-items:center;gap:6px;background:var(--primary-soft, rgba(220,38,38,.08));color:var(--primary);border:1.5px solid var(--primary);border-radius:999px;padding:8px 18px;font-size:15px;font-weight:700;cursor:pointer;margin-bottom:12px;transition:background .15s,transform .1s}.cs-ex-play:hover{background:var(--primary);color:var(--me-bach)}.cs-ex-play:active{transform:scale(.97)}.cs-listen-reveal{margin-top:8px;font-weight:700;color:var(--fg)}.cs-listen-hanzi{font-size:18px}.cs-listen-py{font-size:13px;font-weight:600;color:var(--fg-3)}.cs-complete{padding:40px 24px 100px;text-align:center;position:relative;overflow:hidden}.cs-confetti{position:absolute;top:0;left:0;right:0;pointer-events:none;overflow:hidden;height:200px}.cs-confetti span{position:absolute;top:-10px;width:8px;height:14px;border-radius:2px;animation:cs-fall 2.5s ease-in forwards;opacity:.9}@keyframes cs-fall{0%{transform:translateY(-10px) rotate(0);opacity:1}to{transform:translateY(220px) rotate(540deg);opacity:0}}.cs-mai-complete{width:120px;height:120px;object-fit:contain;margin:0 auto 16px;display:block;position:relative;z-index:1}.cs-complete-title{font-size:24px;font-weight:800;color:var(--fg);margin:0 0 12px}.cs-xp-badge{display:inline-block;background:var(--hoang-kim);color:var(--me-bach);font-size:20px;font-weight:800;border-radius:20px;padding:6px 20px;margin-bottom:16px}.cs-complete-msg{font-size:15px;color:var(--fg-2);line-height:1.6;margin-bottom:28px}.cs-complete-btns{display:flex;flex-direction:column;gap:12px;align-items:center}.cs-complete-btns .cs-btn-primary,.cs-complete-btns .cs-btn-secondary{width:100%;max-width:320px;padding:14px;font-size:16px}.cs-debt-warning{padding:40px 24px;text-align:center;background:var(--warning-bg);border-radius:16px;margin:20px 16px;border:1.5px solid color-mix(in srgb,var(--hoang-kim) 35%,var(--border))}.cs-debt-icon{font-size:40px;margin-bottom:12px}.cs-debt-warning h3{font-size:18px;font-weight:700;color:var(--hoang-kim-2);margin:0 0 8px}.cs-debt-warning p{font-size:14px;color:var(--hoang-kim-2);margin:0 0 20px}.cs-debt-btns{display:flex;flex-direction:column;gap:10px;align-items:center}.cs-debt-btns .cs-btn-primary,.cs-debt-btns .cs-btn-secondary{width:100%;max-width:280px;padding:12px}.cs-coming-soon{padding:60px 24px;text-align:center}.cs-coming-icon{font-size:48px;margin-bottom:16px}.cs-coming-soon h3{font-size:20px;font-weight:700;color:var(--fg);margin:0 0 10px}.cs-coming-soon p{font-size:15px;color:var(--fg-2);margin:0 0 24px}.cs-overlay{position:absolute;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:50;border-radius:inherit}.cs-overlay-box{background:var(--me-bach);border-radius:16px;padding:28px 24px;text-align:center;max-width:300px;box-shadow:0 8px 32px #0000002e}.cs-overlay-icon{font-size:36px;margin-bottom:10px}.cs-overlay-title{font-size:18px;font-weight:800;color:var(--fg);margin-bottom:8px}.cs-overlay-msg{font-size:14px;color:var(--fg-2);line-height:1.5;margin-bottom:18px}.cs-opt:disabled,.cs-opt[disabled]{opacity:1;cursor:default;color:var(--fg-3)}.cs-opt-correct:disabled,.cs-opt-correct[disabled]{color:var(--thuy-luc-2)}.cs-opt-wrong:disabled,.cs-opt-wrong[disabled]{color:var(--primary)}.cs-list{padding:16px 16px 80px}.cs-list-title{font-size:18px;font-weight:700;color:var(--fg);margin:0 0 16px}.cs-path{padding:16px 16px 80px}.cs-path-progress{font-size:12px;font-weight:600;color:var(--thuy-luc);background:#10b9811a;padding:4px 10px;border-radius:12px;flex-shrink:0}.cs-path-hero{background:linear-gradient(135deg,var(--hoang-kim) 0%,var(--hoang-kim-2) 100%);border-radius:16px;padding:20px;margin-bottom:24px;color:var(--me-bach);text-align:center}.cs-path-hero--done{background:linear-gradient(135deg,var(--thuy-luc) 0%,var(--thuy-luc-2) 100%)}.cs-hero-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1px;opacity:.9;margin-bottom:8px}.cs-hero-title{font-size:18px;font-weight:700;margin-bottom:6px}.cs-hero-context{font-size:13px;opacity:.9;margin-bottom:16px;line-height:1.4}.cs-hero-btn{background:#fffffff2;color:var(--hoang-kim);border:none;border-radius:10px;padding:12px 28px;font-size:15px;font-weight:700;cursor:pointer;transition:transform .15s,box-shadow .15s}.cs-hero-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}.cs-path-hero--done .cs-hero-btn{display:none}.cs-chapter{margin-bottom:24px}.cs-chapter-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.cs-chapter-label{font-size:11px;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.5px}.cs-chapter-title{font-size:14px;font-weight:600;color:var(--fg);flex:1}.cs-chapter-count{font-size:12px;color:var(--fg-3)}.cs-chapter-bar{height:4px;background:var(--border-2);border-radius:2px;overflow:hidden;margin-bottom:12px}.cs-chapter-fill{height:100%;background:var(--thuy-luc);border-radius:2px;transition:width .4s ease}.cs-nodes{display:flex;flex-wrap:wrap;gap:8px}.cs-node{width:44px;height:44px;border-radius:50%;border:2.5px solid var(--border-2);background:var(--surface-2);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color .15s,transform .15s,box-shadow .15s;font:inherit;padding:0}.cs-node:hover{transform:scale(1.08)}.cs-node-icon{font-size:14px;font-weight:700;color:var(--fg-2)}.cs-node--done{border-color:var(--thuy-luc);background:#10b9811a}.cs-node--done .cs-node-icon{color:var(--thuy-luc);font-size:16px}.cs-node--current{border-color:var(--hoang-kim);background:#f59e0b26;box-shadow:0 0 0 4px #f59e0b33;animation:cs-pulse 2s ease-in-out infinite}.cs-node--current .cs-node-icon{color:var(--hoang-kim)}@keyframes cs-pulse{0%,to{box-shadow:0 0 0 4px #f59e0b33}50%{box-shadow:0 0 0 8px #f59e0b1a}}.cs-node--locked{opacity:.45;cursor:pointer}.cs-node--locked .cs-node-icon{color:var(--fg-3)}.cs-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}.cs-tab{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:22px;border:2px solid var(--border-2);background:var(--surface-2);font:inherit;font-weight:700;font-size:13px;color:var(--fg-2);cursor:pointer;transition:border-color .15s,background .15s,color .15s}.cs-tab:hover{border-color:var(--hoang-kim)}.cs-tab--active{background:var(--hoang-kim);border-color:var(--hoang-kim);color:var(--me-bach)}.cs-tab--locked{opacity:.5;cursor:not-allowed}.cs-tab--locked:hover{border-color:var(--border-2)}.cs-tab-count{font-size:11px;font-weight:600;opacity:.8}.cs-nodes--list{flex-direction:column;gap:4px}.cs-node-row{display:flex;align-items:center;gap:12px;width:100%;text-align:left;background:none;border:none;padding:5px 4px;border-radius:10px;cursor:pointer;font:inherit;transition:background .15s}.cs-node-row:hover{background:var(--surface-2)}.cs-node-row:hover .cs-node{transform:scale(1.08)}.cs-node-row .cs-node{flex-shrink:0}.cs-node-row-title{font-size:14px;font-weight:600;color:var(--fg);line-height:1.3}.cs-node-row--done .cs-node-row-title{color:var(--fg-3)}.cs-node-row--locked{opacity:.55}.cs-node-rowwrap{display:flex;align-items:center;gap:2px}.cs-node-rowwrap .cs-node-row{flex:1;min-width:0}.cs-node-handout{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:8px;background:none;color:var(--fg-3);cursor:pointer;transition:background .15s,color .15s}.cs-node-handout:hover{background:var(--surface-2);color:var(--primary)}[data-theme=dark] .cs-node-handout:hover,[data-theme=dark] .cs-node-row:hover{background:#ffffff0d}.cs-checkpoint-wrap{margin:4px 0 4px 14px;padding-left:14px;border-left:2px dashed var(--border-2)}.cs-node-row--checkpoint .cs-node-row-title{font-weight:700}.cs-node-row--checkpoint:not(.cs-node-row--locked):not(.cs-node-row--done) .cs-node-row-title{color:var(--warning)}.cs-node-row--checkpoint[disabled]{cursor:default}.cs-chapter--boss{border:1px solid var(--warning);border-radius:14px;padding:10px 12px}.cs-node-row--boss .cs-node-row-title{color:var(--warning)}.cs-node-row--checkpoint.cs-node-row--review:not(.cs-node-row--locked):not(.cs-node-row--done) .cs-node-row-title{color:var(--primary)}[data-theme=dark] .cs-tab{background:var(--card-bg)}[data-theme=dark] .cs-tab--active{background:var(--hoang-kim);border-color:var(--hoang-kim);color:var(--me-bach)}[data-theme=dark] .cs-node{background:var(--card-bg)}[data-theme=dark] .cs-path-progress{background:#10b98126}[data-theme=dark] .cs-question,[data-theme=dark] .cs-exercise,[data-theme=dark] .cs-vocab-card{background:var(--card-bg)}[data-theme=dark] .cs-header,[data-theme=dark] .cs-controls{background:var(--bg);border-color:var(--border-2)}@media(min-width:640px){.cs-vocab-grid{grid-template-columns:repeat(3,1fr)}.cs-controls{padding:12px 24px}}@media(max-width:375px){.cs-text-zh{font-size:22px}.cs-vc-hanzi{font-size:20px}}.cs-vn-stage{position:relative;overflow:hidden;background:linear-gradient(180deg,color-mix(in srgb,var(--hoang-kim-3) 14%,transparent),color-mix(in srgb,var(--thuy-luc) 10%,transparent) 55%,color-mix(in srgb,var(--hsk-3) 25%,transparent));background-size:cover;background-position:center;border-bottom:1px solid var(--border-2);aspect-ratio:16 / 9;min-height:320px;max-height:480px;display:flex;flex-direction:column;justify-content:flex-end;padding:12px 16px 10px}.cs-vn-stage:before{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,#0000001a,#0000000d,#00000059);pointer-events:none;z-index:0}.cs-vn-scene-tag,.cs-vn-cast,.cs-vn-narrator-card{position:relative;z-index:1}[data-theme=dark] .cs-vn-stage{background:linear-gradient(180deg,color-mix(in srgb,var(--info) 25%,transparent),color-mix(in srgb,var(--thuy-luc-2) 20%,transparent) 55%,color-mix(in srgb,var(--mac-hac-3) 40%,transparent));background-size:cover;background-position:center top}[data-theme=dark] .cs-vn-stage:before{background:linear-gradient(to bottom,#00000038,#0000001f,#00000080)}.cs-vn-scene-tag{position:absolute;top:12px;left:12px;background:#00000085;color:var(--me-bach);padding:4px 12px;border-radius:999px;font-size:.74rem;font-weight:600;backdrop-filter:blur(4px);max-width:calc(100% - 24px);white-space:normal;word-break:keep-all;overflow-wrap:break-word}.cs-vn-cast{display:flex;justify-content:space-around;align-items:flex-end;gap:12px;min-height:220px;padding-bottom:8px}.cs-vn-char{display:flex;flex-direction:column;align-items:center;gap:6px;flex:0 0 auto;width:120px;transition:transform .28s ease,opacity .28s ease,filter .28s ease}.cs-vn-char.active{transform:translateY(-8px) scale(1.08);opacity:1;z-index:2}.cs-vn-char.active .cs-vn-avatar{filter:drop-shadow(0 10px 18px rgba(0,0,0,.28)) brightness(1.04)}.cs-vn-char.active .cs-vn-avatar:after{content:"";position:absolute;left:50%;bottom:2px;width:78%;height:14px;transform:translate(-50%);background:radial-gradient(ellipse at center,#0000004d,#0000 70%);pointer-events:none}.cs-vn-char.cs-vn-speaking .cs-vn-avatar-img{animation:cs-vn-talk .9s ease-in-out infinite}@keyframes cs-vn-talk{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-4px) scale(1.02)}}.cs-vn-char.inactive{opacity:.45;filter:grayscale(.65) brightness(.82);transform:scale(.85) translateY(2px);z-index:1}.cs-vn-avatar{width:100%;height:180px;position:relative;display:flex;align-items:flex-end;justify-content:center;flex-shrink:0;transition:filter .28s ease}.cs-vn-avatar-emoji{font-size:48px;line-height:1;pointer-events:none;position:absolute;bottom:20px}.cs-vn-avatar-img{width:100%;height:100%;object-fit:contain;object-position:bottom center;transition:transform .28s ease}.cs-vn-char-name{font-size:.74rem;font-weight:700;color:var(--me-bach);background:var(--char-color, var(--text3));padding:2px 10px;border-radius:999px;white-space:nowrap}.cs-vn-char-role{font-size:.64rem;color:var(--fg-3);text-align:center}.cs-vn-narrator-card{align-self:center;margin:auto;background:#00000094;color:var(--me-bach);padding:14px 20px;border-radius:14px;text-align:center;font-size:.95rem;line-height:1.55;max-width:82%;backdrop-filter:blur(4px)}.cs-vn-dlg{background:color-mix(in srgb,var(--surface) 90%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border-2);border-radius:18px;box-shadow:0 -1px 8px #0000000d,0 8px 22px #0000002e;margin:-34px 14px 14px;padding:16px;position:relative;z-index:3;min-height:120px}[data-theme=dark] .cs-vn-dlg{background:color-mix(in srgb,var(--card-bg) 90%,transparent)}.cs-vn-dlg-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.cs-vn-dlg-speaker{display:inline-flex;align-items:center;gap:5px;font-size:.82rem;font-weight:700;color:var(--me-bach);padding:4px 12px;border-radius:999px;white-space:nowrap}.cs-vn-speak-btn{border:none;background:#dc26261a;color:var(--primary);width:40px;height:40px;border-radius:50%;cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}.cs-vn-speak-btn:hover{background:var(--primary);color:var(--me-bach)}.cs-vn-dlg-pinyin{color:var(--hoang-kim);font-size:.95rem;font-weight:500;margin-bottom:4px;min-height:1.2em}.cs-vn-dlg-hanzi{font-size:1.85rem;font-weight:700;color:var(--fg);line-height:1.4;letter-spacing:1px}.cs-vn-dlg-vi{font-size:.95rem;color:var(--fg-2);font-style:italic;margin-top:8px;line-height:1.5}.cs-vn-dlg-hanzi .cs-vn-word{cursor:pointer;border-radius:4px;padding:0 1px;transition:background .12s}.cs-vn-dlg-hanzi .cs-vn-word:hover,.cs-vn-dlg-hanzi .cs-vn-word:active{background:var(--primary-soft)}.cs-vn-dlg-hanzi .cs-vn-h-focus{color:var(--primary);border-bottom:2px solid var(--primary)}.cs-vn-h-skip{cursor:default}.cs-vn-wordpop{position:absolute;z-index:1200;width:220px;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow-3);padding:12px 14px;font-family:var(--font-ui);font-style:normal}.cs-vn-wp-head{display:flex;align-items:center;gap:6px;margin-bottom:6px}.cs-vn-wp-h{flex:1;font-size:22px;font-weight:700;font-family:var(--font-hanzi);color:var(--text)}.cs-vn-wp-ic{background:none;border:none;cursor:pointer;font-size:15px;color:var(--text2);padding:2px 4px;line-height:1}.cs-vn-wp-ic:hover{color:var(--text)}.cs-vn-wp-py{color:var(--hoang-kim-2);font-size:14px;margin-bottom:2px}.cs-vn-wp-vi{color:var(--text);font-size:14px;margin-bottom:8px;line-height:1.4}.cs-vn-wp-foot{display:flex;align-items:center;justify-content:space-between}.cs-vn-wp-lv{font-size:11px;font-weight:700;color:var(--text3)}.cs-vn-wp-add{background:var(--primary);color:var(--me-bach);border:none;border-radius:8px;padding:5px 12px;font-size:12px;font-weight:700;cursor:pointer}.cs-vn-wp-add:hover{background:var(--primary-light)}.cs-vn-py-toggle{background:var(--surface-3);border:1px solid var(--border-2);border-radius:6px;padding:3px 8px;font-size:.72rem;font-weight:600;color:var(--fg-3);cursor:pointer;flex-shrink:0;transition:color .15s,border-color .15s}.cs-vn-py-toggle:hover{color:var(--primary);border-color:var(--primary)}@media(max-width:375px){.cs-vn-stage{min-height:240px}.cs-vn-char{width:90px}.cs-vn-avatar{height:140px}.cs-vn-avatar-emoji{font-size:36px}.cs-vn-dlg-hanzi{font-size:1.6rem}}@media(min-width:500px){.cs-vn-char{width:140px}.cs-vn-avatar{height:210px}.cs-vn-avatar-emoji{font-size:56px}}@media(min-width:640px){.cs-vn-stage{max-height:520px}}.cs-order-strip{display:flex;flex-wrap:wrap;gap:6px;align-items:center;min-height:46px;padding:8px 10px;margin-bottom:10px;border:1px dashed var(--border);border-radius:10px}.cs-order-ph{color:var(--text-muted);font-size:13px}.cs-word-btn.cs-word-used{opacity:.35;pointer-events:none}.cs-word-btn.cs-word-placed{border-color:var(--primary)}.cs-btn-sm:disabled{opacity:.45;cursor:not-allowed}
