.learn-header{margin-bottom:16px}.mode-select-wrap{margin-top:10px}#learnModeSelect{padding:8px 16px;border-radius:10px;background:var(--surface2);border:1px solid var(--border);color:var(--text);font-size:15px;font-weight:600;cursor:pointer}.learn-setup-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;display:flex;flex-direction:column;gap:20px;margin-bottom:24px}.setup-mode-badge{display:inline-block;background:var(--surface2);padding:6px 12px;border-radius:8px;font-size:14px;font-weight:600;color:var(--primary);align-self:flex-start}.setup-fields{display:flex;gap:20px;flex-wrap:wrap}.setup-field{display:flex;flex-direction:column;gap:8px}.setup-field label{font-size:13px;color:var(--text2);font-weight:600}.setup-field select{padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:14px;cursor:pointer;min-width:120px}.btn-start-learn{padding:14px;font-size:16px;margin-top:8px}.flashcard-area,.typing-area,.mcq-area,.session-result{max-width:var(--maxw-narrow, 720px);margin-left:auto;margin-right:auto}.session-header{display:flex;align-items:center;gap:var(--s-3);margin-bottom:var(--s-6)}.session-prog{flex:1;height:8px}.session-progress-num{font-size:var(--t-small);font-weight:600;color:var(--text3);white-space:nowrap}.session-score{display:flex;align-items:center;gap:var(--s-3);font-size:var(--t-small);font-weight:700}.session-score .ss-correct{display:inline-flex;align-items:center;gap:3px;color:var(--success)}.session-score .ss-wrong{display:inline-flex;align-items:center;gap:3px;color:var(--danger)}.btn-exit{display:inline-flex;align-items:center;justify-content:center;background:var(--surface2);border:none;width:36px;height:36px;border-radius:50%;color:var(--text2);cursor:pointer;flex-shrink:0;transition:background var(--d-base) var(--ease-out),color var(--d-base) var(--ease-out)}.btn-exit:hover{background:var(--danger-bg);color:var(--danger)}.flashcard{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-5);padding:var(--s-8) var(--s-6);text-align:center;min-height:380px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow-2);transition:transform var(--d-fast) var(--ease-out);perspective:1000px;position:relative}.flashcard:active{transform:scale(.98)}.fc-front,.fc-back{width:100%}.fc-front{display:flex;flex-direction:column;align-items:center;gap:var(--s-3)}.fc-back,.flashcard.flipped .fc-front{display:none}.flashcard.flipped .fc-back{display:flex;flex-direction:column;align-items:center;gap:10px}.fc-hanzi{font-family:var(--font-hanzi);font-size:72px;font-weight:400;line-height:1.15;color:var(--text)}.fc-hanzi-sm{font-family:var(--font-hanzi);font-size:40px;font-weight:400;color:var(--text)}.fc-front #fcPinyin{display:none;font-size:var(--t-pinyin);color:var(--hoang-kim);font-weight:500}.fc-front.pinyin-shown #fcPinyin{display:block}.fc-front.pinyin-shown .fc-pinyin-toggle{display:none}.fc-pinyin-toggle{font-size:var(--t-small);padding:4px 8px}.fc-pinyin-back{color:var(--hoang-kim);font-size:var(--t-pinyin);font-weight:500}.fc-tap{color:var(--text3);font-size:var(--t-small);margin-top:var(--s-4)}.fc-meaning-vi{font-size:var(--t-body-lg);font-weight:600;color:var(--text);margin-top:8px}.fc-meaning-en{font-size:var(--t-small);color:var(--text3)}.fc-pos-chip{font-size:11px;font-weight:600;letter-spacing:.4px;color:var(--text3);background:var(--surface2);border:1px solid var(--border);border-radius:999px;padding:2px 9px;margin-top:4px;display:none}.fc-pos-chip:not(:empty){display:inline-block}.fc-ex-block{background:var(--surface2);padding:12px;border-radius:var(--r-3);margin-top:16px;width:100%;text-align:left}.fc-ex-zh{font-family:var(--font-hanzi);font-size:15px;color:var(--text);margin-bottom:4px}.fc-ex-py{font-size:12px;color:var(--hoang-kim)}.fc-context-card{margin-top:12px;padding:8px 12px;background:var(--primary-soft);border-radius:var(--r-3);font-size:13px;color:var(--text2);width:100%;text-align:left}.srs-buttons{margin-top:var(--s-6)}.srs-btns-inner{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s-2);width:100%}.srs-btn{min-height:56px;padding:8px;border-radius:var(--r-3);border:1px solid var(--border);font-size:15px;font-weight:600;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;transition:background var(--d-base) var(--ease-out),border-color var(--d-base) var(--ease-out);background:var(--surface);color:var(--text)}.srs-btn small{font-size:11px;font-weight:400;color:var(--text3)}.srs-again{background:var(--danger-bg);border-color:var(--danger);color:var(--danger)}.srs-again small{color:var(--danger);opacity:.8}.srs-easy{background:var(--success-bg);border-color:var(--success);color:var(--success)}.srs-easy small{color:var(--success);opacity:.8}.srs-again:hover{background:var(--danger);color:var(--me-bach)}.srs-again:hover small{color:var(--me-bach)}.srs-easy:hover{background:var(--success);color:var(--me-bach)}.srs-easy:hover small{color:var(--me-bach)}.srs-hard:hover,.srs-good:hover{border-color:var(--primary);background:var(--surface2)}body.session-active .right-sidebar,body.session-active .bottom-nav{display:none}@media(max-width:640px){.srs-btn{min-height:60px;font-size:16px}.srs-btns-inner{gap:var(--s-2)}.flashcard{min-height:300px;padding:var(--s-6) var(--s-4)}body.session-active .srs-buttons{position:fixed;left:0;right:0;bottom:0;margin:0;z-index:50;padding:var(--s-3) var(--s-3) calc(var(--s-3) + env(safe-area-inset-bottom));background:var(--bg);border-top:1px solid var(--border)}body.session-active .srs-buttons .srs-btns-inner{max-width:720px;margin:0 auto}body.session-active .flashcard-area,body.session-active .typing-area,body.session-active .mcq-area{padding-bottom:132px}}.typing-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-5);padding:var(--s-6);box-shadow:var(--shadow-2);max-width:560px;margin:0 auto}.ty-label{font-size:12px;color:var(--text3);font-weight:600;text-transform:uppercase;margin-bottom:6px}.ty-meaning{font-size:var(--t-h2);font-weight:700;color:var(--text);margin-bottom:16px}.ty-example{font-family:var(--font-hanzi);font-size:16px;color:var(--text2);margin-bottom:24px;background:var(--surface2);padding:12px;border-radius:8px;border-left:3px solid var(--primary)}.ty-hint-label{font-size:12px;color:var(--text3);font-weight:600;margin-bottom:4px}.ty-hint{font-size:20px;font-family:monospace;letter-spacing:2px;color:var(--primary);margin-bottom:20px}.ty-input-row{display:flex;gap:12px}.ty-input-row input{flex:1;background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:14px 16px;font-size:16px;color:var(--text);outline:none;transition:.2s}.ty-input-row input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.ty-feedback{margin-top:16px;padding:12px;border-radius:var(--r-3);font-weight:600;font-size:14px;text-align:center}.ty-feedback.correct{background:var(--success-bg);color:var(--success)}.ty-feedback.wrong{background:var(--danger-bg);color:var(--danger)}.ty-answer-block{margin-top:24px;border-top:1px solid var(--border);padding-top:24px;text-align:center}.ty-ans-row{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:8px}.ty-ans-hanzi{font-family:var(--font-hanzi);font-size:40px;color:var(--text)}.ty-ans-pinyin{font-size:var(--t-pinyin);color:var(--hoang-kim)}.ty-ans-meaning{font-size:16px;font-weight:500;margin-bottom:16px}.ty-next-btn{width:100%}.mcq-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-5);padding:var(--s-6);box-shadow:var(--shadow-2);text-align:center;max-width:560px;margin:0 auto}.mcq-question-word{margin-bottom:20px}.mcq-hanzi{font-family:var(--font-hanzi);font-size:56px;line-height:1.15;color:var(--text)}.mcq-pinyin{font-size:var(--t-pinyin);color:var(--hoang-kim);margin-top:4px}.mcq-pinyin.mcq-pinyin-masked{visibility:hidden}.mcq-word-actions{display:flex;align-items:center;justify-content:center;gap:var(--s-3);margin-top:var(--s-2)}.mcq-pinyin-toggle{font-size:var(--t-small);padding:4px 8px}.mcq-prompt{font-size:14px;font-weight:600;color:var(--text2);margin-bottom:20px}.mcq-options{display:grid;gap:var(--s-2)}.mcq-options .q-opt{min-height:52px}.tts-inline-btn{background:var(--surface2);border:1px solid var(--border);border-radius:50%;width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text2);transition:background var(--d-base) var(--ease-out),color var(--d-base) var(--ease-out)}.tts-inline-btn:hover{background:var(--primary);color:var(--me-bach);border-color:transparent}.session-result{text-align:center;padding:var(--s-8) 0}.sr-emoji{font-size:64px;margin-bottom:16px}.sr-emoji-img{display:inline-block;width:120px;height:120px;object-fit:contain;vertical-align:middle}.sr-title{font-size:var(--t-h1);margin-bottom:var(--s-6)}.sr-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-3);max-width:460px;margin:0 auto var(--s-6)}.sr-stat{display:flex;flex-direction:column;align-items:center;background:var(--surface2);border-radius:var(--r-3);padding:var(--s-4) var(--s-2)}.sr-stat span{font-size:28px;font-weight:700;color:var(--text)}.sr-stat small{font-size:12px;color:var(--text3);font-weight:500;text-transform:uppercase;margin-top:4px}.sr-correct span{color:var(--success)}.sr-wrong span{color:var(--danger)}.sr-xp span{color:var(--hoang-kim)}.sr-due{color:var(--text2);font-size:14px;margin:0 0 var(--s-5)}.sr-actions{display:flex;gap:var(--s-3);justify-content:center;flex-wrap:wrap}.srs-btn-simple{font-size:16px!important}.ty-slots-row{display:flex;align-items:center;gap:10px;justify-content:center;margin:8px 0 4px}.ty-char-slots{display:flex;gap:6px}.ty-char-slot{width:44px;height:48px;border-bottom:2px solid var(--border);display:flex;align-items:flex-end;justify-content:center;font-size:24px;font-family:var(--font-hanzi);color:var(--text);padding-bottom:4px;transition:border-color var(--d-base) var(--ease-out),color var(--d-base) var(--ease-out)}.ty-char-slot.revealed{border-color:var(--primary);color:var(--primary)}.ty-char-count{font-size:12px;color:var(--text3);white-space:nowrap}.ty-hint-row{display:flex;align-items:center;gap:8px;justify-content:center;margin-bottom:4px}.ty-reveal-btn{display:inline-flex;align-items:center;justify-content:center;background:none;border:1px solid var(--border);border-radius:var(--r-2);padding:6px;cursor:pointer;color:var(--text2);transition:background var(--d-base) var(--ease-out)}.ty-reveal-btn:hover{background:var(--surface2);color:var(--hoang-kim)}.ls-tts-block{display:flex;flex-direction:column;align-items:center;gap:8px;margin:16px 0 24px}.ls-tts-btn{width:72px;height:72px;border-radius:50%;border:none;background:var(--primary-soft);color:var(--primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform var(--d-fast) var(--ease-out)}.ls-tts-btn:hover{transform:scale(1.06)}.ls-tts-btn:active{transform:scale(.96)}.ls-tts-btn.playing{animation:ls-pulse .8s ease-in-out infinite alternate}.ls-tts-label{font-size:12px;color:var(--text3)}@keyframes ls-pulse{0%{box-shadow:0 0 0 0 var(--primary-soft)}to{box-shadow:0 0 0 10px transparent}}.dd-header{display:flex;align-items:center;gap:14px;margin-bottom:12px}.dd-header-info{flex:1}.dd-header-info h2{margin:0;font-size:20px;font-weight:800}.dd-meta-row{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text2);margin-top:2px}.dd-dot{color:var(--text3)}.preview-card-wrap{position:relative;margin:14px 0;display:flex;align-items:center;justify-content:center;gap:12px}.preview-card{flex:1;min-height:220px;max-width:600px;background:var(--surface);border-radius:18px;border:1.5px solid var(--border);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:32px 20px;cursor:pointer;user-select:none;position:relative;transition:transform .15s,box-shadow .15s;box-shadow:var(--shadow)}.preview-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-2)}.pc-hanzi{font-size:var(--t-hanzi-lg);line-height:1;color:var(--text);font-family:var(--font-hanzi);text-align:center}.pc-pinyin{font-size:var(--t-pinyin);color:var(--hoang-kim);font-weight:500;text-align:center}.pc-pinyin.pc-pinyin-masked{visibility:hidden}.pc-pinyin-toggle{font-size:var(--t-small);padding:4px 8px}.pc-tts{background:var(--surface2);border:1px solid var(--border);border-radius:50%;width:36px;height:36px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--d-base) var(--ease-out),color var(--d-base) var(--ease-out),transform var(--d-fast) var(--ease-out);color:var(--text2);position:absolute;top:14px;right:14px}.pc-tts:hover{background:var(--primary);color:var(--me-bach);border-color:transparent;transform:scale(1.1)}.pc-meaning{font-size:24px;color:var(--primary);font-weight:600;text-align:center;margin-top:6px}.pc-tap-hint{font-size:12px;color:var(--text3);margin-top:8px;letter-spacing:.5px}.preview-card.flipped{background:color-mix(in srgb,var(--thuy-luc) 8%,var(--surface))}[data-theme=dark] .preview-card.flipped{background:color-mix(in srgb,var(--thuy-luc) 14%,var(--surface))}[data-theme=dark] .pc-meaning{color:var(--thuy-luc)}.preview-nav{background:var(--surface);border:1.5px solid var(--border);border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background var(--d-base) var(--ease-out),color var(--d-base) var(--ease-out),border-color var(--d-base) var(--ease-out);color:var(--text2);flex-shrink:0}.preview-nav:hover{background:var(--primary);color:var(--me-bach);border-color:transparent}.preview-counter{position:absolute;bottom:-28px;left:50%;transform:translate(-50%);font-size:13px;color:var(--text2);font-weight:600;background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:3px 12px}.kb-hint{display:flex;align-items:center;gap:6px;flex-wrap:wrap;font-size:12px;color:var(--text3);margin:36px 0 14px;padding:8px 12px;background:var(--surface2);border-radius:8px}.kb-hint kbd{background:var(--surface);border:1px solid var(--border);border-radius:5px;padding:2px 6px;font-size:11px;font-family:monospace;color:var(--text2)}.mode-chips-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.mode-chip{background:var(--surface);border:1.5px solid var(--border);border-radius:22px;padding:8px 18px;font-size:14px;font-weight:600;cursor:pointer;transition:background var(--d-base) var(--ease-out),color var(--d-base) var(--ease-out),border-color var(--d-base) var(--ease-out);color:var(--text2);font-family:var(--font-ui);display:flex;align-items:center;gap:6px}.mode-chip.active{background:var(--primary-soft);color:var(--primary);border-color:var(--primary)}.mode-chip:hover:not(.active):not(.disabled){border-color:var(--primary);color:var(--primary)}.mode-chip.disabled{opacity:.45;cursor:not-allowed}.mode-chip small{font-size:10px;font-weight:400;opacity:.7}.btn-study-now{width:100%;max-width:400px;margin:0 auto 24px;display:flex}.dd-word-list-header{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:var(--text2);margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--border)}.dd-wl-count{font-size:12px;color:var(--text3)}.dd-word-list{display:flex;flex-direction:column;gap:4px}.ddwl-row{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:10px;background:var(--surface);border:1px solid transparent;cursor:pointer;transition:.15s}.ddwl-row:hover{border-color:var(--primary);background:var(--surface2)}.ddwl-num{font-size:11px;color:var(--text3);min-width:22px;text-align:right}.ddwl-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;background:var(--status-new)}.ddwl-dot--new{background:var(--status-new)}.ddwl-dot--learning{background:var(--status-learning)}.ddwl-dot--due{background:var(--status-due)}.ddwl-dot--mastered{background:var(--status-mastered)}.ddwl-hanzi{font-size:22px;min-width:44px;text-align:center;font-family:var(--font-hanzi)}.ddwl-info{flex:1}.ddwl-pinyin{font-size:13px;color:var(--hoang-kim);font-weight:500}.ddwl-meaning{font-size:13px;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ddwl-tts{background:none;border:none;cursor:pointer;color:var(--text3);display:inline-flex;align-items:center;justify-content:center;opacity:.7;transition:opacity var(--d-base) var(--ease-out),color var(--d-base) var(--ease-out),transform var(--d-fast) var(--ease-out);padding:4px}.ddwl-tts:hover{opacity:1;color:var(--hoang-kim);transform:scale(1.15)}#learnHub{padding:4px 0 32px}.lh-hero{margin-bottom:20px}.lh-hero-label{font-size:var(--t-label);font-weight:600;text-transform:uppercase;letter-spacing:var(--tracking-eyebrow);opacity:.85;margin-bottom:10px}.lh-hero-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.lh-hero-info{flex:1;min-width:0}.lh-cont-name{font-size:var(--t-h2);font-weight:700;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lh-cont-meta{font-size:var(--t-small);opacity:.9;margin-bottom:8px}.lh-hero .lh-cont-bar-wrap{background:#ffffff4d}.lh-cont-bar{background:var(--me-bach)}.lh-cont-btn.btn-primary{background:var(--me-bach);color:var(--primary);box-shadow:0 4px #0000002e;flex-shrink:0}.lh-cont-btn.btn-primary:active{box-shadow:0 2px #0000002e}.lh-section{margin-bottom:24px}.lh-section-label{font-size:var(--t-label);font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:var(--tracking-eyebrow);margin-bottom:12px}.lh-milestone{width:100%;display:flex;align-items:center;gap:12px;margin-bottom:12px;padding:12px 14px;border:1px solid color-mix(in srgb,var(--hoang-kim) 45%,var(--border));border-left:4px solid var(--hoang-kim);border-radius:var(--r-4);background:color-mix(in srgb,var(--hoang-kim) 8%,var(--surface));cursor:pointer;text-align:left;transition:background var(--d-base) var(--ease-out)}.lh-milestone:hover{background:color-mix(in srgb,var(--hoang-kim) 14%,var(--surface))}.lh-ms-icon{flex:0 0 auto;color:var(--hoang-kim);display:inline-flex}.lh-ms-body{flex:1 1 auto;display:flex;flex-direction:column;gap:2px;min-width:0}.lh-ms-title{font-size:14px;font-weight:700;color:var(--text)}.lh-ms-desc{font-size:12.5px;color:var(--text2)}.lh-ms-cta{flex:0 0 auto;display:inline-flex;align-items:center;gap:2px;font-size:13px;font-weight:700;color:var(--hoang-kim);white-space:nowrap}@media(max-width:480px){.lh-ms-cta{display:none}}.lh-today-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.lh-today-grid--3{grid-template-columns:repeat(3,1fr)}.lh-today-card{text-align:left;cursor:pointer;font:inherit;color:var(--text);display:flex;flex-direction:column;gap:4px;position:relative}.lh-today-card--done{background:var(--success-bg);border-color:var(--success)}.lh-today-card--done:hover{border-color:var(--success)}.lh-today-card--due .lh-today-num{color:var(--status-due)}.lh-today-card--new .lh-today-num{color:var(--primary)}.lh-today-icon{width:44px;height:44px;margin-bottom:4px}.lh-today-num{font-size:var(--t-h2);font-weight:800;line-height:1;margin-bottom:2px}.lh-today-lbl{font-size:13px;font-weight:600}.lh-today-desc{font-size:11px;color:var(--text2)}.lh-today-check:not(:empty){position:absolute;top:10px;right:12px;width:22px;height:22px;border-radius:50%;background:var(--success);color:var(--me-bach);font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center}.lh-dplan-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.lh-dplan-head-lbl{display:inline-flex;align-items:center;gap:6px;font-size:14px;font-weight:700;color:var(--text)}.lh-dplan-budget{padding:5px 10px;border-radius:8px;border:1px solid var(--border);background:var(--surface2);color:var(--text);font:inherit;font-size:12.5px;font-weight:600;cursor:pointer}.lh-dplan-list{display:flex;flex-direction:column;gap:8px}.lh-dplan-item{display:flex;align-items:center;gap:10px;width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-4);padding:6px 10px 6px 6px;transition:background var(--d-base) var(--ease-out),border-color var(--d-base) var(--ease-out)}.lh-dplan-item--done{background:var(--success-bg);border-color:var(--success)}.lh-dplan-check{flex:0 0 auto;width:26px;height:26px;border-radius:50%;border:2px solid var(--border);background:var(--surface);display:inline-flex;align-items:center;justify-content:center;color:var(--me-bach);cursor:pointer;padding:0;transition:.15s}.lh-dplan-check:hover{border-color:var(--success)}.lh-dplan-item--done .lh-dplan-check{background:var(--success);border-color:var(--success)}.lh-dplan-body{flex:1;min-width:0;display:flex;align-items:center;justify-content:space-between;gap:10px;background:none;border:none;padding:6px 0;text-align:left;font:inherit;color:var(--text);cursor:pointer}.lh-dplan-label{font-size:13.5px;font-weight:600}.lh-dplan-item--done .lh-dplan-label{color:var(--text2);text-decoration:line-through}.lh-dplan-min{font-size:11.5px;color:var(--text2);font-weight:600;white-space:nowrap}.lh-dplan-carry{display:inline-block;margin-left:4px;padding:1px 6px;border-radius:20px;background:var(--warning-bg);color:var(--warning);font-size:10px;font-weight:700;vertical-align:middle}.lh-dplan-arrow{flex:0 0 auto;color:var(--text3);display:inline-flex}.lh-dplan-empty{display:flex;flex-direction:column;align-items:flex-start;gap:12px;padding:16px;background:var(--surface);border:1px dashed var(--border);border-radius:var(--r-4)}.lh-dplan-empty-text{font-size:13.5px;color:var(--text2);line-height:1.5}.lh-dplan-empty-actions{display:flex;gap:8px;flex-wrap:wrap}.lh-timeline{display:flex;flex-direction:column}.lh-skel{display:flex;align-items:center;gap:12px;padding:12px 14px}.lh-skel .skel-dot{width:32px;height:32px;border-radius:50%;flex-shrink:0}.lh-skel .skel-line{height:14px;max-width:60%}.lh-tl-node{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);cursor:pointer;transition:.18s;text-align:left;width:100%;font:inherit;color:var(--text)}.lh-tl-node:hover{border-color:var(--primary);background:var(--surface2)}.lh-tl-node--active{border-color:var(--primary);background:color-mix(in srgb,var(--primary) 8%,var(--surface))}.lh-tl-node--done{opacity:.65}.lh-tl-node--soon{cursor:default;opacity:.5}.lh-tl-node--soon:hover{border-color:var(--border);background:var(--surface)}.lh-tl-node--hsk0{cursor:default;align-items:flex-start}.lh-tl-node--hsk0:hover{border-color:var(--border);background:var(--surface)}.lh-hsk0-modules{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:10px}.deck-preview-banner{margin:0 0 12px;padding:10px 14px;border-radius:10px;background:color-mix(in srgb,var(--hoang-kim) 12%,var(--surface));border:1px solid color-mix(in srgb,var(--hoang-kim) 35%,var(--border));color:var(--text);font-size:13px;line-height:1.5}.lh-tl-node--hsk0-collapsed .lh-hsk0-modules{display:none}.lh-hsk0-toggle{margin-top:8px;padding:6px 12px;border:1px solid var(--border);border-radius:8px;background:var(--surface2);color:var(--text2);font:inherit;font-size:12px;font-weight:600;cursor:pointer;transition:border-color .18s,color .18s}.lh-hsk0-toggle:hover{border-color:var(--primary);color:var(--text)}.lh-tl-node--hsk0:not(.lh-tl-node--hsk0-collapsed) .lh-hsk0-toggle{display:none}.lh-hsk0-mod{display:flex;flex-direction:column;align-items:center;gap:5px;padding:10px 6px;background:var(--surface2);border:1px solid var(--border);border-radius:10px;cursor:pointer;font:inherit;transition:border-color .18s,background .18s}.lh-hsk0-mod:hover{border-color:var(--primary);background:color-mix(in srgb,var(--primary) 8%,var(--surface))}.lh-hsk0-mod img{width:40px;height:40px;object-fit:contain}.lh-hsk0-mod-name{font-size:11px;font-weight:600;color:var(--text);text-align:center;line-height:1.3}.lh-tl-icon{min-width:32px;display:inline-flex;align-items:center;justify-content:center;color:var(--text2)}.lh-tl-node--active .lh-tl-icon,.lh-tl-node--spine.lh-tl-node--active .lh-tl-icon{color:var(--primary)}.lh-tl-body{flex:1;min-width:0}.lh-tl-name{font-size:15px;font-weight:600}.lh-tl-progress{height:4px;background:var(--surface2);border-radius:2px;overflow:hidden;margin:5px 0 4px}.lh-tl-bar{height:100%;background:var(--primary);border-radius:2px;transition:width .5s}.lh-tl-sub{font-size:12px;color:var(--text2)}.lh-here-chip{background:var(--primary);color:var(--me-bach);padding:1px 7px;border-radius:20px;font-size:11px;font-weight:600}.lh-tl-badge-soon{font-style:italic}.lh-tl-arrow-active{color:var(--primary);padding-left:4px;display:inline-flex;align-items:center}.lh-tl-connector{height:8px;width:2px;background:var(--border);margin:0 0 0 28px}.lh-tl-map-link{margin-top:10px;padding:10px 14px;text-align:center;font-size:13px;font-weight:600;color:var(--primary);background:none;border:1px dashed var(--border);border-radius:10px;cursor:pointer;transition:.18s;width:100%;font:inherit}.lh-tl-map-link:hover{background:var(--surface2);border-style:solid}.lh-tl-node--spine{border-width:2px}.lh-tl-node--spine.lh-tl-node--active{border-color:var(--primary);background:color-mix(in srgb,var(--primary) 10%,var(--surface));box-shadow:0 2px 10px color-mix(in srgb,var(--primary) 14%,transparent)}.lh-spine-tag{display:inline-block;margin-left:6px;vertical-align:middle;font-size:10px;font-weight:700;letter-spacing:.02em;color:var(--primary);background:color-mix(in srgb,var(--primary) 12%,var(--surface));padding:1px 7px;border-radius:20px}.lh-vocab-group{border:1px solid var(--border);border-radius:12px;background:var(--surface);overflow:hidden}.lh-vocab-head{display:flex;align-items:center;gap:12px;width:100%;padding:12px 14px;background:none;border:none;cursor:pointer;font:inherit;text-align:left;color:var(--text);transition:.15s}.lh-vocab-head:hover{background:var(--surface2)}.lh-vocab-chevron{color:var(--text2);display:inline-flex;align-items:center;transition:transform var(--d-base) var(--ease-out)}.lh-vocab-group.open .lh-vocab-chevron{transform:rotate(90deg)}.lh-hsk0-tog-chev{display:inline-flex;vertical-align:middle}.lh-vocab-list{display:none;padding:0 8px 8px;border-top:1px solid var(--border)}.lh-vocab-group.open .lh-vocab-list{display:block}.lh-vocab-row{display:flex;align-items:center;gap:10px;width:100%;padding:9px 8px;background:none;border:none;cursor:pointer;font:inherit;text-align:left;color:var(--text);border-radius:8px;transition:.15s}.lh-vocab-row:hover{background:var(--surface2)}.lh-vocab-row--cur{background:color-mix(in srgb,var(--primary) 7%,var(--surface))}.lh-vocab-ic{font-size:17px;min-width:24px;text-align:center}.lh-vocab-dot{width:24px;height:24px;min-width:24px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--me-bach)}.lh-vocab-nm{font-size:13px;font-weight:600;min-width:78px}.lh-vocab-mini{flex:1;height:4px;background:var(--surface2);border-radius:2px;overflow:hidden;min-width:40px}.lh-vocab-mini-bar{display:block;height:100%;background:var(--primary);border-radius:2px}.lh-vocab-cnt{font-size:11px;color:var(--text2);white-space:nowrap}.lh-resource-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}@media(max-width:480px){.lh-resource-grid{grid-template-columns:1fr}}.lh-resource-card{align-items:flex-start;text-align:left;font:inherit}.lh-resource-card .tool-card-icon{margin-top:2px}.lh-rc-body{flex:1;min-width:0}.lh-rc-title{font-size:15px;font-weight:700;color:var(--text);margin-bottom:4px}.lh-rc-purpose{font-size:12px;color:var(--text2);line-height:1.45;margin-bottom:10px}.lh-rc-progbar{height:5px;margin-bottom:8px}.lh-rc-foot{display:flex;align-items:center;justify-content:space-between;gap:8px}.lh-rc-count{font-size:11px;font-weight:600;color:var(--text2)}.lh-mistake-banner{display:flex;align-items:center;gap:10px;width:100%;margin-top:12px;padding:12px 16px;background:color-mix(in srgb,var(--warning) 10%,var(--surface));border:1px solid var(--warning);border-radius:var(--r-4);cursor:pointer;transition:background var(--d-base) var(--ease-out);text-align:left}.lh-mistake-banner:hover{background:color-mix(in srgb,var(--warning) 18%,var(--surface))}.lh-mb-icon{display:inline-flex;color:var(--warning)}.lh-mb-text{flex:1;font-size:14px;color:var(--text)}.lh-mb-cta{display:inline-flex;align-items:center;gap:2px;font-size:13px;font-weight:700;color:var(--warning);white-space:nowrap}.lh-util-row{display:flex;gap:8px;flex-wrap:wrap}.lh-util-chip{cursor:pointer;font-family:var(--font-ui)}.lh-story-card{display:flex;align-items:center;gap:14px;width:100%;background:var(--warning-bg);border:1.5px solid color-mix(in srgb,var(--warning) 60%,transparent);border-radius:var(--r-lg);padding:14px 16px;cursor:pointer;text-align:left;transition:box-shadow .18s,transform .15s;font:inherit}.lh-story-card:hover{box-shadow:0 4px 16px color-mix(in srgb,var(--warning) 20%,transparent);transform:translateY(-1px)}.lh-story-thumb{font-size:32px;flex-shrink:0}.lh-story-info{flex:1;min-width:0}.lh-story-title{font-size:15px;font-weight:700;color:var(--text)}.lh-story-meta{font-size:12px;color:var(--text2);margin-top:2px}.lh-story-arrow{font-size:18px;color:var(--primary);font-weight:700;flex-shrink:0}[data-theme=dark] .lh-story-card{background:linear-gradient(135deg,var(--warning-bg) 0%,var(--warning-bg) 100%);border-color:var(--hoang-kim-3)}[data-theme=dark] .lh-story-card:hover{box-shadow:0 4px 16px #f59e0b33}[data-theme=dark] .lh-story-title{color:var(--mac-hac)}[data-theme=dark] .lh-story-meta{color:var(--text3)}.lh-story-list-link{text-align:center;margin-top:8px}.lh-story-list-btn{background:none;border:none;color:var(--primary);font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;padding:4px 8px;border-radius:6px}.lh-story-list-btn:hover{background:var(--primary-soft, rgba(220,38,38,.08))}.lh-all-decks{margin-top:8px}.lh-all-btn{font-family:var(--font-ui)}@media(max-width:600px){.lh-support-grid{grid-template-columns:repeat(2,1fr)}.lh-today-grid{gap:10px}.lh-hero{padding:16px}.lh-cont-name{font-size:18px}.lh-cont-btn{width:100%;text-align:center}}.shortcut-hint-line{margin-top:16px;font-size:12px;color:var(--text3);text-align:center}@media(max-width:768px){.shortcut-hint-line{display:none}}
