@import"https://fonts.googleapis.com/css2?family=Fredoka:wght@400;600;700&family=Nunito:wght@400;600;700;800&display=swap";:root{--bg: #080714;--bg2: #0f0c2a;--card: rgba(255, 255, 255, .06);--card-border: rgba(255, 255, 255, .11);--card-hover: rgba(255, 255, 255, .1);--purple: #8b5cf6;--purple-light: #a78bfa;--purple-dark: #6d28d9;--gold: #f59e0b;--gold-light: #fbbf24;--pink: #ec4899;--blue: #3b82f6;--green: #10b981;--red: #ef4444;--teal: #14b8a6;--text: #f0eeff;--text-muted: #8b8daa;--text-dim: #4f516a;--glow-purple: 0 0 28px rgba(139, 92, 246, .45);--glow-gold: 0 0 28px rgba(245, 158, 11, .55);--glow-green: 0 0 28px rgba(16, 185, 129, .5);--radius: 18px;--radius-sm: 12px;--transition: .18s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:Nunito,sans-serif;background:var(--bg);color:var(--text);min-height:100dvh;overflow-x:hidden;-webkit-font-smoothing:antialiased}h1,h2,h3,.display{font-family:Fredoka,sans-serif;font-weight:600}.star-field{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;overflow:hidden}.star{position:absolute;border-radius:50%;background:#fff;animation:twinkle var(--dur, 3s) ease-in-out infinite;animation-delay:var(--delay, 0s)}@keyframes twinkle{0%,to{opacity:var(--min-opacity, .1);transform:scale(1)}50%{opacity:var(--max-opacity, .8);transform:scale(1.3)}}.page{position:relative;z-index:1;min-height:100dvh;display:flex;flex-direction:column;align-items:center;padding:1rem 1rem 2rem}.container{width:100%;max-width:480px}.card{background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.card-padded{padding:1.5rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border:none;border-radius:var(--radius-sm);font-family:Fredoka,sans-serif;font-size:1.1rem;font-weight:600;cursor:pointer;padding:.75rem 1.5rem;min-height:52px;transition:transform var(--transition),box-shadow var(--transition),opacity var(--transition);-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.btn:active{transform:scale(.96)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:disabled:active{transform:none}.btn-primary{background:linear-gradient(135deg,var(--purple),var(--purple-dark));color:#fff;box-shadow:var(--glow-purple)}.btn-primary:hover:not(:disabled){box-shadow:0 0 36px #8b5cf699}.btn-gold{background:linear-gradient(135deg,var(--gold),#d97706);color:#1a1000;box-shadow:var(--glow-gold)}.btn-ghost{background:var(--card);border:1px solid var(--card-border);color:var(--text)}.btn-ghost:hover:not(:disabled){background:var(--card-hover)}.btn-danger{background:linear-gradient(135deg,var(--red),#b91c1c);color:#fff}.btn-icon{width:52px;padding:0;border-radius:50%;font-size:1.4rem;background:var(--card);border:1px solid var(--card-border);color:var(--text)}.btn-lg{font-size:1.3rem;padding:1rem 2rem;min-height:62px;border-radius:var(--radius)}.btn-full{width:100%}.input{width:100%;background:#ffffff12;border:1.5px solid var(--card-border);border-radius:var(--radius-sm);color:var(--text);font-family:Nunito,sans-serif;font-size:1rem;padding:.75rem 1rem;outline:none;transition:border-color var(--transition),box-shadow var(--transition);-webkit-appearance:none}.input:focus{border-color:var(--purple-light);box-shadow:0 0 0 3px #8b5cf633}.input::placeholder{color:var(--text-dim)}.input-large{font-size:1.4rem;padding:1rem 1.25rem;text-align:center;letter-spacing:.05em;border-radius:var(--radius)}.label{display:block;font-size:.85rem;font-weight:600;color:var(--text-muted);margin-bottom:.4rem;text-transform:uppercase;letter-spacing:.04em}.form-group{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem}select.input{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2394a3b8' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2.5rem;cursor:pointer}.alert{padding:.75rem 1rem;border-radius:var(--radius-sm);font-size:.9rem;font-weight:500}.alert-error{background:#ef444426;border:1px solid rgba(239,68,68,.3);color:#fca5a5}.alert-success{background:#10b98126;border:1px solid rgba(16,185,129,.3);color:#6ee7b7}.auth-page{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem;position:relative;z-index:1}.auth-card{width:100%;max-width:400px;padding:2rem 1.5rem}.auth-logo{text-align:center;margin-bottom:2rem}.auth-logo .logo-emoji{font-size:3.5rem;display:block;margin-bottom:.5rem}.auth-logo h1{font-size:2.2rem;background:linear-gradient(135deg,var(--purple-light),var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-logo p{color:var(--text-muted);font-size:.9rem;margin-top:.25rem}.home-header{width:100%;max-width:480px;display:flex;align-items:center;justify-content:space-between;padding:1rem 0 .5rem}.home-logo{display:flex;align-items:center;gap:.5rem}.home-logo span{font-size:1.8rem}.home-logo h1{font-size:1.5rem;background:linear-gradient(135deg,var(--purple-light),var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:Fredoka,sans-serif;font-weight:700;font-size:1rem;color:#fff;flex-shrink:0}.hero-greeting{font-size:1rem;color:var(--text-muted);margin-bottom:.25rem}.hero-name{font-size:1.8rem;color:var(--text);margin-bottom:.5rem}.year-badge{display:inline-block;background:#8b5cf633;border:1px solid rgba(139,92,246,.4);color:var(--purple-light);padding:.2rem .75rem;border-radius:999px;font-size:.8rem;font-weight:600;margin-bottom:1.5rem}.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:1.5rem}.stat-box{background:#ffffff0d;border:1px solid var(--card-border);border-radius:var(--radius-sm);padding:.75rem .5rem;text-align:center}.stat-value{font-family:Fredoka,sans-serif;font-size:1.5rem;font-weight:700;color:var(--gold)}.stat-label{font-size:.7rem;color:var(--text-muted);margin-top:.1rem}.home-actions{width:100%;max-width:480px;display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.action-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.action-card{padding:1.25rem 1rem;text-align:center;cursor:pointer;transition:transform var(--transition),background var(--transition);text-decoration:none;color:var(--text);display:flex;flex-direction:column;align-items:center;gap:.4rem}.action-card:active{transform:scale(.97)}.action-card:hover{background:var(--card-hover)}.action-card .icon{font-size:1.8rem}.action-card .label{font-size:.85rem;font-weight:600;color:var(--text-muted)}.session-page{min-height:100dvh;display:flex;flex-direction:column;align-items:center;padding:1rem;position:relative;z-index:1}.session-header{width:100%;max-width:480px;display:flex;align-items:center;gap:1rem;padding:.5rem 0 1rem}.progress-bar-wrap{flex:1;height:8px;background:#ffffff1a;border-radius:999px;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--purple),var(--gold));border-radius:999px;transition:width .4s cubic-bezier(.4,0,.2,1)}.word-count{font-size:.85rem;color:var(--text-muted);white-space:nowrap;font-weight:600}.spell-area{width:100%;max-width:480px;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem}.listen-card{width:100%;padding:2.5rem 1.5rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1.25rem;background:linear-gradient(135deg,#8b5cf61f,#3b82f614);border:1px solid rgba(139,92,246,.2)}.speaker-btn{width:80px;height:80px;border-radius:50%;border:none;font-size:2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s,box-shadow .2s;-webkit-tap-highlight-color:transparent;background:linear-gradient(135deg,var(--purple),var(--purple-dark));box-shadow:var(--glow-purple);color:#fff;position:relative}.speaker-btn:active{transform:scale(.93)}.speaker-btn.speaking{animation:pulse-speaker .6s ease-in-out infinite alternate}@keyframes pulse-speaker{0%{box-shadow:0 0 16px #8b5cf680;transform:scale(1)}to{box-shadow:0 0 36px #8b5cf6e6;transform:scale(1.06)}}.listen-hint{color:var(--text-muted);font-size:.9rem}.listen-hint strong{color:var(--purple-light)}.spell-input-wrap{width:100%;display:flex;flex-direction:column;gap:.75rem}.spell-input-label{text-align:center;color:var(--text-muted);font-size:.9rem}.results-page{min-height:100dvh;display:flex;flex-direction:column;align-items:center;padding:1rem;position:relative;z-index:1}.score-circle{width:120px;height:120px;border-radius:50%;margin:0 auto 1rem;display:flex;flex-direction:column;align-items:center;justify-content:center;font-family:Fredoka,sans-serif;position:relative}.score-circle:before{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:50%;background:conic-gradient(var(--purple) calc(var(--pct) * 1%),rgba(255,255,255,.1) 0);z-index:-1}.score-circle .score-num{font-size:2.5rem;font-weight:700;line-height:1}.score-circle .score-denom{font-size:.9rem;color:var(--text-muted)}.score-stars{font-size:1.8rem;letter-spacing:.1em;margin-bottom:.5rem}.score-message{font-size:1.1rem;color:var(--text-muted)}.results-list{width:100%;max-width:480px;display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem}.result-item{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;border-radius:var(--radius-sm);animation:slide-in .3s ease both;animation-delay:var(--delay, 0s)}@keyframes slide-in{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:translate(0)}}.result-item.correct{background:#10b9811f;border:1px solid rgba(16,185,129,.25)}.result-item.wrong{background:#ef44441a;border:1px solid rgba(239,68,68,.2)}.result-icon{font-size:1.25rem;flex-shrink:0}.result-words{flex:1;min-width:0}.result-correct-word{font-weight:700;font-size:1rem}.result-typed{font-size:.82rem;color:var(--text-muted);margin-top:.1rem}.result-typed .typed-wrong{color:var(--red);text-decoration:line-through}.achievement-toast{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);z-index:100;display:flex;flex-direction:column;gap:.5rem;align-items:center;pointer-events:none}.toast-item{background:linear-gradient(135deg,#8b5cf6e6,#f59e0b99);border:1px solid rgba(255,255,255,.2);border-radius:999px;padding:.6rem 1.25rem;display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:600;white-space:nowrap;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);animation:toast-in .4s cubic-bezier(.34,1.56,.64,1) both,toast-out .3s ease 3s both}@keyframes toast-in{0%{opacity:0;transform:translateY(20px) scale(.8)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes toast-out{0%{opacity:1}to{opacity:0;transform:translateY(-10px)}}.confetti-piece{position:fixed;width:8px;height:8px;border-radius:2px;pointer-events:none;z-index:200;animation:confetti-fall var(--dur, 2s) ease-in var(--delay, 0s) forwards}@keyframes confetti-fall{0%{transform:translateY(-20px) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(720deg);opacity:0}}.page-header{width:100%;max-width:480px;display:flex;align-items:center;gap:.75rem;padding:.75rem 0 1rem}.page-header h2{font-size:1.4rem;flex:1}.section-title{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:.75rem}.word-table{width:100%;max-width:480px;display:flex;flex-direction:column;gap:.4rem;margin-bottom:1.5rem}.word-row{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:var(--radius-sm);background:var(--card);border:1px solid var(--card-border)}.word-row .word-text{font-weight:600;flex:1}.word-row .word-group{font-size:.7rem;color:var(--text-muted);background:#ffffff14;padding:.15rem .5rem;border-radius:999px}.accuracy-pill{font-size:.8rem;font-weight:700;padding:.2rem .6rem;border-radius:999px}.acc-good{background:#10b98133;color:#6ee7b7}.acc-ok{background:#f59e0b33;color:#fcd34d}.acc-bad{background:#ef444433;color:#fca5a5}.session-history{width:100%;max-width:480px;display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem}.session-row{display:flex;align-items:center;padding:.875rem 1rem;gap:1rem;border-radius:var(--radius-sm);background:var(--card);border:1px solid var(--card-border)}.session-score{font-family:Fredoka,sans-serif;font-size:1.2rem;font-weight:700;color:var(--gold)}.session-date{font-size:.8rem;color:var(--text-muted);flex:1}.session-bar-wrap{width:60px;height:6px;background:#ffffff1a;border-radius:999px;overflow:hidden}.session-bar-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--purple),var(--gold))}.collection-grid{width:100%;max-width:480px;display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:1.5rem}.collectible-card{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.3rem;border-radius:var(--radius);padding:.75rem .5rem;text-align:center;position:relative;overflow:hidden}.collectible-card.locked{background:#ffffff08;border:1px solid rgba(255,255,255,.08);filter:grayscale(1);opacity:.4}.collectible-card.earned{background:var(--card);border:1px solid var(--card-border);animation:glow-in .6s ease}.collectible-card.earned.legendary{border-color:#f59e0b80;box-shadow:0 0 20px #f59e0b33;background:linear-gradient(135deg,#f59e0b14,#8b5cf614)}.collectible-card.earned.rare{border-color:#8b5cf666;box-shadow:0 0 12px #8b5cf626}@keyframes glow-in{0%{box-shadow:0 0 40px #f59e0bcc}to{box-shadow:inherit}}.collectible-icon{font-size:2rem}.collectible-name{font-size:.65rem;font-weight:700;color:var(--text-muted);line-height:1.2}.rarity-dot{width:6px;height:6px;border-radius:50%;position:absolute;top:6px;right:6px}.rarity-dot.common{background:var(--text-dim)}.rarity-dot.rare{background:var(--purple-light)}.rarity-dot.legendary{background:var(--gold)}.tabs{display:flex;gap:.5rem;margin-bottom:1rem;padding:.25rem;background:#ffffff0d;border-radius:var(--radius-sm)}.tab{flex:1;padding:.5rem;border:none;border-radius:calc(var(--radius-sm) - 2px);background:transparent;color:var(--text-muted);font-family:Fredoka,sans-serif;font-size:.95rem;cursor:pointer;transition:background var(--transition),color var(--transition)}.tab.active{background:var(--purple);color:#fff}.word-admin-row{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius-sm);margin-bottom:.4rem}.word-admin-row .word-text{flex:1;font-weight:600}.word-admin-row .hint-text{font-size:.75rem;color:var(--text-dim);flex:2;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.loading-screen{min-height:100dvh;display:flex;align-items:center;justify-content:center;position:relative;z-index:1}.spinner{width:40px;height:40px;border:3px solid rgba(139,92,246,.3);border-top-color:var(--purple);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:2.5rem 1rem;color:var(--text-muted)}.empty-state .icon{font-size:3rem;margin-bottom:.75rem}.divider{height:1px;background:var(--card-border);margin:1rem 0}.text-center{text-align:center}.text-muted{color:var(--text-muted)}.text-small{font-size:.85rem}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.gap-1{gap:.5rem}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.streak-badge{display:inline-flex;align-items:center;gap:.3rem;background:#f59e0b26;border:1px solid rgba(245,158,11,.3);color:var(--gold-light);padding:.3rem .75rem;border-radius:999px;font-size:.85rem;font-weight:700}.wand-swing{display:inline-block;animation:wand 1.2s ease-in-out infinite alternate;transform-origin:bottom center}@keyframes wand{0%{transform:rotate(-15deg)}to{transform:rotate(15deg)}}.shake{animation:shake .4s cubic-bezier(.36,.07,.19,.97)}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-6px)}80%{transform:translate(6px)}}.choice-btn{background:#ffffff0a;border:2px solid rgba(255,255,255,.12);border-radius:var(--radius);color:var(--text);cursor:pointer;padding:1rem .5rem .75rem;display:flex;flex-direction:column;align-items:center;transition:border-color .2s,background .2s,transform .15s,box-shadow .2s;-webkit-tap-highlight-color:transparent}.choice-btn.chosen{border-color:var(--purple-light);background:#8b5cf626;box-shadow:var(--glow-purple);transform:scale(1.03)}.choice-btn:active{transform:scale(.97)}.year-choice-btn{padding:.875rem 1rem;border-radius:var(--radius-sm);border:2px solid rgba(255,255,255,.1);background:#ffffff0a;color:var(--text);cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-family:Nunito,sans-serif;transition:border-color .2s,background .2s;-webkit-tap-highlight-color:transparent}.year-choice-btn.chosen{border-color:var(--purple);background:#8b5cf626}.hero-card{width:100%;max-width:480px;padding:1.5rem;margin:.75rem 0;background:linear-gradient(135deg,#8b5cf621,#f59e0b12);border:1px solid rgba(139,92,246,.22);position:relative;overflow:hidden}.hero-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 30% 0%,rgba(139,92,246,.12) 0%,transparent 60%),radial-gradient(ellipse at 70% 100%,rgba(245,158,11,.08) 0%,transparent 60%);pointer-events:none}.hero-character-row{display:flex;align-items:center;gap:1rem;margin-bottom:1.25rem}.hero-identity{flex:1;min-width:0}.wizard-title-badge{display:inline-block;background:linear-gradient(135deg,var(--purple-dark),#4c1d95);border:1px solid rgba(167,139,250,.3);color:var(--purple-light);padding:.2rem .75rem;border-radius:999px;font-size:.75rem;font-weight:700;letter-spacing:.03em;margin-bottom:.35rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.hero-name{font-size:1.7rem;margin-bottom:.35rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.xp-section{margin-bottom:1.25rem}.xp-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.level-badge{background:linear-gradient(135deg,var(--gold),#d97706);color:#1a0f00;font-family:Fredoka,sans-serif;font-weight:700;font-size:.9rem;padding:.2rem .75rem;border-radius:999px;box-shadow:0 0 12px #f59e0b66}.xp-text{font-size:.78rem;color:var(--text-muted);font-weight:600}.xp-bar-track{height:12px;background:#ffffff14;border-radius:999px;overflow:hidden;border:1px solid rgba(255,255,255,.06)}.xp-bar-fill{height:100%;background:linear-gradient(90deg,var(--purple),var(--gold));border-radius:999px;transition:width .8s cubic-bezier(.4,0,.2,1);box-shadow:0 0 8px #8b5cf699}.mini-xp-bar-wrap{margin-top:1rem;padding:.75rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-sm)}.mini-xp-bar-track{height:8px;background:#ffffff14;border-radius:999px;overflow:hidden}.mini-xp-bar-fill{height:100%;background:linear-gradient(90deg,var(--purple),var(--gold));border-radius:999px;transition:width 1s cubic-bezier(.4,0,.2,1)}.xp-gained-pill{display:inline-block;background:linear-gradient(135deg,#f59e0b33,#8b5cf626);border:1px solid rgba(245,158,11,.4);color:var(--gold-light);font-family:Fredoka,sans-serif;font-weight:700;font-size:1.1rem;padding:.3rem 1rem;border-radius:999px;margin-top:.5rem;animation:xp-pop .5s cubic-bezier(.34,1.56,.64,1) both;animation-delay:.4s}@keyframes xp-pop{0%{opacity:0;transform:scale(.7) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.achievement-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#080714eb;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:500;display:flex;align-items:center;justify-content:center;padding:1.5rem;animation:overlay-in .3s ease both}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.achievement-popup{background:linear-gradient(160deg,#8b5cf62e,#f59e0b1a,#080714e6);border:1.5px solid rgba(139,92,246,.4);border-radius:24px;padding:2rem 1.5rem 1.5rem;max-width:380px;width:100%;text-align:center;position:relative;overflow:hidden;animation:popup-in .45s cubic-bezier(.34,1.56,.64,1) both;box-shadow:0 0 80px #8b5cf640,0 0 120px #f59e0b1a}@keyframes popup-in{0%{opacity:0;transform:scale(.7) translateY(30px)}to{opacity:1;transform:scale(1) translateY(0)}}.achievement-sparkles{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.sparkle{position:absolute;width:6px;height:6px;border-radius:50%;background:var(--gold);animation:sparkle-orbit 2s ease-in-out infinite;animation-delay:calc(var(--i) * .25s);top:50%;left:50%}@keyframes sparkle-orbit{0%{opacity:0;transform:rotate(calc(var(--i) * 45deg)) translate(100px) scale(0)}20%{opacity:1;transform:rotate(calc(var(--i) * 45deg + 20deg)) translate(110px) scale(1)}80%{opacity:.5}to{opacity:0;transform:rotate(calc(var(--i) * 45deg + 360deg)) translate(130px) scale(0)}}.achievement-badge{width:90px;height:90px;border-radius:50%;background:linear-gradient(135deg,#8b5cf64d,#f59e0b33);border:2px solid rgba(245,158,11,.5);display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;animation:badge-pulse 1.5s ease-in-out infinite alternate}@keyframes badge-pulse{0%{transform:scale(1);box-shadow:0 0 20px #f59e0b4d}to{transform:scale(1.06);box-shadow:0 0 40px #f59e0b99}}.achievement-unlock-label{font-size:.8rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--gold);margin-bottom:.5rem}.achievement-name{font-family:Fredoka,sans-serif;font-size:1.7rem;font-weight:700;margin-bottom:.5rem;background:linear-gradient(135deg,var(--text),var(--gold-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.achievement-desc{color:var(--text-muted);font-size:.95rem;line-height:1.5;margin-bottom:1rem}.achievement-collectible{background:#ffffff0d;border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-sm);padding:.75rem}.rarity-label{display:block;font-size:.7rem;font-weight:800;letter-spacing:.1em;margin-bottom:.25rem}.collectible-earned-name{font-size:.9rem;color:var(--text-muted)}.collectible-earned-name strong{color:var(--text);font-weight:700}.score-hero{width:100%;padding:2rem 1.5rem;text-align:center;background:linear-gradient(135deg,#8b5cf61f,#f59e0b0f);border:1px solid rgba(139,92,246,.2)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:200;display:flex;align-items:center;justify-content:center;padding:1rem}.modal-box{width:100%;max-width:420px;max-height:90dvh;overflow-y:auto;padding:1.5rem;animation:popup-in .3s cubic-bezier(.34,1.56,.64,1) both}.child-card{width:100%;padding:0;overflow:hidden}.child-card-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;cursor:pointer;transition:background .15s}.child-card-header:hover{background:#ffffff0a}.child-card-body{padding:1rem 1.25rem 1.25rem;border-top:1px solid var(--card-border)}.choice-row{display:flex;gap:.75rem}.choice-btn--active{border-color:var(--purple-light)!important;background:#8b5cf626!important;box-shadow:var(--glow-purple)}.hair-choice-row{display:flex;gap:.75rem;align-items:center}.hair-swatch{width:48px;height:48px;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:transform .15s,border-color .15s,box-shadow .15s;position:relative;flex-shrink:0}.hair-swatch:hover{transform:scale(1.1)}.hair-swatch--active{border-color:#fff!important;box-shadow:0 0 0 2px #ffffff4d}.hair-swatch--locked{cursor:not-allowed}.hair-check{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.1rem;font-weight:900;text-shadow:0 1px 3px rgba(0,0,0,.6)}.practice-card{padding:2rem;text-align:center}.practice-word-reveal{padding:1.5rem;background:#8b5cf61f;border:1px solid rgba(139,92,246,.3);border-radius:var(--radius);margin:.5rem 0}.practice-word{font-family:Fredoka,sans-serif;font-size:2.5rem;font-weight:700;color:var(--text);letter-spacing:.05em}.practice-countdown{margin-top:1.5rem;display:flex;justify-content:center}.countdown-ring{width:56px;height:56px;border-radius:50%;background:conic-gradient(var(--purple) var(--pct, 100%),rgba(255,255,255,.08) 0);display:flex;align-items:center;justify-content:center;font-family:Fredoka,sans-serif;font-size:1.3rem;font-weight:700;color:var(--text);position:relative}.countdown-ring:before{content:"";position:absolute;top:4px;right:4px;bottom:4px;left:4px;border-radius:50%;background:var(--bg2)}.countdown-ring span{position:relative;z-index:1}.practice-word-gone{position:relative;height:80px;display:flex;flex-direction:column;align-items:center;justify-content:center}.sparkle-gone{font-size:2rem;animation:float-sparkle 1.5s ease-in-out infinite alternate}@keyframes float-sparkle{0%{transform:translateY(-4px) rotate(-10deg)}to{transform:translateY(4px) rotate(10deg)}}.practice-input{font-size:1.4rem;text-align:center;letter-spacing:.1em}.practice-word-result{font-family:Fredoka,sans-serif;font-size:1.8rem;padding:.5rem 1rem;border-radius:var(--radius-sm);display:inline-block;margin:.25rem 0}.correct-word{color:var(--green);background:#10b9811a;border:1px solid rgba(16,185,129,.3)}.wrong-word{color:var(--red);background:#ef44441a;border:1px solid rgba(239,68,68,.3);text-decoration:line-through;opacity:.7}.alert-success{background:#10b9811f;border-color:#10b9814d;color:#34d399}@media (min-width: 400px){.collection-grid{grid-template-columns:repeat(4,1fr)}}@media (min-width: 480px){.auth-card{padding:2.5rem 2rem}.hero-card{padding:2rem}}
