*{box-sizing:border-box;margin:0;padding:0}:root{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#213547;background-color:#f5f7fa;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{width:100%;min-height:100vh}button{font-family:inherit}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2}a{font-weight:500;color:#667eea;text-decoration:none}a:hover{color:#764ba2}.stats-container{max-width:1200px;margin:0 auto;padding:2rem}.stats-container h1{text-align:center;font-size:2.5rem;margin-bottom:2rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stats-tabs{display:flex;gap:1rem;margin-bottom:2rem;border-bottom:2px solid #e0e0e0;flex-wrap:wrap}.stats-tabs button{background:none;border:none;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;color:#666;cursor:pointer;border-bottom:3px solid transparent;transition:all .3s ease;margin-bottom:-2px}.stats-tabs button:hover{color:#667eea;background:#f5f5f5}.stats-tabs button.active{color:#667eea;border-bottom-color:#667eea}.stats-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:3rem}.stat-box{background:#fff;padding:1.5rem;border-radius:16px;box-shadow:0 4px 12px #0000001a;display:flex;align-items:center;gap:1rem;transition:transform .3s ease}.stat-box:hover{transform:translateY(-4px);box-shadow:0 6px 20px #00000026}.stat-icon{font-size:3rem;width:60px;height:60px;display:flex;align-items:center;justify-content:center}.stat-info{flex:1}.stat-value{font-size:2rem;font-weight:700;color:#667eea;margin-bottom:.25rem}.stat-label{font-size:1rem;font-weight:500;color:#333;margin-bottom:.25rem}.stat-sub{font-size:.85rem;color:#666}.difficulty-breakdown{background:#fff;padding:2rem;border-radius:16px;box-shadow:0 4px 12px #0000001a;margin-bottom:2rem}.difficulty-breakdown h2{margin:0 0 1.5rem;font-size:1.5rem;color:#333}.difficulty-bars{display:flex;flex-direction:column;gap:1rem}.difficulty-bar-item{display:flex;flex-direction:column;gap:.5rem}.difficulty-label{display:flex;justify-content:space-between;font-size:.9rem;color:#666;font-weight:500}.difficulty-count{color:#999}.difficulty-bar{width:100%;height:24px;background:#e0e0e0;border-radius:12px;overflow:hidden}.difficulty-bar-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);transition:width .3s ease}.category-stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.category-stat-card{background:#fff;padding:1.5rem;border-radius:16px;box-shadow:0 4px 12px #0000001a;transition:transform .3s ease}.category-stat-card:hover{transform:translateY(-4px);box-shadow:0 6px 20px #00000026}.category-stat-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.category-icon{font-size:2rem}.category-stat-header h3{margin:0;font-size:1.2rem;color:#333}.category-stat-progress{margin-bottom:1rem}.category-stat-progress .progress-bar{width:100%;height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden;margin-bottom:.5rem}.category-stat-progress .progress-fill{height:100%;background:linear-gradient(90deg,#11998e,#38ef7d);transition:width .3s ease}.progress-text{font-size:.9rem;color:#666}.category-stat-details{display:flex;gap:1rem;flex-wrap:wrap}.stat-detail{display:flex;flex-direction:column;gap:.25rem}.detail-label{font-size:.8rem;color:#999}.detail-value{font-size:1.1rem;font-weight:600;color:#333}.difficulty-section{background:#fff;padding:2rem;border-radius:16px;box-shadow:0 4px 12px #0000001a;margin-bottom:2rem}.difficulty-section h3{margin:0 0 1rem;font-size:1.3rem;color:#333}.difficulty-words-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.difficulty-word-card{background:#f8f9fa;padding:1rem;border-radius:8px;border:1px solid #e0e0e0;transition:all .3s ease}.difficulty-word-card:hover{border-color:#667eea;box-shadow:0 2px 8px #667eea33}.difficulty-word-card.more-words{display:flex;align-items:center;justify-content:center;font-style:italic;color:#999;border-style:dashed}.word-main{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.5rem}.word-main strong{font-size:1rem;color:#333}.word-translation{font-size:.85rem;color:#666}.word-stats{display:flex;gap:.75rem;font-size:.8rem;color:#999;flex-wrap:wrap}.word-category{font-size:.75rem;color:#999;padding:.25rem .5rem;background:#e0e0e0;border-radius:4px}.stat-correct{color:#11998e}.stat-incorrect{color:#ee0979}.weak-words-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem}.weak-word-card{background:#fff;padding:1.5rem;border-radius:16px;box-shadow:0 4px 12px #0000001a;border-left:4px solid #ee0979;transition:transform .3s ease}.weak-word-card:hover{transform:translateY(-4px);box-shadow:0 6px 20px #00000026}.word-pronunciation{font-size:.85rem;color:#999;font-style:italic;margin-top:.5rem}.no-weak-words{text-align:center;padding:4rem 2rem;background:#fff;border-radius:16px;box-shadow:0 4px 12px #0000001a}.no-weak-words p{font-size:1.2rem;color:#666;margin:0}@media(max-width:768px){.stats-tabs{flex-direction:column}.stats-tabs button{width:100%;text-align:left}.stats-summary,.category-stats-grid{grid-template-columns:1fr}}.dashboard{max-width:1200px;margin:0 auto;padding:2rem}.dashboard-header{text-align:center;margin-bottom:3rem}.dashboard-header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.dashboard-header-top-left{flex:1}.dashboard-header-title{flex:2;text-align:center;margin:0}.dashboard-header-top-right{flex:1;display:flex;justify-content:flex-end}.dashboard-header h1{font-size:3rem;margin:0 0 .5rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.subtitle{font-size:1.2rem;color:#666;margin:0}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:3rem}.stat-card{background:#fff;padding:2rem;border-radius:16px;text-align:center;box-shadow:0 4px 12px #0000001a;transition:transform .3s ease}.stat-card:hover{transform:translateY(-4px);box-shadow:0 6px 20px #00000026}.stat-value{font-size:2.5rem;font-weight:700;color:#667eea;margin-bottom:.5rem}.stat-label{font-size:1rem;color:#666;font-weight:500}.categories-section h2,.game-mode-section h2{text-align:center;font-size:2rem;margin-bottom:2rem;color:#333}.categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem}.category-card{background:#fff;padding:2rem;border-radius:16px;border:2px solid #e0e0e0;cursor:pointer;transition:all .3s ease;text-align:center;display:flex;flex-direction:column;gap:.75rem}.category-card:hover{border-color:#667eea;transform:translateY(-4px);box-shadow:0 8px 24px #667eea33}.category-icon{font-size:3rem}.category-card h3{margin:0;font-size:1.3rem;color:#333}.category-word-count{margin:0;color:#666;font-size:.9rem}.category-progress{margin-top:auto;display:flex;flex-direction:column;gap:.5rem}.category-progress-bar{width:100%;height:6px;background:#e0e0e0;border-radius:3px;overflow:hidden}.category-progress-fill{height:100%;background:linear-gradient(90deg,#11998e,#38ef7d);transition:width .3s ease}.category-progress-text{font-size:.85rem;color:#666}.back-button{background:#f5f5f5;border:2px solid #e0e0e0;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;color:#666;margin-bottom:2rem;transition:all .3s ease}.back-button:hover{background:#e0e0e0;border-color:#ccc}.game-modes{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;max-width:1000px;margin:0 auto}.game-mode-card{background:#fff;padding:2.5rem;border-radius:16px;border:3px solid #e0e0e0;cursor:pointer;transition:all .3s ease;text-align:center;display:flex;flex-direction:column;gap:1rem}.game-mode-card:hover{border-color:#667eea;transform:translateY(-4px);box-shadow:0 8px 24px #667eea4d}.game-mode-card.selected{border-color:#667eea;background:linear-gradient(135deg,#f0f7ff,#e8f4fd);box-shadow:0 8px 24px #667eea4d}.mode-icon{font-size:4rem}.game-mode-card h3{margin:0;font-size:1.5rem;color:#333}.game-mode-card p{margin:0;color:#666;font-size:1rem;line-height:1.5}.settings-button{background:#f5f5f5;border:2px solid #e0e0e0;padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-size:1.2rem;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.settings-button:hover{background:#e0e0e0;border-color:#667eea;transform:scale(1.05)}.settings-panel{background:#fff;border-radius:16px;padding:2rem;margin-bottom:2rem;box-shadow:0 4px 12px #0000001a;border:2px solid #e0e0e0}.settings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #e0e0e0}.settings-header h3{margin:0;font-size:1.5rem;color:#333}.close-settings-button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666;padding:.25rem .5rem;border-radius:4px;transition:all .3s ease}.close-settings-button:hover{background:#f5f5f5;color:#333}.settings-content{display:flex;flex-direction:column;gap:2rem}.setting-item{display:flex;flex-direction:column;gap:.75rem}.setting-item label{font-size:1rem;font-weight:500;color:#333}.speed-control{display:flex;align-items:center;gap:1rem;margin:.5rem 0}.speed-label{font-size:.9rem;color:#666;min-width:60px}.speed-slider{flex:1;height:8px;border-radius:4px;background:#e0e0e0;outline:none;-webkit-appearance:none;appearance:none}.speed-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:#667eea;cursor:pointer;transition:all .3s ease}.speed-slider::-webkit-slider-thumb:hover{background:#764ba2;transform:scale(1.2)}.speed-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#667eea;cursor:pointer;border:none;transition:all .3s ease}.speed-slider::-moz-range-thumb:hover{background:#764ba2;transform:scale(1.2)}.setting-description{font-size:.9rem;color:#666;margin:0;line-height:1.5}.test-pronunciation-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease;align-self:flex-start}.test-pronunciation-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.test-pronunciation-button:disabled{opacity:.5;cursor:not-allowed}.stats-button{background:#f5f5f5;border:2px solid #e0e0e0;padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-size:1.2rem;transition:all .3s ease;display:flex;align-items:center;justify-content:center;margin-right:.5rem}.stats-button:hover{background:#e0e0e0;border-color:#667eea;transform:scale(1.05)}.practice-mode-toggle{background:#fff;padding:1.5rem;border-radius:16px;box-shadow:0 4px 12px #0000001a;margin-bottom:2rem}.practice-mode-checkbox{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-size:1.1rem;font-weight:500;color:#333;margin-bottom:.5rem}.practice-mode-checkbox input[type=checkbox]{width:20px;height:20px;cursor:pointer}.practice-mode-description{font-size:.9rem;color:#666;margin:0}.search-section{margin-bottom:2rem}.search-input{width:100%;padding:1rem;font-size:1rem;border:2px solid #e0e0e0;border-radius:12px;transition:all .3s ease}.search-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:1rem}.search-results-count{font-size:.9rem;color:#666;font-style:italic}.setting-select{width:100%;padding:.75rem;font-size:1rem;border:2px solid #e0e0e0;border-radius:8px;background:#fff;cursor:pointer;transition:all .3s ease;margin-top:.5rem}.setting-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.setting-checkbox{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-size:1rem;font-weight:500;color:#333}.setting-checkbox input[type=checkbox]{width:20px;height:20px;cursor:pointer}.stats-view{margin-top:2rem}.close-stats-button{background:#f5f5f5;border:2px solid #e0e0e0;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;color:#666;margin-bottom:2rem;transition:all .3s ease}.close-stats-button:hover{background:#e0e0e0;border-color:#ccc}.achievement-popup{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .3s ease;cursor:pointer}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.achievement-content{background:#fff;padding:2rem;border-radius:16px;max-width:500px;width:90%;box-shadow:0 8px 24px #0000004d;animation:slideUp .3s ease;cursor:default;position:relative}.achievement-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #e0e0e0}.achievement-close-button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666;padding:.25rem .5rem;border-radius:4px;transition:all .3s ease;line-height:1;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.achievement-close-button:hover{background:#f5f5f5;color:#333}.achievement-close-button:active{transform:scale(.9)}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.achievement-content h3{margin:0;font-size:1.8rem;color:#667eea;text-align:center;flex:1}.achievement-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#f8f9fa;border-radius:8px;margin-bottom:1rem}.achievement-icon{font-size:3rem}.achievement-item strong{display:block;font-size:1.2rem;color:#333;margin-bottom:.25rem}.achievement-item p{margin:0;color:#666;font-size:.9rem}.achievement-ok-button{width:100%;padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:1rem}.achievement-ok-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.achievement-ok-button:active{transform:translateY(0)}.export-button,.import-button,.reset-button{padding:.75rem 1.5rem;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .3s ease;border:2px solid #e0e0e0;background:#fff;color:#333}.export-button:hover{background:#e8f5e9;border-color:#4caf50;transform:translateY(-2px)}.import-button:hover{background:#e3f2fd;border-color:#2196f3;transform:translateY(-2px)}.reset-button:hover{background:#ffebee;border-color:#f44336;transform:translateY(-2px)}.dark-mode{--bg-color: #1a1a1a;--text-color: #ffffff;--card-bg: #2d2d2d;--border-color: #404040;--input-bg: #2d2d2d;--hover-bg: #3d3d3d}.dark-mode body{background-color:var(--bg-color);color:var(--text-color)}.dark-mode .dashboard,.dark-mode .stat-card,.dark-mode .category-card,.dark-mode .game-mode-card,.dark-mode .settings-panel,.dark-mode .practice-mode-toggle{background:var(--card-bg);color:var(--text-color)}.dark-mode .stat-card,.dark-mode .category-card,.dark-mode .game-mode-card{border-color:var(--border-color)}.dark-mode .search-input,.dark-mode .setting-select{background:var(--input-bg);color:var(--text-color);border-color:var(--border-color)}.dark-mode .settings-button:hover,.dark-mode .stats-button:hover{background:var(--hover-bg)}@media(max-width:768px){.dashboard-header h1{font-size:2rem}.categories-grid,.game-modes{grid-template-columns:1fr}.speed-control{flex-direction:column;align-items:stretch;gap:.5rem}.speed-label{min-width:auto;text-align:center}.dashboard-header-top{flex-direction:column;gap:1rem}.dashboard-header-title{margin:0}.dashboard-header-top-left,.dashboard-header-top-right{flex:1;display:flex;justify-content:center;gap:.5rem}}.flashcard-container{display:flex;flex-direction:column;align-items:center;gap:2rem;padding:2rem;max-width:600px;margin:0 auto}.flashcard-progress{width:100%;display:flex;flex-direction:column;gap:.5rem}.progress-text{text-align:center;font-size:.9rem;color:#666}.flashcard{width:100%;height:400px;perspective:1000px;cursor:pointer}.flashcard-inner{position:relative;width:100%;height:100%;text-align:center;transition:transform .6s;transform-style:preserve-3d}.flashcard.flipped .flashcard-inner{transform:rotateY(180deg)}.flashcard-front,.flashcard-back{position:absolute;width:100%;height:100%;backface-visibility:hidden;border-radius:16px;box-shadow:0 8px 24px #00000026;display:flex;align-items:center;justify-content:center}.flashcard-front{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.flashcard-back{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;transform:rotateY(180deg)}.flashcard-content{padding:2rem;text-align:center}.word-header{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:1rem}.flashcard-content h2{font-size:2.5rem;margin:0;font-weight:600}.pronunciation{font-size:1.2rem;opacity:.9;font-style:italic;margin:.5rem 0}.example{font-size:1.1rem;opacity:.95;font-style:italic;margin:1rem 0;line-height:1.6}.hint{font-size:.9rem;opacity:.8;margin-top:2rem}.learned-badge{display:inline-block;background:#ffffff4d;padding:.5rem 1rem;border-radius:20px;font-size:.9rem;margin-top:1rem}.flashcard.learned .flashcard-front{background:linear-gradient(135deg,#11998e,#38ef7d)}.flashcard-actions{display:flex;gap:1rem;width:100%;justify-content:center}.flashcard-actions button{padding:1rem 2rem;font-size:1.1rem;border:none;border-radius:12px;cursor:pointer;font-weight:600;transition:all .3s ease;min-width:150px}.btn-correct{background:linear-gradient(135deg,#11998e,#38ef7d);color:#fff}.btn-correct:hover{transform:translateY(-2px);box-shadow:0 4px 12px #11998e66}.btn-wrong{background:linear-gradient(135deg,#ee0979,#ff6a00);color:#fff}.btn-wrong:hover{transform:translateY(-2px);box-shadow:0 4px 12px #ee097966}.result-message{text-align:center;font-size:1.2rem;color:#11998e;font-weight:600}@media(max-width:768px){.flashcard{height:350px}.flashcard-content h2{font-size:2rem}.flashcard-actions{flex-direction:column}.flashcard-actions button{width:100%}}.quiz-container{display:flex;flex-direction:column;gap:2rem;padding:2rem;max-width:700px;margin:0 auto}.quiz-progress{width:100%;display:flex;flex-direction:column;gap:.5rem}.progress-text{text-align:center;font-size:.9rem;color:#666;display:flex;justify-content:space-between}.score-text{text-align:center;font-size:1rem;font-weight:600;color:#4a90e2}.quiz-question{text-align:center;padding:2rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;color:#fff;box-shadow:0 8px 24px #00000026}.quiz-question h2{margin:0 0 1.5rem;font-size:1.5rem;font-weight:500}.question-word-header{display:flex;align-items:center;justify-content:center;gap:1rem}.question-pronunciation-section{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:.5rem}.question-word h3{font-size:2.5rem;margin:0;font-weight:600}.speaker-button{background:#ffffff4d;border:2px solid rgba(255,255,255,.5);border-radius:50%;width:50px;height:50px;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.speaker-button:hover{background:#ffffff80;border-color:#fffc;transform:scale(1.1)}.speaker-button:active{transform:scale(.95)}.pronunciation{font-size:1.2rem;opacity:.9;font-style:italic;margin:.5rem 0 0}.quiz-answers{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.quiz-button{padding:1.5rem;font-size:1.1rem;border:2px solid #e0e0e0;border-radius:12px;background:#fff;cursor:pointer;font-weight:500;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:.5rem;min-height:80px}.answer-content{display:flex;flex-direction:column;align-items:center;gap:.5rem;flex:1}.answer-text{font-size:1.1rem;font-weight:500}.answer-pronunciation{font-size:.9rem;color:#666;font-style:italic;opacity:.8}.answer-speaker-button{background:#667eea1a;border:2px solid rgba(102,126,234,.3);border-radius:50%;width:35px;height:35px;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;position:absolute;top:.5rem;right:.5rem;z-index:2;flex-shrink:0}.answer-speaker-button:hover{background:#667eea33;border-color:#667eea80;transform:scale(1.1)}.quiz-button{position:relative}.quiz-button:hover:not(:disabled){border-color:#4a90e2;background:#f0f7ff;transform:translateY(-2px);box-shadow:0 4px 12px #4a90e233}.quiz-button.correct{background:linear-gradient(135deg,#11998e,#38ef7d);color:#fff;border-color:transparent}.quiz-button.incorrect{background:linear-gradient(135deg,#ee0979,#ff6a00);color:#fff;border-color:transparent}.quiz-button.disabled{opacity:.6;cursor:not-allowed}.check-mark,.x-mark{font-size:1.5rem}.result-message{text-align:center;padding:1rem;border-radius:12px;font-size:1.2rem;font-weight:600;animation:slideIn .3s ease}.result-message.correct{background:#d4edda;color:#155724}.result-message.incorrect{background:#f8d7da;color:#721c24}.result-message p{margin:.5rem 0}.correct-answer{margin-top:.75rem;font-size:1.3rem}.correct-answer strong{display:block;margin-bottom:.5rem}.pronunciation-hint{font-size:1rem;font-style:italic;opacity:.9;font-weight:400}@media(max-width:768px){.quiz-answers{grid-template-columns:1fr}.quiz-button{min-height:70px}.question-word h3{font-size:2rem}}.matching-container{display:flex;flex-direction:column;gap:2rem;padding:2rem;max-width:900px;margin:0 auto}.matching-header{display:flex;flex-direction:column;gap:.5rem}.matching-progress{display:flex;justify-content:space-between;font-weight:600;color:#666}.progress-bar{width:100%;height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#4a90e2,#357abd);transition:width .3s ease}.matching-game{display:grid;grid-template-columns:1fr 1fr;gap:2rem;min-height:500px}.matching-column{display:flex;flex-direction:column;gap:1rem}.matching-column h3{text-align:center;font-size:1.5rem;color:#333;margin:0;padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px}.word-list{display:flex;flex-direction:column;gap:.75rem;flex:1}.matching-word{padding:1.25rem;font-size:1.1rem;border:2px solid #e0e0e0;border-radius:12px;background:#fff;cursor:pointer;font-weight:500;transition:all .3s ease;text-align:left;display:flex;justify-content:space-between;align-items:center;min-height:60px;gap:.5rem}.word-text{flex:1}.matching-word:hover:not(:disabled){border-color:#4a90e2;background:#f0f7ff;transform:translate(4px);box-shadow:0 4px 12px #4a90e233}.matching-word.selected{border-color:#4a90e2;background:#e3f2fd;transform:translate(4px);box-shadow:0 4px 12px #4a90e24d}.matching-word.matched{background:linear-gradient(135deg,#11998e,#38ef7d);color:#fff;border-color:transparent;cursor:not-allowed;opacity:.8}.matching-speaker-button{background:#f0f7ff;border:1px solid #4a90e2;border-radius:50%;width:32px;height:32px;font-size:.9rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0;padding:0}.matching-speaker-button:hover{background:#e3f2fd;transform:scale(1.1)}.matching-speaker-button:active{transform:scale(.95)}.check-icon{font-size:1.5rem;flex-shrink:0}.match-feedback{text-align:center;padding:1rem;border-radius:12px;font-size:1.3rem;font-weight:600;animation:popIn .3s ease}.match-feedback.correct{background:#d4edda;color:#155724}.match-feedback.incorrect{background:#f8d7da;color:#721c24}@keyframes popIn{0%{transform:scale(.8);opacity:0}50%{transform:scale(1.05)}to{transform:scale(1);opacity:1}}@media(max-width:768px){.matching-game{grid-template-columns:1fr;gap:1.5rem}.matching-progress{flex-direction:column;gap:.5rem;text-align:center}}.typing-container{max-width:800px;margin:0 auto;padding:2rem}.typing-progress{margin-bottom:2rem}.typing-stats{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}.progress-text,.score-text,.time-text{font-size:.9rem;color:#666;font-weight:500}.typing-question{text-align:center;margin-bottom:2rem;background:#fff;padding:2rem;border-radius:16px;box-shadow:0 4px 12px #0000001a}.typing-question h2{margin:0 0 1.5rem;font-size:1.5rem;color:#333}.question-word{display:flex;flex-direction:column;gap:1rem;align-items:center}.question-word-header{display:flex;align-items:center;gap:1rem}.question-word-header h3{font-size:2.5rem;margin:0;color:#667eea;font-weight:700}.pronunciation{font-size:1.2rem;color:#999;font-style:italic;margin:0}.speaker-button{background:#f5f5f5;border:2px solid #e0e0e0;padding:.5rem 1rem;border-radius:8px;font-size:1.2rem;cursor:pointer;transition:all .3s ease}.speaker-button:hover{background:#e0e0e0;border-color:#667eea;transform:scale(1.05)}.typing-input-section{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.typing-hint-section{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.hint-button{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;border:none;padding:.5rem 1rem;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .3s ease}.hint-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #f5576c66}.typing-direction{margin:0;font-size:.9rem;color:#666}.typing-input{width:100%;padding:1.5rem;font-size:1.5rem;border:3px solid #e0e0e0;border-radius:12px;text-align:center;transition:all .3s ease;font-family:inherit}.typing-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.typing-input.correct{border-color:#11998e;background:#f0fff4}.typing-input.incorrect{border-color:#ee0979;background:#fff0f5}.typing-input:disabled{background:#f5f5f5;cursor:not-allowed}.submit-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:1rem 2rem;border-radius:12px;font-size:1.2rem;font-weight:600;cursor:pointer;transition:all .3s ease;align-self:center;min-width:200px}.submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.submit-button:disabled{opacity:.5;cursor:not-allowed}.typing-result{text-align:center;padding:2rem;border-radius:16px;margin-bottom:1.5rem;animation:slideIn .3s ease}.typing-result.correct{background:linear-gradient(135deg,#11998e,#38ef7d);color:#fff}.typing-result.incorrect{background:linear-gradient(135deg,#ee0979,#f5576c);color:#fff}.result-icon{font-size:4rem;margin:0 0 1rem}.result-message{font-size:1.5rem;font-weight:600;margin:0}.pronunciation-hint{font-size:1.2rem;margin:1rem 0 0;opacity:.9;font-style:italic}.typing-answer-display{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 4px 12px #0000001a;display:flex;flex-direction:column;gap:1rem}.answer-info{padding:1rem;background:#f8f9fa;border-radius:8px;font-size:1.1rem}.answer-info strong{color:#667eea;margin-right:.5rem}@media(max-width:768px){.typing-container{padding:1rem}.question-word-header h3{font-size:2rem}.typing-input{font-size:1.2rem;padding:1rem}.typing-stats{flex-direction:column;gap:.5rem}}.pronunciation-container{max-width:800px;margin:0 auto;padding:2rem}.pronunciation-progress{margin-bottom:2rem}.progress-bar{width:100%;height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden;margin-bottom:1rem}.progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);transition:width .3s ease}.pronunciation-stats{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}.progress-text,.score-text{font-size:.9rem;color:#666;font-weight:500}.pronunciation-word{text-align:center;margin-bottom:3rem;background:#fff;padding:3rem 2rem;border-radius:16px;box-shadow:0 4px 12px #0000001a}.pronunciation-word h2{margin:0 0 2rem;font-size:1.8rem;color:#333}.word-display{display:flex;flex-direction:column;gap:1.5rem;align-items:center}.word-display h3{font-size:2.5rem;margin:0;color:#667eea;font-weight:700}.word-hint{font-size:1.2rem;color:#666;margin:0;font-weight:500}.french-word-display{display:flex;flex-direction:column;gap:.5rem;align-items:center}.french-word-display strong{font-size:3rem;color:#333;font-weight:700}.pronunciation-guide{font-size:1.5rem;color:#999;font-style:italic}.word-example{font-size:1rem;color:#666;font-style:italic;margin:0;max-width:600px}.pronunciation-controls{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap;margin-bottom:2rem}.hear-button,.listen-button,.skip-button{padding:1rem 2rem;border-radius:12px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;border:none;min-width:180px}.hear-button{background:linear-gradient(135deg,#11998e,#38ef7d);color:#fff}.hear-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #11998e66}.listen-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:1.2rem}.listen-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.listen-button.listening{background:linear-gradient(135deg,#ee0979,#f5576c);animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.skip-button{background:#f5f5f5;color:#666;border:2px solid #e0e0e0}.skip-button:hover:not(:disabled){background:#e0e0e0;border-color:#ccc}.hear-button:disabled,.listen-button:disabled,.skip-button:disabled{opacity:.5;cursor:not-allowed}.listening-status{text-align:center;padding:2rem;background:linear-gradient(135deg,#ff6b6b,#ee5a6f);color:#fff;border-radius:16px;margin-bottom:2rem;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.wave-animation{display:flex;justify-content:center;gap:.3rem;margin-bottom:1rem;height:40px;align-items:center}.wave-animation span{width:4px;background:#fff;border-radius:2px;animation:wave 1.2s ease-in-out infinite}.wave-animation span:nth-child(1){animation-delay:0s;height:20px}.wave-animation span:nth-child(2){animation-delay:.1s;height:30px}.wave-animation span:nth-child(3){animation-delay:.2s;height:40px}.wave-animation span:nth-child(4){animation-delay:.3s;height:30px}.wave-animation span:nth-child(5){animation-delay:.4s;height:20px}@keyframes wave{0%,to{transform:scaleY(.5)}50%{transform:scaleY(1)}}.listening-status p{font-size:1.3rem;font-weight:600;margin:0}.listening-indicator{animation:bounce 1s ease-in-out infinite;display:inline-block}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.user-speech-display{text-align:center;padding:1.5rem;background:#f8f9fa;border-radius:12px;margin-bottom:1rem;font-size:1.1rem;color:#333}.pronunciation-result{text-align:center;padding:2.5rem;border-radius:16px;margin-bottom:2rem;animation:slideIn .3s ease}.pronunciation-result.correct{background:linear-gradient(135deg,#11998e,#38ef7d);color:#fff}.pronunciation-result.incorrect{background:linear-gradient(135deg,#ee0979,#f5576c);color:#fff}.result-icon{font-size:5rem;margin:0 0 1rem}.result-message{font-size:1.8rem;font-weight:600;margin:0 0 1rem}.result-detail{font-size:1.2rem;margin:.5rem 0;opacity:.95}.try-again-button{margin-top:1rem;padding:.75rem 1.5rem;background:#ffffff4d;color:#fff;border:2px solid white;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.try-again-button:hover{background:#fff;color:#ee0979}.pronunciation-help{background:#f8f9fa;padding:1.5rem;border-radius:12px;margin-top:2rem}.pronunciation-help p{margin:.5rem 0;font-size:.9rem;color:#666;line-height:1.6}.pronunciation-error{text-align:center;padding:3rem 2rem;background:#fff;border-radius:16px;box-shadow:0 4px 12px #0000001a}.pronunciation-error h2{margin:0 0 1.5rem;color:#333}.pronunciation-error ul{text-align:left;display:inline-block;margin:1rem 0;padding-left:2rem}.pronunciation-error li{margin:.5rem 0;color:#666}@media(max-width:768px){.pronunciation-container{padding:1rem}.french-word-display strong{font-size:2rem}.pronunciation-controls{flex-direction:column}.hear-button,.listen-button,.skip-button{width:100%}}.game-results{display:flex;justify-content:center;align-items:center;min-height:60vh;padding:2rem}.results-card{background:#fff;border-radius:24px;padding:3rem;max-width:500px;width:100%;box-shadow:0 12px 40px #00000026;text-align:center}.results-header{margin-bottom:2rem}.results-emoji{font-size:4rem;display:block;margin-bottom:1rem}.results-header h2{font-size:2rem;margin:0 0 .5rem;color:#333}.results-category{color:#666;font-size:1rem;margin:0}.results-score{display:flex;flex-direction:column;align-items:center;gap:2rem;margin-bottom:2rem}.score-circle{width:200px;height:200px;border-radius:50%;background:conic-gradient(var(--color) 0%,var(--color) var(--percentage),#e0e0e0 var(--percentage),#e0e0e0 100%);display:flex;align-items:center;justify-content:center;position:relative;animation:fillCircle 1s ease-out}.score-circle:before{content:"";position:absolute;width:160px;height:160px;border-radius:50%;background:#fff}.score-inner{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center}.score-value{font-size:3rem;font-weight:700;color:var(--color);line-height:1}.score-label{font-size:1rem;color:#666;margin-top:.5rem}.score-details{display:flex;gap:3rem}.score-stat{display:flex;flex-direction:column;gap:.5rem}.stat-label{font-size:.9rem;color:#666}.stat-value{font-size:1.8rem;font-weight:700;color:#333}.results-message{font-size:1.3rem;font-weight:600;margin-bottom:2rem}.results-actions{display:flex;gap:1rem;flex-direction:column}.results-actions button{padding:1rem 2rem;font-size:1.1rem;border:none;border-radius:12px;cursor:pointer;font-weight:600;transition:all .3s ease}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.btn-secondary{background:#f5f5f5;color:#666;border:2px solid #e0e0e0}.btn-secondary:hover{background:#e0e0e0}@keyframes fillCircle{0%{background:conic-gradient(var(--color) 0%,var(--color) 0%,#e0e0e0 0%,#e0e0e0 100%)}}@media(max-width:768px){.results-card{padding:2rem}.score-circle{width:160px;height:160px}.score-circle:before{width:130px;height:130px}.score-value{font-size:2.5rem}}.app{width:100%;min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#e8ecf1)}.app-container{width:100%;min-height:100vh;padding-bottom:2rem}.game-view{position:relative;padding:2rem;max-width:1200px;margin:0 auto}.exit-game-button{background:#fff;border:2px solid #e0e0e0;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;color:#666;margin-bottom:2rem;transition:all .3s ease;box-shadow:0 2px 8px #0000001a}.exit-game-button:hover{background:#f5f5f5;border-color:#ccc;transform:translateY(-2px);box-shadow:0 4px 12px #00000026}@media(max-width:768px){.game-view{padding:1rem}}
