:root{--font-kid:"M PLUS Rounded 1c", "Zen Maru Gothic", system-ui, sans-serif;--focus-ring:#9b7bd8}*{box-sizing:border-box}html,body{font-family:var(--font-kid);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;padding:0}html{height:100%}body{background:radial-gradient(circle at 20% 20%,#fff1f4 0%,#0000 50%),radial-gradient(circle at 80% 70%,#e8f5f1 0%,#0000 50%),#fafaf6;justify-content:center;align-items:center;min-height:100dvh;padding:24px;display:flex}@media (width<=480px){body{padding:0}}#root{justify-content:center;align-items:center;width:100%;display:flex}button{font-family:var(--font-kid)}:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px;border-radius:4px}button:focus-visible,[role=button]:focus-visible,a:focus-visible,input:focus-visible{outline:2px solid var(--focus-ring);outline-offset:3px;box-shadow:0 0 0 2px #fff}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.001ms!important;animation-duration:.001ms!important;animation-iteration-count:1!important}}@keyframes breath{0%,to{transform:scale(1)translateY(0)}50%{transform:scale(1.03)translateY(-3px)}}@keyframes wobble{0%,to{transform:rotate(-2deg)scale(1.02)}50%{transform:rotate(2deg)scale(1.04)}}.char-breath{animation:3s ease-in-out infinite breath}.char-wobble{animation:.6s ease-in-out infinite wobble}@keyframes pulse-out{0%{opacity:.85;transform:translate(-50%,-50%)scale(.6)}to{opacity:0;transform:translate(-50%,-50%)scale(1.6)}}.pulse-ring{opacity:0;pointer-events:none;border:3px solid;border-radius:50%;width:200px;height:200px;animation:2.4s ease-out infinite pulse-out;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)scale(.6)}.pulse-1{animation-delay:0s}.pulse-2{animation-delay:.8s}.pulse-3{animation-delay:1.6s}.pulse-talk{animation-duration:1.2s}@keyframes kpa-spin{to{transform:rotate(360deg)}}@keyframes sparkle{0%,to{opacity:.2;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}.sparkle{animation:2.4s ease-in-out infinite sparkle}@keyframes mic-glow{0%,to{box-shadow:0 6px 24px #ff6b9d66,0 2px 4px #0000001a}50%{box-shadow:0 6px 32px #ff6b9db3,0 2px 4px #0000001a}}.mic-btn{transition:transform .15s;animation:2.2s ease-in-out infinite mic-glow}.mic-btn:hover{transform:scale(1.05)}.mic-btn:active{transform:scale(.95)}.app-shell{background:#fff;flex-direction:column;width:100%;max-width:540px;height:100dvh;margin:0 auto;display:flex;position:relative;overflow:hidden}@media (width>=481px){.app-shell{height:min(100dvh - 48px,920px)}}.screen-bg,.screen-body{flex-direction:column;flex:1;min-height:0;display:flex;position:relative;overflow:hidden}.screen-body.scrollable{overflow-y:auto}.top-bar{padding:max(env(safe-area-inset-top,0px), 16px) 16px 12px;z-index:5;flex-shrink:0;justify-content:space-between;align-items:center;display:flex}
