.language-switcher{display:flex;gap:.5rem;align-items:center;background:#ffffffe6;padding:.5rem;border-radius:20px;box-shadow:0 2px 8px #0000001a}.lang-btn{padding:.5rem 1rem;border:2px solid transparent;border-radius:15px;background:transparent;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;color:#666;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.lang-btn:hover{background:#ffb6c14d;transform:scale(1.05)}.lang-btn.active{background:linear-gradient(135deg,#ff6b9d,#c44569);color:#fff;border-color:#ff6b9d;box-shadow:0 2px 8px #ff6b9d4d}@media (max-width: 768px){.lang-btn{padding:.4rem .8rem;font-size:.8rem}}.login-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;position:relative}.login-container{width:100%;max-width:400px}.login-card{background:#fff;border-radius:30px;padding:3rem;box-shadow:0 15px 50px #ff6b9d33;border:4px solid #ffb6c1;animation:bounceIn .6s ease-out}.welcome-emoji{font-size:4rem;text-align:center;margin-bottom:1rem;animation:wave 2s ease-in-out infinite}@keyframes wave{0%,to{transform:rotate(0)}25%{transform:rotate(15deg)}75%{transform:rotate(-15deg)}}.login-card h1{color:#ff6b9d;margin-bottom:.5rem;text-align:center;font-size:2.5rem;font-weight:800;text-shadow:2px 2px 4px rgba(255,107,157,.2)}.hint{font-size:.875rem;color:#888;margin-top:.5rem;font-style:italic}.register-link{text-align:center;margin-top:1.5rem;color:#666}.register-link a{color:#ff6b9d;text-decoration:none;font-weight:700;font-size:1.1rem}.register-link a:hover{text-decoration:underline}.register-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;position:relative}.language-switcher-container{position:absolute;top:2rem;right:2rem;z-index:10}.register-container{width:100%;max-width:400px}.register-card{background:#fff;border-radius:30px;padding:3rem;box-shadow:0 15px 50px #ff6b9d33;border:4px solid #ffb6c1;animation:bounceIn .6s ease-out}.welcome-emoji{font-size:4rem;text-align:center;margin-bottom:1rem;animation:spin 3s linear infinite}.register-card h1{color:#ff6b9d;margin-bottom:.5rem;text-align:center;font-size:2.5rem;font-weight:800;text-shadow:2px 2px 4px rgba(255,107,157,.2)}.subtitle{text-align:center;color:#666;margin-bottom:2rem}.login-link{text-align:center;margin-top:1.5rem;color:#666}.login-link a{color:#ff6b9d;text-decoration:none;font-weight:700;font-size:1.1rem}.login-link a:hover{text-decoration:underline}.student-dashboard{min-height:100vh}.btn-large{width:100%;padding:1rem;font-size:1.1rem;margin-top:1rem}.deck-select{font-size:1rem}.deck-description{margin-top:.5rem;color:#666;font-style:italic}.user-info{color:#333;font-weight:500}.teacher-dashboard{min-height:100vh}.tabs{display:flex;gap:1rem;margin-bottom:2rem;border-bottom:3px solid #ffb6c1}.student-stats,.chart-container{margin-top:2rem}.chart-container h4{margin-bottom:1rem;color:#333}.word-error-list{margin-top:1rem}.word-error-item{display:flex;align-items:center;padding:1rem;margin-bottom:.5rem;background:#fff5f7;border-radius:15px;border:3px solid #ffb6c1;transition:transform .2s ease,box-shadow .2s ease}.word-error-item:hover{transform:translate(5px);box-shadow:0 4px 12px #ff6b9d33}.word-rank{font-weight:800;color:#ff6b9d;margin-right:1rem;min-width:50px;font-size:1.2rem}.word-text{font-size:1.8rem;font-weight:800;color:#ff6b9d;margin-right:1rem;min-width:100px;font-family:Comic Sans MS,Chalkboard SE,Comic Neue,sans-serif}.error-ratio{flex:1;display:flex;align-items:center;gap:1rem}.ratio-bar{flex:1;height:20px;background:#e0e0e0;border-radius:10px;overflow:hidden}.ratio-fill{height:100%;background:linear-gradient(90deg,#ff6b9d,#c44569);transition:width .3s ease;border-radius:10px}.ratio-text{font-size:.9rem;color:#666;min-width:120px;text-align:right}@media (max-width: 768px){.tabs{flex-direction:column}.word-error-item{flex-direction:column;align-items:flex-start}.error-ratio{width:100%;flex-direction:column;gap:.5rem}.ratio-text{text-align:left}}.admin-dashboard{min-height:100vh}.tabs{display:flex;gap:1rem;margin-bottom:2rem;border-bottom:3px solid #ffb6c1;flex-wrap:wrap}.tab{padding:1rem 2rem;border:none;background:transparent;font-size:1.1rem;font-weight:700;color:#666;cursor:pointer;border-bottom:4px solid transparent;transition:all .3s ease;border-radius:15px 15px 0 0;font-family:Comic Sans MS,Chalkboard SE,Comic Neue,sans-serif}.tab:hover{color:#ff6b9d;background:#ffb6c133;transform:translateY(-3px)}.tab.active{color:#ff6b9d;border-bottom-color:#ff6b9d;background:#ffb6c14d;font-weight:800}.message{margin:1rem 2rem;padding:1rem;border-radius:20px;text-align:center;font-weight:700;font-size:1.1rem;border:3px solid;animation:slideDown .3s ease-out}@keyframes slideDown{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.message.success{background:#d4edda;color:#155724;border-color:#c3e6cb}.message.error{background:#f8d7da;color:#721c24;border-color:#f5c6cb}.section{margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid #e0e0e0}.section:last-child{border-bottom:none}.section h3{color:#ff6b9d;margin-bottom:1rem;font-size:1.5rem;font-weight:800;font-family:Comic Sans MS,Chalkboard SE,Comic Neue,sans-serif}.input-group{display:flex;gap:.5rem}.input-group input{flex:1}.deck-actions,.words-list{margin-top:1rem}.word-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;margin-bottom:.5rem;background:#fff5f7;border-radius:15px;border:3px solid #ffb6c1;transition:transform .2s ease,box-shadow .2s ease}.word-item:hover{transform:translate(5px);box-shadow:0 4px 12px #ff6b9d33}.word-text{font-size:1.8rem;font-weight:800;color:#ff6b9d;font-family:Comic Sans MS,Chalkboard SE,Comic Neue,sans-serif}.btn-sm{padding:.5rem 1rem;font-size:.875rem}.stats-section{margin-top:2rem}.stats-section h3{margin-bottom:1rem;color:#333}@media (max-width: 768px){.input-group{flex-direction:column}.word-item{flex-direction:column;align-items:flex-start;gap:.5rem}}.swipe-card{width:100%;max-width:500px;height:400px;background:linear-gradient(135deg,#fff5f7,#ffeef2);border-radius:30px;box-shadow:0 15px 50px #ff6b9d4d;border:4px solid #ffb6c1;display:flex;align-items:center;justify-content:center;cursor:grab;-webkit-user-select:none;user-select:none;transition:transform .1s ease-out,opacity .1s ease-out,box-shadow .3s ease;margin:0 auto;position:relative;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.swipe-card.dragging{cursor:grabbing;transition:none}.swipe-card.disabled{cursor:not-allowed;opacity:.6}.card-content{text-align:center;padding:2rem}.word-display{font-size:5rem;font-weight:800;color:#ff6b9d;margin-bottom:2rem;min-height:120px;display:flex;align-items:center;justify-content:center;text-shadow:3px 3px 6px rgba(255,107,157,.3);font-family:PingFang SC,Hiragino Sans GB,Microsoft YaHei,WenQuanYi Micro Hei,Noto Sans CJK SC,Comic Sans MS,Chalkboard SE,Comic Neue,sans-serif;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.card-hint{font-size:1rem;color:#ff6b9d;margin-top:2rem;font-weight:600}.card-hint p{margin:.5rem 0}.realtime-recognition{margin:1rem 0;padding:1rem;background:linear-gradient(135deg,#e3f2fd,#bbdefb);border:2px solid #2196f3;border-radius:15px;text-align:center;animation:fadeIn .3s ease-in}.realtime-label{font-size:.85rem;font-weight:600;color:#1976d2;margin-bottom:.5rem}.realtime-text{font-size:1.3rem;font-weight:700;color:#0d47a1;font-family:PingFang SC,Hiragino Sans GB,Microsoft YaHei,WenQuanYi Micro Hei,Noto Sans CJK SC,sans-serif;min-height:1.5rem}.feedback-container{margin:1.5rem 0;padding:1.5rem;border-radius:20px;display:flex;align-items:center;gap:1rem;animation:slideIn .4s ease-out;box-shadow:0 8px 24px #00000026}.feedback-container.correct{background:linear-gradient(135deg,#d4edda,#c3e6cb);border:3px solid #28a745}.feedback-container.incorrect{background:linear-gradient(135deg,#f8d7da,#f5c6cb);border:3px solid #dc3545}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.feedback-icon{font-size:3rem;font-weight:700;flex-shrink:0;width:60px;height:60px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#fff;box-shadow:0 4px 12px #0003}.feedback-container.correct .feedback-icon{color:#28a745}.feedback-container.incorrect .feedback-icon{color:#dc3545}.feedback-text{flex:1;text-align:left}.feedback-status{font-size:1.3rem;font-weight:700;margin-bottom:.5rem}.feedback-container.correct .feedback-status{color:#155724}.feedback-container.incorrect .feedback-status{color:#721c24}.feedback-recognition{margin-top:.75rem;padding-top:.75rem;border-top:2px solid rgba(0,0,0,.1)}.feedback-label{font-size:.9rem;font-weight:600;color:#666;margin-bottom:.25rem}.feedback-value{font-size:1.1rem;font-weight:600;color:#333;font-family:PingFang SC,Hiragino Sans GB,Microsoft YaHei,WenQuanYi Micro Hei,Noto Sans CJK SC,sans-serif}.feedback-comparison{margin-top:1rem;padding-top:1rem;border-top:2px solid rgba(0,0,0,.1)}.comparison-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding:.5rem;background:#ffffff80;border-radius:8px}.comparison-label{font-size:.9rem;font-weight:600;color:#666;flex:1}.comparison-value{font-size:1rem;font-weight:700;color:#333;font-family:Courier New,monospace;flex:1;text-align:right}.comparison-value.match{color:#28a745}.comparison-value.mismatch{color:#dc3545}.feedback-message{margin-top:.75rem;padding-top:.75rem;border-top:1px dashed rgba(0,0,0,.2);font-size:.95rem;font-style:italic;color:#555}@media (max-width: 768px){.swipe-card{height:350px;max-width:90%}.word-display{font-size:3rem}.feedback-container{flex-direction:column;text-align:center;padding:1rem}.feedback-text{text-align:center}.feedback-icon{width:50px;height:50px;font-size:2.5rem}.feedback-status{font-size:1.1rem}}.game-page{min-height:100vh;padding:2rem;display:flex;flex-direction:column}.game-header{margin-bottom:2rem}.progress-bar{width:100%;height:8px;background:#e0e0e0;border-radius:4px;margin:1rem 0;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(135deg,#ff6b9d,#c44569);transition:width .3s ease;border-radius:4px;box-shadow:0 2px 8px #ff6b9d66}.word-counter{text-align:center;color:#666;font-weight:600;margin-top:.5rem}.game-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center}.game-actions{margin-top:2rem;display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}.btn-record{min-width:200px;font-size:1.1rem;padding:1rem 2rem}.btn-record.recording{background:#dc3545;animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.game-complete{max-width:600px;margin:0 auto;text-align:center;background:#fff;border-radius:30px;padding:3rem;box-shadow:0 15px 50px #ff6b9d4d;border:4px solid #ffb6c1;animation:bounceIn .6s ease-out}@keyframes bounceIn{0%{transform:scale(.8);opacity:0}50%{transform:scale(1.05)}to{transform:scale(1);opacity:1}}.celebration-emoji{font-size:5rem;margin-bottom:1rem;animation:bounce 1s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.game-complete h1{color:#ff6b9d;margin-bottom:2rem;font-size:2.5rem;font-weight:800;text-shadow:2px 2px 4px rgba(255,107,157,.2)}.score-display{margin:2rem 0}.score-value{font-size:5rem;font-weight:700;color:#ff6b9d;text-shadow:3px 3px 6px rgba(255,107,157,.3);animation:pulse 2s ease-in-out infinite}.score-label{font-size:1.2rem;color:#666;margin-top:.5rem}.stats{display:flex;justify-content:space-around;margin:2rem 0;padding:2rem 0;border-top:2px solid #e0e0e0;border-bottom:2px solid #e0e0e0}.stat-item{text-align:center}.stat-value{font-size:2rem;font-weight:700;color:#333}.stat-label{font-size:.9rem;color:#666;margin-top:.5rem}.error-message{background:#fee;color:#c33;padding:1rem;border-radius:8px;margin-bottom:1rem;text-align:center}.volume-bar-container{width:100%;max-width:500px;margin:1.5rem auto;padding:0 1rem}.volume-bar-label{text-align:center;color:#ff6b9d;font-weight:600;font-size:.9rem;margin-bottom:.5rem}.volume-bar{width:100%;height:12px;background:#e0e0e0;border-radius:6px;overflow:hidden;box-shadow:inset 0 2px 4px #0000001a}.volume-bar-fill{height:100%;background:linear-gradient(90deg,#4caf50,#8bc34a,#ffeb3b);transition:width .1s ease-out;border-radius:6px;box-shadow:0 0 10px #4caf5080;animation:pulse-volume 1s ease-in-out infinite}@keyframes pulse-volume{0%,to{opacity:1}50%{opacity:.8}}.processing-message{width:100%;max-width:500px;margin:1.5rem auto;padding:1.5rem;text-align:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 4px 15px #667eea4d;animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.processing-spinner{font-size:2rem;margin-bottom:.5rem;animation:spin 2s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.processing-text{color:#fff;font-weight:600;font-size:1.1rem}.playback-container{width:100%;max-width:500px;margin:1rem auto;display:flex;justify-content:center}.btn-playback{min-width:180px;font-size:1rem;padding:.75rem 1.5rem}.btn-playback.playing{background:#ff6b9d;color:#fff}.btn-next{min-width:200px;font-size:1.1rem;padding:1rem 2rem}@media (max-width: 768px){.game-page{padding:1rem}.game-actions{flex-direction:column}.btn-record{width:100%}.stats{flex-direction:column;gap:1.5rem}.volume-bar-container{max-width:100%}}.statistics-page{min-height:100vh}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1.5rem;margin-top:1rem}.stat-card{background:linear-gradient(135deg,#ff6b9d,#c44569);color:#fff;padding:1.5rem;border-radius:20px;text-align:center;box-shadow:0 8px 20px #ff6b9d4d;border:3px solid #ffb6c1;transition:transform .3s ease,box-shadow .3s ease}.stat-card:hover{transform:translateY(-5px) scale(1.05);box-shadow:0 12px 30px #ff6b9d66}.stat-card .stat-value{font-size:3rem;font-weight:800;margin-bottom:.5rem;text-shadow:2px 2px 4px rgba(0,0,0,.2);font-family:Comic Sans MS,Chalkboard SE,Comic Neue,sans-serif}.stat-card .stat-label{font-size:.9rem;opacity:.9}.wrong-words-list{margin-top:1rem}.wrong-word-item{display:flex;align-items:center;padding:1rem;margin-bottom:.5rem;background:#fff5f7;border-radius:15px;border-left:5px solid #ff6b9d;border:3px solid #ffb6c1;transition:transform .2s ease}.wrong-word-item:hover{transform:translate(5px);box-shadow:0 4px 12px #ff6b9d33}.word-rank{font-weight:800;color:#ff6b9d;margin-right:1rem;min-width:40px;font-size:1.2rem}.word-text{font-size:1.8rem;font-weight:800;color:#ff6b9d;margin-right:1rem;flex:1;font-family:Comic Sans MS,Chalkboard SE,Comic Neue,sans-serif}.word-stats{display:flex;flex-direction:column;align-items:flex-end;font-size:.9rem;color:#666}.wrong-count{font-weight:700;color:#ff6b9d;font-size:1rem}.wrong-ratio{font-size:.8rem}.no-data{text-align:center;color:#666;padding:2rem;font-style:italic}@media (max-width: 768px){.stats-grid{grid-template-columns:repeat(2,1fr)}.wrong-word-item{flex-direction:column;align-items:flex-start}.word-stats{align-items:flex-start;margin-top:.5rem}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Comic Sans MS,Chalkboard SE,Comic Neue,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#ff9a9e,#fecfef,#fecfef);min-height:100vh;position:relative;overflow-x:hidden}body:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background-image:radial-gradient(circle at 20% 50%,rgba(255,182,193,.3) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(255,192,203,.3) 0%,transparent 50%),radial-gradient(circle at 40% 20%,rgba(255,182,193,.2) 0%,transparent 50%);pointer-events:none;z-index:0}#root{min-height:100vh;position:relative;z-index:1}.loading{display:flex;justify-content:center;align-items:center;min-height:100vh;font-size:2rem;color:#fff;font-weight:700;text-shadow:2px 2px 4px rgba(0,0,0,.3);animation:pulse 2s ease-in-out infinite}.container{max-width:1200px;margin:0 auto;padding:2rem}.card{background:#fff;border-radius:25px;padding:2rem;box-shadow:0 8px 20px #ff6b9d33;margin-bottom:2rem;border:3px solid #ffb6c1;transition:transform .3s ease,box-shadow .3s ease}.card:hover{transform:translateY(-5px);box-shadow:0 12px 30px #ff6b9d4d}.btn{padding:1rem 2rem;border:none;border-radius:20px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .3s ease;text-decoration:none;display:inline-block;text-align:center;box-shadow:0 4px 15px #0003;font-family:Comic Sans MS,Chalkboard SE,Comic Neue,sans-serif}.btn-primary{background:linear-gradient(135deg,#ff6b9d,#c44569);color:#fff;border:3px solid #ffb6c1}.btn-primary:hover{transform:translateY(-3px) scale(1.05);box-shadow:0 6px 20px #ff6b9d80;background:linear-gradient(135deg,#ff8fb3,#d65a7f)}.btn-primary:active{transform:translateY(-1px) scale(1.02)}.btn-secondary{background:linear-gradient(135deg,#a8e6cf,#88d8a3);color:#2d5016;border:3px solid #b8f5d3}.btn-secondary:hover{background:linear-gradient(135deg,#b8f5d3,#98e8b3);transform:translateY(-3px) scale(1.05);box-shadow:0 6px 20px #a8e6cf80}.btn-danger{background:linear-gradient(135deg,#ff6b6b,#ee5a6f);color:#fff;border:3px solid #ffb3b3}.btn-danger:hover{background:linear-gradient(135deg,#ff8b8b,#f06a7f);transform:translateY(-3px) scale(1.05);box-shadow:0 6px 20px #ff6b6b80}.btn-success{background:linear-gradient(135deg,#51cf66,#40c057);color:#fff;border:3px solid #8ce99a}.btn-success:hover{background:linear-gradient(135deg,#69db7c,#51cf66);transform:translateY(-3px) scale(1.05);box-shadow:0 6px 20px #51cf6680}.btn:disabled{opacity:.6;cursor:not-allowed}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:700;color:#ff6b9d;font-size:1.1rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:1rem;border:3px solid #ffb6c1;border-radius:15px;font-size:1.1rem;transition:all .3s ease;background:#fff;font-family:Comic Sans MS,Chalkboard SE,Comic Neue,sans-serif}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#ff6b9d;box-shadow:0 0 0 4px #ff6b9d33;transform:scale(1.02)}.error{color:#dc3545;font-size:1rem;margin-top:1rem;padding:1rem;background:#fee;border:2px solid #fcc;border-radius:15px;font-weight:600;text-align:center;animation:shake .5s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.header{background:#fff;padding:1.5rem 2rem;box-shadow:0 4px 15px #ff6b9d33;display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;border-radius:0 0 25px 25px;border-bottom:4px solid #ffb6c1}.header h1{color:#ff6b9d;font-size:2rem;font-weight:800;text-shadow:2px 2px 4px rgba(255,107,157,.2);font-family:Comic Sans MS,Chalkboard SE,Comic Neue,sans-serif}.header-actions{display:flex;gap:1rem;align-items:center}.grid{display:grid;gap:1.5rem}.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.grid-3{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}@media (max-width: 768px){.container{padding:1rem}.card{padding:1.5rem}.header{flex-direction:column;gap:1rem;align-items:flex-start}.grid-2,.grid-3{grid-template-columns:1fr}}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400}body{margin:0;min-height:100vh}
