@import "https://fonts.googleapis.com/css2?family=Fredoka:wght@400;600;700&display=swap";:root{--primary:#5b6af0;--secondary:#ff6b6b;--yellow:#ffd93d;--green:#6bcb77;--purple:#a855f7;--surface:#fff;--text:#1e1b4b;--text-muted:#6b7280;--radius-lg:28px;--radius-md:18px;--radius-sm:12px}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%}body{color:var(--text);background:#f1f5f9;align-items:stretch;min-height:100vh;font-family:Fredoka,sans-serif;display:flex}#root{flex-direction:column;align-items:stretch;width:100%;min-height:100vh;display:flex;position:relative}#root:before{content:"";z-index:0;background:linear-gradient(145deg,#667eea 0%,#8b5cf6 50%,#ec4899 100%);height:38vh;position:fixed;top:0;left:0;right:0}#root:after{content:"";z-index:0;background:#f1f5f9;border-radius:32px 32px 0 0;height:70vh;position:fixed;bottom:0;left:0;right:0}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes wiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-5deg)}75%{transform:rotate(5deg)}}@keyframes popIn{0%{opacity:0;transform:scale(.5)}70%{transform:scale(1.05)}to{opacity:1;transform:scale(1)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}@keyframes feverPulse{0%{box-shadow:0 0 20px #ef4444,inset 0 0 20px #f97316}50%{box-shadow:0 0 40px #f97316,inset 0 0 40px #ef4444}to{box-shadow:0 0 20px #ef4444,inset 0 0 20px #f97316}}@keyframes pulseBorder{0%{box-shadow:0 0 #ef4444b3}70%{box-shadow:0 0 0 10px #ef444400}to{box-shadow:0 0 #ef444400}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-6px)}80%{transform:translate(6px)}}@keyframes revealPop{0%{opacity:0;transform:scale(0)rotate(-10deg)}60%{transform:scale(1.25)rotate(3deg)}to{opacity:1;transform:scale(1)rotate(0)}}@keyframes btnBounceUp{0%,to{transform:translateY(0)scale(1)}40%{transform:translateY(-10px)scale(1.08)}70%{transform:translateY(-4px)scale(1.04)}}.animate-pop-in{animation:.5s cubic-bezier(.175,.885,.32,1.275) forwards popIn}.animate-slide-up{animation:.4s ease-out forwards slideUp}.animate-float{animation:4s ease-in-out infinite float}.game-container{z-index:1;flex-direction:column;align-items:center;width:100%;max-width:860px;min-height:100vh;margin:0 auto;display:flex;position:relative}.game-hero{width:100%;padding-top:env(safe-area-inset-top,0px)}.game-panel{background:#fff;border-radius:32px 32px 0 0;flex-direction:column;flex:1;align-items:center;width:100%;margin-top:.5rem;display:flex;overflow:hidden auto;box-shadow:0 -4px 32px #5b6af01f}.fever-mode{animation:1.5s infinite alternate feverPulse}.fever-mode .player-title{color:#ef4444;text-shadow:2px 2px #fde047}.scoreboard{justify-content:space-between;align-items:center;gap:.5rem;width:100%;padding:1.25rem 1.5rem 1rem;display:flex}.player-title{color:#fff;white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:.5rem;font-size:1.5rem;font-weight:700;display:flex;overflow:hidden}.player-avatar-badge{flex-shrink:0;font-size:1.8rem;line-height:1}.player-name{font-weight:700}.player-label{color:#fff;font-size:1.5rem;font-weight:700}.score-right{flex-shrink:0;align-items:center;gap:1rem;display:flex}.store-btn{color:#fff;border-radius:var(--radius-sm);cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff40;border:2px solid #fff6;align-items:center;gap:.4rem;padding:.4rem .9rem;font-family:Fredoka,sans-serif;font-size:1rem;font-weight:700;transition:background .15s;display:flex}.store-btn:hover{background:#ffffff59}.store-btn:active{background:#ffffff26}.score-item{align-items:center;gap:.3rem;display:flex}.icon{font-size:1.6rem}.star-icon{animation:2.5s ease-in-out infinite wiggle}.score-text{font-size:1.4rem;font-weight:700}.score-text.coins{color:#fde68a}.score-text.stars{color:#fff}.trophy-case{background:#f8fafc;border-bottom:2px solid #f1f5f9;flex-wrap:wrap;justify-content:center;gap:.5rem;width:100%;padding:.5rem 1rem;display:flex}.trophy-item{filter:drop-shadow(0 2px 3px #0003);font-size:1.8rem}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.w-full{width:100%}.gap-4{gap:1rem}.mt-6{margin-top:1.5rem}.mb-8{margin-bottom:2rem}.text-center{text-align:center}.text-xl{color:#475569;font-size:1.25rem;font-weight:600}.auth-container{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1.5rem;width:100%;padding:3rem 2rem;display:flex}.auth-container h2{color:var(--primary);font-size:2rem}.auth-form{flex-direction:column;gap:1rem;width:100%;max-width:320px;display:flex}.auth-form input{border-radius:var(--radius-sm);border:2px solid #e2e8f0;outline:none;padding:.75rem 1rem;font-family:Fredoka,sans-serif;font-size:1.1rem;transition:border-color .2s}.auth-form input:focus{border-color:var(--primary)}.switch-mode-btn{color:var(--primary);cursor:pointer;background:0 0;border:none;margin-top:.5rem;font-family:Fredoka,sans-serif;font-size:1rem;font-weight:700;text-decoration:underline}.error-text{color:#ef4444;font-weight:700}.profile-selector{text-align:center;width:100%;padding:2.5rem 2rem}.profile-selector-title{color:var(--primary);margin-bottom:2rem;font-size:2.2rem;font-weight:700}.profiles-grid{flex-wrap:wrap;justify-content:center;gap:1.5rem;margin-bottom:2rem;display:flex}.profile-card{cursor:pointer;background:#fff;border:3px solid #e2e8f0;border-bottom:7px solid #cbd5e1;border-radius:24px;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;width:150px;height:170px;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;box-shadow:0 4px 12px #00000012}.profile-card:hover{border-color:var(--primary);border-bottom-color:#4f46e5;transform:translateY(-6px)scale(1.03);box-shadow:0 12px 24px #5b6af033}.profile-card:active{border-bottom-width:3px;transform:translateY(3px)}.profile-card-wrapper{display:inline-flex;position:relative}.profile-delete-btn{color:#fff;cursor:pointer;opacity:0;background:#ef4444;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:.7rem;font-weight:700;line-height:1;transition:opacity .15s;display:flex;position:absolute;top:-8px;right:-8px;box-shadow:0 2px 6px #0003}.profile-card-wrapper:hover .profile-delete-btn{opacity:1}.delete-confirm{text-align:center;color:#7f1d1d;background:#fef2f2;border:2px solid #fca5a5;border-radius:14px;max-width:360px;margin:1rem auto 0;padding:1rem 1.5rem;font-size:1rem}.profile-avatar{font-size:4rem}.profile-name{color:var(--text);font-family:Fredoka,sans-serif;font-size:1.4rem;font-weight:700}.menu-area{flex-direction:column;flex:1;align-items:center;width:100%;padding:1.5rem 1.5rem 2rem;display:flex;position:relative}.menu-area h2{color:var(--text);margin-bottom:1.25rem;font-size:2rem;font-weight:700}.category-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;align-self:flex-start;margin-bottom:.75rem;padding-left:.25rem;font-size:1.1rem;font-weight:600}.menu-grid{grid-template-columns:1fr 1fr 1fr;gap:1rem;width:100%;margin-bottom:1rem;display:grid}.menu-grid-2col{grid-template-columns:1fr 1fr}.menu-btn{border-radius:var(--radius-md);color:var(--text);cursor:pointer;background:#fff;border:2.5px solid #e2e8f0;border-bottom:6px solid #d1d5db;flex-direction:column;align-items:center;gap:.6rem;padding:1.25rem 1rem;font-family:Fredoka,sans-serif;font-size:1.1rem;font-weight:700;transition:all .12s ease-out;display:flex;box-shadow:0 4px 8px #0000000d}.menu-btn span{text-align:center;line-height:1.2}.menu-btn:hover{filter:brightness(.97);transform:translateY(-2px);box-shadow:0 8px 16px #0000001a}.menu-btn:active{border-bottom:2.5px solid #d1d5db;transform:translateY(4px)}.menu-btn.addition{color:#1d4ed8;background:#eff6ff;border-color:#93c5fd #93c5fd #3b82f6}.menu-btn.addition svg{color:#3b82f6}.menu-btn.subtraction{color:#b91c1c;background:#fef2f2;border-color:#fca5a5 #fca5a5 #ef4444}.menu-btn.subtraction svg{color:#ef4444}.menu-btn.make10{color:#92400e;background:#fffbeb;border-color:#fcd34d #fcd34d #d97706}.menu-btn.count{color:#14532d;background:#f0fdf4;border-color:#86efac #86efac #16a34a}.menu-btn.seq{color:#4c1d95;background:#f5f3ff;border-color:#c4b5fd #c4b5fd #7c3aed}.menu-btn.sight{color:#0c4a6e;background:#f0f9ff;border-color:#7dd3fc #7dd3fc #0284c7}.menu-btn.phonics{color:#831843;background:#fdf2f8;border-color:#f9a8d4 #f9a8d4 #db2777}.menu-btn.mixed{color:#064e3b;background:#ecfdf5;border-color:#6ee7b7 #6ee7b7 #059669}.menu-icon{letter-spacing:.05em;font-size:1.8rem;line-height:1}.admin-access-btn{color:#fffc;cursor:pointer;background:#ffffff26;border:2px solid #ffffff4d;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:.45rem;transition:all .2s;display:flex}.admin-access-btn:hover{color:#fff;background:#ffffff4d}.level-badge{background:#f5f3ff;border-bottom:2px solid #ede9fe;justify-content:space-between;align-items:center;width:100%;margin-bottom:.75rem;padding:.5rem 1.25rem;display:flex}.game-mode-label{color:var(--primary);letter-spacing:.01em;text-align:center;flex:1;font-size:1rem;font-weight:700}.back-btn{color:#7c3aed;cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;align-items:center;gap:.5rem;padding:.35rem .75rem;font-family:Fredoka,sans-serif;font-size:1rem;font-weight:700;transition:background .15s;display:flex}.back-btn:hover{background:#ede9fe}.session-progress{color:var(--primary);align-items:center;gap:.75rem;font-weight:700;display:flex}.progress-bar{background:#e5e7eb;border-radius:999px;width:130px;height:10px;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--primary), #a855f7);border-radius:999px;height:100%;transition:width .4s ease-out}.progress-text{font-size:1rem}.eq-zone{flex-shrink:0;justify-content:center;width:100%;padding:.75rem 1.5rem .25rem;display:flex}.game-area{flex-direction:column;flex:1;justify-content:flex-start;align-items:center;gap:.75rem;width:100%;min-height:80px;padding:.5rem 1.5rem 0;display:flex}.word-game-layout{flex-direction:column;align-items:center;gap:1.25rem;display:flex}.word-game-instruction{color:var(--text-muted);text-align:center;font-size:1.2rem;font-weight:600}.math-problem{color:var(--primary);text-align:center;text-shadow:3px 3px #f1f5f9;letter-spacing:.2rem;justify-content:center;align-items:center;gap:1.25rem;width:100%;font-size:5.5rem;font-weight:700;display:flex}.operator{color:var(--secondary)}.make10-box{border:3px dashed var(--purple);border-radius:var(--radius-sm);color:#c4b5fd;background:#a855f70f;min-width:90px;padding:0 .75rem;display:inline-block}.fever-mode .math-problem{color:#ef4444}.math-problem-small{letter-spacing:.1rem;text-shadow:none;gap:.6rem;margin-bottom:.25rem;font-size:2.2rem}.object-grid{flex-wrap:wrap;justify-content:center;gap:.75rem;max-width:400px;font-size:3.5rem;display:flex}.seq-display{color:var(--primary);align-items:center;gap:1rem;font-size:4.5rem;font-weight:700;display:flex}.play-audio-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#3b82f6,#6366f1);border:none;border-bottom:5px solid #3730a3;border-radius:999px;flex-direction:row;justify-content:center;align-items:center;gap:.75rem;width:auto;height:auto;padding:1rem 2.5rem;font-family:Fredoka,sans-serif;font-size:1.4rem;font-weight:700;transition:all .15s ease-out;display:flex;box-shadow:0 8px 24px #6366f14d}.play-audio-btn:hover{transform:translateY(-3px);box-shadow:0 12px 28px #6366f166}.play-audio-btn:active{box-shadow:none;border-bottom-width:2px;transform:translateY(3px)}.hint-btn-v2{color:#1d4ed8;cursor:pointer;background:#eff6ff;border:2.5px solid #93c5fd;border-radius:999px;align-items:center;gap:.65rem;margin-top:1.25rem;padding:.65rem 1.75rem;font-family:Fredoka,sans-serif;font-size:1.15rem;font-weight:700;transition:all .2s cubic-bezier(.175,.885,.32,1.275);display:flex;box-shadow:0 5px #93c5fd,0 8px 12px #3b82f626}.hint-icon-wrapper{color:#2563eb;background:#fff;border-radius:50%;justify-content:center;align-items:center;padding:.2rem;display:flex;box-shadow:inset 0 2px 4px #00000014}.hint-btn-v2:hover{background:#dbeafe;transform:translateY(-3px);box-shadow:0 8px #93c5fd,0 14px 20px #3b82f633}.hint-btn-v2:hover .hint-icon-wrapper{animation:.8s infinite bounce}.hint-btn-v2:active{transform:translateY(5px);box-shadow:0 0 #93c5fd}.visual-aid{background:#f8fafc;border:2px solid #f1f5f9;border-radius:20px;flex-direction:column;justify-content:center;align-items:center;gap:.6rem;width:100%;max-width:420px;padding:.75rem 1rem;display:flex}.visual-aid-dots-row{flex-wrap:nowrap;justify-content:center;align-items:center;gap:.75rem;display:flex}.visual-aid .dot{width:20px;height:20px}.visual-aid .dot-number{font-size:.65rem}.visual-aid .dots-group{gap:.25rem;padding:.3rem}.visual-aid .make-10-grid{gap:.4rem;padding:.5rem}.number-bond{flex-direction:column;align-items:center;display:flex}.bond-circle{border:3px solid var(--primary);width:48px;height:48px;color:var(--text);background:#fff;border-radius:50%;justify-content:center;align-items:center;font-size:1.4rem;font-weight:700;display:flex;box-shadow:0 3px 6px #00000014}.bond-total{border-color:var(--secondary)}.bond-legs{justify-content:space-between;width:90px;height:28px;display:flex;position:relative}.bond-line{background:#cbd5e1;width:2.5px;height:36px;position:absolute;top:0}.bond-line.left{transform-origin:top;left:20%;transform:rotate(35deg)}.bond-line.right{transform-origin:top;right:20%;transform:rotate(-35deg)}.bond-parts{z-index:1;gap:2rem;display:flex}.dots-group{background:#fff9;border:1.5px solid #0000000a;border-radius:10px;grid-template-columns:repeat(5,1fr);gap:.4rem;padding:.5rem;display:grid}.make-10-grid{grid-template-columns:repeat(5,1fr);gap:.65rem;padding:.85rem}.dot{border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s cubic-bezier(.175,.885,.32,1.275);display:flex;box-shadow:inset -2px -2px 4px #00000026,0 2px 4px #00000014}.dot.interactive{cursor:pointer}.dot.interactive:hover{transform:scale(1.15)}.dot.interactive:active{transform:scale(.9)}.dot.empty{box-shadow:none;background:0 0;border:2.5px dashed #d1d5db}.dot.empty-dash{box-shadow:none;background:0 0;border:2.5px dashed #9ca3af}.dot.bg-blue{background:#3b82f6}.dot.bg-purple{background:#a855f7}.dot.crossed-out{box-shadow:none;background:#e5e7eb}.dot.crossed-out .cross{color:#ef4444;font-size:1.4rem;font-weight:900;position:absolute}.dot-number{color:#fff;text-shadow:1px 1px #0003;font-size:1rem;font-weight:800}.highlight-target{animation:1.5s infinite pulseBorder}.equation-card{background:#fff;border:3px solid #e2e8f0;border-radius:24px;flex-direction:column;align-items:center;gap:.75rem;width:100%;max-width:500px;padding:1rem 1.75rem .9rem;transition:border-color .2s,box-shadow .2s;display:flex;box-shadow:0 8px 24px #00000014,0 2px 6px #0000000a}.equation-card.eq-correct{border-color:#86efac;box-shadow:0 8px 32px #22c55e2e,0 2px 6px #0000000a}.equation-card.eq-incorrect{border-color:#fca5a5;animation:.4s ease-out shake;box-shadow:0 8px 24px #ef444426,0 2px 6px #0000000a}.eq-row{flex-wrap:wrap;justify-content:center;align-items:center;gap:.5rem;line-height:1;display:flex}.eq-num{color:var(--text);align-items:center;font-size:3.5rem;font-weight:700;line-height:1.1;display:flex}.eq-op{color:var(--primary);align-items:center;padding:0 .15rem;font-size:3rem;font-weight:700;line-height:1.1;display:flex}.eq-blank{color:#94a3b8;text-align:center;background:#f1f5f9;border:3px dashed #cbd5e1;border-radius:14px;justify-content:center;align-items:center;min-width:88px;height:72px;padding:0 .5rem;font-size:3.5rem;font-weight:700;line-height:1;display:flex}.eq-blank-revealed{color:#16a34a;background:#f0fdf4;border:3px solid #86efac;animation:.45s cubic-bezier(.175,.885,.32,1.275) forwards revealPop}.revealed-seq{animation:.45s cubic-bezier(.175,.885,.32,1.275) forwards revealPop;color:#16a34a!important;background:#f0fdf4!important;border-color:#86efac!important}.feedback-slot{flex-shrink:0;justify-content:center;align-items:center;width:100%;height:52px;transition:height .2s;display:flex;overflow:hidden}.feedback-slot.feedback-slot-hidden{height:0}.inline-feedback{border-radius:50px;justify-content:center;align-items:center;gap:.6rem;width:100%;max-width:320px;padding:.55rem 1.25rem;display:flex}.correct-banner{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:2.5px solid #86efac}.incorrect-banner{background:linear-gradient(135deg,#fff7ed,#fef3c7);border:2.5px solid #fcd34d}.fb-emoji{font-size:1.5rem}.fb-text{color:#15803d;font-size:1.5rem;font-weight:700}.incorrect-banner .fb-text{color:#92400e}.coins-container{flex-wrap:wrap;flex-shrink:0;justify-content:center;gap:1rem;width:100%;padding:.5rem 1.5rem 1.25rem;display:flex}.coins-container.coins-compact{gap:.6rem;padding:.25rem 1rem .75rem}.coins-compact .coin-button{width:86px;height:86px;font-size:2.4rem}.coins-compact .coin-button.text-coin{width:auto;min-width:86px;font-size:1.8rem}.coin-button{border-radius:var(--radius-md);width:110px;height:110px;color:var(--text);cursor:pointer;background:#fff;border:3px solid #e2e8f0;border-bottom:8px solid #cbd5e1;flex-direction:column;justify-content:center;align-items:center;gap:.1rem;font-family:Fredoka,sans-serif;font-size:3rem;font-weight:700;transition:all .15s ease-out;display:flex;position:relative;box-shadow:0 4px 8px #0000000f}.coin-button.text-coin{width:auto;min-width:110px;padding:0 1rem;font-size:2.2rem}.coin-button:hover:not(:disabled){background:#f8fafc;transform:translateY(-3px);box-shadow:0 8px 16px #0000001a}.coin-button:active:not(:disabled){border-bottom:3px solid #cbd5e1;transform:translateY(5px)}.coin-button.dimmed{opacity:.35;box-shadow:none;pointer-events:none;transform:scale(.9)}.coin-button.btn-correct{color:#15803d;background:linear-gradient(145deg,#dcfce7,#bbf7d0);border:3px solid #86efac;border-bottom:8px solid #4ade80;animation:.5s cubic-bezier(.175,.885,.32,1.275) forwards btnBounceUp;box-shadow:0 6px 20px #22c55e40}.coin-button.btn-correct .btn-check{color:#16a34a;font-size:1.5rem;line-height:1}.coin-button.btn-correct span:last-child{font-size:2.2rem}.coin-button.btn-wrong{color:#dc2626;background:linear-gradient(145deg,#fee2e2,#fecaca);border:3px solid #fca5a5;border-bottom:8px solid #f87171;animation:.35s ease-out shake;box-shadow:0 4px 12px #ef444433}.coin-button.btn-wrong .btn-x{color:#dc2626;font-size:1.4rem;line-height:1}.coin-button.btn-wrong span:last-child{font-size:2.2rem}.coin-button.btn-fade{opacity:.3;box-shadow:none;pointer-events:none;transform:scale(.9)}.modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-radius:var(--radius-lg);z-index:50;background:#00000073;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.modal-content{background:#fff;border-radius:24px;width:90%;max-width:480px;padding:2rem;box-shadow:0 20px 50px #0003}.modal-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.modal-header h2{color:var(--primary);font-size:1.8rem}.close-btn{color:#9ca3af;cursor:pointer;background:0 0;border:none;border-radius:50%;align-items:center;padding:.4rem;transition:all .2s;display:flex}.close-btn:hover{color:#ef4444;background:#fee2e2}.store-balance{color:#d97706;text-align:center;background:#fef3c7;border-radius:10px;margin-bottom:1.25rem;padding:.5rem;font-size:1.4rem;font-weight:600}.store-grid{grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:1rem;display:grid}.store-item-card{text-align:center;background:#f9fafb;border:2px solid #e5e7eb;border-radius:14px;flex-direction:column;align-items:center;padding:.85rem;display:flex}.store-item-card.owned{background:#f0fdf4;border-color:#86efac}.item-icon{margin-bottom:.4rem;font-size:2.8rem}.item-name{color:#6b7280;margin-bottom:.4rem;font-size:.95rem;font-weight:600}.buy-btn{color:#9ca3af;cursor:not-allowed;background:#e5e7eb;border:none;border-radius:8px;width:100%;padding:.4rem;font-family:Fredoka,sans-serif;font-size:.95rem;font-weight:700}.buy-btn.can-afford{color:#78350f;cursor:pointer;background:#fbbf24;box-shadow:0 3px #d97706}.buy-btn.can-afford:active{box-shadow:none;transform:translateY(3px)}.item-owned{color:#fff;text-align:center;background:#22c55e;border-radius:8px;width:100%;padding:.4rem;font-size:.95rem;font-weight:700}.summary-area{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:1.5rem;padding:2rem 1.5rem;display:flex}.summary-area h2{color:var(--primary);font-size:2.2rem}.admin-panel{flex-direction:column;flex:1;justify-content:center;align-items:center;width:100%;padding:2.5rem 2rem;display:flex}.admin-panel h2{color:var(--primary);margin-bottom:.4rem;font-size:1.8rem}.admin-panel p{color:var(--text-muted);margin-bottom:2rem}.pin-pad{width:100%;max-width:280px}.pin-dots{justify-content:center;gap:1rem;margin-bottom:1.5rem;display:flex}.pin-dot{background:#fff;border:2.5px solid #cbd5e1;border-radius:50%;width:18px;height:18px;transition:all .2s}.pin-dot.filled{background:var(--primary);border-color:var(--primary);transform:scale(1.15)}.pin-grid{grid-template-columns:repeat(3,1fr);gap:.65rem;display:grid}.pin-btn{border-radius:var(--radius-md);cursor:pointer;color:#334155;background:#f8fafc;border:2px solid #e2e8f0;border-bottom:4px solid #cbd5e1;padding:.9rem;font-family:Fredoka,sans-serif;font-size:1.5rem;font-weight:700;transition:all .1s}.pin-btn:hover{background:#f1f5f9;transform:translateY(-1px)}.pin-btn:active{border-bottom-width:2px;transform:translateY(3px)}.pin-btn.clear{color:#ef4444;background:#fee2e2;border-color:#fca5a5 #fca5a5 #ef4444}.admin-dashboard-container{flex-direction:column;flex:1;width:100%;display:flex;overflow:hidden}.admin-tab-bar{background:#fff;border-bottom:2px solid #f1f5f9;gap:.5rem;padding:1rem 1.5rem .75rem;display:flex}.sidebar-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:999px;padding:.55rem 1.1rem;font-family:Fredoka,sans-serif;font-size:1rem;font-weight:700;transition:all .15s}.sidebar-tab:hover{color:var(--text);background:#f1f5f9}.sidebar-tab.active{background:var(--primary);color:#fff}.sidebar-tab.exit{color:#ef4444;background:#fee2e2;margin-left:auto}.sidebar-tab.exit:hover{background:#fecaca}.admin-content{flex:1;padding:1.5rem;overflow-y:auto}.admin-header{justify-content:space-between;align-items:center;margin-bottom:1.25rem;display:flex}.admin-header h2{color:#0f172a;font-size:1.6rem}.stats-row{flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;display:flex}.stat-card{text-align:center;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1.5px solid #e2e8f0;border-radius:16px;flex:1;min-width:90px;padding:1.25rem 1rem;box-shadow:0 2px 8px #0000000a}.stat-value{color:var(--primary);margin-bottom:.25rem;font-size:2rem;font-weight:800}.stat-label{color:#64748b;text-transform:uppercase;letter-spacing:.06em;font-size:.75rem;font-weight:600}.admin-content h3{color:#334155;margin-bottom:.75rem;font-size:1.1rem}.table-container{border:1.5px solid #e2e8f0;border-radius:12px;overflow-x:auto}.sessions-table{border-collapse:collapse;width:100%}.sessions-table th{text-align:left;color:#475569;background:#f8fafc;border-bottom:2px solid #e2e8f0;padding:.7rem 1rem;font-size:.9rem;font-weight:700}.sessions-table td{color:#334155;border-bottom:1px solid #f8fafc;padding:.7rem 1rem;font-size:.9rem}.sessions-table tr:last-child td{border-bottom:none}.sessions-table tbody tr:hover{background:#f8fafc}@media (width<=700px){#root:before{height:28vh}#root:after{height:78vh}.game-panel{border-radius:24px 24px 0 0}.scoreboard{padding:1rem 1.25rem .75rem}.menu-grid{grid-template-columns:1fr 1fr}.math-problem{gap:1rem;font-size:4.5rem}.seq-display{font-size:3.5rem}.coin-button{width:90px;height:90px;font-size:2.4rem}.coin-button.text-coin{min-width:90px;font-size:1.6rem}.admin-tab-bar{gap:.4rem;padding:.75rem 1rem}.sidebar-tab{padding:.45rem .8rem;font-size:.9rem}.admin-content{padding:1rem}}@media (width<=400px){.menu-grid{grid-template-columns:1fr 1fr;gap:.65rem}.menu-btn{padding:1rem .75rem;font-size:1rem}.player-title,.score-text{font-size:1.2rem}.profiles-grid{gap:1rem}.profile-card{width:120px;height:140px}.profile-avatar{font-size:3rem}.profile-name{font-size:1.2rem}}.menu-btn.rhyme{color:#831843;background:#fdf2f8;border-color:#f9a8d4 #f9a8d4 #db2777}.menu-btn.family{color:#14532d;background:#f0fdf4;border-color:#86efac #86efac #16a34a}.menu-btn.digraph{color:#4c1d95;background:#f5f3ff;border-color:#c4b5fd #c4b5fd #7c3aed}.menu-btn.scramble{color:#92400e;background:#fffbeb;border-color:#fcd34d #fcd34d #d97706}.family-badge{color:var(--primary);letter-spacing:.1em;background:#eff6ff;border:3px solid #93c5fd;border-radius:16px;padding:.2rem 1.2rem;font-size:3.5rem;font-weight:800}.scramble-layout{flex-direction:column;align-items:center;gap:.75rem;width:100%;display:flex}.scramble-tray{background:#f0fdf4;border:2.5px dashed #86efac;border-radius:16px;flex-wrap:wrap;justify-content:center;align-items:center;gap:.5rem;width:100%;max-width:480px;min-height:56px;padding:.6rem .75rem;display:flex}.scramble-tray-hint{color:#94a3b8;font-size:1rem;font-style:italic;font-weight:600}.scramble-pool{flex-wrap:wrap;justify-content:center;gap:.6rem;width:100%;padding:.25rem 1rem;display:flex}.tile{cursor:pointer;border:none;border-radius:12px;font-family:Fredoka,sans-serif;font-weight:700;line-height:1;transition:all .15s cubic-bezier(.175,.885,.32,1.275)}.tile-pool{color:#4c1d95;background:#fff;border:2.5px solid #c4b5fd;border-bottom:5px solid #a855f7;padding:.5rem .9rem;font-size:1.2rem;box-shadow:0 3px 8px #a855f726}.tile-pool:hover{transform:translateY(-3px);box-shadow:0 6px 14px #a855f740}.tile-pool:active{border-bottom-width:2px;transform:translateY(2px)}.tile-selected{color:#1d4ed8;background:#eff6ff;border:2.5px solid #93c5fd;border-bottom:5px solid #3b82f6;padding:.5rem .9rem;font-size:1.2rem;box-shadow:0 3px 8px #3b82f626}.tile-selected:hover{background:#dbeafe;transform:translateY(-2px)}.tile-selected:active{border-bottom-width:2px;transform:translateY(2px)}.scramble-confirm-row{flex-shrink:0;justify-content:center;gap:.75rem;width:100%;padding:.5rem 1.5rem .75rem;display:flex}.scramble-check-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#6bcb77,#22c55e);border:none;border-bottom:5px solid #15803d;border-radius:999px;padding:.75rem 2.5rem;font-family:Fredoka,sans-serif;font-size:1.3rem;font-weight:700;transition:all .15s ease-out;box-shadow:0 6px 16px #22c55e4d}.scramble-check-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #22c55e66}.scramble-check-btn:active:not(:disabled){border-bottom-width:2px;transform:translateY(3px)}.scramble-check-btn:disabled{color:#9ca3af;cursor:not-allowed;box-shadow:none;background:#e5e7eb;border-bottom-color:#d1d5db}.scramble-reset-btn{color:#64748b;cursor:pointer;background:#f8fafc;border:2px solid #e2e8f0;border-bottom:4px solid #cbd5e1;border-radius:999px;padding:.75rem 1.5rem;font-family:Fredoka,sans-serif;font-size:1.1rem;font-weight:700;transition:all .15s}.scramble-reset-btn:hover{color:#334155;background:#f1f5f9}.scramble-reset-btn:active{transform:translateY(2px)}.coins-hidden{display:none!important}.grade-picker{flex-wrap:wrap;gap:.6rem;display:flex}.grade-btn{color:#64748b;cursor:pointer;text-align:center;background:#f8fafc;border:2px solid #e2e8f0;border-bottom:4px solid #cbd5e1;border-radius:12px;flex:1;min-width:90px;padding:.6rem .75rem;font-family:Fredoka,sans-serif;font-size:.95rem;font-weight:700;transition:all .15s}.grade-btn:hover{color:#334155;background:#f1f5f9}.grade-btn.active{background:var(--primary);border-color:var(--primary);color:#fff;border-bottom-color:#4338ca;box-shadow:0 4px 12px #5b6af04d}@keyframes celebBounce{0%,to{transform:scale(1)translateY(0)}40%{transform:scale(1.2)translateY(-18px)}70%{transform:scale(1.05)translateY(-6px)}}.purchase-celebration{z-index:200;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:pointer;background:#0000008c;flex-direction:column;justify-content:center;align-items:center;gap:1rem;display:flex;position:fixed;inset:0}.celebration-emoji{filter:drop-shadow(0 8px 24px #0006);font-size:7rem;line-height:1;animation:.7s cubic-bezier(.175,.885,.32,1.275) infinite celebBounce}.celebration-name{color:#fff;text-shadow:0 2px 8px #0006;font-size:2.2rem;font-weight:700}.celebration-tagline{color:#fde68a;text-shadow:0 2px 6px #0000004d;text-align:center;padding:0 2rem;font-size:1.5rem;font-weight:600}.item-locked{flex-direction:column;align-items:center;gap:.3rem;width:100%;display:flex}.item-lock-label{color:#94a3b8;text-align:center;font-size:.8rem;font-weight:700}.item-lock-track{background:#e5e7eb;border-radius:999px;width:100%;height:6px;overflow:hidden}.item-lock-fill{background:linear-gradient(90deg, var(--primary), #a855f7);border-radius:999px;height:100%;transition:width .4s ease-out}.fact-card{text-align:center;background:linear-gradient(135deg,#fffbeb,#fef3c7);border:2px solid #fcd34d;border-radius:18px;width:100%;max-width:380px;padding:1rem 1.5rem}.fact-label{color:#d97706;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.4rem;font-size:.9rem;font-weight:700}.fact-text{color:#78350f;font-size:1.15rem;font-weight:600;line-height:1.4}
