:root{--primary:#ff6b9d;--primary-light:#ffb3c6;--secondary:#7c5cff;--bg-gradient:linear-gradient(135deg, #fff5f8 0%, #f0e6ff 100%);--card-bg:#fff;--text-main:#333;--text-secondary:#666;--shadow:0 4px 20px #ff6b9d26}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-gradient);min-height:100vh;color:var(--text-main);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.app{flex-direction:column;max-width:480px;height:100vh;margin:0 auto;display:flex;overflow:hidden}.app-header{z-index:100;background:#fff;justify-content:space-between;align-items:center;padding:12px 16px;display:flex;position:sticky;top:0;box-shadow:0 2px 10px #0000000d}.back-btn{color:var(--primary);cursor:pointer;background:0 0;border:none;font-size:14px}.eq-info{color:var(--secondary);align-items:center;gap:8px;font-size:14px;font-weight:600;display:flex}.exp-bar-small{background:#eee;border-radius:3px;width:60px;height:6px;overflow:hidden}.exp-fill{background:linear-gradient(90deg, var(--primary), var(--secondary));border-radius:3px;height:100%;transition:width .3s}.app-main{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.menu-screen{flex-direction:column;flex:1;padding:20px;display:flex;overflow-y:auto}.menu-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.menu-header h1{background:linear-gradient(135deg, var(--primary), var(--secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:24px}.user-phone{color:var(--text-secondary);font-size:13px}.section-title{color:var(--text-main);margin-bottom:12px;font-size:16px}.character-list{margin-bottom:20px}.character-cards{flex-direction:column;gap:12px;display:flex}.character-card{cursor:pointer;background:#fff;border-radius:16px;flex-direction:row;align-items:center;gap:14px;padding:14px;transition:transform .15s,box-shadow .15s;display:flex;position:relative;box-shadow:0 2px 12px #0000000f}.character-card:active{transform:scale(.98)}.character-card:hover{box-shadow:0 4px 20px #ff6b9d33}.card-avatar{object-fit:cover;border:2px solid var(--primary-light);border-radius:50%;flex-shrink:0;width:64px;height:64px}.card-info{flex-direction:column;flex:1;gap:3px;display:flex}.card-name{color:var(--text-main);font-size:16px;font-weight:600}.card-tags{color:var(--text-secondary);font-size:12px}.card-affection{color:var(--primary);font-size:12px}.card-delete{color:#bbb;cursor:pointer;background:#0000000d;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:18px;transition:all .2s;display:flex}.card-delete:hover{color:#fff;background:#ff4d4f}.empty-text{text-align:center;color:#bbb;padding:30px 0;font-size:14px}.loading-text{text-align:center;color:#bbb;padding:20px 0}.modal-overlay{z-index:999;background:#0006;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-card{text-align:center;background:#fff;border-radius:20px;width:100%;max-width:320px;padding:28px 24px 20px}.modal-title{color:var(--text-main);margin-bottom:8px;font-size:16px;font-weight:600}.modal-desc{color:var(--text-secondary);margin-bottom:24px;font-size:13px}.modal-actions{gap:12px;display:flex}.modal-btn{cursor:pointer;border:none;border-radius:12px;flex:1;padding:12px;font-size:15px;transition:opacity .2s}.modal-btn.cancel{color:var(--text-secondary);background:#f0f0f0}.modal-btn.confirm{color:#fff;background:#ff4d4f}.logout-btn{color:#bbb;cursor:pointer;text-align:center;background:0 0;border:none;margin-top:12px;padding:10px;font-size:13px}.subtitle{color:var(--text-secondary);margin-bottom:32px;font-size:16px}.eq-display{box-shadow:var(--shadow);background:#fff;border-radius:16px;margin-bottom:40px;padding:16px 24px}.exp-bar{background:#eee;border-radius:4px;width:200px;height:8px;margin-top:8px;overflow:hidden}.start-btn{background:linear-gradient(135deg, var(--primary), #ff8fab);color:#fff;cursor:pointer;border:none;border-radius:30px;padding:16px 48px;font-size:18px;transition:transform .2s,box-shadow .2s;box-shadow:0 8px 25px #ff6b9d66}.start-btn:hover{transform:translateY(-2px);box-shadow:0 12px 30px #ff6b9d80}.quiz-container{flex-direction:column;flex:1;padding:24px 20px;display:flex}.quiz-header{text-align:center;margin-bottom:24px}.quiz-header h2{color:var(--primary);margin-bottom:16px;font-size:24px}.step-indicator{justify-content:center;gap:16px;display:flex}.step-indicator span{color:#999;background:#eee;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;transition:all .3s;display:flex}.step-indicator span.active{background:var(--primary);color:#fff}.swipe-container{flex-direction:column;flex:1;justify-content:center;align-items:center;display:flex}.swipe-hint{color:var(--text-secondary);margin-bottom:16px;font-size:14px}.swipe-card-wrapper{cursor:grab;-webkit-user-select:none;user-select:none;width:280px;height:360px}.swipe-card-wrapper:active{cursor:grabbing}.swipe-card{width:100%;height:100%;transition:transform .1s ease-out,opacity .2s}.quiz-card{background:#fff;border-radius:24px;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;padding:24px;display:flex;box-shadow:0 8px 40px #0000001a}.quiz-card .card-avatar{background:linear-gradient(135deg, var(--primary-light), var(--secondary));object-fit:cover;border-radius:50%;width:140px;height:140px;margin-bottom:16px}.card-badge{background:var(--secondary);color:#fff;border-radius:20px;margin-bottom:8px;padding:6px 16px;font-size:18px;font-weight:700}.character-card h3{color:var(--text-main);margin-bottom:16px;font-size:24px}.card-traits{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.trait-tag{background:var(--bg-gradient);color:var(--secondary);border-radius:16px;padding:6px 12px;font-size:12px}.zodiac-card .zodiac-image{width:100px;height:100px;margin-bottom:16px}.zodiac-date{color:var(--text-secondary);margin-bottom:16px;font-size:14px}.swipe-dots{justify-content:center;gap:8px;margin-top:24px;display:flex}.dot{background:#ddd;border-radius:50%;width:8px;height:8px;transition:all .3s}.dot.active{background:var(--primary);border-radius:4px;width:24px}.personality-input{flex-direction:column;flex:1;padding:20px;display:flex}.personality-input textarea{border:2px solid var(--primary-light);resize:none;border-radius:16px;outline:none;flex:1;width:100%;padding:16px;font-family:inherit;font-size:16px}.personality-input textarea:focus{border-color:var(--primary)}.char-count{text-align:right;color:var(--text-secondary);margin-top:8px;font-size:12px}.complete-message{color:var(--primary);flex:1;justify-content:center;align-items:center;font-size:24px;display:flex}.next-btn{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;cursor:pointer;border:none;border-radius:30px;margin-top:24px;padding:16px 32px;font-size:18px;transition:transform .2s,opacity .2s}.next-btn:disabled{opacity:.5;cursor:not-allowed}.next-btn:not(:disabled):hover{transform:translateY(-2px)}.dialogue-container{flex-direction:column;flex:1;height:100%;display:flex;overflow:hidden}.character-top-bar{background:linear-gradient(#fff 0%,#faf5f8 100%);flex-shrink:0;align-items:center;gap:16px;padding:12px 16px;display:flex;box-shadow:0 2px 10px #0000000d}.character-top-avatar{border:2px solid var(--primary-light);border-radius:50%;flex-shrink:0;width:56px;height:56px;overflow:hidden}.character-top-avatar img{object-fit:cover;width:100%;height:100%}.character-meta h3{color:var(--text-main);margin-bottom:2px;font-size:17px}.character-meta .character-tags{color:var(--text-secondary);margin-bottom:6px;font-size:12px}.character-stats{gap:12px;font-size:13px;display:flex}.character-stats span{color:var(--text-secondary)}.character-avatar{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;border-radius:50%;justify-content:center;align-items:center;width:50px;height:50px;font-size:20px;font-weight:700;display:flex;overflow:hidden}.character-avatar img{object-fit:cover;width:100%;height:100%}.character-info h3{font-size:16px}.character-info p{color:var(--text-secondary);font-size:12px}.character-status{gap:16px;margin-left:auto;display:flex}.status-item{align-items:center;gap:4px;font-size:14px;display:flex}.chat-area{background:#f8f9fa;flex-direction:column;flex:1;gap:12px;min-height:0;padding:16px;display:flex;overflow-y:auto}.welcome-message{text-align:center;color:var(--text-secondary);padding:40px 20px}.welcome-message .hint{opacity:.7;margin-top:8px;font-size:14px}.message .avatar{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;display:flex;overflow:hidden}.message .bubble{background:#fff;border-radius:16px;padding:12px 16px;line-height:1.5;box-shadow:0 2px 8px #0000000d}.message.user .bubble{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff}.typing-indicator{gap:4px;padding:12px 16px;display:flex}.typing-indicator span{background:#ccc;border-radius:50%;width:8px;height:8px;animation:1.4s infinite typing}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-8px)}}.choices-area{background:#fff;border-top:1px solid #eee;flex-shrink:0;padding:12px 16px}.choice-btn{background:var(--bg-gradient);border:2px solid var(--primary-light);cursor:pointer;text-align:left;border-radius:12px;padding:12px 16px;font-size:14px;transition:all .2s}.choice-btn:hover{background:var(--primary-light);border-color:var(--primary);color:#fff}.input-area{background:#fff;flex-shrink:0;gap:12px;padding:12px 16px;display:flex;box-shadow:0 -2px 10px #0000000d}.login-container{background:var(--bg-gradient);flex:1;justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{background:#fff;border-radius:24px;width:100%;max-width:380px;padding:40px 32px;box-shadow:0 8px 40px #ff6b9d26}.login-header{text-align:center;margin-bottom:36px}.login-header h1{background:linear-gradient(135deg, var(--primary), var(--secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:8px;font-size:28px}.login-header p{color:var(--text-secondary);font-size:14px}.login-tabs{border-bottom:2px solid #f0f0f0;margin-bottom:24px;display:flex}.login-tabs .tab{color:#999;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;margin-bottom:-2px;padding:12px;font-size:15px;transition:all .2s}.login-tabs .tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.login-form{flex-direction:column;gap:16px;display:flex}.login-form .input-group{border:2px solid #e0e0e0;border-radius:12px;align-items:center;transition:border-color .2s;display:flex;overflow:hidden}.login-form .input-group:focus-within{border-color:var(--primary)}.login-form .input-prefix{color:var(--text-main);background:#f8f8f8;border-right:1px solid #e0e0e0;padding:14px 12px;font-size:15px;font-weight:500}.login-form .input-group input{background:0 0;border:none;outline:none;flex:1;padding:14px 16px;font-size:16px}.login-form .code-group .resend-btn{color:var(--primary);cursor:pointer;white-space:nowrap;background:0 0;border:none;margin-right:8px;padding:8px 16px;font-size:13px;font-weight:500}.login-form .code-group .resend-btn:disabled{color:#999;cursor:not-allowed}.login-error{color:#e74c3c;text-align:center;margin:-4px 0;font-size:13px}.login-btn{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;cursor:pointer;border:none;border-radius:12px;width:100%;margin-top:8px;padding:14px;font-size:16px;font-weight:600;transition:opacity .2s,transform .1s}.login-btn:active{transform:scale(.98)}.login-btn:disabled{opacity:.5;cursor:not-allowed}.login-footer{text-align:center;color:#aaa;margin-top:24px;font-size:11px}.gender-card .gender-emoji{margin-bottom:16px;font-size:100px}.confirm-container{flex-direction:column;flex:1;padding:20px;display:flex;overflow-y:auto}.confirm-header{text-align:center;margin-bottom:24px}.confirm-header h2{color:var(--primary);margin-bottom:8px;font-size:24px}.confirm-header .subtitle{color:var(--text-secondary);font-size:14px}.character-showcase{flex-direction:column;align-items:center;gap:24px;display:flex}.avatar-display{width:280px;height:280px;position:relative}.avatar-large{object-fit:cover;opacity:0;border:4px solid #fff;border-radius:50%;width:100%;height:100%;transition:opacity .3s;box-shadow:0 8px 40px #ff6b9d4d}.avatar-large.loaded{opacity:1}.avatar-glow{background:linear-gradient(135deg, var(--primary-light), var(--secondary));z-index:-1;border-radius:50%;animation:2s ease-in-out infinite glow-pulse;position:absolute;inset:-10px}@keyframes glow-pulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:.3;transform:scale(1.05)}}.avatar-loading,.avatar-error{width:100%;height:100%;color:var(--text-secondary);background:#fff;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;display:flex}.avatar-loading p,.avatar-error p{margin-top:12px;font-size:14px}.avatar-error span{font-size:48px}.character-details{text-align:center;width:100%}.character-name{color:var(--text-main);margin-bottom:16px;font-size:28px}.detail-tags{flex-wrap:wrap;justify-content:center;gap:8px;margin-bottom:20px;display:flex}.detail-tag{background:#fff;border-radius:20px;align-items:center;gap:6px;padding:8px 14px;font-size:13px;display:flex;box-shadow:0 2px 8px #0000000d}.detail-tag .tag-icon{font-size:14px}.detail-tag .tag-text{color:var(--secondary);font-weight:600}.detail-tag .tag-desc{color:var(--text-secondary);font-size:12px}.detail-tag.mbti{border-left:3px solid var(--primary)}.detail-tag.zodiac{border-left:3px solid var(--secondary)}.detail-tag.gender{border-left:3px solid #4ecdc4}.personality-section{background:#fff;border-radius:16px;padding:16px;box-shadow:0 2px 12px #0000000d}.personality-section h4{color:var(--text-secondary);margin-bottom:8px;font-size:14px}.personality-text{color:var(--text-main);font-size:15px;line-height:1.6}.action-buttons{gap:12px;margin-top:24px;display:flex}.btn-secondary{border:2px solid var(--primary-light);color:var(--text-main);cursor:pointer;background:#fff;border-radius:16px;flex:1;justify-content:center;align-items:center;gap:8px;padding:14px 20px;font-size:14px;transition:all .2s;display:flex}.btn-secondary:hover:not(:disabled){background:var(--primary-light);border-color:var(--primary)}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary.regenerate:hover:not(:disabled){color:#fff;background:var(--secondary);border-color:var(--secondary)}.btn-icon{font-size:16px}.confirm-btn{background:linear-gradient(135deg, var(--primary), #ff4757);color:#fff;cursor:pointer;border:none;border-radius:30px;justify-content:center;align-items:center;gap:10px;width:100%;margin-top:16px;padding:18px 32px;font-size:18px;font-weight:600;transition:all .3s;display:flex;box-shadow:0 4px 20px #ff6b9d66}.confirm-btn:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 8px 30px #ff6b9d80}.confirm-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.hint-text{text-align:center;color:var(--text-secondary);margin-top:16px;font-size:13px}.loading-spinner{border:3px solid #f3f3f3;border-top:3px solid var(--primary);border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.generating{flex-direction:column;align-items:center;gap:16px;padding:40px;display:flex}.generating p{color:var(--text-secondary);font-size:16px}.emotion-bar{background:#fff;border-bottom:1px solid #f0f0f0;align-items:center;gap:12px;padding:12px 16px;display:flex;box-shadow:0 2px 8px #0000000d}.emotion-label{color:var(--text-secondary);white-space:nowrap;font-size:13px}.emotion-options{flex-wrap:wrap;gap:8px;padding:4px 0;display:flex;overflow-x:auto}.emotion-btn{cursor:pointer;background:#f5f5f5;border:2px solid #0000;border-radius:50%;flex-shrink:0;width:40px;height:40px;padding:0;transition:all .2s;overflow:hidden}.emotion-btn:hover{border-color:var(--primary-light);transform:scale(1.1)}.emotion-btn.active{border-color:var(--primary);box-shadow:0 0 0 3px #ff6b9d33}.emotion-icon{object-fit:cover;width:100%;height:100%}.loading-text{color:var(--text-secondary);font-size:13px;font-style:italic}.avatar-expression{object-fit:cover;border-radius:50%;width:100%;height:100%}.message{gap:10px;max-width:80%;display:flex}.message.user{flex-direction:row-reverse;align-self:flex-end}.message.ai{align-self:flex-start}.message .avatar{background:linear-gradient(135deg, var(--primary), var(--secondary));border-radius:50%;flex-shrink:0;width:40px;height:40px;overflow:hidden}.message .avatar img{object-fit:cover;width:100%;height:100%}.message .bubble{white-space:pre-wrap;word-break:break-word;border-radius:18px;padding:12px 16px;font-size:15px;line-height:1.5}.message.user .bubble{background:var(--primary);color:#fff;border-bottom-right-radius:4px}.message.ai .bubble{color:var(--text-primary);background:#fff;border-bottom-left-radius:4px;box-shadow:0 2px 8px #00000014}.message.typing .bubble{align-items:center;gap:4px;display:flex}.message.typing .bubble span{background:#ccc;border-radius:50%;width:8px;height:8px;animation:1.4s ease-in-out infinite typing}.message.typing .bubble span:first-child{animation-delay:0s}.message.typing .bubble span:nth-child(2){animation-delay:.2s}.message.typing .bubble span:nth-child(3){animation-delay:.4s}.choices-area{background:#fff;border-top:1px solid #f0f0f0;padding:16px}.choices-hint{color:var(--text-secondary);text-align:center;margin-bottom:12px;font-size:13px}.choices{flex-direction:column;gap:10px;display:flex}.choice-btn{cursor:pointer;text-align:left;background:#fff;border:2px solid #e0e0e0;border-radius:12px;padding:14px 20px;font-size:15px;transition:all .2s}.choice-btn:hover:not(:disabled){border-color:var(--primary);background:#ff6b9d0d}.choice-btn:disabled{opacity:.6;cursor:not-allowed}.input-area{background:#fff;border-top:1px solid #f0f0f0;gap:10px;padding:16px;display:flex}.input-area input{border:2px solid #e0e0e0;border-radius:24px;outline:none;flex:1;padding:12px 16px;font-size:15px;transition:border-color .2s}.input-area input:focus{border-color:var(--primary)}.input-area button{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:24px;padding:12px 24px;font-size:15px;transition:opacity .2s}.input-area button:disabled{opacity:.5;cursor:not-allowed}.input-area button:hover:not(:disabled){opacity:.9}.tts-toggle{cursor:pointer;background:#f5f5f5;border:2px solid #e0e0e0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;padding:0;font-size:18px;transition:all .2s;display:flex}.tts-toggle.active{border-color:var(--primary);background:var(--primary-light)}.tts-toggle:hover{border-color:var(--primary)}.chat-avatar-display{background:#f8f9fa;flex-direction:column;flex-shrink:0;align-items:center;padding:12px 0 8px;display:flex}.chat-avatar-large{border:3px solid #fff;border-radius:50%;width:280px;height:280px;position:relative;overflow:hidden;box-shadow:0 6px 24px #ff6b9d33}.chat-avatar-large img,.chat-avatar-large video{object-fit:cover;width:100%;height:100%}.chat-avatar-state{color:var(--text-secondary);background:#fffc;border-radius:10px;margin-top:8px;padding:2px 12px;font-size:12px}.welcome-hint{text-align:center;color:var(--text-secondary);padding:8px 0 16px;font-size:14px}.chat-avatar-large{transform-origin:bottom;animation:4s ease-in-out infinite idle-breathe}.chat-avatar-large.speaking{animation:1.2s ease-in-out infinite speaking-nod,2.4s ease-in-out infinite speaking-sway}.chat-avatar-large.listening{animation:2.5s ease-in-out infinite listening-tilt}@keyframes videoFadeIn{0%{opacity:.6}to{opacity:1}}.character-video.expression-transition,.character-image.expression-transition{animation:.3s ease-in-out videoFadeIn}.welcome-message{text-align:center;color:var(--text-secondary);flex-direction:column;flex:1;justify-content:center;align-items:center;display:flex}.welcome-message p{margin:8px 0}.welcome-message .hint{opacity:.7;font-size:13px}.character-avatar-large{border:4px solid #fff;border-radius:50%;flex-shrink:0;width:90px;height:90px;position:relative;overflow:hidden;box-shadow:0 8px 32px #00000026}.character-video,.character-image{object-fit:cover;width:100%;height:100%}.character-state-indicator{color:#fff;white-space:nowrap;background:#0009;border-radius:20px;padding:4px 12px;font-size:12px;position:absolute;bottom:10px;left:50%;transform:translate(-50%)}.character-avatar-small{border-radius:50%;flex-shrink:0;width:40px;height:40px;overflow:hidden}.character-avatar-small img{object-fit:cover;width:100%;height:100%}.expression-transition{transition:opacity .3s,filter .3s,transform .3s}.character-avatar-large{transform-origin:bottom;animation:4s ease-in-out infinite idle-breathe}@keyframes idle-breathe{0%{transform:scale(1)rotate(0)translateY(0)}15%{transform:scale(1.008)rotate(.3deg)translateY(-1px)}30%{transform:scale(1.015)rotate(.5deg)translateY(-2px)}50%{transform:scale(1.02)rotate(0)translateY(-3px)}70%{transform:scale(1.015)rotate(-.5deg)translateY(-2px)}85%{transform:scale(1.008)rotate(-.3deg)translateY(-1px)}to{transform:scale(1)rotate(0)translateY(0)}}.character-avatar-large.speaking{animation:1.2s ease-in-out infinite speaking-nod,2.4s ease-in-out infinite speaking-sway}@keyframes speaking-nod{0%,to{transform:translateY(0)scale(1.01)}25%{transform:translateY(-5px)scale(1.025)}50%{transform:translateY(-2px)scale(1.015)}75%{transform:translateY(-6px)scale(1.02)}}@keyframes speaking-sway{0%,to{transform:rotate(0)}20%{transform:rotate(1.2deg)}40%{transform:rotate(-.8deg)}60%{transform:rotate(1deg)}80%{transform:rotate(-.5deg)}}.character-avatar-large.listening{animation:2.5s ease-in-out infinite listening-tilt}@keyframes listening-tilt{0%,to{transform:rotate(0)scale(1)translateY(0)}30%{transform:rotate(3deg)scale(1.01)translateY(-2px)}60%{transform:rotate(1deg)scale(1.015)translateY(-4px)}80%{transform:rotate(2.5deg)scale(1.01)translateY(-2px)}}.emotion-btn{border-radius:12px;flex-direction:column;align-items:center;gap:2px;width:auto;min-width:48px;height:auto;padding:4px 6px;display:flex}.emotion-btn .emotion-icon{object-fit:cover;border-radius:50%;width:28px;height:28px;animation:3s ease-in-out infinite emoji-float}.emotion-btn.active .emotion-icon{animation:1s ease-in-out infinite emoji-active}@keyframes emoji-float{0%,to{transform:translateY(0)scale(1)}50%{transform:translateY(-1px)scale(1.03)}}@keyframes emoji-active{0%,to{transform:translateY(0)scale(1.05)}50%{transform:translateY(-2px)scale(1.12)}}.emotion-btn .emotion-text{color:var(--text-secondary);font-size:10px}.emotion-btn.active .emotion-text{color:var(--primary);font-weight:600}.emotion-btn .emotion-emoji{font-size:20px}.emotion-btn.emoji-only{border-radius:8px;width:auto;height:auto;padding:6px 10px;font-size:13px}.emotion-btn.emoji-only span{white-space:nowrap}.character-avatar-large.speaking:has(video){animation:none}.character-video{object-fit:cover;border-radius:50%;width:100%;height:100%}
