.error-boundary{display:flex;align-items:center;justify-content:center;height:100vh;height:100dvh;background:#fff3e0}.error-card{text-align:center;padding:32px}.error-emoji{font-size:56px;display:block;margin-bottom:12px}.error-card h2{font-size:20px;color:#e65100;margin:0 0 8px}.error-card p{font-size:14px;color:#888;margin:0 0 16px}.error-card button{padding:10px 28px;border:none;border-radius:20px;background:#ff9800;color:#fff;font-size:15px;cursor:pointer}.login-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;padding:1rem;background:linear-gradient(135deg,#e8f5e9,#fff9e6)}.login-card{width:100%;max-width:320px;text-align:center}.login-title{font-size:1.8rem;margin:0 0 .25rem;color:#333}.login-subtitle{color:#888;margin:0 0 2rem;font-size:.95rem}.login-form{display:flex;flex-direction:column;gap:.75rem}.pin-label{display:flex;flex-direction:column;gap:.4rem;font-size:.9rem;color:#666}.pin-input{padding:.75rem;font-size:1.5rem;text-align:center;letter-spacing:.5rem;border:2px solid #ddd;border-radius:12px;outline:none;transition:border-color .2s}.pin-input:focus{border-color:#4caf50}.login-error{color:#e53935;font-size:.85rem;margin:0}.pin-submit{padding:.75rem;font-size:1rem;background:#4caf50;color:#fff;border:none;border-radius:12px;cursor:pointer;font-weight:600}.pin-submit:disabled{opacity:.5;cursor:not-allowed}.login-hint{margin-top:1.5rem;color:#aaa;font-size:.8rem}.login-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;color:#888;font-size:.9rem}.child-selector{display:flex;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;padding:1rem}.child-selector-card{width:100%;max-width:360px;text-align:center}.child-selector-card h2{margin:0 0 .5rem;font-size:1.3rem}.child-empty{color:#999;margin:1rem 0}.child-list{display:flex;flex-direction:column;gap:.5rem;margin:1rem 0}.child-card{display:flex;align-items:center;gap:.6rem;padding:.75rem 1rem;border:1px solid #e0e0e0;border-radius:12px;background:#fff;cursor:pointer;width:100%;text-align:left}.child-avatar{font-size:1.8rem}.child-name{font-weight:600;flex:1}.child-age{color:#888;font-size:.85rem}.child-sessions{color:#4caf50;font-size:.8rem}.child-create-form{display:flex;flex-direction:column;gap:.6rem;padding:.75rem;background:#fafafa;border-radius:12px;margin:.5rem 0}.child-name-input{padding:.5rem;font-size:1rem;border:1px solid #ddd;border-radius:8px}.child-create-row select{padding:.4rem;border-radius:8px;border:1px solid #ddd}.avatar-picker{display:flex;flex-wrap:wrap;gap:.3rem}.avatar-option{font-size:1.5rem;padding:.5rem .65rem;border:2px solid transparent;border-radius:8px;background:none;cursor:pointer}.avatar-option.selected{border-color:#4caf50;background:#e8f5e9}.child-create-actions{display:flex;gap:.5rem;justify-content:flex-end}.child-create-actions button{padding:.6rem 1.2rem;border-radius:8px;border:1px solid #ddd;cursor:pointer;font-size:.95rem}.child-create-actions button[type=submit]{background:#4caf50;color:#fff;border-color:#4caf50}.child-create-actions button[type=submit]:disabled{opacity:.5}.child-error{color:#e53935;font-size:.8rem;margin:0}.add-child-btn{width:100%;padding:.75rem;border:2px dashed #ccc;border-radius:12px;background:none;color:#888;font-size:.95rem;cursor:pointer}.logout-link{margin-top:1.5rem;background:none;border:none;color:#aaa;font-size:.85rem;cursor:pointer;text-decoration:underline}.scene-bg{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;background-size:cover;background-position:center}.scene-bg-free-talk{background:linear-gradient(135deg,#fff8e1cc,#ffe0b2cc),url(/bg/free-talk-2.jpg) center/cover}.scene-bg-classroom-greeting{background:linear-gradient(135deg,#ffe0b2cc,#fff3e0cc),url(/bg/classroom-greeting-2.jpg) center/cover}.scene-bg-invitation-play{background:linear-gradient(135deg,#ede7f6cc,#e8eaf6cc),url(/bg/invitation-play-2.jpg) center/cover}.scene-bg-lele-puppy{background:linear-gradient(135deg,#c8e6c9cc,#a5d6a7cc),url(/bg/lele-puppy-2.jpg) center/cover}.scene-bg-park-sharing{background:linear-gradient(135deg,#c8e6c9cc,#fff9c4cc),url(/bg/park-sharing-2.jpg) center/cover}.scene-bg-birthday-celebration{background:linear-gradient(135deg,#f8bbd0cc,#f48fb1cc),url(/bg/birthday-celebration-2.jpg) center/cover}.scene-bg-apology-sorry{background:linear-gradient(135deg,#bbdefbcc,#90caf9cc),url(/bg/apology-sorry-2.jpg) center/cover}.scene-bg-playground-conflict{background:linear-gradient(135deg,#b3e5fccc,#e8f5e9cc),url(/bg/playground-conflict-2.jpg) center/cover}.scene-bg-pet-adventure{background:linear-gradient(135deg,#fff3e0cc,#ffe0b2cc,#ffcc80cc),url(/bg/pet-adventure-2.jpg) center/cover}.scene-bg-free-talk-intro{background:linear-gradient(135deg,#fff8e1cc,#ffe0b2cc),url(/bg/free-talk-1.jpg) center/cover}.scene-bg-classroom-greeting-intro{background:linear-gradient(135deg,#ffe0b2cc,#fff3e0cc),url(/bg/classroom-greeting-1.jpg) center/cover}.scene-bg-invitation-play-intro{background:linear-gradient(135deg,#ede7f6cc,#e8eaf6cc),url(/bg/invitation-play-1.jpg) center/cover}.scene-bg-lele-puppy-intro{background:linear-gradient(135deg,#c8e6c9cc,#a5d6a7cc),url(/bg/lele-puppy-1.jpg) center/cover}.scene-bg-park-sharing-intro{background:linear-gradient(135deg,#c8e6c9cc,#fff9c4cc),url(/bg/park-sharing-1.jpg) center/cover}.scene-bg-birthday-celebration-intro{background:linear-gradient(135deg,#f8bbd0cc,#f48fb1cc),url(/bg/birthday-celebration-1.jpg) center/cover}.scene-bg-apology-sorry-intro{background:linear-gradient(135deg,#bbdefbcc,#90caf9cc),url(/bg/apology-sorry-1.jpg) center/cover}.scene-bg-playground-conflict-intro{background:linear-gradient(135deg,#b3e5fccc,#e8f5e9cc),url(/bg/playground-conflict-1.jpg) center/cover}.scene-bg-pet-adventure-intro{background:linear-gradient(135deg,#fff3e0cc,#ffe0b2cc,#ffcc80cc),url(/bg/pet-adventure-1.jpg) center/cover}.scene-entry{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:100;transition:opacity .8s ease-out}.scene-entry.fade-out{opacity:0;pointer-events:none}.npc-character{position:absolute;bottom:22%;left:58%;opacity:0;transform:translateY(30px) scale(1.5);transform-origin:bottom center;transition:all .8s ease-out}.npc-character.visible{opacity:1;transform:translateY(0) scale(1.5)}.npc-head{width:36px;height:40px;background:#ffcc80;border-radius:50%;position:relative;margin:0 auto}.npc-hair{position:absolute;top:-3px;left:-2px;right:-2px;height:18px;background:#4e342e;border-radius:50% 50% 0 0}.npc-eye{position:absolute;width:5px;height:6px;background:#333;border-radius:50%;top:16px}.npc-eye.left{left:9px}.npc-eye.right{right:9px}.npc-mouth{position:absolute;bottom:9px;left:50%;transform:translate(-50%);width:8px;height:4px;border-bottom:2px solid #e57373;border-radius:0 0 50% 50%}.npc-body{width:28px;height:30px;background:#42a5f5;border-radius:6px 6px 2px 2px;margin:-4px auto 0;position:relative}.npc-arm{position:absolute;top:6px;width:7px;height:22px;background:#ffcc80;border-radius:4px}.npc-arm.left-arm{left:-7px;transform-origin:top center}.npc-arm.right-arm{right:-7px;transform-origin:top center}.npc-character.visible .npc-arm.right-arm{animation:npc-wave 2.5s ease-in-out infinite}.npc-character.visible .npc-arm.left-arm{animation:npc-wave 2.5s ease-in-out infinite .6s}.npc-character.greeting .npc-arm.right-arm{animation:npc-wave-big .9s ease-in-out infinite}.npc-character.greeting .npc-arm.left-arm{animation:npc-wave-big .9s ease-in-out infinite .3s}.npc-character.ready{animation:npc-ready-bounce .6s ease-in-out infinite}@keyframes npc-wave{0%,to{transform:rotate(0)}50%{transform:rotate(-8deg)}}@keyframes npc-wave-big{0%,to{transform:rotate(0) translateY(0)}30%{transform:rotate(-20deg) translateY(-4px)}60%{transform:rotate(12deg) translateY(-2px)}}@keyframes npc-ready-bounce{0%,to{transform:translateY(0) scale(1.5)}50%{transform:translateY(-8px) scale(1.5)}}.npc-legs{display:flex;justify-content:center;gap:6px}.npc-leg{width:8px;height:26px;background:#5d4037;border-radius:0 0 4px 4px}.narration-overlay{position:absolute;top:6%;right:4%;z-index:10;max-width:260px}.narration-card{background:#ffffffe0;border-radius:14px;padding:12px 16px;text-align:left;box-shadow:0 4px 20px #0000001a;animation:fade-in-up .5s ease-out}.narration-card.speaking{box-shadow:0 4px 20px #5c6bc026}.narration-speaker{display:flex;align-items:center;gap:4px;margin-bottom:4px}.speaker-icon{font-size:16px}.speaker-wave{color:#5c6bc0;font-weight:700;font-size:12px;animation:pulse-wave .6s ease-in-out infinite}@keyframes pulse-wave{0%,to{opacity:.3}50%{opacity:1}}.narration-label{font-size:11px;color:#9e9e9e;letter-spacing:1.5px;margin-bottom:2px}.narration-text{font-size:13px;line-height:1.6;color:#37474f;margin:0}.skip-btn{margin-top:6px;padding:6px 10px;border:none;background:none;color:#9e9e9e;font-size:12px;cursor:pointer;text-decoration:underline}.continue-bar{position:absolute;bottom:8%;left:50%;transform:translate(-50%);z-index:20;animation:fade-in-up .4s ease-out}.continue-btn-bottom{padding:14px 48px;border:none;border-radius:28px;background:#5c6bc0;color:#fff;font-size:18px;font-weight:700;cursor:pointer;box-shadow:0 6px 24px #5c6bc059;transition:transform .2s,background .2s,box-shadow .2s;letter-spacing:.05em}.continue-btn-bottom:active{transform:scale(.95);background:#3f51b5;box-shadow:0 4px 16px #5c6bc040}@keyframes fade-in-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.npc-container{display:flex;flex-direction:column;align-items:center;gap:2px;padding:10px 0 0;position:relative}.npc-img{width:136px;height:auto;display:block;mix-blend-mode:multiply;border-radius:8px;opacity:.95;margin-top:0}.npc-name-label{font-size:12px;font-weight:700;color:#37474f;margin:-5px 0 0}.npc-emoji-overlay{position:absolute;top:20%;left:calc(50% + 27px);transform:translate(-50%,-50%) scale(0);z-index:20;pointer-events:none;opacity:0;display:flex;flex-direction:row;align-items:center;gap:4px;transition:transform .4s cubic-bezier(.34,1.56,.64,1),opacity .3s ease;background:transparent}.npc-emoji-overlay.show{transform:translate(-50%,-50%) scale(1);opacity:1}.overlay-emoji{font-size:16px;line-height:1;filter:drop-shadow(0 2px 3px rgba(0,0,0,.12))}.overlay-label{font-size:10px;font-weight:600;color:#555;white-space:nowrap;text-shadow:0 1px 2px rgba(255,255,255,.8)}.npc-img-wrapper{transition:opacity .3s ease}.npc-img{transition:transform .3s ease,opacity .25s ease}.expr-talk .npc-img{animation:body-talk .45s ease-in-out infinite}.expr-talk .arm-right{animation:gesture-talk .7s ease-in-out infinite;transform-origin:130px 115px}@keyframes body-talk{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}@keyframes gesture-talk{0%,to{transform:rotate(0) translateY(0)}50%{transform:rotate(-5deg) translateY(-3px)}}.expr-smile .npc-img{animation:body-smile 1s ease-in-out}.expr-happy .npc-img{animation:body-happy .45s ease-in-out 2}.expr-happy .arm-right{animation:gesture-talk .4s ease-in-out 3;transform-origin:130px 115px}@keyframes body-happy{0%,to{transform:translateY(0)}30%{transform:translateY(-6px)}60%{transform:translateY(-3px)}}.expr-think .npc-img{animation:body-think 2.5s ease-in-out infinite}@keyframes body-think{0%,to{transform:rotate(0)}50%{transform:rotate(1.5deg)}}.expr-confused .npc-img{animation:body-confused 2s ease-in-out infinite}@keyframes body-confused{0%,to{transform:rotate(0)}50%{transform:rotate(-1.5deg)}}.expr-wave .arm-right{animation:gesture-wave .6s ease-in-out 3;transform-origin:130px 115px}@keyframes gesture-wave{0%,to{transform:rotate(0)}25%{transform:rotate(-25deg) translateY(-8px)}75%{transform:rotate(15deg) translateY(-2px)}}.expr-high_five .arm-right{animation:gesture-high-five .5s ease-in-out 2;transform-origin:130px 115px}@keyframes gesture-high-five{0%{transform:rotate(0) translateY(0)}50%{transform:rotate(-35deg) translateY(-12px)}to{transform:rotate(0) translateY(0)}}.expr-walk_closer .npc-img{animation:lean-in .8s ease-in-out 2}@keyframes lean-in{0%,to{transform:scale(1) translateY(0)}50%{transform:scale(1.06) translateY(-4px)}}.expr-lean_in .npc-img{animation:lean-in-subtle 1.5s ease-in-out infinite}@keyframes lean-in-subtle{0%,to{transform:translate(0) translateY(0)}50%{transform:translate(-3px) translateY(-2px)}}.pet-character{position:relative;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;-webkit-user-select:none;user-select:none;transition:transform .2s}.pet-character:active{transform:scale(.95)}.pet-character.pet-dragging{opacity:.7;transform:scale(1.1)}.pet-idle{animation:pet-breathe 3s ease-in-out infinite}.pet-happy{animation:pet-bounce .5s ease-in-out infinite}.pet-playing{animation:pet-bounce .35s ease-in-out infinite}.pet-hungry{animation:pet-shiver .3s ease-in-out infinite}.pet-tired{animation:pet-breathe 5s ease-in-out infinite;opacity:.8}.pet-sad{animation:pet-breathe 4s ease-in-out infinite}.pet-sick{animation:pet-slow-pulse 2s ease-in-out infinite;filter:saturate(.5)}.pet-tail{transform-origin:75px 60px;animation:tail-wag .4s ease-in-out infinite}.pet-idle .pet-tail{animation-duration:1.5s}.pet-tired .pet-tail,.pet-sick .pet-tail{animation:none}.pet-sad .pet-tail{animation-duration:3s}.pet-mood-bubble{position:absolute;top:-12px;right:-8px;font-size:1.2rem;animation:bubble-float 1.5s ease-in-out infinite;pointer-events:none}@keyframes pet-breathe{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-3px) scale(1.03)}}@keyframes pet-bounce{0%,to{transform:translateY(0)}30%{transform:translateY(-8px)}50%{transform:translateY(0)}70%{transform:translateY(-4px)}}@keyframes pet-shiver{0%,to{transform:translate(0)}25%{transform:translate(-2px)}75%{transform:translate(2px)}}@keyframes pet-slow-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes tail-wag{0%,to{transform:rotate(-5deg)}50%{transform:rotate(15deg)}}@keyframes bubble-float{0%,to{transform:translateY(0);opacity:1}50%{transform:translateY(-4px);opacity:.7}}.voice-input-container{display:flex;flex-direction:column;align-items:center;gap:8px}.record-button{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;max-width:280px;padding:16px 32px;border:none;border-radius:48px;background:#5c6bc0;color:#fff;font-size:17px;font-weight:600;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.record-button:active:not(.disabled){transform:scale(.96)}.record-button.recording{background:#e53935;animation:pulse-record 1.5s ease-in-out infinite}@keyframes pulse-record{0%,to{box-shadow:0 0 #e5393566}50%{box-shadow:0 0 0 12px #e5393500}}.record-button.disabled{background:#bdbdbd;cursor:not-allowed}.record-icon{font-size:22px}.record-label{font-size:16px}.recording-hint{font-size:13px;color:#9e9e9e;animation:fade-in .3s ease}.mic-error{font-size:13px;color:#e53935;text-align:center;padding:4px 12px;background:#e5393514;border-radius:8px}.asr-error{font-size:13px;color:#f57c00;text-align:center;padding:6px 14px;background:#f57c0014;border-radius:8px;animation:fade-in .3s ease}.text-input-fallback{display:flex;align-items:center;gap:8px;width:100%;max-width:360px;animation:fade-in .3s ease}.text-input{flex:1;padding:12px 16px;border:2px solid #5c6bc0;border-radius:24px;font-size:16px;outline:none;transition:border-color .2s;-webkit-appearance:none}.text-input:focus{border-color:#3f51b5}.text-submit-btn{padding:12px 20px;border:none;border-radius:24px;background:#5c6bc0;color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:background .2s;white-space:nowrap;-webkit-tap-highlight-color:transparent}.text-submit-btn:active{background:#303f9f}.text-submit-btn:disabled{background:#bdbdbd;cursor:not-allowed}.voice-text-divider{display:flex;align-items:center;gap:8px;width:100%;max-width:320px;margin:4px 0 2px}.voice-text-divider:before,.voice-text-divider:after{content:"";flex:1;height:1px;background:#0000001a}.voice-text-divider span{font-size:12px;color:#9e9e9e}.camera-button{width:44px;height:44px;min-width:44px;border-radius:50%;border:2px solid #e0e0e0;background:#fff;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.camera-button:active:not(:disabled){background:#f5f5f5}.camera-button:disabled{opacity:.4;cursor:not-allowed}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.phonecall-container{display:flex;flex-direction:column;align-items:center;gap:16px;padding:12px 0}.phonecall-status-indicator{display:flex;flex-direction:column;align-items:center;gap:6px;transition:transform .3s ease}.phonecall-status-icon{font-size:44px;line-height:1;display:block}.phonecall-status-text{font-size:17px;font-weight:700;color:#37474f;letter-spacing:.02em}.status-npc_talking .phonecall-status-icon{animation:npc-breathe 2s ease-in-out infinite}@keyframes npc-breathe{0%,to{transform:scale(1);opacity:.7}50%{transform:scale(1.12);opacity:1}}.status-npc_talking .phonecall-status-text{color:#607d8b}.status-listening .phonecall-status-icon{animation:listen-bounce .7s ease-in-out infinite;font-size:52px}@keyframes listen-bounce{0%,to{transform:translateY(0) scale(1)}30%{transform:translateY(-8px) scale(1.1)}50%{transform:translateY(0) scale(1.05)}}.status-listening .phonecall-status-text{color:#ff7043}.status-processing .phonecall-status-icon{animation:proc-spin .8s linear infinite}@keyframes proc-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.status-processing .phonecall-status-text{color:#90a4ae}.phonecall-hangup{padding:14px 40px;border:none;border-radius:32px;background:#e53935;color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:background .2s,transform .15s}.phonecall-hangup:active{transform:scale(.96);background:#c62828}.phonecall-ended{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 0;color:#78909c}.phonecall-ended-icon{font-size:36px}.phonecall-ended p{font-size:14px;margin:0}.dialogue-prompt{display:flex;flex-direction:column;align-items:center;gap:8px;animation:fade-in-up .3s ease-out}@keyframes fade-in-up{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.prompt-label{font-size:13px;color:#78909c}.prompt-options{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.prompt-option{padding:10px 18px;border:1.5px solid #5c6bc0;border-radius:24px;background:#fff;color:#5c6bc0;font-size:15px;cursor:pointer;transition:all .2s ease;white-space:nowrap}.prompt-option:hover:not(:disabled){background:#5c6bc0;color:#fff}.prompt-option:disabled{opacity:.4;cursor:not-allowed}.visual-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:visible;z-index:50}.ve-block{position:absolute;bottom:10%;left:25%;width:100px;height:100px;border-radius:14px;box-shadow:0 4px 20px #0000004d;opacity:1}.ve-block.ve-appear{animation:blockPop .6s cubic-bezier(.34,1.56,.64,1) forwards}@keyframes blockPop{0%{transform:translateY(80px) scale(0) rotate(-10deg);opacity:0}50%{transform:translateY(-15px) scale(1.15) rotate(3deg);opacity:1}to{transform:translateY(0) scale(1) rotate(0);opacity:1}}.ve-sparkle{position:absolute;top:25%;left:50%;transform:translate(-50%,-50%)}.ve-sparkle.ve-burst .sparkle-dot{display:inline-block;width:16px;height:16px;border-radius:50%;background:#ffd54f;margin:0 6px;animation:sparkleBurst .8s ease-out forwards;opacity:0}@keyframes sparkleBurst{0%{transform:scale(0) translateY(0);opacity:0}40%{transform:scale(2) translateY(-30px);opacity:1}to{transform:scale(.5) translateY(-60px);opacity:0}}.ve-emoji-float{position:absolute;top:55%;font-size:4rem;animation:floatUp 2s ease-out forwards}@keyframes floatUp{0%{transform:translateY(0) scale(.3);opacity:0}30%{transform:translateY(-50px) scale(1.1);opacity:1}to{transform:translateY(-150px) scale(.5);opacity:0}}.ve-dino{position:absolute;top:15%;font-size:5rem;opacity:.35}.ve-dino.ve-float{animation:dinoFloat 3.5s linear forwards}@keyframes dinoFloat{0%{left:-10%}to{left:110%}}.ve-puzzle{position:absolute;top:30%;left:55%;font-size:4rem}.ve-puzzle.ve-appear{animation:puzzleAppear .6s ease-out forwards}@keyframes puzzleAppear{0%{transform:scale(0) rotate(-30deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}.ve-toy{position:absolute;top:45%;font-size:4rem}.ve-toy.ve-bounce{animation:toyBounce .8s ease-out forwards}@keyframes toyBounce{0%{transform:translateY(0)}30%{transform:translateY(-60px)}50%{transform:translateY(-15px)}70%{transform:translateY(-40px)}to{transform:translateY(0)}}.ve-cake{position:absolute;top:25%;left:50%;font-size:5rem;transform:translate(-50%,-50%)}.ve-cake.ve-sparkle{animation:cakeGlow 1s ease-in-out 3}@keyframes cakeGlow{0%,to{filter:brightness(1);transform:translate(-50%,-50%) scale(1)}50%{filter:brightness(1.4);transform:translate(-50%,-50%) scale(1.15)}}.ve-tower{position:absolute;bottom:0;left:30%;font-size:4rem}.ve-tower.ve-build{animation:towerRise .8s ease-out forwards}@keyframes towerRise{0%{transform:scaleY(0);opacity:0}to{transform:scaleY(1);opacity:1}}.ve-collapse{position:absolute;bottom:10%;left:30%;font-size:4rem}.ve-collapse.ve-shake{animation:collapseShake .6s ease-in-out}@keyframes collapseShake{0%,to{transform:translate(0)}25%{transform:translate(-12px)}50%{transform:translate(12px)}75%{transform:translate(-6px)}}.ve-watercolor{position:absolute;top:35%;left:50%;width:140px;height:70px;border-radius:50%;background:radial-gradient(ellipse,#bbdefb 0%,transparent 70%);transform:translate(-50%,-50%)}.ve-watercolor.ve-fade{animation:waterFade 2s ease-out forwards}@keyframes waterFade{0%{transform:translate(-50%,-50%) scale(.3);opacity:.6}to{transform:translate(-50%,-50%) scale(1.5);opacity:0}}.ve-swing{position:absolute;top:25%;left:45%;font-size:4rem}.ve-swing.ve-swing{animation:swingAnim 1s ease-in-out 2;transform-origin:top center}@keyframes swingAnim{0%,to{transform:rotate(0)}25%{transform:rotate(18deg)}75%{transform:rotate(-18deg)}}.dialogue-view{display:flex;flex-direction:column;height:100vh;height:100dvh;overflow:hidden;position:relative}.dialogue-stop-btn{position:absolute;top:12px;right:12px;z-index:200;width:44px;height:44px;border-radius:50%;border:1px solid rgba(0,0,0,.15);background:#ffffffd9;font-size:20px;color:#888;cursor:pointer;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.dialogue-stop-btn:active{background:#0000000d}.stop-confirm-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:300;background:#0000004d;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.stop-confirm-card{background:#fff;border-radius:16px;padding:24px;text-align:center;max-width:280px;box-shadow:0 8px 32px #00000026}.stop-confirm-card p{margin:0 0 16px;font-size:16px;color:#333}.stop-confirm-actions{display:flex;gap:10px;justify-content:center}.stop-confirm-actions button{padding:10px 20px;border-radius:10px;border:1px solid #ddd;background:#fff;font-size:14px;cursor:pointer}.stop-confirm-yes{background:#e53935!important;color:#fff!important;border-color:#e53935!important}.scene-stage{flex:0 0 25%;display:flex;align-items:flex-start;justify-content:center;position:relative;min-height:0}.transcript-area{flex:1;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:16px}.transcript-area::-webkit-scrollbar{width:4px}.transcript-area::-webkit-scrollbar-thumb{background:#0000001f;border-radius:2px}.turn{display:flex;gap:8px;align-items:flex-start;position:relative;animation:turn-in .3s ease-out}@keyframes turn-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.turn-label{font-size:11px;font-weight:600;padding:1px 6px;border-radius:4px;position:absolute;top:-8px;z-index:2}.child-label{right:4px;background:#1a237e1a;color:#1a237e}.npc-label{left:4px;background:#0000000d;color:#78909c}.turn-text{font-size:16px;line-height:1.5;padding:10px 14px;border-radius:16px;max-width:75%}.child-turn .turn-text{background:#bbdefb;color:#1a237e;margin-left:auto;border-bottom-right-radius:4px}.npc-turn .turn-text{background:#fff;color:#37474f;border-bottom-left-radius:4px;box-shadow:0 1px 4px #00000014}.npc-turn.streaming .turn-text{background:#fff9c4}.cursor-blink{animation:blink .6s step-end infinite;color:#5c6bc0}@keyframes blink{50%{opacity:0}}.error-banner{display:flex;align-items:center;gap:8px;margin:0 16px;padding:10px 14px;background:#fff3e0;border:1px solid #ffcc80;border-radius:10px;font-size:14px;color:#e65100;animation:turn-in .3s ease-out}.error-icon{font-size:18px;flex-shrink:0}.error-msg{line-height:1.4}.interaction-bar{flex:0 0 auto;padding:12px 16px;padding-bottom:max(12px,env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:10px;background:#fffc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid rgba(0,0,0,.06)}.persistent-scene-element{position:absolute;bottom:10%;left:38%;font-size:2.5rem;z-index:15;filter:drop-shadow(0 2px 6px rgba(0,0,0,.15));animation:sceneIdle 3s ease-in-out infinite}.persistent-map{bottom:18%;left:18%;font-size:2.2rem}.persistent-puppy-adventure{bottom:8%;left:42%}@keyframes sceneIdle{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.persistent-scene-element.anim-appear{animation:scenePop .6s cubic-bezier(.34,1.56,.64,1)}.persistent-scene-element.anim-jump{animation:sceneJump .5s ease-out}.persistent-scene-element.anim-bounce{animation:sceneBounce .8s ease-out}.persistent-scene-element.anim-sparkle{animation:sceneGlow 1s ease-in-out 3}.persistent-scene-element.anim-swing{animation:sceneSwing 1.2s ease-in-out 2}.persistent-scene-element.anim-fade{animation:sceneFade 2s ease-out}.persistent-scene-element.anim-wag_tail{animation:sceneShake .2s ease-in-out 8}.persistent-scene-element.anim-sit{animation:sceneSink .4s ease-out forwards}.persistent-scene-element.anim-roll{animation:sceneRoll .8s ease-in-out}.persistent-scene-element.anim-build{animation:sceneRise .7s ease-out}.persistent-scene-element.anim-shake{animation:sceneShake .4s ease-in-out 3}@keyframes scenePop{0%{transform:scale(0) rotate(-20deg)}60%{transform:scale(1.3) rotate(5deg)}to{transform:scale(1) rotate(0)}}@keyframes sceneJump{0%{transform:translateY(0)scaleY(1)}40%{transform:translateY(-50px)scaleY(.7)}60%{transform:translateY(-50px)scaleY(1.3)}to{transform:translateY(0)scaleY(1)}}@keyframes sceneBounce{0%{transform:translateY(0)}30%{transform:translateY(-60px)}50%{transform:translateY(-10px)}70%{transform:translateY(-35px)}to{transform:translateY(0)}}@keyframes sceneGlow{0%,to{filter:drop-shadow(0 4px 12px rgba(0,0,0,.2))}50%{filter:drop-shadow(0 4px 30px rgba(255,200,0,.8))}}@keyframes sceneSwing{0%,to{transform:rotate(0)}25%{transform:rotate(20deg)}75%{transform:rotate(-20deg)}}@keyframes sceneFade{0%{opacity:.6;transform:scale(.6)}to{opacity:0;transform:scale(2)}}@keyframes sceneShake{0%,to{transform:rotate(0)}25%{transform:rotate(15deg)}75%{transform:rotate(-15deg)}}@keyframes sceneSink{0%{transform:translateY(0)}to{transform:translateY(10px)scaleY(.8)}}@keyframes sceneRoll{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes sceneRise{0%{transform:scaleY(0)}to{transform:scaleY(1)}}.scene-ending{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:200;opacity:0;transition:opacity .6s ease}.scene-ending.visible{opacity:1}.scene-ending{background:linear-gradient(135deg,#e8eaf6,#f3e5f5,#e8f5e9)}.ending-content{display:flex;flex-direction:column;align-items:center;gap:12px;padding:40px 32px;background:#ffffffe6;border-radius:24px;box-shadow:0 8px 40px #0000001a;max-width:340px;width:90%;animation:ending-pop .5s ease-out}@keyframes ending-pop{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.ending-stars{display:flex;gap:8px;margin-bottom:4px}.ending-star{font-size:36px;opacity:0;transform:scale(0);transition:none}.ending-stars.show .ending-star.active{animation:starPop .4s cubic-bezier(.34,1.56,.64,1) forwards}@keyframes starPop{0%{opacity:0;transform:scale(0) rotate(-30deg)}to{opacity:1;transform:scale(1) rotate(0)}}.ending-star:not(.active){opacity:.2;transform:scale(.7);filter:grayscale(1)}.ending-stars.show .ending-star:not(.active){opacity:.2;transform:scale(.7);transition:opacity .3s,transform .3s}.ending-title{font-size:24px;font-weight:700;color:#37474f}.ending-message{font-size:15px;color:#607d8b;text-align:center;line-height:1.5}.ending-stats{display:flex;gap:32px;margin:8px 0}.stat{display:flex;flex-direction:column;align-items:center;gap:2px}.stat-value{font-size:28px;font-weight:700;color:#5c6bc0}.stat-label{font-size:12px;color:#90a4ae}.ending-actions{display:flex;gap:12px;margin-top:8px}.btn-primary{padding:12px 32px;border:none;border-radius:24px;background:#5c6bc0;color:#fff;font-size:16px;font-weight:600;cursor:pointer}.btn-secondary{padding:12px 24px;border:1.5px solid #bdbdbd;border-radius:24px;background:transparent;color:#757575;font-size:16px;cursor:pointer}.btn-primary:active,.btn-secondary:active{transform:scale(.96)}.feedback-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px;animation:feedback-fade-in .25s ease}@keyframes feedback-fade-in{0%{opacity:0}to{opacity:1}}.feedback-modal{background:#fff;border-radius:20px;box-shadow:0 8px 40px #0000002e;width:100%;max-width:440px;max-height:85vh;overflow-y:auto;animation:feedback-slide-up .3s ease}@keyframes feedback-slide-up{0%{transform:translateY(24px);opacity:0}to{transform:translateY(0);opacity:1}}.feedback-intro{padding:32px 24px 24px;text-align:center}.feedback-intro-title{font-size:19px;font-weight:700;color:#37474f;margin:0 0 8px;line-height:1.4}.feedback-badge{display:inline-block;background:#e8f5e9;color:#388e3c;font-size:13px;font-weight:600;padding:3px 12px;border-radius:12px;margin-bottom:20px}.feedback-intro-greeting{font-size:17px;font-weight:600;color:#37474f;margin-bottom:12px}.feedback-intro-body{text-align:left;color:#546e7a;font-size:14.5px;line-height:1.7;margin-bottom:24px}.feedback-intro-body p{margin:0 0 8px}.feedback-intro-closing{font-weight:500;color:#388e3c}.feedback-intro-actions{display:flex;flex-direction:column;gap:10px;align-items:center}.feedback-btn-primary{width:100%;padding:14px 24px;border:none;border-radius:14px;background:#43a047;color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:background .2s,transform .15s}.feedback-btn-primary:hover{background:#388e3c}.feedback-btn-primary:active{transform:scale(.98)}.feedback-btn-primary:disabled{background:#c8e6c9;color:#81c784;cursor:not-allowed}.feedback-btn-ghost{padding:8px 20px;border:none;background:transparent;color:#90a4ae;font-size:14px;cursor:pointer}.feedback-btn-ghost:hover{color:#607d8b}.feedback-form{padding:0}.feedback-form-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 0;position:sticky;top:0;background:#fff;z-index:1}.feedback-form-header h2{font-size:18px;font-weight:700;color:#37474f;margin:0}.feedback-close{width:44px;height:44px;border:none;border-radius:50%;background:#f5f5f5;color:#78909c;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}.feedback-close:hover{background:#eee;color:#546e7a}.feedback-form-body{padding:20px 24px 24px}.feedback-q{margin-bottom:20px}.feedback-q-title{display:block;font-size:14.5px;font-weight:600;color:#37474f;margin-bottom:10px;line-height:1.5}.feedback-optional{font-weight:400;color:#90a4ae;font-size:12px;margin-left:4px}.feedback-options{display:flex;flex-direction:column;gap:6px}.feedback-radio,.feedback-check{display:flex;align-items:center;gap:10px;padding:10px 14px;border:1.5px solid #e8eaf0;border-radius:12px;cursor:pointer;font-size:14px;color:#455a64;transition:border-color .15s,background .15s}.feedback-radio:hover,.feedback-check:hover{border-color:#a5d6a7;background:#f1f8e9}.feedback-radio:has(input:checked),.feedback-check:has(input:checked){border-color:#66bb6a;background:#e8f5e9}.feedback-radio input,.feedback-check input{accent-color:#43a047;width:16px;height:16px;flex-shrink:0}.feedback-check-other{flex-wrap:wrap;gap:6px 10px}.feedback-other-input{flex:1;min-width:100px;padding:6px 10px;border:1px solid #e0e0e0;border-radius:8px;font-size:13px;outline:none}.feedback-other-input:focus{border-color:#66bb6a}.feedback-text-input{width:100%;padding:10px 14px;border:1.5px solid #e8eaf0;border-radius:12px;font-size:14px;color:#37474f;outline:none;box-sizing:border-box}.feedback-text-input:focus{border-color:#66bb6a}.feedback-textarea{width:100%;padding:10px 14px;border:1.5px solid #e8eaf0;border-radius:12px;font-size:14px;color:#37474f;outline:none;resize:vertical;font-family:inherit;box-sizing:border-box}.feedback-textarea:focus{border-color:#66bb6a}.feedback-form-actions{margin-top:24px;text-align:center}.feedback-form-note{font-size:12px;color:#b0bec5;margin-top:10px}.feedback-thanks{padding:40px 24px;text-align:center}.feedback-thanks-icon{font-size:48px;margin-bottom:16px}.feedback-thanks h2{font-size:20px;font-weight:700;color:#37474f;margin:0 0 12px}.feedback-thanks p{font-size:14.5px;color:#607d8b;margin:0 0 6px;line-height:1.6}.feedback-thanks .feedback-btn-primary{margin-top:24px}.parent-dashboard{max-width:480px;margin:0 auto;padding:20px 16px;min-height:100vh;background:#f5f5f5}.parent-header{display:flex;align-items:center;justify-content:center;position:relative;margin-bottom:20px}.parent-header h1{font-size:22px;font-weight:700;color:#37474f;margin:0}.parent-back-btn{position:absolute;left:0;padding:6px 12px;border:none;background:transparent;color:#5c6bc0;font-size:15px;font-weight:500;cursor:pointer}.weekly-summary{margin-bottom:16px}.weekly-card{background:#e8f5e9;border-radius:12px;padding:14px 16px;border-left:4px solid #4caf50}.weekly-card h3{margin:0 0 8px;font-size:16px;color:#2e7d32}.weekly-stats{display:flex;gap:16px;font-size:14px;color:#555}.progress-overview{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.progress-card,.scores-card{background:#fff;border-radius:16px;padding:20px;box-shadow:0 1px 4px #0000000f}.progress-card h3,.scores-card h3{font-size:14px;color:#90a4ae;margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.progress-stats{display:flex;gap:24px}.pstat{display:flex;flex-direction:column;gap:2px}.pstat-value{font-size:28px;font-weight:700;color:#37474f}.pstat-label{font-size:12px;color:#90a4ae}.trend-improving .pstat-value{color:#43a047}.trend-declining .pstat-value{color:#e53935}.trend-stable .pstat-value{color:#ff8f00}.dimension-scores{display:flex;flex-direction:column;gap:10px}.dim-row{display:flex;align-items:center;gap:10px}.dim-label{width:72px;font-size:13px;color:#546e7a;flex-shrink:0}.dim-bar-bg{flex:1;height:8px;background:#eceff1;border-radius:4px;overflow:hidden}.dim-bar-fill{height:100%;background:linear-gradient(90deg,#5c6bc0,#7c4dff);border-radius:4px;transition:width .6s ease}.dim-value{font-size:13px;font-weight:600;color:#5c6bc0;width:28px;text-align:right}.focus-areas{display:flex;gap:12px;margin-bottom:20px}.focus-card{flex:1;background:#fff;border-radius:16px;padding:16px;box-shadow:0 1px 4px #0000000f}.focus-card h4{font-size:13px;color:#90a4ae;margin-bottom:8px}.tag-list{display:flex;flex-wrap:wrap;gap:6px}.tag{padding:4px 10px;border-radius:12px;font-size:12px;font-weight:500}.tag-strength{background:#e8f5e9;color:#2e7d32}.tag-focus{background:#fff3e0;color:#e65100}.session-history{background:#fff;border-radius:16px;padding:20px;box-shadow:0 1px 4px #0000000f}.session-history h3{font-size:14px;color:#90a4ae;margin-bottom:12px;text-transform:uppercase}.empty-state{font-size:14px;color:#bdbdbd;text-align:center;padding:24px 0}.session-list{list-style:none;display:flex;flex-direction:column;gap:8px}.session-item{display:flex;justify-content:space-between;align-items:center;padding:12px;background:#fafafa;border-radius:12px}.session-info{display:flex;flex-direction:column;gap:2px}.session-scene{font-size:14px;font-weight:600;color:#37474f}.session-date{font-size:12px;color:#90a4ae}.session-meta{display:flex;gap:8px;align-items:center;font-size:12px;color:#78909c}.session-status{padding:2px 8px;border-radius:8px;font-weight:500}.status-completed{background:#e8f5e9;color:#2e7d32}.status-active{background:#e3f2fd;color:#1565c0}.status-abandoned{background:#fce4ec;color:#c62828}.parent-loading,.parent-error{display:flex;align-items:center;justify-content:center;height:100vh;font-size:15px;color:#90a4ae}.session-item.clickable{cursor:pointer}.session-item.clickable:active{background:#f5f5f5}.session-arrow{color:#bdbdbd;font-size:14px}.parent-settings{margin-top:16px;background:#fff;border-radius:16px;padding:16px 20px;box-shadow:0 1px 4px #0000000f}.settings-toggle{width:100%;padding:10px 0;border:none;background:none;font-size:15px;color:#5c6bc0;cursor:pointer;text-align:left;font-weight:500}.feedback-entry-btn{color:#43a047}.start-screen{display:flex;align-items:center;justify-content:center;height:100vh;height:100dvh;background:linear-gradient(135deg,#5c6bc0,#7c4dff,#e8eaf6)}.start-content{display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center;color:#fff;padding:24px 16px;max-height:100vh;max-height:100dvh;overflow-y:auto;width:100%;max-width:420px}.app-title{font-size:48px;font-weight:800;letter-spacing:-1px}.app-subtitle{font-size:20px;font-weight:500;opacity:.9}.app-description{font-size:16px;opacity:.7;margin-bottom:16px}.start-button{padding:16px 48px;border:none;border-radius:32px;background:#fff;color:#5c6bc0;font-size:18px;font-weight:700;cursor:pointer;box-shadow:0 4px 20px #00000026;transition:transform .2s ease}.start-button:active{transform:scale(.96)}.parent-link{padding:10px 24px;border:1.5px solid rgba(255,255,255,.5);border-radius:24px;background:transparent;color:#fff;font-size:14px;cursor:pointer;margin-top:8px}.scene-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%;max-width:380px}.scene-card-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:14px 10px;border:2px solid rgba(255,255,255,.4);border-radius:16px;background:#ffffff26;color:#fff;font-size:14px;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:background .2s,transform .2s;min-height:90px}.scene-card-btn:active{transform:scale(.97);background:#ffffff40}.scene-emoji{font-size:28px}.scene-name{font-size:15px;font-weight:700;line-height:1.2}.scene-desc{font-size:12px;opacity:.7;line-height:1.2}.mode-card-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:20px 16px;border:2px solid rgba(255,255,255,.4);border-radius:20px;width:100%;max-width:320px;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:background .2s,transform .2s}.mode-card-btn:active{transform:scale(.97)}.mode-card-btn.phone-mode{background:#4caf5040;border-color:#4caf5080}.mode-card-btn.manual-mode{background:#ffffff26}.mode-emoji{font-size:36px}.mode-name{font-size:18px;font-weight:700;color:#fff}.mode-desc{font-size:13px;color:#ffffffb3}.safety-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;height:100vh;height:100dvh;background:#fce4ec;color:#c62828;font-size:18px;padding:32px;text-align:center}
