:root{--bg-primary:#f0f2f5;--bg-card:#fff;--text-primary:#1a1a1a;--text-secondary:#666;--accent-color:#3b82f6;--success-color:#22c55e;--error-color:#ef4444;--font-main:"Inter",system-ui,-apple-system,sans-serif}body{font-family:var(--font-main);background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;justify-content:center;align-items:center;min-height:100vh;margin:0;display:flex}#root{text-align:center;width:100%;max-width:1200px;padding:2rem}.character-display-container{background:#f8fafc;border-radius:.5rem;width:100%;max-width:900px;max-height:300px;margin:0 auto;padding:.5rem;overflow-y:auto;box-shadow:inset 0 2px 4px #0000000d}.lesson-text-flow{flex-wrap:wrap;justify-content:flex-start;align-items:flex-end;gap:.5rem;padding:.5rem;display:flex}.character-item{cursor:pointer;background:#fff;border:2px solid #0000;border-radius:.5rem;flex-direction:column;justify-content:center;align-items:center;min-width:60px;padding:.5rem;font-size:2rem;transition:all .2s;display:inline-flex;position:relative;box-shadow:0 1px 2px #0000000d}.character-item:hover{transform:translateY(-2px);box-shadow:0 4px 6px #0000001a}.character-item.current{border-color:var(--accent-color);z-index:10;background:#eff6ff;transform:scale(1.1);box-shadow:0 0 0 4px #3b82f633}.character-item.completed{color:var(--success-color);opacity:.8;background:#f0fdf4;border-color:#0000}.character-item.pending{color:var(--text-secondary);opacity:.6}.input-feedback-overlay{color:#fff;white-space:nowrap;pointer-events:none;z-index:20;background:#000c;border-radius:.25rem;padding:.2rem .5rem;font-size:.8rem;position:absolute;bottom:-1.5rem;left:50%;transform:translate(-50%)}.input-buffer{color:#fbbf24;font-weight:700}.cursor{animation:1s step-end infinite blink}ruby{ruby-position:over;font-family:BiauKai,DFKai-SB,serif}rt{color:var(--text-secondary);margin-bottom:.1em;font-size:.5em;font-weight:400}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.keyboard{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);-webkit-user-select:none;user-select:none;background:#fffc;border:1px solid #ffffff2e;border-radius:1rem;flex-direction:column;gap:.5rem;margin-top:2rem;padding:1.5rem;display:flex;box-shadow:0 8px 32px #1f268726}.keyboard-row{justify-content:center;gap:.5rem;display:flex}.key{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;flex-direction:column;justify-content:center;align-items:center;width:3.5rem;height:3.5rem;transition:all .1s;display:flex;position:relative;box-shadow:0 2px 4px #0000001a}.key.space-key{width:20rem}.key-main{color:var(--text-primary);font-size:1.2rem;font-weight:600}.key-sub{color:var(--text-secondary);font-size:.7rem;position:absolute;bottom:.2rem;right:.3rem}.key.active{background:var(--accent-color);border-color:var(--accent-color);transform:translateY(1px)}.key.active .key-main,.key.active .key-sub{color:#fff}.key.pressed{background:#dbeafe;transform:translateY(2px);box-shadow:inset 0 2px 4px #0000001a}.scoreboard{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;background:#ffffff1a;border-radius:12px;margin-top:20px;padding:20px}.scoreboard h3{text-align:center;color:gold;margin-top:0;margin-bottom:15px}.scoreboard table{border-collapse:collapse;width:100%}.scoreboard th,.scoreboard td{text-align:left;border-bottom:1px solid #ffffff1a;padding:10px}.scoreboard th{color:#a0aec0;text-transform:uppercase;font-size:.9em;font-weight:600}.scoreboard tr:last-child td{border-bottom:none}.scoreboard .gold td{color:gold;font-weight:700}.scoreboard .silver td{color:silver;font-weight:700}.scoreboard .bronze td{color:#cd7f32;font-weight:700}.scoreboard.empty{text-align:center;color:#a0aec0}.race-track-container{background:#2d3748;border-radius:12px;width:100%;margin-bottom:20px;padding:20px;position:relative;overflow:hidden;box-shadow:inset 0 2px 4px #0000004d}.track-lane{width:calc(100% - 40px);height:40px;margin-bottom:10px;position:relative}.lane-line{z-index:0;background:#4a5568;height:2px;position:absolute;top:50%;left:0;right:0;transform:translateY(-50%)}.racer{z-index:1;font-size:24px;transition:left .1s linear;position:absolute;top:50%;transform:translate(-50%,-50%)}.user-racer{filter:drop-shadow(0 2px 4px #00000080)}.ghost-racer{opacity:.6;filter:grayscale(.5)}.finish-line{background:#ffffff0d;border-left:2px dashed #cbd5e0;justify-content:center;align-items:center;width:20px;font-size:24px;display:flex;position:absolute;top:0;bottom:0;right:20px}.completion-modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#000000b3;justify-content:center;align-items:center;animation:.3s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.completion-modal{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:1.5rem;width:90%;max-width:500px;padding:3rem;animation:.4s slideUp;box-shadow:0 20px 60px #0000004d}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.completion-header{text-align:center;margin-bottom:2rem}.completion-header h2{text-shadow:0 2px 10px #0003;margin:0;font-size:2rem;font-weight:700}.completion-stats{grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:2.5rem;display:grid}.stat-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);text-align:center;background:#ffffff26;border:1px solid #fff3;border-radius:1rem;padding:1.5rem 1rem;transition:transform .2s}.stat-card:hover{transform:translateY(-5px)}.stat-value{text-shadow:0 2px 10px #0003;margin-bottom:.5rem;font-size:2.5rem;font-weight:700}.stat-label{text-transform:uppercase;letter-spacing:1px;opacity:.9;font-size:.9rem;font-weight:600}.completion-actions{justify-content:center;gap:1rem;display:flex}.btn-primary,.btn-secondary{cursor:pointer;text-transform:uppercase;letter-spacing:.5px;border:none;border-radius:.75rem;padding:1rem 2rem;font-size:1rem;font-weight:600;transition:all .2s}.btn-primary{color:#667eea;background:#fff;box-shadow:0 4px 15px #0003}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000004d}.btn-secondary{color:#fff;background:#fff3;border:2px solid #ffffff4d}.btn-secondary:hover{background:#ffffff4d;transform:translateY(-2px)}@media (max-width:600px){.completion-modal{padding:2rem}.completion-stats{grid-template-columns:1fr;gap:1rem}.completion-actions{flex-direction:column}.btn-primary,.btn-secondary{width:100%}}.typing-area{flex-direction:column;align-items:center;width:100%;max-width:1000px;margin:0 auto;display:flex}.lesson-controls{background:#ffffff0d;border-radius:8px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;width:100%;margin-bottom:1rem;padding:.5rem;display:flex}.lesson-selector-group{align-items:center;gap:.5rem;display:flex}.delete-btn{cursor:pointer;background:0 0;border:none;border-radius:.5rem;padding:.5rem;font-size:1.2rem;transition:background .2s}.delete-btn:hover{background:#fee2e2}.lesson-select{border:1px solid #e5e7eb;border-radius:.5rem;min-width:200px;padding:.5rem 1rem;font-size:1rem}.text-display{background:#fff;border-radius:1.5rem;flex-wrap:wrap;justify-content:center;gap:.5rem;width:100%;min-height:150px;margin-bottom:2rem;padding:2rem;display:flex;box-shadow:0 4px 6px -1px #0000001a}.completion-screen{text-align:center;background:#fff;border-radius:1.5rem;width:100%;padding:4rem;box-shadow:0 10px 25px #0000001a}.completion-screen h2{color:var(--success-color);margin-bottom:2rem;font-size:2.5rem}.race-stats{color:gold;background:#000c;border-radius:8px;margin:20px 0;padding:15px;font-size:1.2em;display:inline-block}.restart-btn{background:var(--accent-color);color:#fff;cursor:pointer;border:none;border-radius:.5rem;padding:.75rem 2rem;font-size:1.2rem;transition:background .2s}.restart-btn:hover{background:#2563eb}.status-bar{width:100%;color:var(--text-secondary);justify-content:space-between;margin-bottom:1rem;padding:0 1rem;font-size:.9rem;display:flex}.toggle-switch{cursor:pointer;align-items:center;gap:.5rem;display:flex}.sound-toggle-btn{cursor:pointer;background:0 0;border:1px solid #e2e8f0;border-radius:.5rem;margin-left:.5rem;padding:.5rem .75rem;font-size:1.2rem;transition:all .2s}.sound-toggle-btn:hover{background:#f1f5f9}.sound-toggle-btn.active{color:#3b82f6;background:#e0f2fe;border-color:#3b82f6}.lesson-creator{text-align:left;background:#fff;border-radius:1.5rem;width:100%;max-width:600px;margin:0 auto;padding:2rem;box-shadow:0 10px 25px #0000001a}.lesson-creator h2{color:var(--text-primary);margin-top:0;margin-bottom:1.5rem}.form-group{margin-bottom:1.5rem}.form-group label{color:var(--text-secondary);margin-bottom:.5rem;font-weight:600;display:block}.form-group input,.form-group textarea{border:1px solid #e5e7eb;border-radius:.5rem;width:100%;padding:.75rem;font-family:inherit;font-size:1rem;transition:border-color .2s}.form-group input:focus,.form-group textarea:focus{border-color:var(--accent-color);outline:none;box-shadow:0 0 0 3px #3b82f61a}.hint{color:var(--text-secondary);margin-top:.5rem;font-size:.85rem}.form-actions{justify-content:flex-end;gap:1rem;margin-top:2rem;display:flex}.btn-primary,.btn-secondary{cursor:pointer;border:none;border-radius:.5rem;padding:.75rem 1.5rem;font-weight:600;transition:all .2s}.btn-primary{background:var(--accent-color);color:#fff}.btn-primary:hover{background:#2563eb}.btn-primary:disabled{opacity:.7;cursor:not-allowed}.btn-secondary{color:var(--text-secondary);background:#f3f4f6}.btn-secondary:hover{background:#e5e7eb}.flashcard-container{perspective:1000px;background-color:#0000;width:400px;height:300px;margin:20px auto}.flashcard-inner{text-align:center;width:100%;height:100%;transform-style:preserve-3d;border-radius:15px;transition:transform .6s;position:relative;box-shadow:0 4px 8px #0003}.flashcard-container.flipped .flashcard-inner{transform:rotateY(180deg)}.flashcard-front,.flashcard-back{backface-visibility:hidden;color:#333;background-color:#fff;border:2px solid #e0e0e0;border-radius:15px;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:absolute}.flashcard-front{background:linear-gradient(135deg,#fff 0%,#f5f7fa 100%)}.flashcard-back{background:linear-gradient(135deg,#fdfbfb 0%,#ebedee 100%);transform:rotateY(180deg)}.card-content h2{color:#2c3e50;margin:0 0 20px;font-size:3rem}.zhuyin-display{color:#e74c3c;margin-bottom:10px;font-family:BPMF,sans-serif;font-size:1.5rem}.definition{color:#7f8c8d;margin-bottom:15px;font-size:1.2rem}.tags{margin-top:10px}.tag{color:#7f8c8d;background-color:#ecf0f1;border-radius:12px;margin:0 4px;padding:4px 8px;font-size:.8rem}.card-hint{color:#bdc3c7;margin-top:20px;font-size:.9rem}.peek-hint{color:#e74c3c;margin-bottom:10px;font-size:1.2rem;animation:.2s fadeIn}.flashcard-mode-container{outline:none;flex-direction:column;align-items:center;max-width:800px;min-height:80vh;margin:0 auto;padding:20px;display:flex}.flashcard-header{justify-content:space-between;align-items:center;width:100%;margin-bottom:20px;display:flex}.back-btn,.exit-btn{cursor:pointer;color:#666;background:0 0;border:1px solid #ccc;border-radius:20px;padding:8px 16px;transition:all .2s}.back-btn:hover,.exit-btn:hover{color:#333;background-color:#f5f5f5}.keyboard-toggle{color:#3498db;cursor:pointer;background:0 0;border:1px solid #3498db;border-radius:20px;padding:8px 16px;transition:all .2s}.keyboard-toggle.active{color:#fff;background-color:#3498db}.progress-info{color:#2c3e50;font-size:1.1rem;font-weight:700}.input-area{justify-content:center;width:100%;margin-top:30px;display:flex}.input-wrapper{flex-direction:column;align-items:center;display:flex}.zhuyin-input{text-align:center;border:2px solid #3498db;border-radius:30px;outline:none;width:300px;padding:10px 20px;font-size:1.5rem;transition:box-shadow .2s}.zhuyin-input:focus{box-shadow:0 0 0 4px #3498db33}.hint-text{color:#7f8c8d;margin-top:10px;font-size:.9rem}.next-action{text-align:center;animation:.3s ease-out slideUp}.next-action p{color:#7f8c8d;margin-bottom:10px}.next-btn{color:#fff;cursor:pointer;background-color:#2ecc71;border:none;border-radius:30px;padding:12px 30px;font-size:1.2rem;transition:transform .1s,background-color .2s}.next-btn:hover{background-color:#27ae60;transform:translateY(-2px)}.next-btn:active{transform:translateY(0)}.virtual-keyboard-container{justify-content:center;width:100%;margin-top:30px;animation:.3s ease-out slideUp;display:flex}.flashcard-mode-container.finished{text-align:center;justify-content:center}.stats-summary{background-color:#f8f9fa;border-radius:10px;min-width:200px;margin:20px 0;padding:20px}.app-container{flex-direction:column;gap:.5rem;min-height:100vh;padding:.5rem;display:flex}header{background:#1a1a1a;border-radius:8px;flex-direction:row;justify-content:space-between;align-items:center;padding:.5rem 1rem;display:flex;box-shadow:0 2px 4px #0003}header h1{background:linear-gradient(45deg,var(--accent-color),#8b5cf6);-webkit-text-fill-color:transparent;white-space:nowrap;-webkit-background-clip:text;background-clip:text;margin:0;font-size:1.2rem}header p{display:none}.controls-row{flex-direction:row;align-items:center;gap:1rem;margin:0;display:flex}.language-toggle,.mode-toggle{background:#2a2a2a;border-radius:6px;gap:.25rem;padding:.25rem;display:flex}.mode-btn,.lang-btn{cursor:pointer;color:#888;white-space:nowrap;background:0 0;border:none;border-radius:4px;padding:.25rem .75rem;font-size:.85rem;transition:all .2s}.mode-btn:hover,.lang-btn:hover{color:#fff;background:#ffffff1a}.mode-btn.active,.lang-btn.active{color:#fff;background:#646cff}.lang-btn.active{background:#4a90e2}main{flex-direction:column;flex:1;display:flex;overflow:hidden}
