:root{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.5;font-weight:400;color:#333;background-color:#f5f7fa;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background-color:#f5f7fa}a{font-weight:500;color:#667eea;text-decoration:inherit}a:hover{color:#5568d3}.app{min-height:100vh;display:flex;flex-direction:column;background-color:#f5f7fa}.app-header{background:#fff;padding:1rem 2rem;box-shadow:0 1px 3px #00000014;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;position:sticky;top:0;z-index:100}.app-header h1{color:#667eea;font-size:1.8rem;margin:0}.user-info{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.level-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.5rem 1rem;border-radius:20px;font-weight:700;font-size:1rem;box-shadow:0 2px 4px #667eea33}.helpers-badge{background:gold;color:#333;padding:.5rem 1rem;border-radius:20px;font-weight:700;font-size:1rem;box-shadow:0 2px 4px #ffd70033}.user-menu{display:flex;align-items:center;gap:.5rem}.app-main{flex:1;padding:2rem;width:100%}.app-footer{background:#fff;padding:1rem;text-align:center;color:#666;border-top:1px solid #e9ecef}.error-message{background:#f44;color:#fff;padding:1rem;border-radius:8px;margin-bottom:1rem;text-align:center}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;cursor:pointer;font-weight:700;transition:transform .2s}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:#6c757d;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;cursor:pointer;font-weight:700;transition:transform .2s}.btn-secondary:hover:not(:disabled){transform:translateY(-2px);background:#5a6268}.btn-small{padding:.5rem 1rem;font-size:.9rem;background:#667eea;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:700}.btn-small:hover{background:#5568d3}.btn-large{padding:1rem 2rem;font-size:1.2rem}.signup-prompt{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.signup-content{background:#fff;padding:2rem;border-radius:12px;max-width:500px;text-align:center;box-shadow:0 10px 40px #0000004d}.signup-content h2{color:#667eea;margin-bottom:1rem}.signup-content p{margin-bottom:1.5rem;font-size:1.1rem;color:#555}.signup-content button{margin:.5rem}@media(max-width:768px){.app-header{flex-direction:column;text-align:center}.app-header h1{font-size:1.5rem}.app-main{padding:1rem}}.auth-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.auth-modal{background:#fff;padding:2rem;border-radius:12px;max-width:400px;width:90%;position:relative;box-shadow:0 10px 40px #0000004d}.close-btn{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.5rem;cursor:pointer;color:#999;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%}.close-btn:hover{background:#f0f0f0;color:#333}.auth-modal h2{color:#667eea;margin-bottom:1.5rem;text-align:center}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;color:#333;font-weight:700}.form-group input{width:100%;padding:.75rem;border:2px solid #ddd;border-radius:6px;font-size:1rem}.form-group input:focus{outline:none;border-color:#667eea}.error{background:#ffe0e0;color:#c00;padding:.75rem;border-radius:6px;margin-bottom:1rem;text-align:center}.toggle-auth{text-align:center;margin-top:1rem;color:#666}.link-btn{background:none;border:none;color:#667eea;cursor:pointer;font-weight:700;text-decoration:underline}.link-btn:hover{color:#5568d3}.story-prompt{width:100%;max-width:1200px;margin:0 auto}.prompt-container{background:#fff;padding:2.5rem;border-radius:12px;box-shadow:0 2px 8px #00000014;border:1px solid #e9ecef}.prompt-container h2{color:#667eea;margin-bottom:.5rem;text-align:center}.input-container{position:relative;margin-bottom:1rem}.prompt-container textarea{width:100%;padding:1rem 4rem 1rem 1rem;border:2px solid #ddd;border-radius:8px;font-size:1rem;font-family:inherit;resize:vertical}.prompt-container textarea:focus{outline:none;border-color:#667eea}.prompt-container textarea.listening{border-color:#ff5722;background:#fff8f5}.voice-btn{position:absolute;right:10px;top:10px;width:50px;height:50px;border-radius:50%;border:2px solid #667eea;background:#fff;color:#667eea;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;box-shadow:0 2px 4px #0000001a}.voice-btn:hover:not(:disabled){transform:scale(1.1);background:#667eea;box-shadow:0 4px 8px #667eea4d}.voice-btn:disabled{opacity:.5;cursor:not-allowed}.voice-btn.listening{background:#ff5722;border-color:#ff5722;color:#fff;animation:pulse-btn 1.5s infinite}@keyframes pulse-btn{0%,to{box-shadow:0 0 #ff5722b3}50%{box-shadow:0 0 0 10px #ff572200}}.listening-indicator{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#fff3e0;border:2px solid #ff9800;border-radius:8px;margin-bottom:1rem}.pulse-dot{width:12px;height:12px;background:#ff5722;border-radius:50%;animation:pulse-dot 1.5s infinite}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}.listening-text{color:#e65100;font-weight:700;font-size:.95rem}.speech-error{background:#ffebee;color:#c62828;padding:.75rem;border-radius:6px;margin-bottom:1rem;text-align:center;font-size:.9rem}.prompt-container button[type=submit]{width:100%;margin-top:.5rem}.examples{margin-top:2rem;padding-top:2rem;border-top:2px solid #f0f0f0}.examples-title{color:#666;margin-bottom:1rem;font-weight:700}.example-buttons{display:flex;flex-direction:column;gap:.5rem}.example-btn{background:#f8f9fa;border:2px solid #ddd;padding:.75rem;border-radius:8px;cursor:pointer;text-align:left;transition:all .2s;color:#333}.example-btn:hover:not(:disabled){background:#e9ecef;border-color:#667eea;transform:translate(5px)}.example-btn:disabled{opacity:.5;cursor:not-allowed}.anonymous-notice{background:#fff3cd;border:2px solid #ffc107;padding:1rem;border-radius:8px;margin-top:1.5rem;text-align:center;color:#856404}@media(max-width:768px){.prompt-container{padding:1.5rem}.prompt-container h2{font-size:1.5rem}}.story-reading{width:100%;max-width:1200px;margin:0 auto}.reading-container{background:#fff;padding:2.5rem;border-radius:12px;box-shadow:0 2px 8px #00000014;border:1px solid #e9ecef}.reading-container h2{color:#667eea;margin-bottom:.5rem;text-align:center}.instruction{text-align:center;color:#666;margin-bottom:1.5rem;font-size:1.1rem}.story-text{background:#f8f9fa;padding:2rem;border-radius:8px;line-height:2.5;font-size:1.5rem;min-height:200px;margin-bottom:1.5rem;text-align:left}.word{display:inline-block;transition:all .3s ease;opacity:.2;color:#333;margin-right:.3rem}.word.read{opacity:1;color:#28a745;font-weight:700}.word.current{opacity:1;color:#667eea;font-weight:700;font-size:1.1em;background:#667eea1a;padding:.2rem .4rem;border-radius:4px;animation:pulse 1s infinite}.word.next{opacity:.5}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.reading-progress{margin-bottom:1.5rem}.progress-bar{width:100%;height:20px;background:#e9ecef;border-radius:10px;overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);transition:width .3s ease;border-radius:10px}.progress-text{text-align:center;color:#666;font-weight:700}.word-helpers{background:#fff8e1;border:2px solid #ffd700;border-radius:8px;padding:1.5rem;margin-bottom:1.5rem;text-align:center}.helpers-available{font-weight:700;color:#f57c00;margin-bottom:1rem;font-size:1.1rem}.helper-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:.5rem}.btn-helper{background:gold;color:#333;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px #ffd7004d}.btn-helper:hover:not(:disabled){transform:translateY(-2px);background:#ffed4e;box-shadow:0 4px 8px #ffd70066}.btn-helper:disabled{opacity:.4;cursor:not-allowed;transform:none}.helpers-used-note{color:#666;font-size:.9rem;font-style:italic;margin-top:.5rem}.reading-controls{display:flex;gap:1rem;justify-content:center;margin-bottom:1.5rem;flex-wrap:wrap}.reading-tips{background:#e7f3ff;border-left:4px solid #667eea;padding:1rem;border-radius:4px}.reading-tips h3{color:#667eea;margin-bottom:.5rem}.reading-tips ul{margin-left:1.5rem}.reading-tips li{margin-bottom:.5rem;color:#555}@media(max-width:768px){.reading-container{padding:1.5rem}.story-text{font-size:1.2rem;padding:1.5rem;line-height:2}.reading-container h2{font-size:1.5rem}.reading-controls{flex-direction:column}.reading-controls button{width:100%}}.comprehension-questions{width:100%;max-width:1200px;margin:0 auto}.questions-container{background:#fff;padding:2.5rem;border-radius:12px;box-shadow:0 2px 8px #00000014;border:1px solid #e9ecef}.questions-container h2{color:#667eea;margin-bottom:.5rem;text-align:center}.instruction{text-align:center;color:#666;margin-bottom:1.5rem}.question-block{background:#f8f9fa;padding:1.5rem;border-radius:8px;margin-bottom:1.5rem;border:2px solid #e9ecef}.question-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;flex-wrap:wrap;gap:.5rem}.question-label{font-weight:700;color:#667eea}.question-text{font-size:1.1rem;color:#333;margin-bottom:1rem;font-weight:500}.question-block input{width:100%;padding:.75rem;border:2px solid #ddd;border-radius:6px;font-size:1rem}.question-block input:focus{outline:none;border-color:#667eea}.question-block input.helper-answer{border-color:gold;background:#fffbeb}.helper-btn{background:gold;color:#333;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-weight:700;font-size:.9rem;transition:transform .2s}.helper-btn:hover{transform:scale(1.05);background:#ffed4e}.helper-used{color:#28a745;font-weight:700;font-size:.9rem}.submit-section{text-align:center;margin-top:2rem;padding-top:2rem;border-top:2px solid #e9ecef}.submit-section button{width:100%;max-width:400px}.helpers-info{margin-top:1rem;color:#666;font-style:italic}.question-tips{background:#e7f3ff;border-left:4px solid #667eea;padding:1rem;border-radius:4px;margin-top:1.5rem}.question-tips h3{color:#667eea;margin-bottom:.5rem}.question-tips ul{margin-left:1.5rem}.question-tips li{margin-bottom:.5rem;color:#555}@media(max-width:768px){.questions-container{padding:1.5rem}.question-block{padding:1rem}.question-header{flex-direction:column;align-items:flex-start}.helper-btn{width:100%}}.level-up-animation{width:100%;min-height:500px;display:flex;justify-content:center;align-items:center}.celebration{position:relative;background:#fff;padding:3rem;border-radius:12px;box-shadow:0 4px 12px #0000001f;border:1px solid #e9ecef;max-width:700px;width:90%;overflow:hidden}.confetti{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1}.confetti-piece{position:absolute;width:10px;height:10px;top:-10px;opacity:0;animation:confetti-fall 3s linear forwards}@keyframes confetti-fall{0%{opacity:1;top:-10px;transform:rotate(0)}to{opacity:0;top:100%;transform:rotate(720deg)}}.level-up-content{position:relative;z-index:2;text-align:center}.congrats-text{color:#667eea;font-size:2.5rem;margin-bottom:2rem;animation:bounce 1s ease-in-out}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.level-badge-large{position:relative;display:inline-block;background:linear-gradient(135deg,#667eea,#764ba2);width:200px;height:200px;border-radius:50%;display:flex;justify-content:center;align-items:center;margin:2rem auto;box-shadow:0 10px 30px #667eea66;animation:scale-up 1s ease-in-out;overflow:hidden}@keyframes scale-up{0%{transform:scale(0)}60%{transform:scale(1.2)}to{transform:scale(1)}}.badge-shine{position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:linear-gradient(45deg,#fff0,#ffffff4d,#fff0);animation:shine 2s infinite}@keyframes shine{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.level-number{position:relative;z-index:2;color:#fff;font-size:3rem;font-weight:700}.level-message{font-size:1.3rem;color:#555;margin-bottom:2rem}.stars{display:flex;justify-content:center;gap:1rem;margin-bottom:2rem}.star{font-size:2rem;animation:star-twinkle 1s ease-in-out infinite}.star:nth-child(1){animation-delay:0s}.star:nth-child(2){animation-delay:.3s}.star:nth-child(3){animation-delay:.6s}@keyframes star-twinkle{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.8}}.continue-btn{animation:button-appear 1s ease-in-out 2s both}@keyframes button-appear{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.celebration{padding:2rem}.congrats-text{font-size:2rem}.level-badge-large{width:150px;height:150px}.level-number{font-size:2.5rem}.level-message{font-size:1.1rem}}
