: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-combined{scroll-behavior:smooth;-webkit-overflow-scrolling:touch;flex:1;padding:0 20px 32px;overflow:hidden auto}.quiz-container{flex-direction:column;flex:1;padding:24px 20px;display:flex}.quiz-progress{z-index:10;background:#ff6b9d26;border-radius:2px;height:3px;margin-bottom:4px;position:sticky;top:0}.quiz-progress-bar{background:linear-gradient(90deg, var(--primary), var(--secondary));border-radius:2px;height:100%;transition:width .5s cubic-bezier(.4,0,.2,1)}.quiz-progress-label{color:#ccc;justify-content:space-around;margin-bottom:20px;font-size:12px;display:flex}.quiz-progress-label span{transition:color .3s}.quiz-progress-label span.done{color:var(--primary);font-weight:600}.quiz-section{margin-bottom:28px}.section-title{text-align:center;color:var(--primary);letter-spacing:1px;margin-bottom:16px;font-size:18px;font-weight:700}.title-deco{color:var(--primary-light);margin:0 6px;font-size:12px;display:inline-block}.title-deco-sub{color:var(--text-secondary);margin-left:4px;font-size:12px;font-weight:400}.gender-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.gender-option{text-align:center;cursor:pointer;background:#fff;border:2px solid #0000;border-radius:20px;padding:24px 12px 20px;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 12px #0000000a}.gender-option:active{transform:scale(.97)}.gender-option.selected{border-color:var(--primary);background:linear-gradient(#fff5f8 0%,#fff 100%);box-shadow:0 4px 20px #ff6b9d33}.gender-icon{border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 12px;transition:transform .3s;display:flex}.gender-option.selected .gender-icon{transform:scale(1.1)}.gender-icon svg{width:36px;height:36px}.female-icon{color:#e91e63;background:linear-gradient(135deg,#fce4ec,#f8bbd0)}.male-icon{color:#1976d2;background:linear-gradient(135deg,#e3f2fd,#bbdefb)}.gender-label{color:var(--text-main);margin-bottom:6px;font-size:18px;font-weight:700;display:block}.gender-traits{color:var(--text-secondary);letter-spacing:.5px;font-size:11px}.mbti-grid{grid-template-columns:repeat(4,1fr);gap:8px;display:grid}.mbti-chip{background:var(--chip-bg);text-align:center;cursor:pointer;border:2px solid #0000;border-radius:14px;padding:10px 4px;transition:all .25s cubic-bezier(.4,0,.2,1)}.mbti-chip:active{transform:scale(.95)}.mbti-chip.selected{border-color:var(--chip-border);transform:scale(1.02);box-shadow:0 3px 12px #00000014}.mbti-type{color:var(--chip-text);letter-spacing:.5px;margin-bottom:2px;font-size:13px;font-weight:800;display:block}.mbti-name{color:var(--text-secondary);font-size:10px;display:block}.selection-preview{border:1.5px solid;border-radius:14px;align-items:center;gap:8px;margin-top:12px;padding:12px 16px;font-size:14px;animation:.3s ease-out fadeSlideUp;display:flex}.selection-preview strong{font-weight:800}.preview-traits{color:var(--text-secondary);margin-left:auto;font-size:11px}.preview-symbol{font-size:20px}.preview-date{color:var(--text-secondary);font-size:11px}.zodiac-preview{border-color:var(--primary-light);background:linear-gradient(135deg,#fff5f8 0%,#faf0ff 100%)}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.zodiac-grid{grid-template-columns:repeat(4,1fr);gap:8px;display:grid}.zodiac-chip{text-align:center;cursor:pointer;background:#fff;border:2px solid #0000;border-radius:16px;padding:12px 4px;transition:all .25s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 4px #00000008}.zodiac-chip:active{transform:scale(.94)}.zodiac-chip.selected{border-color:var(--primary);background:linear-gradient(#fff5f8 0%,#fff 100%);transform:scale(1.03);box-shadow:0 3px 14px #ff6b9d2e}.zodiac-symbol{margin-bottom:4px;font-size:28px;transition:transform .3s;display:block}.zodiac-chip.selected .zodiac-symbol{transform:scale(1.15)}.zodiac-name{color:var(--text-main);font-size:12px;font-weight:600;display:block}.personality-input{flex-direction:column;display:flex}.personality-input textarea{resize:none;background:#fff;border:2px solid #f0e6ff;border-radius:16px;outline:none;width:100%;height:100px;padding:14px 16px;font-family:inherit;font-size:14px;transition:border-color .3s}.personality-input textarea:focus{border-color:var(--primary)}.char-count{text-align:right;color:var(--text-secondary);margin-top:6px;font-size:11px}.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;position:relative;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-fab{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;cursor:pointer;z-index:20;border:none;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-size:22px;transition:transform .2s,box-shadow .2s;animation:2s ease-in-out infinite fab-pulse;display:flex;position:absolute;bottom:76px;right:16px;box-shadow:0 4px 16px #ff6b9d66}.choices-fab:active{transform:scale(.9)}@keyframes fab-pulse{0%,to{box-shadow:0 4px 16px #ff6b9d66}50%{box-shadow:0 4px 24px #ff6b9d99}}.choices-panel{background:#fff;border-top:1px solid #f0f0f0;flex-shrink:0;padding:12px 16px;animation:.25s ease-out panel-slide-up}.choices-panel-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.choices-panel-header span{color:var(--text-secondary);font-size:13px}.choices-close{color:#999;cursor:pointer;background:#f0f0f0;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:16px;display:flex}@keyframes panel-slide-up{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.choices-area{background:#fff;border-top:1px solid #eee;flex-shrink:0;padding:12px 16px}.choice-btn{color:var(--text-main);cursor:pointer;text-align:left;background:#fff;border:2px solid #e0e0e0;border-radius:12px;padding:12px 16px;font-size:14px;transition:all .2s}.choice-btn:hover{border-color:var(--primary);color:var(--text-main);background:#ff6b9d0d}.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}.submit-btn{margin-top:8px;margin-bottom:16px}.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%}@media (width<=375px){.app{max-width:100%}.login-card{max-width:100%;padding:28px 20px}.menu-screen{padding:16px}.character-card .card-avatar{width:50px;height:50px}.card-name{font-size:14px}.chat-avatar-large{width:200px;height:200px}.character-top-avatar{width:44px;height:44px}.character-meta h3{font-size:15px}.character-stats{gap:8px;font-size:12px}.message .bubble{padding:10px 12px;font-size:14px}.choice-btn{padding:12px 14px;font-size:13px}.input-area{gap:8px;padding:8px 12px}.input-area input{padding:10px 12px;font-size:14px}.input-area button{padding:10px 16px;font-size:13px}.tts-toggle{width:38px;height:38px;font-size:16px}.modal-card{max-width:280px;padding:24px 20px 16px}.start-btn{padding:14px;font-size:16px}.mbti-grid{grid-template-columns:repeat(2,1fr)!important}.zodiac-grid{grid-template-columns:repeat(3,1fr)!important}}@media (width>=376px) and (width<=480px){.app{max-width:100%}.chat-avatar-large{width:240px;height:240px}}@media (width>=481px){.app{border-radius:0;max-width:480px;margin:0 auto;box-shadow:0 0 40px #00000014}body{background:linear-gradient(135deg,#f5f0ff 0%,#fff0f5 100%)}}@media (width>=1024px){.app{border-radius:24px;max-width:420px;height:calc(100vh - 40px);margin:20px auto;box-shadow:0 8px 60px #ff6b9d26}}@media (pointer:coarse){.card-delete{width:44px;height:44px;font-size:20px}.back-btn{min-width:44px;min-height:44px}.choice-btn{min-height:44px}}@supports (padding-bottom:env(safe-area-inset-bottom)){.input-area{padding-bottom:calc(12px + env(safe-area-inset-bottom))}.app-header{padding-top:calc(12px + env(safe-area-inset-top))}}@media (orientation:landscape) and (height<=500px){.chat-avatar-display{padding:4px 0}.chat-avatar-large{width:120px;height:120px}.character-top-bar{padding:6px 16px}}.user-info-row{align-items:center;gap:8px;display:flex}.plan-badge{color:#7a4d00;white-space:nowrap;background:linear-gradient(135deg,gold,#fa0);border-radius:10px;padding:2px 8px;font-size:11px;font-weight:700}.membership-btn{color:#7a4d00;cursor:pointer;background:linear-gradient(135deg,gold 0%,#fa0 100%);border:none;border-radius:14px;width:100%;margin-top:8px;padding:14px 24px;font-size:16px;font-weight:600;transition:all .2s}.membership-btn:hover{transform:translateY(-1px);box-shadow:0 4px 15px #ffaa004d}.membership-page{height:100%;padding:0 16px 32px;overflow-y:auto}.membership-header{z-index:10;background:linear-gradient(135deg,#fff5f8 0%,#f0e6ff 100%);align-items:center;gap:12px;padding:16px 0;display:flex;position:sticky;top:0}.membership-header h2{color:var(--text-main);font-size:20px}.membership-loading{text-align:center;color:var(--text-secondary);padding:60px 0}.membership-status{box-shadow:var(--shadow);background:#fff;border-radius:16px;align-items:center;gap:16px;margin-bottom:20px;padding:20px;display:flex}.status-icon{font-size:36px}.status-info{flex-direction:column;gap:4px;display:flex}.status-label{color:var(--text-main);font-size:18px;font-weight:600}.status-expires{color:var(--text-secondary);font-size:13px}.qr-overlay{z-index:999;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.qr-modal{text-align:center;background:#fff;border-radius:20px;width:90%;max-width:320px;padding:32px 28px}.qr-modal h3{margin-bottom:4px;font-size:18px}.qr-plan{color:var(--primary);margin-bottom:20px;font-size:15px;font-weight:600}.qr-code-wrap{background:#f9f9f9;border-radius:12px;justify-content:center;margin-bottom:16px;padding:16px;display:flex}.qr-tip{color:var(--text-secondary);margin-bottom:8px;font-size:14px}.qr-status{color:var(--primary);margin-bottom:20px;font-size:13px;animation:1.5s ease-in-out infinite qr-pulse}@keyframes qr-pulse{0%,to{opacity:1}50%{opacity:.5}}.qr-cancel{color:#999;cursor:pointer;background:#f0f0f0;border:none;border-radius:8px;padding:10px 24px;font-size:14px}.purchase-success-banner{color:#fff;text-align:center;background:linear-gradient(135deg,#4ade80,#22c55e);border-radius:12px;margin-bottom:16px;padding:12px;font-weight:600}.plan-cards{gap:12px;margin-bottom:24px;display:flex}.plan-card{box-shadow:var(--shadow);text-align:center;background:#fff;border:2px solid #0000;border-radius:16px;flex:1;padding:20px 16px;transition:all .2s;position:relative}.plan-card.active{border-color:var(--primary)}.plan-badge{color:#fff;background:linear-gradient(135deg,#ff6b9d,#ff4081);border-radius:10px;padding:4px 10px;font-size:11px;font-weight:700;position:absolute;top:-8px;right:-8px}.plan-name{color:var(--text-main);margin-bottom:12px;font-size:16px;font-weight:700}.plan-price{margin-bottom:4px}.price-current{color:var(--primary);font-size:28px;font-weight:800}.price-original{color:#ccc;margin-left:6px;font-size:14px;text-decoration:line-through}.plan-duration{color:var(--text-secondary);margin-bottom:16px;font-size:13px}.plan-features{text-align:left;margin:0 0 16px;padding:0;list-style:none}.plan-features li{color:var(--text-secondary);padding:4px 0 4px 18px;font-size:13px;position:relative}.plan-features li:before{content:"✓";color:#4ade80;font-weight:700;position:absolute;left:0}.plan-btn{cursor:pointer;border:none;border-radius:10px;width:100%;padding:10px;font-size:14px;font-weight:600;transition:all .2s}.plan-btn.purchase{background:linear-gradient(135deg, var(--primary), #ff4081);color:#fff}.plan-btn.purchase:hover{transform:translateY(-1px);box-shadow:0 4px 15px #ff6b9d66}.plan-btn.purchase:disabled{opacity:.6;cursor:not-allowed;transform:none}.plan-btn.current{color:#999;cursor:default;background:#f0f0f0}.feature-comparison{box-shadow:var(--shadow);background:#fff;border-radius:16px;padding:20px}.feature-comparison h3{color:var(--text-main);margin-bottom:16px;font-size:16px}.feature-comparison table{border-collapse:collapse;width:100%}.feature-comparison th,.feature-comparison td{text-align:center;border-bottom:1px solid #f0f0f0;padding:10px 8px;font-size:13px}.feature-comparison th{color:var(--text-secondary);font-weight:600}.feature-comparison th:first-child,.feature-comparison td:first-child{text-align:left;font-weight:500}.feature-comparison td{color:var(--text-main)}.upgrade-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.upgrade-card{text-align:center;background:#fff;border-radius:20px;width:100%;max-width:340px;padding:32px 24px;animation:.3s upgradeSlideUp;box-shadow:0 20px 60px #0003}@keyframes upgradeSlideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.upgrade-icon{margin-bottom:16px;font-size:48px}.upgrade-title{color:var(--text-main);margin-bottom:8px;font-size:20px;font-weight:700}.upgrade-desc{color:var(--text-secondary);margin-bottom:24px;font-size:14px;line-height:1.6}.upgrade-actions{flex-direction:column;gap:10px;display:flex}.upgrade-btn{cursor:pointer;border:none;border-radius:12px;width:100%;padding:14px;font-size:16px;font-weight:600;transition:all .2s}.upgrade-btn.primary{color:#7a4d00;background:linear-gradient(135deg,gold 0%,#fa0 100%)}.upgrade-btn.primary:hover{transform:translateY(-1px);box-shadow:0 4px 15px #fa06}.upgrade-btn.secondary{color:var(--text-secondary);background:#f5f5f5}.upgrade-btn.secondary:hover{background:#eee}
