:root{--color-der: #4A90D9;--color-die: #E85D75;--color-das: #5BBD72;--color-der-light: #d0e3f7;--color-die-light: #fad0d7;--color-das-light: #c8ecd0;--color-bg: #FFF8F0;--color-card: #ffffff;--color-star: #FFD700;--color-star-empty: #e0d8c8;--color-text: #3a3a3a;--color-text-light: #888888;--color-shadow: rgba(0, 0, 0, .08);--color-correct: #4CAF50;--color-wrong: #ff7043;--radius-lg: 24px;--radius-md: 16px;--radius-sm: 12px}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes squish{0%{transform:scale(1)}50%{transform:scale(.9)}to{transform:scale(1)}}@keyframes starBurst{0%{opacity:1;transform:scale(0) rotate(0)}50%{opacity:1;transform:scale(1.3) rotate(20deg)}to{opacity:1;transform:scale(1) rotate(0)}}@keyframes fillStar{0%{transform:scale(0);opacity:0}60%{transform:scale(1.4);opacity:1}to{transform:scale(1);opacity:1}}@keyframes gentleShake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}@keyframes glow{0%,to{box-shadow:0 0 8px 2px #4caf5066}50%{box-shadow:0 0 20px 6px #4caf50b3}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}@keyframes confettiDrop{0%{opacity:1;transform:translateY(0) rotate(0)}to{opacity:0;transform:translateY(120px) rotate(360deg)}}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%;width:100%;overflow:hidden}body{font-family:Nunito,Segoe UI,system-ui,-apple-system,sans-serif;background-color:var(--color-bg);color:var(--color-text);user-select:none;-webkit-user-select:none;touch-action:manipulation}button{border:none;cursor:pointer;font-family:inherit;touch-action:manipulation}img{display:block;max-width:100%}.app{height:100%;width:100%;max-width:480px;margin:0 auto;position:relative;overflow:hidden}.start-screen{height:100%;display:flex;flex-direction:column;align-items:center;gap:16px;padding:24px 24px 40px;position:relative;overflow-y:auto;-webkit-overflow-scrolling:touch}.start-emoji{font-size:80px;display:block;animation:bounce 2s ease infinite}.start-stars{font-size:24px;font-weight:800;color:var(--color-star)}.exercise-type-section{width:100%;max-width:320px}.section-label{display:block;font-size:14px;font-weight:800;color:var(--color-text-light);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;text-align:center}.exercise-type-btn{width:100%;display:flex;align-items:center;gap:12px;padding:16px 20px;border-radius:var(--radius-lg);box-shadow:0 4px 16px var(--color-shadow)}.exercise-type-btn:active{animation:squish .2s ease}.exercise-type-icon{font-size:24px;font-weight:800}.exercise-type-label{font-size:15px;font-weight:700;color:var(--color-text)}.category-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;width:100%;max-width:320px}.category-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:20px 12px;border-radius:var(--radius-lg);box-shadow:0 4px 16px var(--color-shadow);transition:transform .15s}.category-btn:active{animation:squish .2s ease}.category-emoji{font-size:44px;line-height:1}.category-label{font-size:15px;font-weight:800;color:var(--color-text)}.btn-stickers{position:absolute;top:20px;left:20px;width:48px;height:48px;border-radius:50%;background:var(--color-card);display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px var(--color-shadow)}.btn-stickers-icon{font-size:24px}.btn-stickers-count{position:absolute;top:-4px;right:-4px;background:var(--color-die);color:#fff;font-size:11px;font-weight:800;min-width:20px;height:20px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 4px}.btn-settings{position:absolute;top:20px;right:20px;width:44px;height:44px;border-radius:50%;background:transparent;font-size:24px;color:var(--color-text-light);display:flex;align-items:center;justify-content:center}.exercise-screen{height:100%;display:flex;flex-direction:column;padding:16px 16px 24px;gap:16px}.exercise-intro{height:100%;display:flex;align-items:center;justify-content:center}.empty-session{display:flex;flex-direction:column;align-items:center;gap:20px}.empty-session-text{font-size:18px;font-weight:700;color:var(--color-text-light);text-align:center;padding:0 24px}.btn-home-round{width:64px;height:64px;border-radius:50%;background:var(--color-card);font-size:28px;color:var(--color-text-light);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px var(--color-shadow)}.retry-label{text-align:center;font-size:20px;font-weight:800;color:var(--color-wrong);flex-shrink:0}.btn-start-session{width:100px;height:100px;border-radius:50%;background:linear-gradient(135deg,var(--color-der),var(--color-das));font-size:40px;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 20px var(--color-shadow);padding-left:6px}.btn-start-session:active{animation:squish .3s ease}.progress-bar{display:flex;flex-direction:column;align-items:center;gap:4px;padding:4px 0;flex-shrink:0}.progress-stars{display:flex;justify-content:center;gap:6px}.progress-star{font-size:22px;color:var(--color-star-empty);transition:color .3s}.progress-star.filled{color:var(--color-star)}.progress-star.wrong{color:var(--color-wrong)}.progress-count{font-size:14px;font-weight:700;color:var(--color-text-light)}.photo-card{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:0;overflow:hidden}.photo-card img{width:100%;max-height:calc(100% - 44px);object-fit:contain;border-radius:var(--radius-lg);box-shadow:0 4px 20px var(--color-shadow)}.photo-label{width:100%;text-align:center;font-size:28px;font-weight:800;color:var(--color-text);margin-top:8px;flex-shrink:0}.photo-skeleton{width:100%;aspect-ratio:1;border-radius:var(--radius-lg);background:linear-gradient(110deg,#f0ebe4 30%,#f7f3ed,#f0ebe4 70%);background-size:200% 100%;animation:shimmer 1.5s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.article-buttons{display:flex;gap:12px;flex-shrink:0}.article-button{flex:1;padding:16px 8px;border-radius:var(--radius-md);border:3px solid;display:flex;flex-direction:column;align-items:center;gap:6px;transition:transform .15s;min-height:90px}.article-button:active:not(:disabled){animation:squish .2s ease}.article-button:disabled{opacity:.7}.article-shape{font-size:28px;line-height:1}.article-label{font-size:22px;font-weight:800}.feedback-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:100}.feedback-correct{animation:fadeIn .2s ease}.feedback-mascot-row{display:flex;flex-direction:column;align-items:center;gap:8px}.feedback-star{font-size:100px;filter:drop-shadow(0 4px 20px rgba(255,215,0,.5))}.feedback-wrong{animation:fadeIn .2s ease}.feedback-hint{background:#fff;padding:20px 32px;border-radius:var(--radius-lg);box-shadow:0 8px 32px #00000026;display:flex;flex-direction:column;align-items:center;gap:4px}.feedback-hint-article{font-size:22px;font-weight:700;color:var(--color-correct)}.feedback-hint-word{font-size:36px;font-weight:800;color:var(--color-text)}.session-complete{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;padding:40px 24px}.result-circle{position:relative;width:180px;height:180px}.result-svg{width:100%;height:100%;transform:rotate(-90deg)}.result-arc{animation:circleGrow 1s ease forwards}@keyframes circleGrow{0%{stroke-dasharray:0 9999}}.result-center{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}.result-percent{font-size:40px;font-weight:800;color:var(--color-text)}.result-legend{display:flex;gap:24px}.legend-item{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:700}.legend-dot{width:14px;height:14px;border-radius:50%}.legend-correct{background:var(--color-correct)}.legend-wrong{background:var(--color-wrong)}.session-complete-buttons{display:flex;gap:20px;margin-top:16px}.btn-play-again{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--color-der),var(--color-das));font-size:32px;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px var(--color-shadow);padding-left:4px}.btn-play-again:active{animation:squish .3s ease}.btn-home{width:80px;height:80px;border-radius:50%;background:var(--color-card);font-size:32px;color:var(--color-text-light);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px var(--color-shadow)}.parent-dashboard{height:100%;overflow-y:auto;padding:20px 16px;-webkit-overflow-scrolling:touch}.dashboard-header{display:flex;align-items:center;gap:12px;margin-bottom:24px}.dashboard-header h2{font-size:24px;font-weight:800}.btn-back{width:44px;height:44px;border-radius:50%;background:var(--color-card);font-size:22px;color:var(--color-text);display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px var(--color-shadow)}.dashboard-summary{display:flex;gap:12px;margin-bottom:28px}.stat-card{flex:1;background:var(--color-card);border-radius:var(--radius-md);padding:16px 12px;text-align:center;box-shadow:0 2px 12px var(--color-shadow)}.stat-value{font-size:28px;font-weight:800;color:var(--color-text)}.stat-label{font-size:13px;color:var(--color-text-light);margin-top:4px}.category-progress{margin-bottom:28px}.category-progress h3{font-size:18px;font-weight:700;margin-bottom:12px}.category-progress-card{background:var(--color-card);border-radius:var(--radius-sm);padding:12px;margin-bottom:8px;box-shadow:0 1px 4px var(--color-shadow)}.category-progress-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.category-progress-emoji{font-size:20px}.category-progress-name{font-size:15px;font-weight:700;flex:1}.category-progress-acc{font-size:16px;font-weight:800}.category-progress-bar-bg{height:8px;background:#eee;border-radius:4px;overflow:hidden}.category-progress-bar-fill{height:100%;border-radius:4px;transition:width .5s ease}.category-progress-detail{font-size:12px;color:var(--color-text-light);margin-top:6px}.word-category-group{margin-bottom:8px}.word-category-header{width:100%;display:flex;align-items:center;gap:8px;padding:12px;background:var(--color-card);border-radius:var(--radius-sm);box-shadow:0 1px 4px var(--color-shadow);font-size:15px;font-weight:700;color:var(--color-text);text-align:left}.word-category-count{margin-left:auto;font-size:13px;color:var(--color-text-light);font-weight:600}.word-category-arrow{font-size:10px;color:var(--color-text-light);margin-left:4px}.dashboard-settings{margin-bottom:28px}.dashboard-settings h3{font-size:18px;font-weight:700;margin-bottom:12px}.setting-row{display:flex;align-items:center;justify-content:space-between;padding:12px;background:var(--color-card);border-radius:var(--radius-sm);box-shadow:0 1px 4px var(--color-shadow);margin-bottom:8px}.setting-label{font-size:15px;font-weight:600}.setting-control{display:flex;align-items:center;gap:12px}.setting-btn{width:36px;height:36px;border-radius:50%;background:var(--color-bg);font-size:20px;font-weight:800;color:var(--color-text);display:flex;align-items:center;justify-content:center;box-shadow:0 1px 4px var(--color-shadow)}.setting-value{font-size:20px;font-weight:800;min-width:28px;text-align:center;margin-top:4px}.dashboard-words h3{font-size:18px;font-weight:700;margin-bottom:12px}.word-list{display:flex;flex-direction:column;gap:6px}.word-row{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--color-card);border-radius:var(--radius-sm);box-shadow:0 1px 4px var(--color-shadow);font-size:15px}.word-article{font-weight:800;width:32px;flex-shrink:0}.word-name{flex:1;font-weight:600}.word-accuracy{font-weight:700;width:40px;text-align:right}.word-box{font-size:12px;color:var(--color-text-light);width:44px;text-align:right}.dashboard-reset{margin-top:32px;text-align:center;padding-bottom:40px}.btn-reset{padding:12px 24px;border-radius:var(--radius-sm);background:var(--color-card);color:var(--color-wrong);font-size:14px;font-weight:700;box-shadow:0 2px 8px var(--color-shadow)}.reset-confirm{display:flex;align-items:center;justify-content:center;gap:12px;font-weight:600}.btn-reset-yes{padding:8px 20px;border-radius:var(--radius-sm);background:var(--color-wrong);color:#fff;font-weight:700}.btn-reset-no{padding:8px 20px;border-radius:var(--radius-sm);background:var(--color-card);color:var(--color-text);font-weight:700;box-shadow:0 2px 8px var(--color-shadow)}.plural-hint{text-align:center;font-size:18px;font-weight:800;color:var(--color-text-light);flex-shrink:0}.plural-prompt{display:flex;align-items:center;justify-content:center;gap:12px;flex-shrink:0}.plural-singular{font-size:22px;font-weight:800;color:var(--color-text)}.plural-arrow{font-size:22px;color:var(--color-text-light)}.plural-question{font-size:28px;font-weight:800;color:var(--color-die)}.plural-options{display:flex;flex-direction:column;gap:8px;flex-shrink:0}.plural-option-btn{width:100%;padding:14px 20px;border-radius:var(--radius-md);background:var(--color-card);border:3px solid #e0e0e0;font-size:20px;font-weight:700;color:var(--color-text);box-shadow:0 2px 8px var(--color-shadow);text-align:center}.plural-option-btn:active:not(:disabled){animation:squish .2s ease}.plural-option-btn:disabled{opacity:.7}.prep-question{text-align:center;font-size:22px;font-weight:800;color:var(--color-text-light);flex-shrink:0}.prep-image-card{flex:1;display:flex;align-items:center;justify-content:center;min-height:0}.prep-image-card img{width:100%;max-height:100%;object-fit:contain;border-radius:var(--radius-lg)}.prep-options{display:flex;gap:10px;justify-content:center;flex-shrink:0}.prep-option-btn{width:70px;height:70px;border-radius:var(--radius-md);background:var(--color-card);border:3px solid #e0e0e0;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px var(--color-shadow);padding:8px}.prep-option-btn:active:not(:disabled){animation:squish .2s ease}.prep-option-btn:disabled{opacity:.7}.prep-feedback{display:flex;flex-direction:column;align-items:center;gap:12px;background:#fff;padding:20px 28px;border-radius:var(--radius-lg);box-shadow:0 8px 32px #00000026;animation:fadeIn .3s ease}.prep-feedback-text{font-size:18px;font-weight:700;text-align:center;line-height:1.4}.prep-feedback-text.correct{color:var(--color-correct)}.prep-feedback-text.wrong{color:var(--color-text)}.story-select-screen{height:100%;display:flex;flex-direction:column;padding:20px 16px;overflow-y:auto;-webkit-overflow-scrolling:touch}.story-select-header{display:flex;align-items:center;gap:12px;margin-bottom:20px;flex-shrink:0}.story-select-title{font-size:20px;font-weight:800;color:var(--color-text)}.story-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding-bottom:24px}.story-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:20px 12px 16px;border-radius:var(--radius-lg);box-shadow:0 4px 16px var(--color-shadow)}.story-card:active{animation:squish .2s ease}.story-card-emoji{font-size:36px;line-height:1}.story-card-title{font-size:14px;font-weight:800;color:var(--color-text);text-align:center;line-height:1.2}.story-card-count{font-size:12px;font-weight:600;color:var(--color-text-light)}.story-intro{display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:24px}.story-intro-emoji{font-size:56px}.story-intro-title{font-size:22px;font-weight:800;color:var(--color-text)}.sentence-question{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;min-height:0}.sentence-scene{width:100%;max-height:140px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sentence-scene-img{max-width:100%;max-height:140px;object-fit:contain;border-radius:var(--radius-md)}.sentence-story-progress{font-size:14px;font-weight:700;color:var(--color-text-light);flex-shrink:0}.sentence-animals{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;flex-shrink:0}.sentence-animal-card{flex:1;max-width:150px;display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 8px 10px;border-radius:var(--radius-lg);border:3px solid #e0e0e0;box-shadow:0 4px 16px var(--color-shadow);transition:border-color .3s,transform .15s}.sentence-animal-card.choosable{border-color:var(--color-star);animation:glow 1.5s ease-in-out infinite}.sentence-animal-card.speaking{border-color:var(--color-der)}.sentence-animal-card:active:not(:disabled){animation:squish .2s ease}.sentence-animal-card:disabled{opacity:.8}.sentence-animal-speaker{font-size:20px;line-height:1}.sentence-vs{font-size:28px;font-weight:800;color:var(--color-text-light);flex-shrink:0}.sentence-controls{display:flex;align-items:center;gap:12px;flex-shrink:0}.sentence-replay-btn{width:44px;height:44px;border-radius:50%;background:var(--color-card);font-size:20px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px var(--color-shadow)}.sentence-replay-btn:active{animation:squish .2s ease}.sentence-phase-hint{font-size:15px;font-weight:700;color:var(--color-text-light);text-align:center}.sentence-list{display:flex;flex-direction:column;gap:4px;padding:4px 0}.sentence-row{display:flex;gap:8px;padding:8px 12px;background:var(--color-card);border-radius:var(--radius-sm);box-shadow:0 1px 4px var(--color-shadow);align-items:flex-start}.sentence-num{font-size:13px;font-weight:800;color:var(--color-text-light);min-width:22px;flex-shrink:0;padding-top:1px}.sentence-pair{display:flex;flex-direction:column;gap:2px;min-width:0}.sentence-correct{font-size:14px;font-weight:700;color:var(--color-correct)}.sentence-wrong{font-size:13px;font-weight:600;color:var(--color-wrong);text-decoration:line-through}.mascot{flex-shrink:0}.mascot-bounce{animation:bounce .8s ease infinite}.mascot-small{transform:scale(.7);transform-origin:center}.sticker-reward{display:flex;flex-direction:column;align-items:center;gap:6px}.sticker-reward-label{font-size:16px;font-weight:700;color:var(--color-text-light)}.sticker-gallery{height:100%;overflow-y:auto;padding:20px 16px;-webkit-overflow-scrolling:touch}.sticker-count{font-size:18px;font-weight:800;color:var(--color-die);margin-left:auto}.sticker-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:60px 24px;text-align:center}.sticker-empty p{font-size:16px;color:var(--color-text-light);font-weight:600}.sticker-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;padding:8px 0}.sticker-cell{display:flex;align-items:center;justify-content:center;background:var(--color-card);border-radius:var(--radius-md);padding:10px;box-shadow:0 2px 8px var(--color-shadow);aspect-ratio:1}
