*{box-sizing:border-box}:root{--primary-color:#ff6b6b;--secondary-color:#4d96ff;--success-color:#6bcb77;--warning-color:#ffd93d;--error-color:#ff6b6b;--text-main:#2d3436;--text-sub:#636e72}body{-webkit-user-select:none;user-select:none;scrollbar-width:none;overscroll-behavior-y:contain;background:linear-gradient(135deg,#f5f7fa 0%,#c3cfe2 100%);width:100vw;height:100dvh;margin:0;padding:0;font-family:Comic Sans MS,Chalkboard SE,"cursive",sans-serif;overflow:hidden}body::-webkit-scrollbar{display:none}#root{height:100%}.app-container{flex-direction:column;justify-content:space-between;align-items:center;height:100%;padding:20px;display:flex;position:relative}.top-left-controls{z-index:200;position:absolute;top:25px;left:20px}.settings-panel{z-index:200;align-items:center;gap:10px;display:flex;position:absolute;top:25px;right:20px}.debug-controls{gap:8px;animation:.3s ease-out slideInRight;display:flex}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.debug-btn{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);cursor:pointer;background:#fffc;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;transition:all .2s;display:flex;box-shadow:0 4px 10px #0000001a}.debug-btn:active{transform:scale(.9)}.debug-stats-bar{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);color:#0f0;z-index:100;pointer-events:none;background:#00000040;border-left:2px solid #0f0;border-radius:8px;flex-direction:column;gap:4px;padding:10px;font-family:Courier New,Courier,monospace;font-size:.7rem;display:flex;position:absolute;top:100px;left:10px}.debug-stat-line{flex-direction:column;gap:2px;display:flex}.debug-stat-line span{justify-content:space-between;gap:10px;display:flex}.debug-history-line{border-top:1px solid #0f03;flex-direction:column;gap:2px;margin-top:8px;padding-top:8px;display:flex}.history-tag{opacity:.8;background:0 0;padding:0}.history-tag:last-child{opacity:1;font-weight:700;text-decoration:underline}.timer-circle,.settings-icon-btn{z-index:10;cursor:pointer;background:#fff;border:3px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;padding:0;transition:transform .2s,background-color .2s;display:flex;box-shadow:0 4px 15px #00000014}.timer-circle{flex-direction:column}.timer-circle:active,.settings-icon-btn:active{transform:scale(.9)}.timer-circle.low-time{border-color:var(--error-color);animation:1s infinite alternate pulse}@keyframes pulse{0%{opacity:1}to{opacity:.6}}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#0006;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.modal-content{scrollbar-width:none;background-color:#fff;border-radius:30px;flex-direction:column;align-items:center;width:85%;max-width:400px;max-height:85vh;padding:25px;display:flex;overflow-y:auto;box-shadow:0 10px 40px #0003}.modal-content::-webkit-scrollbar{display:none}.modal-content h3{color:var(--text-main);margin-top:0;margin-bottom:20px;font-size:1.4rem}.setting-section{flex-direction:column;align-items:flex-start;width:100%;margin-bottom:20px;display:flex}.setting-section label{color:var(--text-sub);margin-bottom:10px;font-size:1.1rem;font-weight:700}.range-options{flex-direction:column;gap:12px;width:100%;display:flex}.toggle-btn{width:100%;color:var(--text-sub);cursor:pointer;background-color:#fff;border:3px solid #dfe6e9;border-radius:15px;padding:15px;font-family:inherit;font-size:1.2rem;font-weight:700;transition:all .2s}.toggle-btn.active{border-color:var(--success-color);color:var(--success-color);background-color:#f0fff4}.range-btn{color:var(--text-sub);cursor:pointer;background-color:#fff;border:3px solid #dfe6e9;border-radius:15px;padding:15px;font-family:inherit;font-size:1.4rem;transition:all .2s}.range-btn.active{border-color:var(--secondary-color);color:var(--secondary-color);background-color:#ebf8ff;font-weight:700}.close-btn{cursor:pointer;color:var(--text-sub);background-color:#dfe6e9;border:none;border-radius:10px;padding:10px 30px;font-size:1rem}.summary-modal{text-align:center;background:linear-gradient(#fff 0%,#f8faff 100%);padding:60px 30px 30px}.summary-header{margin-top:-30px;margin-bottom:20px}.trophy-container{justify-content:center;align-items:center;width:100%;height:120px;margin:0 auto 10px;display:flex;position:relative}.stars-row{z-index:2;align-items:center;gap:15px;display:flex}.summary-star{transition:all .4s cubic-bezier(.175,.885,.32,1.275)}.summary-star.dim{opacity:.2;transform:scale(.8)}.summary-star.lit{opacity:1;filter:drop-shadow(0 0 10px #ffd93d99);animation:.5s cubic-bezier(.175,.885,.32,1.275) star-pop;transform:scale(1)}@keyframes star-pop{0%{opacity:0;transform:scale(.5)}50%{transform:scale(1.2)}to{opacity:1;transform:scale(1)}}.praise-text{color:var(--text-main);margin:10px 0;font-size:1.8rem;font-weight:900;animation:.6s .2s both popIn}.trophy-glow{background:radial-gradient(circle,#ffd93d66 0%,#0000 70%);border-radius:50%;width:150%;height:150%;animation:2s infinite alternate pulse-glow;position:absolute}.trophy-icon{z-index:2;filter:drop-shadow(0 10px 20px #ffd93d66);animation:3s ease-in-out infinite trophy-bounce}.stars-decoration{z-index:1;width:100%;height:100%;position:absolute}.star-mini{animation:1.5s infinite alternate star-twinkle;position:absolute}.star-mini.s1{animation-delay:.2s;top:10%;left:-10%}.star-mini.s2{animation-delay:.5s;top:-20%;right:10%}.star-mini.s3{animation-delay:.8s;bottom:10%;right:-15%}.score-display{flex-direction:column;align-items:center;margin-bottom:30px;display:flex}.score-circle-outer{background:linear-gradient(135deg, var(--secondary-color), var(--success-color));border-radius:50%;width:140px;height:140px;margin-bottom:15px;padding:8px;box-shadow:0 10px 25px #4d96ff4d}.score-circle-inner{background:#fff;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;display:flex}.score-num{color:var(--text-main);font-size:3.5rem;font-weight:900;line-height:1}.score-unit{color:var(--text-sub);text-transform:uppercase;letter-spacing:1px;font-size:.8rem;font-weight:700}.score-label-badge{background:var(--warning-color);color:var(--text-main);border-radius:20px;padding:6px 20px;font-size:1.1rem;font-weight:900;transform:rotate(-2deg);box-shadow:0 4px 12px #ffd93d4d}.summary-stats-grid{grid-template-columns:1fr 1fr;gap:15px;width:100%;margin-bottom:25px;display:grid}.stat-card{background:#f0f4f8;border-radius:20px;flex-direction:column;align-items:center;padding:15px;animation:.5s both slide-up;display:flex}.stat-card:first-child{animation-delay:.1s}.stat-card:nth-child(2){animation-delay:.2s}.stat-card:nth-child(3){animation-delay:.3s}.stat-card.wide{background:linear-gradient(90deg,#f0f4f8 0%,#e1e9f0 100%);grid-column:span 2}.stat-v{color:var(--text-main);font-size:1.8rem;font-weight:900}.stat-l{color:var(--text-sub);font-size:.8rem;font-weight:700}.final-btn{background-color:var(--success-color);color:#fff;cursor:pointer;border:none;border-radius:20px;width:100%;margin-top:10px;padding:15px 40px;font-size:1.5rem;font-weight:700;transition:all .1s;box-shadow:0 6px #4cae5d}.final-btn:active{transform:translateY(4px);box-shadow:0 2px #4cae5d}@keyframes pulse-glow{0%{opacity:.5;transform:scale(.8)}to{opacity:.8;transform:scale(1.2)}}@keyframes trophy-bounce{0%,to{transform:translateY(0)rotate(0)}50%{transform:translateY(-10px)rotate(5deg)}}@keyframes star-twinkle{0%{opacity:.3;transform:scale(.5)rotate(0)}to{opacity:1;transform:scale(1.2)rotate(45deg)}}@keyframes slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.confirm-modal{text-align:center}.confirm-timer-box{border:2px dashed var(--secondary-color);background:#f8f9fa;border-radius:20px;margin:15px 0 25px;padding:15px 30px}.confirm-time-label{color:var(--text-sub);margin-bottom:5px;font-size:.9rem}.confirm-time-value{color:var(--secondary-color);font-family:monospace;font-size:2.5rem;font-weight:700}.confirm-actions{gap:15px;width:100%;display:flex}.confirm-actions button{cursor:pointer;border:none;border-radius:15px;flex:1;padding:15px;font-size:1.1rem;font-weight:700;transition:all .2s}.btn-continue{color:var(--text-sub);background-color:#dfe6e9}.btn-end{background-color:var(--error-color);color:#fff;box-shadow:0 4px #d63031}.btn-end:active{transform:translateY(2px);box-shadow:0 2px #d63031}.about-modal{background:linear-gradient(#fff 0%,#f0f7ff 100%);padding:35px 25px}.about-header-icon{filter:drop-shadow(0 5px 15px #0000001a);justify-content:center;margin-bottom:10px;animation:3s ease-in-out infinite float;display:flex}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.about-features-grid{grid-template-columns:1fr 1fr;gap:12px;margin:20px 0;display:grid}.about-feature-card{text-align:center;background:#fff;border:2px solid #0000;border-radius:18px;flex-direction:column;align-items:center;gap:8px;padding:15px 10px;transition:all .2s;display:flex;box-shadow:0 4px 12px #0000000a}.about-feature-card:hover{border-color:var(--secondary-color);transform:translateY(-3px)}.feature-icon{font-size:1.8rem}.feature-text{color:var(--text-main);font-size:.85rem;font-weight:700;line-height:1.2}.vision-box{background:#fff;border-radius:20px;margin-bottom:20px;padding:18px;position:relative;overflow:hidden;box-shadow:0 4px 15px #0000000d}.vision-box:before{content:"";background:var(--accent-color,var(--primary-color));width:6px;height:100%;position:absolute;top:0;left:0}.about-footer-text{color:var(--text-sub);opacity:.8;margin-bottom:15px;font-size:.8rem}.math-area{color:var(--text-main);flex-direction:column;flex-grow:1;justify-content:center;align-items:center;width:100%;font-size:4.5rem;font-weight:700;display:flex}.vertical-calc{background:#fff;border-radius:40px;flex-direction:column;justify-content:center;align-items:flex-end;width:240px;height:388px;padding:35px 25px;display:flex;position:relative;box-shadow:0 15px 40px #0000000f}.row{text-align:right;width:100%;padding-right:5px;line-height:1.2}.operand2-row{justify-content:space-between;width:100%;padding-right:5px;line-height:1.2;display:flex}.line{background-color:var(--text-main);border-radius:10px;width:100%;height:6px;margin:15px 0}.result-box{width:100%;height:100px;color:var(--secondary-color);background-color:#f8f9fa;border:4px solid #dfe6e9;border-radius:20px;justify-content:flex-end;align-items:center;margin-top:10px;padding-right:15px;transition:all .3s cubic-bezier(.175,.885,.32,1.275);display:flex}.result-box.correct{border-color:var(--success-color);color:var(--success-color);background-color:#f0fff4;transform:scale(1.1)}.result-box.wrong{border-color:var(--error-color);color:var(--error-color);background-color:#fff5f5;animation:.4s ease-in-out shake}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-8px)}40%,80%{transform:translate(8px)}}.numpad{grid-template-columns:repeat(5,1fr);gap:12px;width:100%;max-width:700px;padding-bottom:30px;display:grid}.num-btn{cursor:pointer;color:#fff;text-shadow:0 2px 4px #0000001a;background-color:#fff;border:none;border-radius:20px;justify-content:center;align-items:center;height:80px;font-size:2.2rem;transition:all .1s;display:flex;box-shadow:0 6px #0000001a}.num-btn:active{transform:translateY(4px);box-shadow:0 2px #0000001a}.num-btn:first-child{background:#ffadad}.num-btn:nth-child(2){background:#ffd6a5}.num-btn:nth-child(3){color:#666;background:#fdffb6}.num-btn:nth-child(4){color:#666;background:#caffbf}.num-btn:nth-child(5){color:#666;background:#9bf6ff}.num-btn:nth-child(6){background:#a0c4ff}.num-btn:nth-child(7){background:#bdb2ff}.num-btn:nth-child(8){background:#ffc6ff}.num-btn:nth-child(9){color:#666;background:#fffffc}.num-btn:nth-child(10){color:#666;background:#e2ece9}.handwriting-container{background:#fff;border:2px solid #dfe6e9;border-radius:15px;flex-direction:column;width:100%;max-width:500px;height:360px;margin-bottom:5px;display:flex;position:relative;overflow:hidden;box-shadow:0 8px 25px #0000000d}.canvas-wrapper{cursor:crosshair;background-color:#fcfcfc;flex-grow:1;position:relative}.canvas-placeholder{color:#bdc3c7;pointer-events:none;font-size:1.2rem;font-weight:700;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.handwriting-controls{z-index:5;position:absolute;bottom:15px;right:15px}.hw-btn.clear{color:#fff;cursor:pointer;background-color:#ffadad;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;padding:0;display:flex;box-shadow:0 4px 10px #ffadad80}.voice-input-container{background:#fff;border:3px solid #dfe6e9;border-radius:30px;flex-direction:column;align-items:center;gap:15px;width:100%;max-width:500px;margin-bottom:20px;padding:20px;display:flex;box-shadow:0 8px 25px #0000000d}.voice-transcript-area{flex-direction:column;justify-content:center;align-items:center;width:100%;min-height:80px;display:flex;position:relative}.transcript-bubble{max-width:90%;color:var(--text-main);white-space:nowrap;background:#f0f2f5;border:2px solid #0000;border-radius:20px 20px 20px 5px;justify-content:flex-end;align-items:center;padding:12px 20px;font-size:1.1rem;line-height:1.4;transition:transform .2s,box-shadow .2s;display:flex;position:relative;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,#0000,#000 15%);mask-image:linear-gradient(90deg,#0000,#000 15%)}.transcript-bubble.active{border-color:#4d96ff33;transform:scale(1.05);box-shadow:0 0 15px #4d96ff4d}.transcript-bubble span{flex-shrink:0}.interim-text{color:var(--secondary-color);font-weight:700}.highlight-digit{color:var(--primary-color);padding:0 2px;font-weight:800;text-decoration:underline}.recognized-number-badge{background:var(--success-color);color:#fff;border-radius:20px;padding:4px 12px;font-size:.9rem;font-weight:700;animation:.3s cubic-bezier(.175,.885,.32,1.275) popIn;position:absolute;top:-15px;right:0;box-shadow:0 4px 8px #6bcb774d}.mic-btn{background:var(--secondary-color);color:#fff;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:100px;height:100px;transition:all .3s cubic-bezier(.175,.885,.32,1.275);display:flex;position:relative;box-shadow:0 8px 20px #4d96ff4d}.mic-btn.listening{background:var(--error-color);transform:scale(1.1);box-shadow:0 8px 25px #ff6b6b66}.mic-waves span{background:inherit;opacity:.4;z-index:-1;border-radius:50%;width:100%;height:100%;position:absolute;top:0;left:0}.mic-btn.listening .mic-waves span{animation:1.5s infinite wave}@keyframes wave{0%{opacity:.4;transform:scale(1)}to{opacity:0;transform:scale(2)}}.voice-status{color:var(--text-sub);text-align:center;font-size:1.2rem;font-weight:700}.easter-hint{background:var(--primary-color);color:#fff;white-space:nowrap;z-index:100;pointer-events:none;border-radius:12px;padding:6px 12px;font-size:.9rem;font-weight:700;animation:.3s cubic-bezier(.175,.885,.32,1.275) bounceIn;position:absolute;top:-25px;left:50%;transform:translate(-50%);box-shadow:0 4px 10px #ff6b6b4d}@keyframes bounceIn{0%{opacity:0;transform:translate(-50%)scale(0)}to{opacity:1;transform:translate(-50%)scale(1)}}.manual-calc-layout{flex-direction:column;align-items:flex-end;gap:10px;width:100%;padding:20px 0;display:flex}.manual-row{justify-content:flex-end;align-items:center;gap:15px;width:100%;display:flex}.manual-operator-clickable{color:var(--secondary-color);cursor:pointer;-webkit-user-select:none;user-select:none;background:#f0f7ff;border-radius:15px;padding:10px 20px;font-size:3rem;font-weight:700;transition:all .2s}.manual-operator-clickable:active{background:#e1f0ff;transform:scale(.9)}.manual-input{text-align:right;width:120px;color:var(--text-main);border:3px solid #dfe6e9;border-radius:15px;outline:none;padding:10px;font-family:inherit;font-size:3rem;font-weight:700;transition:all .2s}.manual-input:focus{border-color:var(--secondary-color);background-color:#f8fbff;box-shadow:0 0 0 4px #4d96ff1a}.manual-input.error{border-color:var(--error-color);color:var(--error-color);background-color:#fff5f5;animation:.4s ease-in-out shake}.manual-error-text{color:var(--error-color);text-align:center;background:#fff5f5;border-radius:10px;margin-bottom:15px;padding:5px 15px;font-size:.9rem;font-weight:700}.manual-line{background:var(--text-main);border-radius:2px;width:100%;height:4px;margin:10px 0}.feedback-msg{-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);text-align:center;width:auto;min-width:320px;color:var(--text-main);z-index:2000;pointer-events:none;white-space:nowrap;background:#fffffffa;border:4px solid #fff;border-radius:50px;flex-direction:column;align-items:center;gap:25px;padding:40px 60px;font-size:2.5rem;font-weight:700;animation:.5s cubic-bezier(.175,.885,.32,1.275) feedbackPop;display:flex;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 30px 60px #0003}@keyframes feedbackPop{0%{opacity:0;transform:translate(-50%,-50%)scale(.5)}to{opacity:1;transform:translate(-50%,-50%)scale(1)}}.feedback-icon{border-radius:50%;justify-content:center;align-items:center;width:100px;height:100px;display:flex}.feedback-msg .lucide-trophy{color:#ffd93d;stroke-width:2.5px}.feedback-msg .lucide-x-circle{color:#ff6b6b;stroke-width:2.5px}.hint-overlay{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:#00000080;justify-content:center;align-items:center;padding:20px;display:flex;z-index:2500!important}.hint-msg{border:6px solid var(--secondary-color);cursor:default;scrollbar-width:none;background-color:#fff;border-radius:40px;flex-direction:column;align-items:center;width:95vw;max-width:700px;max-height:90vh;padding:60px 20px 25px;animation:.4s cubic-bezier(.175,.885,.32,1.275) popIn;display:flex;position:relative;overflow-y:auto;box-shadow:0 30px 70px #0000004d}@keyframes popIn{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.hint-msg::-webkit-scrollbar{display:none}.hint-close-btn{width:44px;height:44px;color:var(--text-sub);cursor:pointer;background:#f0f2f5;border:none;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex;position:absolute;top:15px;right:15px}.hint-close-btn:active{background:#dfe6e9;transform:scale(.9)}.visual-hint-clean{background:#fff;width:100%;padding:10px 0}.hint-visual-container{flex-direction:column;justify-content:center;align-items:center;gap:15px;width:100%;display:flex}.dot-frames-container{flex-direction:column;justify-content:center;align-items:center;gap:12px;width:100%;display:flex}.dot-grid{background:#f8f9fa;border:3px solid #eee;border-radius:20px;grid-template-columns:repeat(5,1fr);gap:12px;padding:15px;display:grid;box-shadow:inset 0 2px 5px #00000005}.dot-grid.align-right{direction:rtl}.dot-grid.align-right .dot{direction:ltr}@media (width>=768px){.hint-msg{width:85vw;max-width:900px;padding:50px 40px}.dot-frames-container{flex-direction:column;align-items:center;gap:15px}.dot-grid{grid-template-columns:repeat(10,1fr);gap:10px;width:auto;min-width:500px;min-height:70px;padding:15px 30px}.dot{width:40px;height:40px}}.dot{border-radius:50%;width:44px;height:44px;position:relative;box-shadow:inset -4px -4px 8px #0000001f}.dot.dot-1{background:radial-gradient(circle at 30% 30%,#4d96ff,#2196f3)}.dot.dot-2{background:radial-gradient(circle at 30% 30%,#ffd93d,#ff9800)}.dot.crossed:after{content:"✕";color:var(--error-color);text-shadow:0 0 4px #fff;font-size:32px;font-weight:900;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.mini-badge{color:var(--secondary-color);background:#eef6ff;border:3px solid #4d96ff26;border-radius:15px;padding:5px 20px;font-size:1.5rem;font-weight:900}.op-symbol{color:var(--text-sub);font-size:3rem;font-weight:900}.hint-steps{flex-direction:column;gap:10px;width:100%;margin-top:20px;display:flex}.hint-steps.multi-step{border-top:2px dashed #eee;padding-top:20px}.hint-step{color:var(--text-sub);text-align:center;font-size:1.3rem;font-weight:700}.hint-step:last-child{color:var(--success-color);text-align:center;border-top:3px solid #f0f2f5;width:100%;margin-top:15px;padding-top:20px;font-size:3rem;font-weight:900;display:block}@media (height<=700px){.math-area{font-size:4rem}.vertical-calc{border-radius:30px;width:200px;height:324px;padding:25px}.result-box{height:80px;padding-right:10px}.num-btn{border-radius:15px;height:60px;font-size:1.8rem}.summary-modal{padding:40px 20px 20px}.summary-header{margin-top:-20px;margin-bottom:10px}.trophy-container{width:80px;height:80px}.trophy-icon{width:60px!important;height:60px!important}.score-circle-outer{width:100px;height:100px;margin-bottom:10px;padding:5px}.score-num{font-size:2.2rem}.score-display{margin-bottom:15px}.stat-card{padding:8px}.stat-v{font-size:1.4rem}.final-btn{height:50px;padding:10px;font-size:1.2rem}.feedback-msg{min-width:260px;padding:30px 40px;font-size:1.8rem;top:50%;transform:translate(-50%,-50%)}.feedback-icon{width:80px;height:80px}.hint-msg{border-width:4px;border-radius:25px;padding:50px 15px 20px}.hint-steps{gap:5px;margin-top:10px}.hint-steps.multi-step{padding-top:10px}.hint-step{font-size:1.1rem}.hint-step:last-child{border-width:2px;padding-top:15px;font-size:2.2rem}.dot{width:28px;height:28px}.dot-grid{gap:6px;padding:8px}.timer-circle,.settings-icon-btn{width:44px;height:44px}.top-left-controls,.settings-panel{top:20px}.handwriting-container{height:280px}.voice-input-container{gap:10px;padding:15px}.mic-btn{width:70px;height:70px}.voice-status{font-size:1rem}}@media (width<=380px){.numpad{gap:8px}}
