@import "https://fonts.googleapis.com/css2?family=Be+Vietnam+Pro:wght@400;500;600;700;800&family=Noto+Serif+SC:wght@600;700;900&display=swap";:root{color:#2c241d;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;--ink:#2c241d;--muted:#756b60;--paper:#fffcf6;--red:#b94135;--red-dark:#913128;--green:#37725c;--line:#e7ddcf;--yellow:#f4c85c;background:#f8f3e9;font-family:Be Vietnam Pro,system-ui,sans-serif}*{box-sizing:border-box}html{background:#f8f3e9;min-width:320px}body{background:radial-gradient(circle at 5% 10%,#f4c85c2e,#0000 28rem),radial-gradient(circle at 95% 35%,#b9413517,#0000 30rem),#f8f3e9;min-width:320px;min-height:100vh;margin:0}button,a{font:inherit}button{-webkit-tap-highlight-color:transparent}button:focus-visible,a:focus-visible{outline-offset:3px;outline:3px solid #37725c59}#root{min-height:100vh}.app-shell{width:min(1180px,100% - 32px);margin:0 auto}.site-header{justify-content:space-between;align-items:center;min-height:92px;padding-top:12px;display:flex}.top-highlights{scrollbar-width:none;flex-wrap:wrap;gap:10px;padding:8px 0 10px;display:flex;overflow-x:auto}.top-highlights::-webkit-scrollbar{display:none}.top-highlight-item{min-height:42px;color:var(--muted);cursor:default;background:#fffcf6d9;border:1px solid #ffffffc7;border-radius:999px;align-items:center;gap:8px;padding:10px 16px;font-size:12px;font-weight:700;display:inline-flex;box-shadow:0 10px 26px #4b3a280f}.brand{color:var(--ink);align-items:center;gap:12px;text-decoration:none;display:inline-flex}.brand-mark{color:#fffaf0;background:linear-gradient(180deg, #ff8f75 0%, var(--red) 100%);border-radius:20px;place-items:center;width:56px;height:56px;font:700 30px/1 Noto Serif SC,serif;display:grid;box-shadow:0 14px 28px #b9413538}.brand strong,.brand small{display:block}.brand strong{letter-spacing:-.02em;font-size:18px}.brand small{color:var(--muted);margin-top:2px;font-size:12px}.header-badges{flex-wrap:wrap;gap:10px;display:flex}.free-badge,.play-badge{border:1px solid #d8e2d6;border-radius:999px;padding:7px 12px;font-size:12px;font-weight:700}.free-badge{color:var(--green);background:#edf6f1}.play-badge{color:#946200;background:#fff2cb;border-color:#f0d892}.hero-banner{grid-template-columns:360px minmax(0,1fr);gap:24px;margin:18px 0 10px;display:grid}.hero-mascot-card,.hero-summary{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffcf6c7;border:1px solid #ffffffa6;border-radius:28px;box-shadow:0 22px 50px #4b3a2814}.hero-mascot-card{background:radial-gradient(circle at top,#f4c85c47,#0000 42%),#fffcf6e0;place-items:center;min-height:250px;padding:24px 18px 18px;display:grid;position:relative;overflow:hidden}.hero-mascot{width:min(240px,100%);animation:3.2s ease-in-out infinite floaty}.hero-bubble{color:#5d4f41;text-align:center;background:#ffffffd1;border-radius:18px;gap:4px;width:100%;margin-top:4px;padding:13px 15px;font-size:13px;line-height:1.5;display:grid}.hero-bubble strong{color:var(--red-dark)}.hero-summary{align-content:center;gap:12px;padding:28px 28px 24px;display:grid}.hero-summary-label{color:var(--red);letter-spacing:.14em;text-transform:uppercase;margin:0;font-size:12px;font-weight:800}.hero-summary h2{letter-spacing:-.04em;margin:0;font-size:clamp(28px,4vw,42px);line-height:1.08}.hero-summary p{max-width:640px;color:var(--muted);margin:0;font-size:15px;line-height:1.7}.hero-highlights{flex-wrap:wrap;gap:10px;padding-top:4px;display:flex}.hero-highlights span{color:#785a12;background:#fff6dcbf;border:1px solid #f0dfb4;border-radius:999px;align-items:center;gap:6px;min-height:38px;padding:8px 14px;font-size:12px;font-weight:700;display:inline-flex}.hero-copy{grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:40px;padding:42px 0 26px;display:grid}.eyebrow{color:var(--red);letter-spacing:.12em;text-transform:uppercase;margin:0 0 8px;font-size:12px;font-weight:800}h1{color:#2f231b;letter-spacing:-.045em;max-width:680px;margin:0;font-size:clamp(32px,5vw,54px);line-height:1.08}.intro{max-width:580px;color:var(--muted);margin:14px 0 0;font-size:15px;line-height:1.7}.hero-mini-cards,.hero-stat-row{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:20px;display:grid}.hero-stat-card{border:1px solid #fffc;border-radius:22px;gap:4px;padding:16px 18px;display:grid;box-shadow:0 14px 34px #4b3a280f}.hero-stat-card strong{font-size:26px;line-height:1}.hero-stat-card span{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-size:11px;font-weight:700}.hero-stat-card.warm{color:#b86100;background:linear-gradient(#fff5da 0%,#fffaf0 100%)}.hero-stat-card.cool{color:#285d83;background:linear-gradient(#eef8ff 0%,#fafcff 100%)}.hero-stat-card.soft{color:#2d6b54;background:linear-gradient(#eef8f2 0%,#fbfffc 100%)}.mini-card{background:#fffcf6d1;border:1px solid #ffffffb8;border-radius:20px;align-items:flex-start;gap:10px;padding:14px;display:flex;box-shadow:0 14px 34px #4b3a280f}.mini-card-icon{background:linear-gradient(180deg, #ff8f75 0%, var(--red) 100%);color:#fff;border-radius:10px;flex:none;place-items:center;width:28px;height:28px;font-size:12px;font-weight:800;display:grid}.mini-card strong,.mini-card small{display:block}.mini-card strong{font-size:12px}.mini-card small{color:var(--muted);margin-top:4px;font-size:11px;line-height:1.5}.progress-wrap{min-width:210px;padding-bottom:5px}.language-switch{border:1px solid var(--line);background:#fffcf6cc;border-radius:12px;gap:4px;margin-bottom:15px;padding:4px;display:flex}.language-switch button{min-height:30px;color:var(--muted);cursor:pointer;background:0 0;border:0;border-radius:8px;flex:1;padding:5px 8px;font-size:10px;font-weight:800}.language-switch button.active{color:#fff;background:var(--green)}.progress-label{color:var(--muted);justify-content:space-between;margin-bottom:9px;font-size:11px;font-weight:700;display:flex}.progress-track{background:#e8dfd2;border-radius:999px;height:8px;overflow:hidden}.progress-bar{border-radius:inherit;background:var(--green);height:100%;transition:width .35s}.lesson-nav{scrollbar-width:none;gap:8px;padding:0 0 18px;display:flex;overflow-x:auto}.lesson-nav::-webkit-scrollbar{display:none}.lesson-pill{border:1px solid var(--line);min-height:48px;color:var(--muted);cursor:pointer;background:#fffcf6e0;border-radius:999px;flex:none;align-items:center;gap:8px;padding:9px 15px 9px 9px;transition:all .18s;display:inline-flex}.lesson-pill:hover{border-color:#c9bbab;transform:translateY(-1px)}.lesson-pill.active{color:var(--ink);background:linear-gradient(#fff8df 0%,#fffaf0 100%);border-color:#f1d48e;box-shadow:0 10px 24px #47362514}.pill-char{color:#fffaf0;background:#817568;border-radius:50%;place-items:center;width:31px;height:31px;font:700 17px Noto Serif SC,serif;display:grid}.lesson-pill.active .pill-char{background:var(--red)}.lesson-pill strong{font-size:12px}.category-strip{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin:4px 0 18px;display:grid}.overview-actions{margin-bottom:14px}.study-header{justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px;padding:18px 20px;display:flex}.study-header-main{align-items:center;gap:14px;display:flex}.study-title{gap:4px;display:grid}.study-title strong{font-size:18px}.study-title span{color:var(--muted);font-size:12px}.study-tabs{flex-wrap:wrap;gap:8px;display:flex}.study-tab{border:1px solid var(--group-border,#d9d5cf);background:var(--group-soft,#f4efe6);min-height:40px;color:var(--group-accent-dark,#73675b);cursor:pointer;border-radius:999px;padding:9px 14px;font-size:12px;font-weight:800;box-shadow:0 6px 14px #4b3a280a}.study-tab.active{border-color:var(--group-accent,var(--red));background:color-mix(in srgb, var(--group-soft,#fff0eb) 84%, white 16%);color:var(--group-accent-dark,var(--red-dark));box-shadow:0 10px 20px color-mix(in srgb, var(--group-accent,var(--red)) 18%, transparent)}.category-card{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fffc;border:1px solid #ffffffb8;border-radius:24px;align-items:center;gap:12px;padding:16px;display:flex;box-shadow:0 16px 34px #4b3a280f}.category-card.active{background:linear-gradient(#fff1ec 0%,#fffaf4 100%);border-color:#f3cfbf}.category-card strong,.category-card small{display:block}.category-card strong{font-size:14px}.category-card small{color:var(--muted);margin-top:4px;font-size:11px;line-height:1.5}.category-icon{background:#fff6dc;border-radius:16px;flex:none;place-items:center;width:46px;height:46px;font-size:22px;display:grid}.set-overview{gap:18px;display:grid}.home-quick-guide{background:linear-gradient(#fff8e8 0%,#fff3d8 100%);border-color:#f1cf97;margin-bottom:18px;padding:18px 22px}.home-quick-guide-copy strong{color:#8a4b00;margin-bottom:6px;font-size:14px;display:block}.home-quick-guide-copy p{color:#7a5a2d;margin:0;font-size:13px;line-height:1.6}.set-group-card{border-color:var(--group-border,var(--line));background:linear-gradient(180deg, color-mix(in srgb, var(--group-soft,#fff8f0) 62%, white 38%) 0%, #fffcf6fa 100%);padding:24px}.set-group-header h2{color:var(--group-accent-dark,var(--ink));letter-spacing:-.03em;margin:0;font-size:28px}.set-group-header p{max-width:640px;color:var(--muted);margin:10px 0 0;font-size:14px;line-height:1.7}.set-group-eyebrow{color:var(--group-accent-dark,var(--red-dark));letter-spacing:.08em;text-transform:uppercase;margin:0 0 8px;font-size:12px;font-weight:800}.set-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:18px;display:grid}.set-card{border:1px solid var(--group-border,#eadfce);background:linear-gradient(180deg, color-mix(in srgb, var(--group-card-color,#fffdf9) 72%, white 28%) 0%, color-mix(in srgb, var(--group-soft,#fff6ea) 82%, #fff6ea 18%) 100%);text-align:left;cursor:pointer;border-radius:24px;align-items:center;gap:16px;padding:18px;transition:transform .18s,box-shadow .18s,border-color .18s;display:flex;box-shadow:0 14px 28px #4b3a280d}.set-card:hover{border-color:var(--group-accent,#d6c5af);box-shadow:0 20px 32px color-mix(in srgb, var(--group-accent,#d6c5af) 14%, #4b3a2817);transform:translateY(-2px)}.set-card-char{background:var(--group-char-bg,#fff);width:74px;height:74px;color:var(--group-accent-dark,var(--red-dark));box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--group-border,#f1e7d8) 72%, white 28%);border-radius:22px;flex:none;place-items:center;font:800 40px/1 Noto Serif SC,serif;display:grid}.set-card-body{gap:4px;display:grid}.set-card-body strong{color:var(--group-accent-dark,#3b2c22);font-size:16px}.set-card-body small{color:var(--muted);font-size:12px;line-height:1.5}.set-card-meta{color:var(--group-accent,#8b6840);letter-spacing:.05em;text-transform:uppercase;margin-top:6px;font-size:11px;font-weight:800}.game-grid{grid-template-columns:minmax(300px,.82fr) minmax(420px,1.18fr);gap:18px;display:grid}.challenge-shell{display:block}.challenge-panel{padding:28px}.challenge-story{background:#f8f1e7;border-radius:22px;margin-top:18px;padding:20px}.challenge-instruction{color:var(--muted);margin-top:16px;font-size:12px;font-weight:700}.challenge-story strong{margin-bottom:8px;font-size:13px;display:block}.challenge-story p{color:#5d5247;margin:0;font-size:15px;line-height:1.7}.challenge-options{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-top:18px;display:grid}.challenge-option{border:1px solid var(--line);cursor:pointer;background:#fffaf1;border-radius:22px;align-content:center;justify-items:center;gap:6px;min-height:110px;display:grid}.challenge-option span{font:800 42px/1 Noto Serif SC,serif}.challenge-option small{color:var(--muted);font-size:11px;font-weight:700}.challenge-option.selected{color:var(--red-dark);background:#fff1ef;border-color:#d39c94;box-shadow:0 12px 24px #b941351a}.challenge-option.answer{box-shadow:inset 0 0 0 3px #477b6124}.challenge-actions{flex-wrap:wrap;align-items:center;gap:12px;margin-top:16px;display:flex}.panel{border:1px solid var(--line);background:#fffcf6eb;border-radius:30px;box-shadow:0 20px 52px #4b3a2814}.character-card{text-align:center;background:linear-gradient(180deg, color-mix(in srgb, var(--group-card-color,#fffcf6eb) 56%, white 44%) 0%, #fffcf6f5 100%);flex-direction:column;justify-content:center;align-items:center;min-height:520px;padding:42px 34px;display:flex;position:relative;overflow:hidden}.character-card:before,.character-card:after{content:"";background:#eee5da;width:230px;height:1px;position:absolute;transform:rotate(45deg)}.character-card:after{transform:rotate(-45deg)}.card-label{color:var(--muted);letter-spacing:.08em;text-transform:uppercase;margin:0;font-size:11px;font-weight:700;position:absolute;top:26px;left:26px}.character-card-badge{color:#9b6800;background:#fff3d0;border-radius:999px;padding:8px 12px;font-size:11px;font-weight:800;position:absolute;top:24px;right:24px;box-shadow:0 8px 18px #4b3a280d}.han-character{z-index:1;color:var(--ink);text-shadow:4px 6px #b941351c;margin:6px 0 8px;font:900 clamp(116px,15vw,164px)/1 Noto Serif SC,serif;animation:.5s cubic-bezier(.175,.885,.32,1.275) both snapIn;position:relative}.pinyin{z-index:1;color:var(--red);margin:0;font-size:24px;font-weight:800;position:relative}.meaning{z-index:1;margin:8px 0 0;font-size:16px;font-weight:700;position:relative}.hanviet{color:var(--muted);letter-spacing:.06em;margin-left:6px;font-size:11px;font-weight:600}.audio-button{z-index:1;color:var(--ink);cursor:pointer;background:#fffaf0;border:1px solid #ddcfc0;border-radius:999px;align-items:center;gap:8px;margin-top:20px;padding:12px 17px;font-size:12px;font-weight:700;transition:all .18s;display:inline-flex;position:relative;box-shadow:0 10px 20px #4b3a280d}.audio-button:hover{border-color:var(--red);color:var(--red)}.audio-button.playing{color:#fff;border-color:var(--green);background:var(--green)}.audio-button svg{width:17px;height:17px}.audio-credit{z-index:1;color:var(--muted);text-underline-offset:2px;margin-top:8px;font-size:9px;line-height:1.4;text-decoration:underline;display:block;position:relative}.story-card{z-index:1;color:#625749;text-align:left;background:linear-gradient(#f7efe4 0%,#f4ede2 100%);border-radius:18px;width:100%;margin-top:26px;padding:17px 18px;font-size:12px;line-height:1.65;position:relative}.story-card strong{color:var(--ink);margin-bottom:3px;font-size:11px;display:block}.game-panel{min-height:520px;padding:34px}.step-row{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;gap:20px;padding-bottom:22px;display:flex}.step-number{color:#fff;background:var(--group-accent,var(--red));border-radius:9px;place-items:center;width:30px;height:30px;margin-right:9px;font-size:12px;font-weight:800;display:inline-grid}.step-row h2{letter-spacing:-.02em;margin:0;font-size:18px;display:inline}.step-subtitle{color:var(--muted);margin:8px 0 0;font-size:12px;line-height:1.5}.score{color:var(--green);white-space:nowrap;font-size:12px;font-weight:800}.equation{justify-content:center;align-items:center;gap:clamp(12px,3vw,24px);min-height:126px;display:flex}.equation-char,.equation-result{border-radius:22px;place-items:center;width:82px;height:82px;font:800 50px/1 Noto Serif SC,serif;display:grid}.equation-char{color:var(--ink);background:#f1e9dd}.equation-result{color:#fffaf0;background:var(--group-accent,var(--red));animation:.26s ease-out pop}.equation-placeholder{color:#b3a696;background:#fbf7ef;border:2px dashed #d7c9b9;border-radius:18px;place-items:center;width:82px;height:82px;font-size:26px;display:grid}.operator{color:#a49687;font-size:25px;font-weight:500}@keyframes pop{0%{opacity:0;transform:scale(.7)}70%{transform:scale(1.08)}to{opacity:1;transform:scale(1)}}.instruction{color:var(--muted);margin:0;font-size:12px;font-weight:600}.instruction-row{justify-content:space-between;align-items:center;gap:12px;margin-bottom:13px;display:flex}.instruction-badge{color:#8d7a63;text-transform:uppercase;letter-spacing:.05em;background:#f7efe1;border-radius:999px;align-items:center;min-height:30px;padding:6px 11px;font-size:10px;font-weight:800;display:inline-flex}.component-options{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.component-button{border:1px solid var(--line);min-height:98px;color:var(--ink);cursor:pointer;background:#fffaf1;border-radius:20px;flex-direction:column;justify-content:center;align-items:center;gap:4px;transition:all .18s;display:flex}.component-button:hover:not(:disabled){border-color:var(--red);transform:translateY(-2px);box-shadow:0 9px 20px #513a2314}.component-button:disabled{cursor:default}.component-button.selected{border-color:var(--green);color:var(--green);background:#edf6f1}.component-button.wrong{color:var(--red);background:#fff1ef;border-color:#d9a39d;animation:.26s shake}.component-symbol{font:700 32px/1 Noto Serif SC,serif}.component-name{color:var(--muted);font-size:11px;font-weight:600}@keyframes shake{0%,to{transform:translate(0)}33%{transform:translate(-4px)}66%{transform:translate(4px)}}.feedback{background:#f4ede2;border-radius:18px;min-height:92px;margin-top:16px;padding:16px 18px}.feedback.success{color:#285c49;background:#e8f2ed}.feedback.error{color:#913128;background:#fff0ed}.feedback strong{margin-bottom:4px;font-size:13px;display:block}.feedback p{margin:0;font-size:11px;line-height:1.55}.feedback .audio-button{margin-top:10px;padding:7px 11px;font-size:10px}.feedback .audio-credit{margin-left:8px;display:inline-block}.game-actions{justify-content:space-between;gap:10px;margin-top:18px;display:flex}.nav-button{color:#5c4330;cursor:pointer;background:linear-gradient(#fff9ef 0%,#ffefd6 100%);border:1px solid #cebfa9;border-radius:14px;min-height:46px;padding:10px 18px;font-size:11px;font-weight:800;box-shadow:0 8px 18px #4b3a280f}.nav-button.primary{border-color:var(--group-accent,var(--red));color:#fff;background:linear-gradient(180deg, color-mix(in srgb, var(--group-accent,#ff8f75) 72%, white 28%) 0%, var(--group-accent,var(--red)) 100%);box-shadow:0 12px 24px color-mix(in srgb, var(--group-accent,var(--red)) 24%, transparent);margin-left:auto}.nav-button:disabled{opacity:.35;cursor:default}.site-footer{color:#938679;flex-wrap:wrap;justify-content:space-between;gap:14px;padding:28px 0 34px;font-size:11px;display:flex}@keyframes snapIn{0%{opacity:0;transform:scale(.4)translateY(50px)}70%{opacity:1;transform:scale(1.12)translateY(-5px)}to{opacity:1;transform:scale(1)translateY(0)}}@keyframes floaty{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@media (width<=800px){.app-shell{width:min(100% - 24px,620px)}.site-header{min-height:76px}.brand-mark{width:41px;height:41px;font-size:24px}.hero-copy{grid-template-columns:1fr;gap:22px;padding-top:30px}.study-header,.study-header-main{flex-direction:column;align-items:flex-start}.hero-stat-row,.hero-mini-cards,.category-strip,.set-grid,.hero-banner{grid-template-columns:1fr}.progress-wrap{min-width:0}.game-grid{grid-template-columns:1fr}.challenge-options{grid-template-columns:repeat(2,minmax(0,1fr))}.character-card,.game-panel{min-height:auto}.character-card{padding:58px 24px 25px}.han-character{font-size:112px}.game-panel{padding:24px 18px}.site-footer{text-align:center;justify-content:center}}@media (width<=420px){.brand small{display:none}.component-options{gap:7px}.instruction-row{flex-direction:column;align-items:flex-start}.hero-highlights span{justify-content:center;width:100%}.component-button{min-height:78px}.equation-char,.equation-result,.equation-placeholder{width:66px;height:66px}}
