.page-tutor{min-height:100vh;padding:24px 20px 40px;background:var(--bg);display:flex;flex-direction:column;align-items:center;gap:24px;max-width:500px;margin:0 auto}.tutor-header{width:100%;display:flex;align-items:center;gap:12px}.tutor-dots{display:flex;gap:8px;margin-left:auto}.tutor-dot{width:10px;height:10px;border-radius:50%;background:#444;transition:background .3s}.tutor-dot--active{background:var(--accent)}.tutor-dot--done{background:var(--correct)}.tutor-card{width:100%;background:var(--bg-card);border-radius:20px;padding:32px 24px;box-shadow:0 4px 20px #0000004d;border:1px solid rgba(255,255,255,.08);text-align:center;display:flex;flex-direction:column;align-items:center;gap:20px}.tutor-emoji{font-size:56px;line-height:1}.tutor-title{font-size:22px;font-weight:700;color:var(--text);line-height:1.3}.tutor-subtitle{font-size:15px;color:var(--text-muted);line-height:1.5;max-width:320px}.teach-visual{width:100%;padding:16px;background:#ffffff0d;border-radius:16px;border:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;align-items:center;gap:12px}.pv-columns{display:flex;gap:24px;justify-content:center}.pv-column{display:flex;flex-direction:column;align-items:center;gap:4px}.pv-label{font-size:11px;font-weight:600;text-transform:uppercase;color:var(--text-muted);letter-spacing:.05em}.pv-digit{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;color:var(--text);background:var(--bg-card);border:2px solid #444}.pv-digit--carry{border-color:var(--accent);color:var(--accent);font-size:16px}.number-line{width:100%;max-width:360px;position:relative;padding:32px 0 8px}.number-line-track{height:3px;background:#444;border-radius:2px;position:relative}.number-line-ticks{display:flex;justify-content:space-between;margin-top:4px}.number-line-tick{font-size:12px;color:var(--text-muted);text-align:center;width:24px}.number-line-hop{position:absolute;top:-24px;font-size:16px;color:var(--accent);font-weight:700;transform:translate(-50%)}.step-list{width:100%;text-align:left;display:flex;flex-direction:column;gap:12px}.step-item{display:flex;gap:12px;align-items:flex-start}.step-num{width:28px;height:28px;border-radius:50%;background:var(--accent);color:#1a1a2e;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex-shrink:0}.step-text{font-size:15px;color:var(--text);line-height:1.5;padding-top:3px}.tutor-problem{width:100%;display:flex;flex-direction:column;align-items:center;gap:16px}.tutor-problem-text{font-size:20px;font-weight:600;color:var(--text)}.tutor-options{width:100%;display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.tutor-option{min-width:72px;padding:12px 20px;border-radius:14px;border:2px solid #444;background:var(--bg-card);color:var(--text);font-size:18px;font-weight:600;cursor:pointer;transition:all .15s}.tutor-option:hover{border-color:var(--accent);background:var(--bg-card-hover)}.tutor-option--correct{border-color:var(--correct);background:#2ecc7126}.tutor-option--wrong{border-color:var(--incorrect);background:#e74c3c26}.tutor-feedback{font-size:15px;font-weight:500;min-height:24px}.tutor-feedback--correct{color:var(--correct)}.tutor-feedback--wrong{color:var(--incorrect)}.tutor-result-score{font-size:36px;font-weight:700;color:var(--accent)}.tutor-actions{display:flex;gap:12px;width:100%}.tutor-actions .btn{flex:1}.teach-dots{display:flex;gap:6px;justify-content:center}.teach-dot{width:8px;height:8px;border-radius:50%;background:#ffffff26;transition:background .3s,transform .3s}.teach-dot--active{background:var(--accent);transform:scale(1.35)}.teach-dot--done{background:var(--correct)}.teach-step-emoji{font-size:72px;line-height:1;animation:teachPop .35s ease-out}@keyframes teachPop{0%{transform:scale(.5);opacity:0}70%{transform:scale(1.12)}to{transform:scale(1);opacity:1}}.teach-step-visual{width:100%;padding:16px;background:#ffffff0d;border-radius:16px;border:1px solid rgba(255,255,255,.06);display:flex;justify-content:center;align-items:center}.teach-step-text{font-size:20px;font-weight:600;color:var(--text);line-height:1.5;text-align:center;max-width:340px}.teach-step-highlight{font-size:14px;font-weight:500;color:var(--accent);background:#ffd70014;padding:10px 16px;border-radius:12px;border:1px solid rgba(255,215,0,.15);text-align:center;max-width:340px}.tutor-phase-badge{font-size:13px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;padding:6px 14px;background:#ffffff0f;border-radius:20px;border:1px solid rgba(255,255,255,.08)}.feedback-card{background:var(--bg-card);border:1.5px solid rgba(255,215,0,.2);box-shadow:0 4px 24px #00000059}.feedback-title{font-size:20px;font-weight:700;color:var(--accent);text-align:center}.feedback-visual{width:100%;padding:12px;background:#ffffff0a;border-radius:14px;display:flex;justify-content:center;align-items:center}.feedback-steps{width:100%;display:flex;flex-direction:column;gap:10px;text-align:left}.feedback-step{font-size:16px;color:var(--text);line-height:1.5;padding:8px 14px;background:#ffffff0a;border-radius:10px;border-left:3px solid var(--accent)}.tutor-option:focus-visible{outline:3px solid var(--accent);outline-offset:2px}@media(prefers-reduced-motion:reduce){.tutor-dot,.tutor-option,.tutor-feedback,.teach-dot,.teach-step-emoji{transition:none;animation:none}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}button{color:inherit;font:inherit}:root{--bg: #1a1a2e;--bg-card: #16213e;--bg-card-hover: #1e2a4a;--text: #eee;--text-muted: #b0b0b0;--primary: #6C5CE7;--primary-light: #a29bfe;--secondary: #2d3436;--accent: #fdcb6e;--correct: #2ECC71;--incorrect: #e74c3c;--success: #27ae60;--success-bg: rgba(39, 174, 96, .15);--border: #444;--radius: 16px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased;overscroll-behavior:none}.app{max-width:520px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column}.page{flex:1;padding:28px 20px 40px;display:flex;flex-direction:column;align-items:center;gap:20px}.btn{border:none;cursor:pointer;border-radius:var(--radius);font-size:18px;font-weight:600;padding:16px 32px;min-height:52px;transition:transform .1s,opacity .15s;-webkit-tap-highlight-color:transparent;text-align:center}.btn:active{transform:scale(.94)}.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;box-shadow:0 3px 10px #6c5ce759}.btn-secondary{background:var(--secondary);color:var(--text);border:1px solid #444}.btn-ghost{background:transparent;color:var(--text-muted);padding:8px 14px;font-size:15px}.btn-lg{font-size:22px;padding:22px 40px;min-height:60px}.btn-sm{font-size:14px;padding:10px 18px;min-height:44px}.page-landing{justify-content:center;text-align:center}.landing-icon{font-size:88px;margin-bottom:8px}.landing-title{font-size:38px;color:var(--primary-light);margin-bottom:8px}.landing-sub{color:var(--text-muted);font-size:17px;margin-bottom:32px;max-width:320px}.page-profiles h1{font-size:24px;text-align:center}.profile-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;width:100%}.profile-card{background:linear-gradient(145deg,var(--bg-card),rgba(30,25,55,.95));border:2px solid #444;border-radius:var(--radius);padding:32px 16px 24px;min-height:160px;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;transition:border-color .2s,box-shadow .2s;box-shadow:0 2px 8px #0003}.profile-card:hover{border-color:var(--primary-light);box-shadow:0 4px 16px #6c5ce733}.profile-card--add{border-style:dashed;border-color:#444}.profile-avatar{font-size:52px}.profile-name{font-size:17px;font-weight:600}.profile-delete{background:none;border:none;color:#e74c3c;font-size:18px;cursor:pointer;padding:4px;position:absolute;top:8px;right:8px}.profile-card-wrap{position:relative}.modal{background:var(--bg-card);border-radius:var(--radius);padding:28px;width:100%;max-width:360px}.modal h2{margin-bottom:18px;font-size:20px}.modal label{display:block;margin-bottom:5px;color:var(--text-muted);font-size:14px}.modal input[type=text],.modal input[type=date]{width:100%;padding:11px 14px;border-radius:var(--radius-sm);border:1px solid #444;background:#0f0f23;color:var(--text);font-size:16px;margin-bottom:14px}.modal input[type=date]::-webkit-calendar-picker-indicator{filter:invert(1)}.avatar-picker{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.avatar-btn{background:#222;border:2px solid #444;border-radius:12px;padding:6px 10px;font-size:26px;cursor:pointer;transition:border-color .2s}.avatar-btn.active{border-color:var(--primary);background:#2a2050}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:8px}.page-home{gap:24px}.home-header{display:flex;justify-content:space-between;width:100%;align-items:center}.home-points{color:var(--accent);font-weight:700;font-size:18px}.home-greeting{text-align:center}.home-avatar{font-size:68px;display:block;margin-bottom:6px}.home-greeting h1{font-size:28px}.home-streak{color:#fd9644;font-weight:600;margin-top:4px;font-size:16px}.home-actions{width:100%;display:flex;flex-direction:column;gap:14px}.home-btn{width:100%}.home-row{display:flex;gap:14px}.home-row .btn{flex:1}.daily-goal-card{background:linear-gradient(135deg,#6c5ce733,#4a90e21f);border:3px solid var(--primary-light);border-radius:20px;padding:24px;width:100%;box-shadow:0 4px 16px #6c5ce733;position:relative;overflow:hidden}.daily-goal-card:after{content:"🎯";position:absolute;top:-10px;right:-10px;font-size:80px;opacity:.15;transform:rotate(15deg)}.daily-goal-header{display:flex;align-items:center;gap:14px;margin-bottom:12px}.daily-goal-icon{font-size:32px;flex-shrink:0}.daily-goal-info{flex:1}.daily-goal-title{display:block;font-size:18px;font-weight:700;color:var(--text)}.daily-goal-subtitle{display:block;font-size:14px;color:var(--text-muted);margin-top:2px}.daily-goal-badge{font-size:13px;color:var(--correct);font-weight:600;background:#2ecc7126;padding:4px 10px;border-radius:12px}.daily-goal-bar{width:100%;height:8px;background:#2d3436;border-radius:4px;overflow:hidden}.daily-goal-bar-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--primary-light));border-radius:4px;transition:width .4s}.suggested-reviews{background:#fdcb6e1f;border:2px solid rgba(253,203,110,.4);border-radius:var(--radius);padding:16px 18px;width:100%}.suggested-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}.suggested-icon{font-size:24px}.suggested-title{font-size:16px;font-weight:700;color:var(--accent)}.suggested-desc{font-size:13px;color:var(--text-muted);margin-bottom:10px}.suggested-skill{background:var(--bg-card-hover);border:2px solid rgba(253,203,110,.3);border-radius:var(--radius-sm);padding:16px 18px;min-height:52px;width:100%;display:flex;justify-content:space-between;align-items:center;cursor:pointer;margin-bottom:6px;font-size:15px;font-weight:600;color:var(--text);transition:border-color .2s,background .2s;-webkit-tap-highlight-color:transparent}.suggested-skill:hover{border-color:var(--accent);background:#fdcb6e1f}.suggested-skill:last-child{margin-bottom:0}.suggested-arrow{color:var(--accent);font-weight:700}.home-sections{width:100%;display:flex;flex-direction:column;gap:12px}.section-card{background:linear-gradient(135deg,var(--bg-card),rgba(30,25,55,.95));border:3px solid var(--section-color, #444);border-radius:20px;padding:24px 26px;min-height:88px;display:flex;align-items:center;gap:16px;cursor:pointer;width:100%;transition:all .3s cubic-bezier(.68,-.55,.265,1.55);-webkit-tap-highlight-color:transparent;position:relative;overflow:hidden}.section-card:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);opacity:0;transition:opacity .3s}.section-card:hover:before{opacity:1}.section-card:hover{box-shadow:0 8px 24px #0000004d,0 0 20px var(--section-color, rgba(108,92,231,.4));transform:translateY(-6px) scale(1.02)}.section-card:active{transform:translateY(-3px) scale(.98)}.section-icon{font-size:48px;flex-shrink:0;animation:bounceIn .6s ease-out;transition:transform .3s}.section-card:hover .section-icon{transform:scale(1.2) rotate(-10deg);animation:wiggle .5s ease-in-out}.section-info{flex:1;text-align:left}.section-name{display:block;font-size:20px;font-weight:700;color:var(--text)}.section-status{display:block;font-size:13px;color:var(--text-muted);margin-top:2px}.section-progress{text-align:right;flex-shrink:0}.section-bar{width:72px;height:6px;background:#2d3436;border-radius:3px;overflow:hidden;margin-bottom:5px}.section-bar-fill{height:100%;border-radius:3px;transition:width .4s}.section-pct{font-size:12px;color:var(--text-muted);font-weight:600}.page-lesson{gap:14px;padding-top:20px}.lesson-header{display:flex;justify-content:space-between;align-items:center;width:100%}.lesson-skill{font-size:14px;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.lesson-streak{color:#fd9644;font-weight:700;font-size:24px;animation:streakPop .4s ease-out;text-shadow:0 0 10px rgba(253,203,110,.6);padding:4px 12px;background:#fdcb6e26;border-radius:20px;border:2px solid rgba(253,203,110,.4)}.lesson-quit{color:var(--text-muted);font-size:22px;cursor:pointer;background:none;border:none;padding:4px 8px}.lesson-problem{flex:1;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;text-align:center;animation:fadeSlideIn .3s ease-out;background:linear-gradient(135deg,#6c5ce714,#4a90e20d);border-radius:var(--radius);padding:24px 20px;position:relative;overflow:hidden}.lesson-problem:before{content:"✨";position:absolute;top:12px;right:12px;font-size:20px;animation:wiggle 2s ease-in-out infinite;opacity:.6}.problem-text{font-size:26px;font-weight:700;color:var(--text);text-shadow:0 2px 4px rgba(0,0,0,.2);position:relative;padding-left:40px}.problem-text:before{content:"🦊";position:absolute;left:0;font-size:32px;animation:wiggle 3s ease-in-out infinite}.hint-toggle{color:var(--accent);font-size:15px;background:none;border:none;cursor:pointer;padding:4px}.hint-box{color:var(--accent);font-size:15px;text-align:center;background:#fdcb6e1a;padding:10px 18px;border-radius:var(--radius-sm);max-width:300px}.answer-options{display:grid;gap:14px;width:100%}.options-2col{grid-template-columns:repeat(2,1fr)}.answer-btn{background:linear-gradient(135deg,var(--bg-card),rgba(45,52,54,.9));border:3px solid #555;border-radius:16px;padding:28px;min-height:64px;font-size:28px;font-weight:800;color:var(--text);cursor:pointer;transition:all .2s cubic-bezier(.68,-.55,.265,1.55);-webkit-tap-highlight-color:transparent;position:relative;overflow:hidden}.answer-btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff1a;transform:translate(-50%,-50%);transition:width .6s,height .6s}.answer-btn:hover{border-color:var(--primary-light);background:linear-gradient(135deg,#6c5ce740,#6c5ce71f);box-shadow:0 0 20px #6c5ce766;transform:translateY(-4px) scale(1.02)}.answer-btn:hover:before{width:300px;height:300px}.answer-btn:active{transform:translateY(-2px) scale(.98)}.feedback-overlay{flex:1;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;text-align:center;border-radius:var(--radius)}.feedback-overlay--correct{background:linear-gradient(135deg,#2ecc7126,#2ecc710d);position:relative}.feedback-overlay--correct:after{content:"✨🎉✨";position:absolute;top:20px;left:50%;transform:translate(-50%);font-size:32px;animation:bounceIn .6s ease-out}.feedback-overlay--wrong{background:linear-gradient(135deg,#e74c3c1f,#e74c3c0a)}.feedback-icon{font-size:96px}.feedback-icon--correct{animation:bounceIn .45s cubic-bezier(.175,.885,.32,1.275),heartbeat 1.5s ease-in-out .5s infinite}.feedback-icon--wrong{animation:shake .45s ease}.feedback-label{font-size:28px;font-weight:700}.feedback-label--correct{color:var(--correct)}.feedback-label--wrong{color:var(--incorrect)}.feedback-answer{color:var(--correct);font-size:20px;font-weight:600}.feedback-explain{color:var(--text-muted);font-size:15px;max-width:280px}.mastery-screen{flex:1;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;text-align:center;background:#6c5ce71a;border-radius:var(--radius)}.mastery-burst{font-size:120px;animation:popIn .5s cubic-bezier(.175,.885,.32,1.275),glowPulse 1.5s ease-in-out .5s infinite,rainbowShift 3s linear infinite;position:relative}.mastery-burst:before,.mastery-burst:after{content:"⭐";position:absolute;font-size:40px;animation:confetti 2s ease-out infinite}.mastery-burst:before{left:-60px;animation-delay:.3s}.mastery-burst:after{right:-60px;animation-delay:.6s}.mastery-title{font-size:26px;color:var(--primary-light);font-weight:700}.mastery-skill{font-size:20px;color:var(--text)}.mastery-points{color:var(--accent);font-size:18px;font-weight:600}@keyframes popIn{0%{transform:scale(.3);opacity:0}to{transform:scale(1);opacity:1}}@keyframes bounceIn{0%{transform:scale(0);opacity:0}60%{transform:scale(1.3)}80%{transform:scale(.9)}to{transform:scale(1);opacity:1}}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-10px)}40%{transform:translate(10px)}60%{transform:translate(-6px)}80%{transform:translate(6px)}}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes streakPop{0%{transform:scale(1)}40%{transform:scale(1.45)}70%{transform:scale(.9)}to{transform:scale(1)}}@keyframes glowPulse{0%,to{filter:drop-shadow(0 0 6px rgba(253,203,110,.3))}50%{filter:drop-shadow(0 0 22px rgba(253,203,110,.8))}}@keyframes confetti{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(400px) rotate(720deg);opacity:0}}@keyframes wiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-5deg)}75%{transform:rotate(5deg)}}@keyframes heartbeat{0%,to{transform:scale(1)}14%{transform:scale(1.15)}28%{transform:scale(1)}42%{transform:scale(1.15)}56%{transform:scale(1)}}@keyframes rainbowShift{0%{filter:hue-rotate(0deg)}to{filter:hue-rotate(360deg)}}.summary-screen{flex:1;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;text-align:center}.summary-icon{font-size:72px;animation:bounceIn .5s cubic-bezier(.175,.885,.32,1.275)}.summary-title{font-size:26px;font-weight:700;color:var(--primary-light)}.summary-stats{display:flex;gap:32px}.summary-stat{text-align:center}.summary-stat span{display:block;font-size:34px;font-weight:700;color:var(--primary-light)}.summary-stat label{font-size:13px;color:var(--text-muted)}.page-skillmap{align-items:flex-start}.skillmap-header{display:flex;align-items:center;gap:14px;width:100%}.skillmap-header h1{font-size:22px}.section-tabs{display:flex;gap:8px;width:100%;overflow-x:auto;padding-bottom:8px;margin-bottom:8px}.section-tab{background:var(--bg-card);border:1px solid #444;border-radius:20px;padding:6px 14px;font-size:14px;color:var(--text-muted);cursor:pointer;white-space:nowrap;transition:border-color .2s,color .2s,background .2s;-webkit-tap-highlight-color:transparent}.section-tab:hover{border-color:var(--text-muted)}.section-tab.active{border-color:var(--section-color, var(--primary-light));color:var(--text);background:#ffffff0f}.age-group{width:100%}.age-label{font-size:17px;color:var(--text-muted);font-weight:600;border-bottom:1px solid #2d3436;padding-bottom:6px;margin-bottom:10px}.skills-row{display:flex;flex-wrap:wrap;gap:8px}.skill-node{background:var(--bg-card);border:2px solid #444;border-radius:var(--radius-sm);padding:10px 14px;cursor:pointer;transition:border-color .2s;display:flex;flex-direction:column;gap:3px;min-width:110px;max-width:160px;text-align:left}.skill-node:hover{border-color:var(--primary-light)}.skill-node--locked{opacity:.35;cursor:default}.skill-node--locked:hover{border-color:#444}.skill-node--available{border-color:#4ecdc4}.skill-node--inprogress{border-color:#ffe66d}.skill-node--mastered{border-color:#2ecc71}.skill-icon{font-size:13px}.skill-name{font-size:12px;font-weight:600;color:var(--text);line-height:1.3}.skill-cat{font-size:10px;color:var(--text-muted)}.page-stats{gap:24px}.stats-header{display:flex;align-items:center;gap:14px;width:100%}.stats-header h1{font-size:22px}.stat-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;width:100%}.stat-card{background:linear-gradient(145deg,var(--bg-card),rgba(30,25,55,.95));border-radius:var(--radius);padding:22px 16px;text-align:center;box-shadow:0 2px 8px #0003;border:1px solid #3a3060}.stat-card .stat-val{display:block;font-size:34px;font-weight:700;color:var(--primary-light)}.stat-card label{font-size:13px;color:var(--text-muted)}.page-settings{align-items:flex-start}.settings-header{display:flex;align-items:center;gap:14px;width:100%}.settings-header h1{font-size:22px}.settings-section{width:100%;display:flex;flex-direction:column;gap:12px}.settings-section h2{font-size:17px;color:var(--text-muted);margin-top:8px}.settings-status{color:var(--correct);font-size:14px;margin-top:4px}.settings-hint{font-size:13px;color:var(--text-muted);margin-top:-4px;line-height:1.4}.file-input-label{display:inline-flex;align-items:center;justify-content:center;background:var(--secondary);color:var(--text);border:1px solid #444;border-radius:var(--radius);padding:10px 20px;font-size:16px;font-weight:600;cursor:pointer}.file-input-label input{display:none}.modal-overlay{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease-out}.modal-content{background:var(--bg-card);border:2px solid #444;border-radius:var(--radius);max-width:500px;width:100%;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease-out}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid #444}.modal-header h2{font-size:20px;margin:0;color:var(--text)}.btn-close{background:none;border:none;color:var(--text-muted);font-size:32px;line-height:1;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:color .2s}.btn-close:hover{color:var(--text)}.modal-body{padding:20px}.modal-footer{display:flex;gap:12px;justify-content:flex-end;padding:20px;border-top:1px solid #444}.qr-modal .modal-body{display:flex;flex-direction:column;align-items:center;gap:16px}.qr-code-image{width:100%;max-width:400px;height:auto;border:2px solid #444;border-radius:var(--radius);background:#fff;padding:10px}.qr-instructions{text-align:center;color:var(--text-muted);font-size:14px;line-height:1.5;margin:0}.conflict-modal{max-width:600px}.conflict-intro{color:var(--text-muted);font-size:14px;margin:0 0 16px}.conflict-item{background:var(--bg);border:1px solid #444;border-radius:var(--radius);padding:16px;margin-bottom:12px}.conflict-profile-info{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.conflict-profile-info strong{font-size:16px;color:var(--text)}.conflict-detail{font-size:13px;color:var(--text-muted)}.conflict-options{display:flex;flex-direction:column;gap:8px}.conflict-options label{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text);cursor:pointer;padding:6px;border-radius:var(--radius-sm);transition:background .2s}.conflict-options label:hover{background:#ffffff0d}.conflict-options input[type=radio]{width:18px;height:18px;cursor:pointer;accent-color:var(--primary)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.visual-objects{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;padding:12px}.visual-emoji{font-size:48px;animation:bounceIn .5s cubic-bezier(.68,-.55,.265,1.55);transition:transform .2s}.visual-emoji:hover{transform:scale(1.1) rotate(-5deg);cursor:default}.visual-groups{display:flex;align-items:center;gap:14px;justify-content:center;flex-wrap:wrap}.visual-group{display:flex;flex-wrap:wrap;gap:5px;justify-content:center;max-width:140px}.visual-group label{width:100%;text-align:center;font-size:13px;color:var(--text-muted);margin-top:4px}.visual-operator{font-size:28px;font-weight:700;color:var(--primary)}.visual-eq-mark{font-size:28px;color:var(--text-muted);font-weight:700}.visual-equation{display:flex;align-items:center;gap:12px;justify-content:center}.visual-equation span{font-size:32px;font-weight:700;color:var(--text)}.visual-shape{display:flex;justify-content:center;padding:12px 0}.visual-blocks{display:flex;align-items:center;gap:8px;justify-content:center;flex-wrap:wrap}.block{background:var(--bg-card);border:2px solid #444;border-radius:var(--radius-sm);padding:10px 16px;font-size:20px;font-weight:700;color:var(--text);min-width:48px;text-align:center}.block--missing{background:#fdcb6e26;border:2px dashed var(--accent);color:var(--accent)}.block-arrow{color:var(--text-muted);font-size:20px}.visual-number-line{width:100%;overflow-x:auto;padding:16px 0}.visual-clock{display:flex;justify-content:center;padding:12px 0}.visual-coins{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.coin{background:linear-gradient(135deg,#f0c040,#d4a017);border-radius:50%;width:54px;height:54px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#5a3e00;box-shadow:0 2px 6px #0000004d;line-height:1.2}.visual-bar-chart{width:100%;max-width:300px}.bar-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.bar-row label{width:55px;font-size:13px;color:var(--text-muted);text-align:right;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bar{border-radius:4px;height:28px;display:flex;align-items:center;padding:0 8px;font-size:13px;font-weight:600;color:#fff;transition:width .3s;min-width:24px}.visual-rectangle{display:flex;justify-content:center;padding:12px 0}.visual-default{color:var(--text-muted);font-size:15px}.assessment-card{display:flex;align-items:center;gap:12px;width:100%;padding:16px 20px;background:linear-gradient(135deg,#3498db,#2980b9);border:none;border-radius:var(--radius-md);cursor:pointer;margin:16px 0;transition:transform .15s,box-shadow .15s}.assessment-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #3498db66}.assessment-icon{font-size:32px}.assessment-info{flex:1;text-align:left}.assessment-title{display:block;font-size:16px;font-weight:600;color:#fff}.assessment-desc{display:block;font-size:13px;color:#fffc}.assessment-arrow{font-size:20px;color:#ffffffb3}.page-assessment-hub{padding:20px;max-width:600px;margin:0 auto}.assessment-header{display:flex;align-items:center;gap:12px;margin-bottom:24px}.assessment-header h1{font-size:24px;font-weight:700;color:var(--text);margin:0}.assessment-content{display:flex;flex-direction:column;gap:24px}.assessment-section h2{font-size:16px;font-weight:600;color:var(--text);margin-bottom:12px}.grade-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.grade-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px 16px;background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all .15s}.grade-card:hover{border-color:var(--primary);background:var(--bg-card-hover)}.grade-card--selected{border-color:var(--primary);background:#3498db26}.grade-number{font-size:36px;font-weight:800;color:var(--primary)}.grade-name{font-size:14px;font-weight:600;color:var(--text);margin-top:4px}.grade-ages{font-size:12px;color:var(--text-muted)}.type-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.type-card{display:flex;flex-direction:column;align-items:center;padding:16px;background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all .15s}.type-card:hover{border-color:var(--primary)}.type-card--selected{border-color:var(--primary);background:#3498db26}.type-icon{font-size:28px;margin-bottom:8px}.type-name{font-size:14px;font-weight:600;color:var(--text)}.type-desc{font-size:12px;color:var(--text-muted);text-align:center;margin-top:4px}.assessment-start{text-align:center;margin-top:8px}.assessment-info{font-size:13px;color:var(--text-muted);margin-top:12px}.test-history{display:flex;flex-direction:column;gap:8px}.history-card{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:background .15s}.history-card:hover{background:var(--bg-card-hover)}.history-info{display:flex;flex-direction:column}.history-grade{font-size:14px;font-weight:600;color:var(--text)}.history-date{font-size:12px;color:var(--text-muted)}.history-score{display:flex;align-items:center;gap:10px}.history-level{padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;color:#fff}.history-percent{font-size:16px;font-weight:700;color:var(--text)}.loading-text,.empty-text{color:var(--text-muted);font-size:14px;text-align:center;padding:20px 0}.page-assessment-test{display:flex;flex-direction:column;height:100vh;padding:0}.test-loading{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px}.loading-spinner{width:40px;height:40px;border:4px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.test-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--bg-card);border-bottom:1px solid var(--border)}.test-header-left,.test-header-right{display:flex;align-items:center;gap:12px}.test-progress-text{font-size:14px;color:var(--text);font-weight:500}.test-timer{font-size:16px;font-weight:700;color:var(--primary)}.test-timer--warning{color:#e74c3c;animation:pulse 1s infinite}@keyframes pulse{50%{opacity:.6}}.test-progress-bar{height:4px;background:var(--border)}.test-progress-fill{height:100%;background:var(--primary);transition:width .3s}.test-nav{display:flex;flex-wrap:wrap;gap:6px;padding:12px 16px;background:var(--bg);border-bottom:1px solid var(--border);overflow-x:auto}.test-nav-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;cursor:pointer;position:relative}.test-nav-btn:disabled{opacity:.4;cursor:not-allowed}.test-nav-btn--current{border-color:var(--primary);background:#3498db33;color:var(--primary)}.test-nav-btn--answered{background:var(--success-bg);border-color:var(--success);color:var(--success)}.test-nav-btn--flagged:after{content:"🚩";position:absolute;top:-6px;right:-6px;font-size:10px}.flag-indicator{position:absolute;top:-6px;right:-6px;font-size:10px}.test-content{flex:1;overflow-y:auto;padding:20px 16px}.question-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:20px;max-width:600px;margin:0 auto}.question-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.question-domain{font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-weight:600}.flag-btn{font-size:12px}.flag-btn.flagged{color:#e74c3c}.question-text{font-size:18px;font-weight:500;color:var(--text);line-height:1.5;margin-bottom:20px}.answer-options{display:flex;flex-direction:column;gap:10px}.answer-btn{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--bg);border:2px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all .15s;text-align:left}.answer-btn:hover:not(:disabled){border-color:var(--primary);background:var(--bg-card-hover)}.answer-btn--selected{border-color:var(--primary);background:#3498db26}.answer-btn--correct{border-color:#27ae60;background:#27ae6026}.answer-btn--wrong{border-color:#e74c3c;background:#e74c3c26}.answer-btn:disabled{cursor:default}.answer-letter{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--bg-card);border-radius:50%;font-size:14px;font-weight:600;color:var(--text-muted)}.answer-btn--selected .answer-letter{background:var(--primary);color:#fff}.answer-btn--correct .answer-letter{background:#27ae60;color:#fff}.answer-btn--wrong .answer-letter{background:#e74c3c;color:#fff}.answer-text{font-size:15px;color:var(--text);flex:1}.feedback-section{margin-top:20px;padding-top:20px;border-top:1px solid var(--border)}.feedback-result{font-size:18px;font-weight:700;margin-bottom:12px}.feedback-correct{color:#27ae60}.feedback-wrong{color:#e74c3c}.feedback-explanation{font-size:14px;color:var(--text-muted);line-height:1.5}.test-actions{display:flex;flex-direction:column;gap:10px;padding:16px;background:var(--bg-card);border-top:1px solid var(--border)}.page-assessment-results{padding:20px;max-width:600px;margin:0 auto}.results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.results-content{display:flex;flex-direction:column;gap:24px}.results-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;min-height:300px}.score-card{display:flex;flex-direction:column;align-items:center;padding:32px 24px;background:var(--bg-card);border-radius:var(--radius-lg)}.score-circle{width:140px;height:140px;display:flex;flex-direction:column;align-items:center;justify-content:center;border:6px solid;border-radius:50%;margin-bottom:16px}.score-percent{font-size:42px;font-weight:800;color:var(--text)}.score-fraction{font-size:14px;color:var(--text-muted)}.score-level{padding:8px 20px;border-radius:20px;font-size:14px;font-weight:600;color:#fff;margin-bottom:16px}.score-feedback{font-size:15px;color:var(--text-muted);text-align:center;line-height:1.5}.domain-section{background:var(--bg-card);border-radius:var(--radius-lg);padding:20px}.domain-section h2{font-size:16px;font-weight:600;color:var(--text);margin-bottom:16px}.domain-chart{display:flex;flex-direction:column;gap:14px}.domain-bar{display:flex;flex-direction:column;gap:6px}.domain-label{display:flex;justify-content:space-between;align-items:center}.domain-name{font-size:13px;color:var(--text)}.domain-score{font-size:12px;color:var(--text-muted)}.domain-bar-bg{height:8px;background:var(--border);border-radius:4px;overflow:hidden}.domain-bar-fill{height:100%;border-radius:4px;transition:width .5s}.domain-percent{font-size:12px;font-weight:600;color:var(--text-muted);align-self:flex-end}.insights-section{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.insight-card{padding:16px;border-radius:var(--radius-md)}.insight-card h3{font-size:14px;margin-bottom:10px}.insight-card ul{list-style:none;padding:0;margin:0}.insight-card li{font-size:13px;color:var(--text);padding:4px 0}.insight-strengths{background:#27ae601a}.insight-strengths h3{color:#27ae60}.insight-improvement{background:#f39c121a}.insight-improvement h3{color:#f39c12}.next-steps-section{background:var(--bg-card);border-radius:var(--radius-lg);padding:20px}.next-steps-section h3{font-size:16px;font-weight:600;color:var(--text);margin-bottom:12px}.next-steps-list{list-style:disc;padding-left:20px;margin:0}.next-steps-list li{font-size:14px;color:var(--text-muted);padding:4px 0}.results-actions{display:flex;gap:12px;margin-top:8px}.results-actions .btn{flex:1}.review-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.review-nav{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:20px}.review-nav-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;border:1px solid var(--border);border-radius:6px;cursor:pointer;background:var(--bg-card)}.review-nav-btn--current{border-color:var(--primary);background:#3498db33}.review-nav-btn--correct{background:#27ae6033;border-color:#27ae60;color:#27ae60}.review-nav-btn--wrong{background:#e74c3c33;border-color:#e74c3c;color:#e74c3c}.review-content{flex:1}.review-question{background:var(--bg-card);border-radius:var(--radius-lg);padding:20px}.review-answers{display:flex;flex-direction:column;gap:10px;margin:20px 0}.review-answer{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--bg);border:2px solid var(--border);border-radius:var(--radius-md)}.review-answer--correct{border-color:#27ae60;background:#27ae601a}.review-answer--wrong{border-color:#e74c3c;background:#e74c3c1a}.answer-indicator{margin-left:auto;font-size:12px;font-weight:600}.review-answer--correct .answer-indicator{color:#27ae60}.review-answer--wrong .answer-indicator{color:#e74c3c}.review-explanation{font-size:14px;color:var(--text-muted);line-height:1.5;padding-top:16px;border-top:1px solid var(--border)}.review-actions{display:flex;gap:12px;margin-top:20px}.review-actions .btn{flex:1}.skill-node--review{border-color:#fd9644;border-style:dashed}:focus-visible{outline:3px solid var(--primary-light);outline-offset:2px}.btn-ghost,.hint-toggle,.lesson-quit,.profile-delete,.section-tab,.test-nav-btn,.review-nav-btn{min-height:44px;min-width:44px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}body.theme-young{--primary: #e84393;--primary-light: #fd79a8;--accent: #fdcb6e;--bg: #1a1029;--bg-card: #251540}body.theme-young .answer-btn{padding:26px;font-size:28px;border-radius:22px;background:linear-gradient(135deg,#2d1f4e,#3a2660);border-color:#6a4fa0}body.theme-young .answer-btn:hover{border-color:#fd79a8;background:linear-gradient(135deg,#3d2d60,#4e3575);box-shadow:0 0 16px #e843934d}body.theme-young .visual-emoji{font-size:64px}body.theme-young .problem-text{font-size:26px}body.theme-young .btn-primary{background:linear-gradient(135deg,#e84393,#fd79a8);box-shadow:0 3px 12px #e8439366}body.theme-young .profile-card{background:linear-gradient(145deg,#2d1f4e,#3a2660);border-color:#6a4fa0}body.theme-young .profile-card:hover{border-color:#fd79a8;box-shadow:0 4px 18px #e8439340}body.theme-young .stat-card{background:linear-gradient(145deg,#2d1f4e,#3a2660);border-color:#6a4fa0}body.theme-young .visual-group label{color:#fd79a8;font-weight:600}body.theme-young .hint-box{background:#fd79a81f;color:#fd79a8}body.theme-mid{--primary: #6C5CE7;--primary-light: #a29bfe;--accent: #fdcb6e;--bg: #0f1b2d;--bg-card: #162236}body.theme-mid .answer-btn{background:linear-gradient(135deg,#162236,#1c2d42);border-color:#2e4a6e}body.theme-mid .answer-btn:hover{border-color:#a29bfe;background:linear-gradient(135deg,#1e3050,#243a54);box-shadow:0 0 14px #a29bfe40}body.theme-mid .profile-card{background:linear-gradient(145deg,#162236,#1c2d42);border-color:#2e4a6e}body.theme-mid .profile-card:hover{border-color:#a29bfe;box-shadow:0 4px 18px #a29bfe33}body.theme-mid .stat-card{background:linear-gradient(145deg,#162236,#1c2d42);border-color:#2e4a6e}body.theme-mid .skill-node{background:#162236;border-color:#2e4a6e}body.theme-mid .skill-node--available{border-color:#4ecdc4;background:#4ecdc414}body.theme-mid .skill-node--inprogress{border-color:#ffe66d;background:#ffe66d14}body.theme-mid .skill-node--mastered{border-color:#2ecc71;background:#2ecc7114}
