@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--color-red-400:oklch(70.4% .191 22.216);--color-gray-500:oklch(55.1% .027 264.364);--spacing:.25rem;--text-sm:.875rem;--text-sm--line-height:calc(1.25/.875);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.mt-2{margin-top:calc(var(--spacing)*2)}.flex{display:flex}.h-64{height:calc(var(--spacing)*64)}.w-64{width:calc(var(--spacing)*64)}.w-full{width:100%}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.p-8{padding:calc(var(--spacing)*8)}.px-4{padding-inline:calc(var(--spacing)*4)}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-gray-500{color:var(--color-gray-500)}.text-red-400{color:var(--color-red-400)}.opacity-70{opacity:.7}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}}:root{--pastel-pink:#ffb6c1;--pastel-pink-light:#ffe4e8;--warm-beige:#f5e6d3;--warm-beige-light:#fff8f0;--soft-purple:#e8d4f0;--sky-blue:#b8e0f0;--forest-green:#a8d5ba}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;overflow:hidden}body{background:linear-gradient(180deg,var(--sky-blue)0%,var(--warm-beige-light)50%,var(--forest-green)100%);min-height:100vh;font-family:Pretendard,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;position:relative}.background-scene{z-index:0;background:radial-gradient(at 20% 80%,#a8d5ba99,#0000 50%),radial-gradient(at 80% 70%,#a8d5ba80,#0000 45%),radial-gradient(at 50% 20%,#fffc,#0000 60%),linear-gradient(#b8e0f0,#fff8f0 40%,#a8d5ba);position:fixed;inset:0}.clouds{z-index:1;width:100%;height:30%;position:absolute;top:0;overflow:hidden}.cloud{filter:blur(2px);background:#ffffffe6;border-radius:50%;animation:20s ease-in-out infinite float-cloud;position:absolute}.cloud:before,.cloud:after{content:"";background:inherit;border-radius:50%;position:absolute}.cloud-1{width:120px;height:50px;animation-duration:25s;top:10%;left:-10%}.cloud-1:before{width:60px;height:60px;top:-30px;left:20px}.cloud-1:after{width:80px;height:50px;top:-20px;left:50px}.cloud-2{width:100px;height:40px;animation-duration:30s;animation-delay:-5s;top:5%;left:30%}.cloud-2:before{width:50px;height:50px;top:-25px;left:15px}.cloud-2:after{width:60px;height:40px;top:-15px;left:40px}.cloud-3{width:80px;height:35px;animation-duration:22s;animation-delay:-10s;top:15%;left:70%}.cloud-3:before{width:40px;height:40px;top:-20px;left:10px}.cloud-3:after{width:50px;height:30px;top:-10px;left:35px}@keyframes float-cloud{0%{transform:translate(0)}to{transform:translate(calc(100vw + 150px))}}.grass{z-index:1;background:linear-gradient(#0000,#78b48266 30%,#64a06e99);height:15%;position:absolute;bottom:0;left:0;right:0}.app-container{z-index:10;height:100dvh;padding:2rem 1rem 1rem;padding-bottom:env(safe-area-inset-bottom,1rem);flex-direction:column;align-items:center;display:flex;position:relative}.speech-bubble-container{justify-content:center;width:100%;min-height:60px;margin-top:3rem;padding:0 1rem;display:flex}.speech-bubble{border:3px solid var(--pastel-pink);background:#fffffff2;border-radius:24px;max-width:90%;min-height:50px;padding:1.25rem 1.5rem;animation:.4s ease-out bubble-appear;position:relative;box-shadow:0 8px 32px #ffb6c14d,0 2px 8px #0000001a}.speech-bubble:after{content:"";border:12px solid #0000;border-top-color:var(--pastel-pink);position:absolute;bottom:-20px;left:50%;transform:translate(-50%)}.speech-bubble p{color:#5a4a42;text-align:center;font-size:1.1rem;font-weight:500;line-height:1.7}@keyframes bubble-appear{0%{opacity:0;transform:scale(.8)translateY(-10px)}to{opacity:1;transform:scale(1)translateY(0)}}.bottom-controls{flex-direction:column;align-items:center;gap:.75rem;width:100%;max-width:400px;padding:0 1rem;display:flex}.character-container{flex:1;justify-content:center;align-items:center;min-height:0;padding:.5rem;display:flex}.character-image{object-fit:contain;filter:drop-shadow(0 10px 30px #00000026);max-width:90vw;max-height:45vh;animation:3s ease-in-out infinite character-idle}.character-image.listening{animation:.5s ease-in-out infinite character-bounce}.character-image.processing{animation:1s ease-in-out infinite character-think}.character-image.speaking{animation:.3s ease-in-out infinite character-speak}.character-image.sleep{filter:drop-shadow(0 10px 30px #0000001a)brightness(.9);animation:2s ease-in-out infinite character-sleep}@keyframes character-idle{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes character-bounce{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes character-think{0%,to{transform:rotate(-2deg)}50%{transform:rotate(2deg)}}@keyframes character-speak{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}@keyframes character-sleep{0%,to{transform:translateY(0)rotate(-1deg)}50%{transform:translateY(5px)rotate(1deg)}}.mic-button-container{margin-bottom:0;position:relative}.mic-button{background:linear-gradient(145deg,var(--pastel-pink),#ff9aab);cursor:pointer;z-index:10;border:none;border-radius:50%;justify-content:center;align-items:center;width:70px;height:70px;transition:all .3s;display:flex;position:relative;box-shadow:0 8px 25px #ff9aab80,0 4px 10px #0000001a,inset 0 2px 10px #fff6}.mic-button:hover{transform:scale(1.08);box-shadow:0 12px 35px #ff9aab99,0 6px 15px #00000026,inset 0 2px 10px #fff6}.mic-button:active{transform:scale(.95)}.mic-button.listening{background:linear-gradient(145deg,#ff6b8a,#ff4d6d);animation:1.5s ease-in-out infinite pulse-glow}.mic-button svg{fill:#fff;filter:drop-shadow(0 2px 4px #0003);width:32px;height:32px}@keyframes pulse-glow{0%,to{box-shadow:0 8px 25px #ff4d6d80,0 4px 10px #0000001a,0 0 #ff4d6d66}50%{box-shadow:0 12px 35px #ff4d6db3,0 6px 15px #00000026,0 0 0 15px #ff4d6d00}}.ripple{pointer-events:none;background:#ffb6c166;border-radius:50%;animation:1.5s ease-out forwards ripple-expand;position:absolute}@keyframes ripple-expand{0%{opacity:.6;width:70px;height:70px;transform:translate(-50%,-50%)scale(1)}to{opacity:0;width:100px;height:100px;transform:translate(-50%,-50%)scale(4)}}.status-text{text-align:center;color:#7a6a62;opacity:.9;margin-top:.75rem;font-size:1rem;font-weight:500}.sleep-overlay{z-index:5;pointer-events:none;background:#1e283c4d;animation:1s ease-out fade-in;position:fixed;inset:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.text-input-form{flex:1;align-items:center;gap:.5rem;display:flex}.text-input{border:3px solid var(--pastel-pink);color:#5a4a42;background:#fffffff2;border-radius:25px;outline:none;flex:1;padding:.875rem 1.25rem;font-size:1rem;transition:all .3s;box-shadow:0 4px 15px #ffb6c133}.text-input::placeholder{color:#b8a8a0}.text-input:focus{border-color:#ff9aab;box-shadow:0 4px 20px #ff9aab4d,0 0 0 4px #ffb6c133}.text-input:disabled{cursor:not-allowed;background:#fff9}.send-button{background:linear-gradient(145deg,var(--pastel-pink),#ff9aab);cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;transition:all .3s;display:flex;box-shadow:0 4px 15px #ff9aab66}.send-button:hover:not(:disabled){transform:scale(1.1);box-shadow:0 6px 20px #ff9aab80}.send-button:disabled{opacity:.5;cursor:not-allowed}.send-button svg{fill:#fff;width:22px;height:22px;transform:translate(2px)}@media(max-width:640px){.speech-bubble{max-width:95%;padding:1rem 1.5rem}.speech-bubble p{font-size:1.1rem}.character-image{max-height:35vh}.mic-button{width:90px;height:90px}.mic-button svg{width:42px;height:42px}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
