/*! modern-normalize v3.0.1 | MIT License | https://github.com/sindresorhus/modern-normalize */*,:before,:after{box-sizing:border-box}html{font-family:system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji";line-height:1.15;-webkit-text-size-adjust:100%;tab-size:4}body{margin:0}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{border-color:currentcolor}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0}button,[type=button],[type=reset],[type=submit]{-webkit-appearance:button}legend{padding:0}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}body{background:linear-gradient(to bottom right,#f0fdf4,#eff6ff,#faf5ff);margin:0;box-sizing:border-box;background-attachment:fixed;font-family:Helvetica,ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.chat-wrapper{margin:0 auto;max-width:56rem;padding:1rem;height:100vh;height:100dvh;display:flex;flex-direction:column;position:relative;z-index:10}.chat-header{text-align:center;padding:1.5rem 0;border-bottom:1px solid rgba(255,255,255,.2);border-radius:25px;box-shadow:0 1px 3px #0000001a;background:#a2ba60;margin-bottom:20px;font-family:Futura}.chat-title{font-size:35px;font-weight:300;color:#fff;margin-bottom:8px}.chat-subtitle{color:#fff;font-size:14px}video{object-fit:cover;width:100vw;height:100vh;height:100dvh;position:fixed;top:0;left:0;pointer-events:none;z-index:-1}.message-row{display:flex}.message-row.user{justify-content:flex-end}.message-row.assistant{justify-content:flex-start}.message-bubble{max-width:20rem;margin-block:0;padding:10px 15px;border-radius:1rem;box-shadow:#0000 0 0,#0000 0 0,#0000000d 0 1px 2px}.message-bubble.user{background:linear-gradient(135deg,#fff,#fcecdc);box-shadow:0 1px 3px #0000004d;color:#312e28}.message-bubble.assistant{box-shadow:0 1px 3px #0000004d;color:#312e28;background:linear-gradient(135deg,#c3c388,#fff)}.message-text{font-size:14px;line-height:1.625;padding-bottom:5px;display:block;margin-block:0}.emotion-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:.75rem;color:#4b5563}.emotion-icon{width:1rem;height:1rem}.emotion-text{text-transform:capitalize}.message-text{font-size:.875rem;line-height:1.625}.timestamp{font-size:12px;color:#6b7280;margin-top:5px;text-align:right;display:block}.messages-container{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.voice-interface{padding-top:1rem}.voice-controls{display:flex;justify-content:center;align-items:center}.voice-button-container{text-align:center}.voice-button-wrapper{margin-bottom:.75rem}.voice-button{width:4rem;height:4rem;border-radius:50%;margin:0 auto;display:flex;align-items:center;justify-content:center;transition:all .5s;border:none;cursor:pointer}.voice-button:disabled{cursor:not-allowed}.voice-button.connected{background:linear-gradient(to right,#bed875,#85a614);box-shadow:0 10px 15px -3px #0000001a;transform:scale(1.1)}.voice-button.disconnected{background:linear-gradient(to right,#b1c098,#89924f);box-shadow:0 4px 6px -1px #0000001a}.voice-button.connecting{transform:scale(1.2);background:linear-gradient(to right,#bed875,#85a614)}.voice-button.disconnected:hover:not(:disabled){background:linear-gradient(to right,#bed875,#85a614);box-shadow:0 10px 15px -3px #0006}.voice-icon{width:2rem;height:2rem;color:#fff;transition:all .3s}.voice-icon.disconnected{transform:scale(1);color:#ebebeb}.voice-icon.connecting{animation:spin 2s linear infinite}.voice-icon:hover{color:#fff}.voice-status{font-size:.875rem;color:#fff;margin-bottom:.5rem;display:block;margin-top:.5rem;text-shadow:rgba(0,0,0,.1) 1px 0 10px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.text-in{animation:fadeIn .5s ease-in-out}.text-out{animation:fadeOut .5s ease-in-out}
