:root{--bg-primary: #1a0a2e;--bg-secondary: #2d1b4e;--accent-purple: #8b5cf6;--accent-pink: #ec4899;--accent-gold: #fbbf24;--accent-green: #34d399;--accent-blue: #60a5fa;--text-primary: #f8f0ff;--text-secondary: #c4b5d6;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px)}html,body,#root{width:100%;height:100%;margin:0;padding:0;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-primary);color:var(--text-primary)}.app-frame{width:100%;height:100%;max-width:430px;margin:0 auto;position:relative;overflow:hidden;background:linear-gradient(160deg,#1a0a2e,#2d1b4e 40%,#1a0a2e)}@media (min-width: 500px){body{background:linear-gradient(135deg,#0a0612,#150d25,#0a0612);display:flex;align-items:center;justify-content:center;min-height:100vh}.app-frame{height:100vh;max-height:932px;border-radius:44px;box-shadow:0 0 0 4px #2a1a4a,0 0 0 6px #8b5cf64d,0 20px 80px #0009}}.settings-gear{position:absolute;top:calc(12px + var(--safe-top));right:12px;z-index:100;background:#ffffff1a;border:none;border-radius:50%;width:40px;height:40px;font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:.4;transition:opacity .3s;-webkit-tap-highlight-color:transparent}.settings-gear:active{opacity:.8}.start-screen{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px;padding-top:calc(40px + var(--safe-top));padding-bottom:calc(40px + var(--safe-bottom));opacity:0;transform:scale(.95);transition:all .6s cubic-bezier(.34,1.56,.64,1);position:relative;overflow:hidden}.start-screen.visible{opacity:1;transform:scale(1)}.start-bg-notes{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.floating-note{position:absolute;font-size:28px;opacity:.15;animation:floatUp 6s ease-in-out infinite}@keyframes floatUp{0%,to{transform:translateY(100vh) rotate(0);opacity:0}10%{opacity:.15}90%{opacity:.15}to{transform:translateY(-50px) rotate(360deg);opacity:0}}.start-content{display:flex;flex-direction:column;align-items:center;gap:24px;z-index:1}.start-teacher{position:relative;display:flex;flex-direction:column;align-items:center;animation:gentleBounce 2s ease-in-out infinite}.start-teacher-body{width:120px;height:120px;border-radius:50%;background:linear-gradient(135deg,#8b5cf6,#a78bfa);box-shadow:0 0 40px #8b5cf680,0 0 80px #8b5cf633;display:flex;align-items:center;justify-content:center}.start-teacher-body .eyes{gap:22px}.start-teacher-body .eye-dot{width:14px;height:14px}.start-teacher-body .eye-dot:after{width:7px;height:7px;top:3px;left:4px}.start-teacher-body .mouth{width:20px;height:22px}.start-teacher-notes{position:absolute;top:-10px;right:-20px;width:50px;height:50px}@keyframes gentleBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.start-title{font-size:36px;font-weight:800;background:linear-gradient(135deg,var(--accent-purple),var(--accent-pink));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-align:center}.start-subtitle{font-size:16px;color:var(--text-secondary);text-align:center;line-height:1.5}.start-button{display:flex;align-items:center;gap:12px;padding:18px 48px;border:none;border-radius:60px;background:linear-gradient(135deg,var(--accent-purple),var(--accent-pink));color:#fff;font-size:22px;font-weight:700;cursor:pointer;box-shadow:0 8px 32px #8b5cf666;transition:transform .2s,box-shadow .2s;-webkit-tap-highlight-color:transparent}.start-button:active{transform:scale(.95);box-shadow:0 4px 16px #8b5cf64d}.start-button-icon{font-size:26px}.game-screen{width:100%;height:100%;display:flex;flex-direction:column;padding-top:calc(16px + var(--safe-top));padding-bottom:calc(16px + var(--safe-bottom));position:relative;overflow:hidden}.match-glow{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 50% 50%,rgba(52,211,153,.15) 0%,rgba(52,211,153,.05) 40%,transparent 70%);pointer-events:none;transition:opacity .3s}.reward-bank{display:flex;align-items:center;justify-content:center;gap:4px;padding:8px 16px;min-height:48px;flex-shrink:0}.reward-item{font-size:28px;animation:rewardPop .5s cubic-bezier(.34,1.56,.64,1);display:inline-block}@keyframes rewardPop{0%{transform:scale(0);opacity:0}60%{transform:scale(1.4)}to{transform:scale(1);opacity:1}}.reward-placeholder,.reward-remaining{display:flex;gap:6px}.reward-slot{font-size:18px;color:#ffffff26}.vowel-display{text-align:center;padding:4px;flex-shrink:0}.vowel-letter{font-size:28px;font-weight:800;color:var(--accent-gold);text-shadow:0 0 20px rgba(251,191,36,.3)}.singing-area{flex:1;display:flex;align-items:center;justify-content:center;gap:0;padding:0 16px;position:relative}.teacher-container{flex:1;display:flex;align-items:center;justify-content:center}.connection-area{width:60px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.child-container{flex:1;display:flex;align-items:center;justify-content:center;min-height:300px;position:relative}.character-body{width:90px;height:90px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative}.teacher-body{background:linear-gradient(135deg,#8b5cf6,#a78bfa);box-shadow:0 0 30px #8b5cf666;animation:teacherPulse 3s ease-in-out infinite}@keyframes teacherPulse{0%,to{box-shadow:0 0 30px #8b5cf666}50%{box-shadow:0 0 50px #8b5cf699}}.child-body{background:linear-gradient(135deg,#ec4899,#f472b6);box-shadow:0 0 20px #ec48994d;transition:box-shadow .3s}.child-body.glow{box-shadow:0 0 40px #34d39980,0 0 60px #34d39933}.character-face{display:flex;flex-direction:column;align-items:center;gap:6px}.eyes{display:flex;gap:16px}.eye-dot{width:10px;height:10px;border-radius:50%;background:#fff;position:relative}.eye-dot:after{content:"";position:absolute;width:5px;height:5px;border-radius:50%;background:#1a0a2e;top:2px;left:3px}.blink-left,.blink-right{animation:blink 4s ease-in-out infinite}.blink-right{animation-delay:.1s}@keyframes blink{0%,92%,to{transform:scaleY(1)}95%{transform:scaleY(.1)}}.mouth{width:16px;height:16px;border-radius:50%;background:#1a0a2e}.mouth-sing{animation:mouthSing .8s ease-in-out infinite}@keyframes mouthSing{0%,to{width:14px;height:18px;border-radius:50%}50%{width:18px;height:12px;border-radius:50%}}.mouth-talk{animation:mouthTalk .3s ease-in-out infinite}@keyframes mouthTalk{0%,to{width:12px;height:8px;border-radius:50%}50%{width:16px;height:14px;border-radius:50%}}.child-mouth{width:12px;height:12px}.music-notes{position:absolute;top:-10px;right:-10px;width:40px;height:40px}.note{position:absolute;font-size:16px;color:var(--accent-gold);animation:noteFloat 2s ease-out infinite;opacity:0}.note-1{animation-delay:0s;left:0}.note-2{animation-delay:.7s;left:10px}.note-3{animation-delay:1.4s;left:5px}@keyframes noteFloat{0%{opacity:0;transform:translateY(0) rotate(0) scale(.5)}20%{opacity:1}to{opacity:0;transform:translateY(-40px) rotate(20deg) scale(1)}}.child-notes{right:-15px;top:-15px}.child-notes .note{color:var(--accent-pink)}.speech-dot{position:absolute;font-size:20px;color:#fff;animation:speechBounce 1s ease-in-out infinite}.dot-1{left:0;animation-delay:0s}.dot-2{left:12px;animation-delay:.2s}.dot-3{left:24px;animation-delay:.4s}@keyframes speechBounce{0%,to{transform:translateY(0);opacity:.4}50%{transform:translateY(-8px);opacity:1}}.character-label{display:block;text-align:center;margin-top:8px;font-size:20px}.child-character{display:flex;flex-direction:column;align-items:center;transition:transform .25s cubic-bezier(.4,0,.2,1);will-change:transform}.child-placeholder{display:flex;flex-direction:column;align-items:center;gap:8px;opacity:.4;animation:placeholderPulse 2s ease-in-out infinite}@keyframes placeholderPulse{0%,to{opacity:.3;transform:scale(1)}50%{opacity:.5;transform:scale(1.05)}}.placeholder-text{font-size:40px}.placeholder-hint{font-size:14px;color:var(--text-secondary);font-weight:600}.connection-line{width:4px;height:60px;background:linear-gradient(180deg,var(--accent-green),var(--accent-gold));border-radius:2px;position:relative;transition:opacity .3s}.connection-hearts{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:14px;white-space:nowrap;animation:heartPulse 1s ease-in-out infinite}@keyframes heartPulse{0%,to{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.2)}}.progress-section{padding:12px 24px;min-height:80px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.match-progress-container{width:100%;display:flex;flex-direction:column;align-items:center;gap:8px}.match-progress-bar{width:100%;height:12px;background:#ffffff1a;border-radius:6px;overflow:hidden}.match-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-green),var(--accent-gold));border-radius:6px;transition:width .15s ease-out;box-shadow:0 0 10px #34d39980}.countdown-display{text-align:center}.countdown-number{font-size:36px;font-weight:800;color:var(--accent-gold);text-shadow:0 0 20px rgba(251,191,36,.5);animation:countdownPulse 1s ease-in-out infinite}@keyframes countdownPulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.hint-text{font-size:16px;color:var(--text-secondary);text-align:center;animation:fadeIn .3s ease}.pitch-hint{font-size:20px;font-weight:600;color:var(--accent-gold)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.celebration-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#1a0a2ee6;z-index:50;opacity:0;transition:opacity .3s}.celebration-overlay.visible{opacity:1}.celebration-particle{position:absolute;pointer-events:none;animation:particleFly 2s ease-out forwards}@keyframes particleFly{0%{transform:translate(0) rotate(0) scale(0);opacity:1}20%{transform:scale(1);opacity:1}to{transform:translate(var(--vx, 0),var(--vy, -100px)) rotate(var(--rot, 180deg)) scale(.3);opacity:0}}.rainbow-arc{position:absolute;width:200px;height:100px;border:6px solid transparent;border-top:6px solid;border-image:linear-gradient(90deg,red,#f80,#ff0,#0f0,#08f,#80f) 1;border-radius:100px 100px 0 0;top:35%;opacity:0;animation:rainbowAppear .8s .3s ease-out forwards}@keyframes rainbowAppear{0%{opacity:0;transform:scale(.3)}to{opacity:.6;transform:scale(1)}}.celebration-main-emoji{z-index:1}.celebration-emoji-bounce{font-size:80px;display:block;animation:emojiBounce .8s cubic-bezier(.34,1.56,.64,1)}@keyframes emojiBounce{0%{transform:scale(0) rotate(-30deg)}60%{transform:scale(1.3) rotate(10deg)}to{transform:scale(1) rotate(0)}}.celebration-text{font-size:32px;font-weight:800;margin-top:16px;color:var(--accent-gold);text-shadow:0 0 20px rgba(251,191,36,.5);animation:textAppear .5s .3s ease backwards;z-index:1}@keyframes textAppear{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.mega-celebration{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:60;overflow:hidden}.mega-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#1a0a2e,#4a1a6b,#2d1b4e,#6b1a4a,#1a0a2e);background-size:400% 400%;animation:megaBgShift 4s ease-in-out infinite}@keyframes megaBgShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.mega-fireworks{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.firework-spark{position:absolute;font-size:24px;animation:sparkle 2s ease-in-out infinite}@keyframes sparkle{0%,to{transform:scale(0);opacity:0}50%{transform:scale(1.5);opacity:1}}.mega-showcase{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:2}.mega-showcase-item{position:absolute;display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(0);transition:all .5s cubic-bezier(.34,1.56,.64,1)}.mega-showcase-item.active{opacity:1;transform:scale(1)}.mega-showcase-item.done{opacity:0;transform:scale(.3) translateY(-40px);transition:all .3s ease-in}.mega-showcase-emoji{font-size:100px;filter:drop-shadow(0 0 30px rgba(251,191,36,.6));animation:showcasePulse .7s ease-in-out}.mega-showcase-ring{position:absolute;width:160px;height:160px;border-radius:50%;border:4px solid var(--accent-gold);opacity:0;animation:ringExpand .7s ease-out forwards}.mega-showcase-item.active .mega-showcase-ring{opacity:1}@keyframes showcasePulse{0%{transform:scale(0) rotate(-20deg)}50%{transform:scale(1.3) rotate(10deg)}to{transform:scale(1) rotate(0)}}@keyframes ringExpand{0%{transform:scale(.5);opacity:0;border-color:var(--accent-gold)}50%{opacity:.8}to{transform:scale(1.8);opacity:0;border-color:var(--accent-pink)}}.mega-showcase-counter{position:absolute;bottom:25%;font-size:28px;font-weight:700;color:var(--accent-gold);text-shadow:0 0 20px rgba(251,191,36,.5)}.mega-circle{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;animation:circleRotate 4s linear infinite}@keyframes circleRotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.mega-emoji{position:absolute;font-size:48px;transform:translate(-50%,-50%);animation:megaEmojiEnter .5s cubic-bezier(.34,1.56,.64,1) forwards,megaEmojiGlow 1.2s ease-in-out infinite;animation-delay:var(--orbit-delay, 0s);filter:drop-shadow(0 0 12px rgba(251,191,36,.5))}.mega-emoji:after{content:"";display:block}.mega-emoji.exit{animation:megaEmojiExit .8s ease-in forwards;animation-delay:var(--orbit-delay, 0s)}@keyframes megaEmojiEnter{0%{transform:translate(-50%,-50%) scale(0);opacity:0}to{transform:translate(-50%,-50%) scale(1);opacity:1}}@keyframes megaEmojiGlow{0%,to{filter:drop-shadow(0 0 12px rgba(251,191,36,.5));transform:translate(-50%,-50%) scale(1)}50%{filter:drop-shadow(0 0 24px rgba(236,72,153,.8));transform:translate(-50%,-50%) scale(1.15)}}@keyframes megaEmojiExit{0%{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-50%) scale(2.5)}}.mega-center-text{text-align:center;z-index:3;animation:megaTextEnter .8s cubic-bezier(.34,1.56,.64,1) backwards}.mega-center-text.exit{animation:megaTextExit .8s ease-in forwards}@keyframes megaTextEnter{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}@keyframes megaTextExit{0%{transform:scale(1);opacity:1}to{transform:scale(.5);opacity:0}}.mega-crown{font-size:64px;animation:crownBounce 1s ease-in-out infinite}@keyframes crownBounce{0%,to{transform:translateY(0) rotate(-5deg)}50%{transform:translateY(-10px) rotate(5deg)}}.mega-name{font-size:40px;font-weight:800;background:linear-gradient(135deg,var(--accent-gold),var(--accent-pink),var(--accent-purple));background-size:200% 200%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:nameShimmer 2s ease-in-out infinite;margin-top:8px}@keyframes nameShimmer{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.mega-subtitle{font-size:26px;color:var(--accent-gold);font-weight:600;margin-top:4px;text-shadow:0 0 16px rgba(251,191,36,.4)}.mega-confetti{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:1}.confetti-piece{position:absolute;top:-10px;width:8px;height:14px;background:var(--confetti-color, #ffd93d);border-radius:2px;animation:confettiFall 3s ease-in infinite}@keyframes confettiFall{0%{transform:translateY(-10px) translate(0) rotate(0);opacity:1}to{transform:translateY(110vh) translate(var(--confetti-drift, 20px)) rotate(720deg);opacity:.3}}.mega-stars{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.mega-star{position:absolute;animation:starTwinkle 2s ease-in-out infinite}@keyframes starTwinkle{0%,to{opacity:0;transform:scale(.5) rotate(0)}50%{opacity:1;transform:scale(1) rotate(180deg)}}.settings-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000b3;z-index:200;display:flex;align-items:center;justify-content:center;padding:24px;animation:fadeIn .2s ease}.settings-modal{width:100%;max-width:360px;background:var(--bg-secondary);border-radius:24px;padding:24px;box-shadow:0 20px 60px #00000080;animation:modalSlideUp .3s cubic-bezier(.34,1.56,.64,1)}@keyframes modalSlideUp{0%{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}.settings-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.settings-header h2{font-size:20px;font-weight:700}.settings-close{background:#ffffff1a;border:none;border-radius:50%;width:36px;height:36px;color:var(--text-primary);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center}.settings-body{display:flex;flex-direction:column;gap:16px}.setting-row{display:flex;flex-direction:column;gap:6px}.setting-row label{font-size:14px;color:var(--text-secondary);font-weight:500}.setting-input{background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:12px;padding:10px 14px;color:var(--text-primary);font-size:16px;outline:none;transition:border-color .2s}.setting-input:focus{border-color:var(--accent-purple)}.setting-range{width:100%;height:8px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#ffffff26;border-radius:4px;outline:none}.setting-range::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:24px;height:24px;border-radius:50%;background:var(--accent-purple);cursor:pointer;box-shadow:0 2px 8px #8b5cf666}.settings-actions{display:flex;flex-direction:column;gap:10px;margin-top:20px}.btn{padding:14px;border:none;border-radius:14px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s;-webkit-tap-highlight-color:transparent}.btn:active{transform:scale(.97)}.btn-restart{background:linear-gradient(135deg,var(--accent-purple),var(--accent-blue));color:#fff}.btn-reset{background:#ffffff14;color:var(--text-secondary)}.btn-diag{background:#fbbf2426;color:var(--accent-gold);border:1px solid rgba(251,191,36,.3);margin-top:8px}.btn-diag:disabled{opacity:.5}.diag-status{font-size:12px;color:var(--text-secondary);text-align:center;padding:4px;word-break:break-all}
