@import"https://fonts.googleapis.com/css2?family=Nunito:wght@400;500;600;700;800&display=swap";.home-screen{height:100%;display:flex;flex-direction:column;padding:calc(var(--safe-top) + 20px) 24px calc(var(--safe-bottom) + 30px);background:var(--bg-app);position:relative}.home-screen:before{content:"";position:absolute;top:-10%;right:-20%;width:300px;height:300px;background:radial-gradient(circle,rgba(230,92,92,.15) 0%,transparent 70%);filter:blur(40px);z-index:0}.home-header{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;z-index:1}.app-title{font-family:Nunito,sans-serif;font-size:clamp(2.5rem,10vw,3.5rem);font-weight:800;line-height:1.1;color:var(--brand-primary);margin-bottom:8px;letter-spacing:-1px}.app-subtitle{font-size:clamp(1.1rem,5vw,1.5rem);font-weight:300;color:var(--text-primary);opacity:.8;margin-bottom:24px}.app-description{font-size:1rem;color:var(--text-secondary);max-width:280px;line-height:1.6}.personalize-prompt{background:linear-gradient(135deg,#764ba214,#667eea14);border-radius:20px;padding:16px;margin-bottom:24px;display:flex;align-items:center;gap:16px;border:1px solid rgba(118,75,162,.1);z-index:1}.prompt-icon{font-size:1.8rem;background:#fff;width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:14px;box-shadow:0 4px 12px #764ba21a}.prompt-content{flex:1}.prompt-title{font-size:.95rem;font-weight:700;color:#764ba2;margin-bottom:2px}.prompt-text{font-size:.8rem;color:var(--text-secondary);line-height:1.4}.mode-selection{width:100%;display:flex;flex-direction:column;gap:16px;z-index:1}.mode-button.challenge{background:linear-gradient(135deg,#ff4b81,#ff8c52);border:none}.mode-button.challenge .mode-title{color:#fff}.mode-button.challenge .mode-desc{color:#ffffffe6}.mode-button.challenge .mode-icon{background:#fff3}.mode-button.match{background:#fff;border:1px solid #ff4b81}.mode-button.match .mode-title{color:#ff4b81}.mode-button.match .mode-icon{background:#fff0f3}.mode-button{position:relative;background:var(--bg-card);padding:24px;border-radius:24px;display:flex;flex-direction:row;align-items:center;gap:20px;box-shadow:var(--shadow-sm);border:1px solid var(--border-subtle);transition:all .3s var(--ease-smooth);overflow:hidden}.mode-button:active{transform:scale(.98);box-shadow:none}.mode-icon{font-size:2.5rem;background:var(--bg-surface);width:64px;height:64px;display:flex;align-items:center;justify-content:center;border-radius:16px}.mode-info{display:flex;flex-direction:column;align-items:flex-start;text-align:left}.mode-title{font-size:1.2rem;font-weight:700;color:var(--text-primary);margin-bottom:4px}.mode-desc{font-size:.9rem;color:var(--text-secondary)}.home-footer{margin-top:30px;text-align:center}.footer-text{font-size:.8rem;color:var(--text-tertiary);font-weight:500;letter-spacing:1px;text-transform:uppercase}.challenge-dashboard{padding:20px 20px 100px;background:var(--bg-app);min-height:100vh}.dashboard-header{margin-bottom:30px;text-align:center}.dashboard-title{font-size:24px;font-weight:700;color:#1a1a1a;margin-bottom:8px}.dashboard-subtitle{font-size:14px;color:#666}.roadmap{display:flex;flex-direction:column;gap:15px;max-width:500px;margin:0 auto 20px}.day-card{display:flex;align-items:center;background:#fff;padding:20px;border-radius:16px;box-shadow:0 4px 12px #0000000d;cursor:pointer;transition:all .2s ease;border:2px solid transparent;position:relative;overflow:hidden}.day-card.locked{opacity:.6;cursor:not-allowed;filter:grayscale(1)}.day-card.active{border-color:var(--brand-primary);transform:translateY(-2px);box-shadow:0 8px 20px #e65c5c26}.day-card.completed{background:#f0fff4}.day-number{width:40px;height:40px;border-radius:50%;background:#eee;display:flex;align-items:center;justify-content:center;font-weight:700;margin-right:15px;flex-shrink:0}.active .day-number{background:var(--brand-primary);color:#fff}.completed .day-number{background:#48bb78;color:#fff}.day-info{flex-grow:1}.day-title{font-size:16px;font-weight:600;color:#333;margin-bottom:4px}.day-goal{font-size:12px;color:#888}.status-badge{font-size:12px;padding:4px 10px;border-radius:20px;background:#f0f0f0;color:#666}.completed .status-badge{background:#c6f6d5;color:#2f855a}.locked-icon{font-size:20px}.report-unlock-card{margin:30px auto 0;padding:25px;background:linear-gradient(135deg,#e65c5c,#ff9f43);border-radius:20px;color:#fff;text-align:center;box-shadow:0 10px 25px #e65c5c4d;max-width:500px}.unlock-title{font-size:18px;font-weight:700;margin-bottom:10px}.unlock-desc{font-size:13px;opacity:.9;margin-bottom:8px;line-height:1.5}.unlock-price-note{font-size:15px;font-weight:700;opacity:.95;margin-bottom:20px}.unlock-button{background:#fff;color:#e65c5c;border:none;padding:12px 30px;border-radius:30px;font-weight:700;cursor:pointer;transition:transform .2s}.unlock-button:hover{transform:scale(1.05)}.unlock-button.disabled{opacity:.5;cursor:not-allowed}.auth-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-app);padding:20px}.auth-card{background:var(--bg-card);width:100%;max-width:400px;padding:40px;border-radius:24px;box-shadow:var(--shadow-md)}.auth-header{text-align:center;margin-bottom:30px}.auth-logo{font-size:24px;font-weight:800;color:var(--brand-primary);margin-bottom:20px}.auth-header h2{font-size:20px;color:#1a1a1a;margin-bottom:8px}.auth-header p{font-size:14px;color:#666}.auth-form{display:flex;flex-direction:column;gap:20px}.input-group{display:flex;flex-direction:column;gap:8px}.input-group label{font-size:13px;font-weight:600;color:#333}.input-group input{padding:12px 16px;border-radius:12px;border:1px solid #ddd;font-size:15px;transition:border-color .2s}.input-group input:focus{outline:none;border-color:var(--brand-primary)}.auth-button{background:var(--brand-primary);color:#fff;border:none;padding:14px;border-radius:12px;font-size:16px;font-weight:700;cursor:pointer;transition:opacity .2s;margin-top:10px}.auth-button:disabled{opacity:.7;cursor:not-allowed}.auth-message{padding:12px;border-radius:10px;font-size:13px;text-align:center}.auth-message.success{background:#f0fff4;color:#2f855a;border:1px solid #c6f6d5}.auth-message.error{background:#fff5f5;color:#c53030;border:1px solid #fed7d7}.auth-footer{margin-top:25px;text-align:center;font-size:14px;color:#666}.auth-footer span{color:var(--brand-primary);font-weight:600;cursor:pointer}.onboarding-screen{position:fixed;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#e65c5c,#ff9f43);display:flex;align-items:center;justify-content:center;padding:20px;z-index:9999;overflow-y:auto;-webkit-overflow-scrolling:touch}.onboarding-container{background:#fdfbf7;border-radius:24px;padding:40px 32px;max-width:480px;width:100%;box-shadow:0 20px 60px #e65c5c40;display:flex;flex-direction:column;min-height:600px;max-height:90vh;overflow-y:auto;animation:slideUp .4s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.onboarding-progress{display:flex;justify-content:center;gap:8px;margin-bottom:32px}.progress-dot{width:8px;height:8px;border-radius:50%;background:#e0e0e0;transition:all .3s ease}.progress-dot.active{width:24px;background:#e65c5c;border-radius:4px}.progress-dot.completed{background:#e65c5c}.onboarding-content{flex:1;display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:32px}.onboarding-icon{font-size:4rem;margin-bottom:20px;animation:bounce 1s ease-in-out}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.onboarding-title{font-size:1.75rem;font-weight:800;color:#2d3436;margin-bottom:8px;line-height:1.3;letter-spacing:-.5px}.onboarding-subtitle{font-size:.95rem;color:#e65c5c;font-weight:600;margin-bottom:20px;text-transform:uppercase;letter-spacing:1px}.onboarding-description{font-size:1rem;color:#636e72;line-height:1.7;margin-bottom:20px;max-width:400px}.onboarding-highlight{background:linear-gradient(135deg,#e65c5c,#ff9f43);color:#fff;padding:16px 24px;border-radius:12px;font-size:.95rem;font-weight:600;line-height:1.5;margin-bottom:24px;max-width:380px;box-shadow:0 4px 12px #e65c5c4d}.onboarding-features{display:flex;flex-direction:column;gap:12px;width:100%;max-width:360px;margin-top:20px}.feature-item{background:#f4f1ea;padding:12px 16px;border-radius:10px;font-size:.9rem;color:#2d3436;text-align:left;border-left:3px solid #E65C5C;font-weight:500}.onboarding-cta-badge{background:linear-gradient(135deg,#ff9f43,#ffb84d);color:#2d3436;padding:12px 24px;border-radius:20px;font-size:1rem;font-weight:700;margin-top:20px;box-shadow:0 4px 12px #ff9f434d;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);box-shadow:0 4px 12px #ff9f434d}50%{transform:scale(1.05);box-shadow:0 6px 16px #ff9f4366}}.onboarding-actions{display:flex;gap:12px;width:100%}.onboarding-skip{flex:1;padding:14px;border-radius:12px;border:2px solid #E0E0E0;background:transparent;color:#636e72;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.onboarding-skip:hover{border-color:#e65c5c;color:#e65c5c}.onboarding-skip:active{transform:scale(.98)}.onboarding-next{flex:2;padding:14px;border-radius:12px;border:none;background:linear-gradient(135deg,#e65c5c,#ff9f43);color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #e65c5c4d}.onboarding-next:hover{transform:translateY(-2px);box-shadow:0 6px 16px #e65c5c66}.onboarding-next:active{transform:translateY(0);box-shadow:0 2px 8px #e65c5c4d}@media (max-width: 480px){.onboarding-container{padding:32px 24px;min-height:auto;max-height:85vh}.onboarding-icon{font-size:3rem;margin-bottom:16px}.onboarding-title{font-size:1.5rem}.onboarding-subtitle{font-size:.85rem}.onboarding-description{font-size:.95rem}.onboarding-highlight{font-size:.9rem;padding:14px 20px}.feature-item{font-size:.85rem;padding:10px 14px}}@media (max-height: 600px) and (orientation: landscape){.onboarding-container{max-height:95vh;padding:24px 28px}.onboarding-icon{font-size:2.5rem;margin-bottom:12px}.onboarding-title{font-size:1.3rem;margin-bottom:6px}.onboarding-subtitle{font-size:.8rem;margin-bottom:12px}.onboarding-description{font-size:.9rem;margin-bottom:12px}.onboarding-highlight{font-size:.85rem;padding:12px 18px;margin-bottom:16px}.onboarding-features{gap:8px;margin-top:12px}.feature-item{padding:8px 12px;font-size:.8rem}}.tinder-mode{height:100%;display:flex;flex-direction:column;background-color:var(--bg-app);position:relative;overflow:hidden}.match-header{padding:20px;display:flex;align-items:center;gap:15px;z-index:10}.back-icon{background:none;border:none;font-size:24px;cursor:pointer;color:#333}.header-info{display:flex;flex-direction:column}.match-title{font-weight:700;font-size:18px}.match-subtitle{font-size:12px;color:#888}.swipe-container{flex:1;display:flex;align-items:center;justify-content:center;position:relative;margin-top:calc(var(--safe-top) + 10px);max-height:70vh}.character-card{position:absolute;width:min(calc(100% - 40px),400px);height:90%;max-height:560px;background:var(--bg-card);border-radius:32px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden;-webkit-user-select:none;user-select:none;border:1px solid rgba(0,0,0,.02);touch-action:none;will-change:transform,opacity}.card-image-area{flex:1.2;background:var(--bg-surface);display:flex;align-items:center;justify-content:center;position:relative}.character-avatar-placeholder{width:120px;height:120px;background:linear-gradient(135deg,var(--brand-primary) 0%,#ff8e8e 100%);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:4rem;font-weight:800;color:#fff;box-shadow:0 10px 25px #e65c5c4d;transition:transform .3s var(--ease-spring)}.character-card:active .character-avatar-placeholder{transform:scale(1.1)}.card-content-area{flex:1;padding:20px;display:flex;flex-direction:column;background:#fff;overflow-y:auto}.character-name{font-size:clamp(1.4rem,6vw,2rem);font-weight:800;color:var(--text-primary);margin-bottom:4px;letter-spacing:-.5px}.character-meta{font-size:.95rem;color:var(--text-secondary);font-weight:600;margin-bottom:16px;text-transform:uppercase;letter-spacing:.5px}.character-bio{font-size:1rem;color:var(--text-secondary);line-height:1.6;margin-bottom:20px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.tags-container{display:flex;flex-wrap:wrap;gap:8px;margin-top:auto}.tag{background:var(--bg-surface);color:var(--text-primary);padding:6px 12px;border-radius:12px;font-size:.8rem;font-weight:600}.swipe-actions{height:120px;display:flex;justify-content:center;align-items:center;gap:40px;padding-bottom:calc(var(--safe-bottom) + 25px)}.swipe-button{width:70px;height:70px;border-radius:50%;background:#fff;box-shadow:0 10px 25px #00000012;display:flex;align-items:center;justify-content:center;transition:all .4s cubic-bezier(.175,.885,.32,1.275);border:1px solid rgba(0,0,0,.03);cursor:pointer;-webkit-tap-highlight-color:transparent;outline:none}.swipe-button span{transition:transform .2s}.swipe-button:active{transform:scale(.9);box-shadow:0 4px 10px #0000000d}.swipe-button:active span{transform:scale(.8)}.swipe-button.reject{color:#ff5252;font-size:1.6rem}.swipe-button.reject:hover{background:#fff5f5;transform:translateY(-2px);box-shadow:0 15px 30px #ff52521a}.swipe-button.like{color:#00b894;font-size:1.8rem}.swipe-button.like:hover{background:#f0fff4;transform:translateY(-2px);box-shadow:0 15px 30px #00b8941a}.no-more-characters{text-align:center;padding:40px 30px;display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;animation:fadeIn .6s var(--ease-smooth)}.no-more-icon{font-size:4rem;margin-bottom:24px;filter:drop-shadow(0 10px 15px rgba(230,92,92,.2));animation:float 3s ease-in-out infinite}.no-more-title{font-size:1.5rem;font-weight:800;color:var(--text-primary);margin-bottom:16px}.no-more-desc{font-size:.95rem;color:var(--text-secondary);line-height:1.8;margin-bottom:32px}.back-btn{background:var(--brand-primary);color:#fff;border:none;padding:12px 24px;border-radius:12px;font-weight:700;cursor:pointer}@keyframes float{0%{transform:translateY(0)}50%{transform:translateY(-15px)}to{transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.judgment-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .2s}.judgment-modal{background:var(--bg-card);width:100%;max-width:500px;border-top-left-radius:24px;border-top-right-radius:24px;padding:24px;padding-bottom:calc(var(--safe-bottom) + 20px);box-shadow:0 -10px 40px #0000001a;animation:slideUp .3s cubic-bezier(.2,.8,.2,1);display:flex;flex-direction:column;gap:20px;margin:0 auto}@media (min-width: 600px){.judgment-overlay{align-items:center}.judgment-modal{border-radius:24px;padding-bottom:24px;margin:20px;max-height:90vh;overflow-y:auto}}.judgment-header{display:flex;justify-content:space-between;align-items:center}.judgment-header h3{font-size:1.2rem;font-weight:800;color:var(--text-primary)}.close-button{background:var(--bg-surface);width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);font-size:1.2rem}.judgment-content{display:flex;flex-direction:column;gap:16px}.judgment-question{font-size:1.1rem;color:var(--text-primary);line-height:1.4;font-weight:600}.emotion-buttons{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.emotion-button{background:var(--bg-surface);border-radius:16px;padding:12px;display:flex;flex-direction:column;align-items:center;gap:8px;transition:all .2s;border:2px solid transparent}.emotion-button.selected{background:#fff0f0;border-color:var(--brand-primary);color:var(--brand-primary)}.emotion-emoji{font-size:1.5rem}.emotion-label-text{font-size:.75rem;font-weight:700}.judgment-input-section label{font-size:.8rem;font-weight:700;color:var(--text-secondary);margin-bottom:8px;display:block;text-transform:uppercase;letter-spacing:.5px}.judgment-input{width:100%;background:var(--bg-surface);border-radius:16px;padding:16px;font-size:1rem;border:1px solid transparent;transition:all .2s}.judgment-input:focus{background:#fff;border-color:var(--brand-primary);box-shadow:0 0 0 4px #e65c5c1a}.judgment-actions{display:flex;gap:12px;margin-top:10px}.judgment-button{flex:1;padding:16px;border-radius:16px;font-weight:700;font-size:1rem;transition:transform .1s}.judgment-button:active{transform:scale(.98)}.judgment-button.skip{background:var(--bg-surface);color:var(--text-secondary)}.judgment-button.save{background:var(--brand-primary);color:#fff;box-shadow:var(--shadow-md)}.chat-interface{display:flex;flex-direction:column;height:100%;background-color:var(--bg-surface);position:relative;overflow:hidden}.chat-header{background:#ffffffd9;backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);padding:calc(max(var(--safe-top),20px) + 8px) 16px 12px;display:flex;align-items:center;justify-content:center;border-bottom:1px solid rgba(0,0,0,.06);z-index:100;flex-shrink:0;position:sticky;top:0;position:relative}.chat-header .back-button{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:transparent;border-radius:50%;border:none;color:var(--text-primary);font-size:1.4rem;transition:all .2s;cursor:pointer;position:absolute;left:16px;top:50%;transform:translateY(-50%)}.chat-header .header-action-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border-radius:50%;border:none;color:var(--text-primary);font-size:1.2rem;transition:all .2s;cursor:pointer;position:absolute;right:16px;top:50%;transform:translateY(-50%)}.chat-header .header-action-btn:hover,.chat-header .back-button:hover{background:#0000000a}.chat-header .back-button:active{background:#00000014;transform:scale(.95)}.chat-user-profile{display:flex;flex-direction:column;align-items:center;justify-content:center}.chat-name{font-size:1.05rem;font-weight:700;color:var(--text-primary);line-height:1.2}.chat-status{font-size:.72rem;font-weight:600;display:flex;align-items:center;gap:5px;margin-top:2px;transition:color .3s ease}.chat-status:before{content:"";display:block;width:6px;height:6px;background-color:currentColor;border-radius:50%;transition:background-color .3s ease}.chat-status.status-online{color:#00b894}.chat-status.status-online:before{animation:pulse 2s infinite}.chat-status.status-typing{color:#00b894}.chat-status.status-typing:before{animation:pulse 1s infinite}.chat-status.status-away{color:#b2bec3}.chat-status.status-away:before{animation:none;opacity:.6}.chat-status.status-talking{color:#6c5ce7}.chat-status.status-talking:before{animation:pulse .8s infinite;background:#6c5ce7}.chat-status.status-in-scene{color:#fdcb6e}.chat-status.status-in-scene:before{animation:pulse 1.5s infinite;background:#fdcb6e}@keyframes pulse{0%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.chat-messages{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:20px 16px;padding-bottom:calc(20px + env(safe-area-inset-bottom,0px));display:flex;flex-direction:column;gap:16px}.date-divider{text-align:center;font-size:.75rem;color:var(--text-tertiary);font-weight:600;margin:20px 0 12px;text-transform:capitalize;letter-spacing:.5px;position:relative;padding:0 16px}.date-divider:before,.date-divider:after{content:"";position:absolute;top:50%;width:30%;height:1px;background:var(--border-subtle)}.date-divider:before{left:0}.date-divider:after{right:0}.message{max-width:80%;display:flex;flex-direction:column;position:relative}.message-content{padding:12px 18px;border-radius:20px;font-size:1rem;line-height:1.5;box-shadow:var(--shadow-sm);position:relative;word-wrap:break-word}.character-message{align-self:flex-start}.character-message .message-content{background:var(--bg-card);color:var(--text-primary);border-bottom-left-radius:4px}.user-message{align-self:flex-end}.user-message .message-content{background:var(--brand-primary);color:var(--text-on-primary);border-bottom-right-radius:4px;box-shadow:var(--shadow-md)}.message-meta{display:flex;align-items:center;gap:4px;margin-top:4px;padding:0 4px}.message-meta.justify-end{justify-content:flex-end}.message-time{font-size:.7rem;color:var(--text-tertiary)}.read-receipt{font-size:.7rem;font-weight:600;color:var(--text-tertiary)}.read-receipt.read{color:var(--brand-primary)}.environment-message{align-self:center;max-width:90%;margin:20px auto;animation:sceneTransitionIn .8s ease-out}@keyframes sceneTransitionIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}60%{opacity:.7;transform:translateY(5px) scale(1.02)}to{opacity:1;transform:translateY(0) scale(1)}}.environment-content{background:linear-gradient(135deg,#fff8e1cc,#fff3cdcc);border-left:3px solid #ffa726;padding:16px 20px;border-radius:12px;text-align:center;box-shadow:0 2px 8px #ffa72626}.environment-icon{font-size:1.4rem;margin-bottom:8px}.environment-text{font-size:.95rem;line-height:1.6;color:#6d4c00;font-style:italic;white-space:pre-wrap;font-weight:500}.environment-time{margin-top:8px;font-size:.65rem;color:#a97c00;font-style:normal}.narrative-message{align-self:center;max-width:85%;margin:6px auto;animation:narrativeSlideIn .5s ease-out}@keyframes narrativeSlideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.narrative-content{background:linear-gradient(135deg,#e6f0ff99,#dcebff99);border-left:2px solid #9DB4FF;padding:10px 14px;border-radius:10px;display:flex;align-items:flex-start;gap:8px;box-shadow:0 1px 4px #9db4ff1a}.narrative-icon{font-size:.9rem;opacity:.7;flex-shrink:0;margin-top:1px}.narrative-text{font-size:.88rem;line-height:1.5;color:#4a5568;font-style:italic;font-weight:450;flex:1}.system-message{align-self:center;max-width:85%;margin:12px auto}.system-content{background:#0000000a;padding:10px 16px;border-radius:16px;font-size:.85rem;color:var(--text-secondary);text-align:center;line-height:1.4}.typing-bubble{padding:14px 18px;background:var(--bg-card);border-radius:20px 20px 20px 4px;display:inline-flex;gap:4px;width:fit-content;box-shadow:var(--shadow-sm)}.typing-dot{width:8px;height:8px;background:#b2bec3;border-radius:50%;animation:typingBounce 1.4s infinite ease-in-out both}.typing-dot:nth-child(1){animation-delay:-.32s}.typing-dot:nth-child(2){animation-delay:-.16s}.scene-typing-text{font-size:.9rem;color:#6c5ce7;font-style:italic;font-weight:500}@keyframes typingBounce{0%,80%,to{transform:scale(0);opacity:.5}40%{transform:scale(1);opacity:1}}.chat-input-area{background:var(--bg-card);padding:12px 16px calc(var(--safe-bottom) + 12px);border-top:1px solid var(--border-subtle);display:flex;align-items:flex-end;gap:12px;flex-shrink:0;box-shadow:0 -4px 20px #00000005}.input-wrapper{flex:1;background:var(--bg-surface);border-radius:24px;padding:8px 16px;display:flex;align-items:center;min-height:48px;transition:all .2s;border:1px solid transparent}.input-wrapper:focus-within{background:#fff;border-color:var(--brand-primary);box-shadow:0 0 0 3px #e65c5c1a}.chat-input{width:100%;background:transparent;border:none;font-size:1rem;max-height:100px;resize:none;padding:4px 0;line-height:1.4;outline:none}.action-button{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s var(--ease-spring);flex-shrink:0;font-size:1.2rem;border:none;cursor:pointer}.thought-btn{background:#f0f3f4;color:#636e72}.topic-btn{background:#e8f5e9;color:#4caf50}.send-btn{background:var(--brand-primary);color:#fff;opacity:.5;transform:scale(.9)}.send-btn.active{opacity:1;transform:scale(1);box-shadow:var(--shadow-sm)}.character-profile-modal{width:90%!important;max-width:400px!important;max-height:88vh;padding:0!important;overflow:hidden;border-radius:20px!important;display:flex;flex-direction:column;background:#fff!important;box-shadow:0 10px 30px #00000026!important;border:1px solid #E9ECEF;position:relative}.character-profile-modal .close-modal{position:absolute;top:16px;right:16px;background:#f8f9fa;color:#2d3436;width:32px;height:32px;border-radius:50%;border:none;cursor:pointer;z-index:10;display:flex;align-items:center;justify-content:center;font-size:1.2rem;box-shadow:0 2px 8px #00000014;transition:all .2s}.character-profile-modal .close-modal:hover{background:#e9ecef;transform:scale(1.1)}.character-profile-modal .close-modal:active{transform:scale(.95)}.character-full-profile{display:flex;flex-direction:column;overflow-y:auto;-webkit-overflow-scrolling:touch;flex:1}.profile-header-visual{display:none}.profile-main-info{padding:32px 24px 20px;text-align:center;position:relative;z-index:2}.profile-avatar-large{width:100px;height:100px;background:#f8f9fa;color:#2d3436;border:3px solid #E9ECEF;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:3rem;font-weight:800;margin:0 auto 14px;box-shadow:0 4px 12px #00000014}.profile-name{font-size:1.5rem;font-weight:700;color:#2d3436;margin-bottom:6px;letter-spacing:-.3px}.profile-occ{font-size:.8rem;color:#6c757d;font-weight:600;text-transform:uppercase;letter-spacing:.8px;background:#f8f9fa;padding:5px 14px;border-radius:16px;display:inline-block}.profile-details-section{padding:24px;display:flex;flex-direction:column;gap:24px;flex:1}.detail-item{display:flex;flex-direction:column}.detail-item label{font-size:.7rem;font-weight:700;color:#6c757d;text-transform:uppercase;letter-spacing:1.2px;margin-bottom:10px}.profile-bio-text{font-size:1rem;color:#2d3436;line-height:1.65;font-style:normal;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f8f9fa;padding:16px;border-radius:12px;margin:0;border-left:3px solid #2D3436}.profile-tags{display:flex;flex-wrap:wrap;gap:8px}.profile-tag{background:#e9ecef;color:#495057;padding:7px 14px;border-radius:10px;font-size:.85rem;font-weight:600}.profile-meta-row{display:flex;gap:12px}.meta-pill{flex:1;background:#f8f9fa;padding:14px;border-radius:12px;display:flex;flex-direction:column;align-items:center;gap:6px;border:1px solid #E9ECEF}.meta-pill .meta-val{font-size:1rem;font-weight:700;color:#2d3436;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.meta-pill .meta-label{font-size:.65rem;font-weight:600;color:#6c757d;text-transform:uppercase}.modal-actions{padding:16px 24px 20px;background:#fff;border-top:1px solid rgba(0,0,0,.04);flex-shrink:0}.modal-btn.save{width:100%;padding:14px;border-radius:12px;font-size:.95rem;font-weight:600;background:#2d3436;color:#fff;box-shadow:0 2px 8px #0000001f;transition:all .2s;border:none;cursor:pointer}.modal-btn.save:active{transform:scale(.97);box-shadow:0 1px 4px #0000001a}.progress-hint-banner{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:16px;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.hint-content{display:flex;flex-direction:column;gap:8px}.hint-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;opacity:.9}.hint-bars{display:flex;flex-direction:column;gap:6px}.hint-bar{display:flex;align-items:center;gap:8px}.bar-label{font-size:.8rem;font-weight:600;min-width:32px}.bar-track{flex:1;height:8px;background:#fff3;border-radius:4px;overflow:hidden}.bar-fill{height:100%;background:#fff;border-radius:4px;transition:width .5s ease}.hint-tip{font-size:.85rem;margin:4px 0 0;opacity:.95;font-weight:500}.topic-suggestions-panel{background:#fff;border-top:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle);animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.suggestions-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border-subtle);font-size:.9rem;font-weight:600;color:var(--text-secondary)}.suggestions-header button{width:24px;height:24px;border:none;background:transparent;color:var(--text-tertiary);font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.suggestions-header button:hover{background:#0000000d}.suggestions-list{padding:12px;display:flex;flex-direction:column;gap:8px;max-height:200px;overflow-y:auto}.suggestion-item{background:#f8f9fa;border:1px solid #E9ECEF;border-radius:12px;padding:10px 14px;font-size:.9rem;color:var(--text-primary);cursor:pointer;transition:all .2s;text-align:left;font-weight:500}.suggestion-item:hover{background:#e9ecef;border-color:var(--brand-primary);transform:translate(4px)}.suggestion-item:active{transform:scale(.98) translate(4px)}@media (max-width: 360px){.message{max-width:85%}.chat-input-area{padding-left:12px;padding-right:12px}.profile-name{font-size:1.4rem}.profile-details-section{padding:20px;gap:20px}.action-button{width:44px;height:44px}}.scene-status-banner{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:16px;display:flex;justify-content:space-between;align-items:center;animation:slideDown .3s ease-out;border-bottom:1px solid rgba(255,255,255,.2)}.scene-info{display:flex;align-items:center;gap:12px}.scene-icon{font-size:1.5rem}.scene-details{display:flex;flex-direction:column;gap:4px}.scene-name{font-weight:600;font-size:.95rem}.scene-location{font-size:.85rem;opacity:.9}.scene-actions{display:flex;align-items:center;gap:12px}.scene-timer{font-size:.9rem;opacity:.9;transition:all .3s}.scene-timer.urgent{animation:timerPulse 1s infinite;font-weight:700}@keyframes timerPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.1)}}.scene-exit-btn{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:6px 14px;border-radius:20px;font-size:.9rem;cursor:pointer;transition:all .2s}.scene-exit-btn:hover{background:#ffffff4d}.scene-invitation-banner{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;padding:20px;display:flex;justify-content:space-between;align-items:center;animation:slideDown .3s ease-out;border-bottom:1px solid rgba(255,255,255,.2);gap:16px}.invitation-content{display:flex;align-items:flex-start;gap:12px;flex:1}.invitation-icon{font-size:1.8rem;animation:pulse 2s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.invitation-text{display:flex;flex-direction:column;gap:6px}.invitation-title{font-weight:700;font-size:1.05rem}.invitation-desc{font-size:.9rem;opacity:.95;line-height:1.4}.invitation-duration{font-size:.85rem;opacity:.85;margin-top:4px}.invitation-actions{display:flex;flex-direction:column;gap:8px}.invitation-accept-btn{background:#fff;color:#f5576c;border:none;padding:10px 24px;border-radius:24px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.invitation-accept-btn:hover{transform:scale(1.05);box-shadow:0 4px 12px #00000026}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.scene-urgency-banner{background:linear-gradient(135deg,#ff6b6b,#ff4757);color:#fff;padding:12px 16px;text-align:center;font-size:.9rem;font-weight:600;animation:urgencySlide .3s ease-out;border-bottom:1px solid rgba(255,255,255,.2);box-shadow:0 2px 8px #ff47574d}@keyframes urgencySlide{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.scene-invitation-prompt{background:linear-gradient(135deg,#a29bfe,#6c5ce7);color:#fff;padding:16px;animation:slideDown .3s ease-out;border-bottom:1px solid rgba(255,255,255,.2)}.invitation-prompt-content{display:flex;flex-direction:column;gap:12px}.invitation-prompt-title{font-weight:700;font-size:1rem;text-align:center}.invitation-prompt-hint{font-size:.85rem;opacity:.95;text-align:center;line-height:1.5}.invitation-prompt-actions{display:flex;gap:12px;justify-content:center;margin-top:8px}.invitation-btn{flex:1;padding:10px 24px;border:none;border-radius:24px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;max-width:140px}.invitation-btn.accept{background:#fff;color:#6c5ce7}.invitation-btn.accept:hover{transform:scale(1.05);box-shadow:0 4px 12px #00000026}.invitation-btn.reject{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.4)}.invitation-btn.reject:hover{background:#ffffff4d}.invitation-btn:active{transform:scale(.95)}.confirmation-modal{width:90%!important;max-width:380px!important;padding:24px!important;border-radius:20px!important}.confirmation-content{display:flex;flex-direction:column;align-items:center;text-align:center;gap:16px}.confirmation-icon{font-size:3rem}.confirmation-title{font-size:1.3rem;font-weight:700;color:var(--text-primary);margin:0}.confirmation-message{font-size:.95rem;color:var(--text-secondary);line-height:1.6;margin:0}.modal-btn.cancel{background:#f1f3f5;color:var(--text-primary);border:none;padding:12px 24px;border-radius:12px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s}.modal-btn.cancel:hover{background:#e9ecef}.modal-btn.danger{background:#ff6b6b;color:#fff;border:none;padding:12px 24px;border-radius:12px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #ff6b6b4d}.modal-btn.danger:hover{background:#ff5252;box-shadow:0 4px 12px #ff6b6b66}.modal-btn:active{transform:scale(.97)}.invitation-accept-btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}@media (max-width: 480px){.scene-invitation-banner{flex-direction:column;align-items:stretch}.invitation-actions,.invitation-accept-btn{width:100%}.invitation-prompt-actions{flex-direction:column}.invitation-btn{max-width:none}}.payment-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:16px;overflow-y:auto}.payment-modal-card{background:var(--bg-card);width:100%;max-width:400px;border-radius:28px;padding:24px;position:relative;animation:slideUp .3s ease-out;max-height:90vh;overflow-y:auto;margin:auto}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.close-button{position:absolute;top:12px;right:12px;background:none;border:none;font-size:24px;color:#ccc;cursor:pointer;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease;padding:0;line-height:1}.close-button:hover{background:#0000000d;color:#666}.close-button:active{transform:scale(.95);background:#0000001a}.payment-header{text-align:center;margin-bottom:25px}.premium-badge{background:#e3f2fd;color:#1976d2;padding:4px 10px;border-radius:8px;font-size:10px;font-weight:800;letter-spacing:1px}.demo-notice{background:#d4edda;color:#155724;padding:8px 16px;border-radius:12px;font-size:13px;font-weight:600;margin-top:12px;display:inline-block;border:1px solid #c3e6cb}.payment-header h3{font-size:20px;color:#1a1a1a;margin-top:10px}.payment-header p{font-size:13px;color:#666}.payment-features{display:flex;flex-direction:column;gap:16px;margin-bottom:25px}.feature-item{display:flex;gap:12px;align-items:flex-start}.feature-icon{font-size:20px;background:#f5f5f7;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:10px;flex-shrink:0}.feature-text strong{display:block;font-size:14px;color:#333}.feature-text span{font-size:12px;color:#888}.payment-qr-section{background:#fafafa;border-radius:20px;padding:20px;text-align:center;margin-bottom:20px;border:1px dashed #ddd}.qr-box{margin-bottom:10px}.qr-icon{font-size:40px}.qr-box p{font-size:11px;color:#999}.price-tag{display:flex;justify-content:center;align-items:baseline;gap:8px}.original-price{font-size:14px;color:#bbb;text-decoration:line-through}.current-price{font-size:24px;font-weight:800;color:var(--brand-primary)}.confirm-pay-button{width:100%;background:linear-gradient(135deg,#e65c5c,#ff9f43);color:#fff;border:none;padding:16px;border-radius:16px;font-size:16px;font-weight:700;cursor:pointer;box-shadow:0 6px 20px #e65c5c4d;transition:all .2s ease;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.confirm-pay-button:active{transform:scale(.98);box-shadow:0 4px 16px #e65c5c66}.payment-footer{text-align:center;font-size:10px;color:#bbb;margin-top:15px}@media (max-width: 374px){.payment-modal-overlay{padding:12px}.payment-modal-card{padding:20px;border-radius:20px;max-height:95vh}.payment-header h3{font-size:18px}.payment-header p{font-size:12px}.demo-notice{font-size:11px;padding:6px 12px}.payment-features{gap:12px;margin-bottom:20px}.feature-icon{font-size:18px;width:32px;height:32px}.feature-text strong{font-size:13px}.feature-text span{font-size:11px}.payment-qr-section{padding:16px;border-radius:16px}.qr-icon{font-size:32px}.current-price{font-size:20px}.confirm-pay-button{padding:14px;font-size:15px}}@media (min-width: 375px) and (max-width: 767px){.payment-modal-card{padding:26px;max-width:380px}}@media (min-width: 768px){.payment-modal-overlay{padding:32px}.payment-modal-card{padding:32px;max-width:420px;border-radius:32px}.payment-header h3{font-size:22px}.payment-header p{font-size:14px}.demo-notice{font-size:14px;padding:10px 18px}.feature-text strong{font-size:15px}.feature-text span{font-size:13px}.confirm-pay-button{padding:18px;font-size:17px}.confirm-pay-button:hover{transform:translateY(-2px);box-shadow:0 8px 24px #e65c5c66;transition:all .2s ease}}@media (min-width: 1025px){.payment-modal-card{max-width:440px}}@media (max-height: 600px) and (orientation: landscape){.payment-modal-overlay{padding:8px;align-items:flex-start}.payment-modal-card{padding:16px;margin-top:8px;margin-bottom:8px;max-height:calc(100vh - 16px)}.payment-header{margin-bottom:16px}.payment-features{gap:10px;margin-bottom:16px}.payment-qr-section{padding:12px;margin-bottom:16px}.confirm-pay-button{padding:12px}.payment-footer{margin-top:10px}}@media (max-height: 450px) and (orientation: landscape){.payment-header h3{font-size:16px;margin-top:6px}.demo-notice{font-size:10px;padding:5px 10px;margin-top:8px}.feature-item{gap:8px}.feature-icon{width:28px;height:28px;font-size:16px}.qr-icon{font-size:28px}}@supports (padding: max(0px)){.payment-modal-overlay{padding-left:max(16px,env(safe-area-inset-left));padding-right:max(16px,env(safe-area-inset-right));padding-top:max(16px,env(safe-area-inset-top));padding-bottom:max(16px,env(safe-area-inset-bottom))}}.analysis-screen{flex:1;background:var(--bg-app);overflow-y:auto;-webkit-overflow-scrolling:touch;display:block}.analysis-header{background:linear-gradient(135deg,#e65c5c,#ff9f43);color:#fff;padding:calc(max(var(--safe-top),24px) + 20px) 1.5rem 2.5rem;position:relative;overflow:hidden}.analysis-title{font-size:clamp(1.4rem,6vw,1.8rem);font-weight:800;margin-bottom:.5rem;margin-top:40px}.analysis-subtitle{font-size:.9rem;opacity:.9}.analysis-content{padding:clamp(1rem,4vw,1.5rem);padding-bottom:calc(var(--safe-bottom) + 60px)}.analysis-card{background:var(--bg-card);border-radius:24px;padding:24px;margin-bottom:20px;box-shadow:var(--shadow-sm)}.card-header{display:flex;align-items:center;gap:10px;margin-bottom:20px}.card-title{font-size:1.1rem;font-weight:700}.user-traits-hook{text-align:center}.trait-summary{font-size:14px;color:#666;margin-bottom:15px}.keyword-tags{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-bottom:15px}.keyword-tag.highlight{background:#e65c5c1a;color:var(--brand-primary);padding:8px 16px;border-radius:20px;font-weight:700;border:1px solid var(--brand-primary)}.ai-insights-section.locked-section{position:relative;min-height:300px}.insight-lock-overlay{text-align:center;padding:40px 20px}.lock-content{background:var(--bg-card);padding:30px;border-radius:24px;box-shadow:var(--shadow-md);margin-bottom:20px}.payment-note{font-size:.85rem;color:#ff6b6b;margin-top:12px;margin-bottom:0;font-weight:500}.demo-badge{background:#d4edda;color:#155724;padding:8px 16px;border-radius:12px;font-size:.9rem;font-weight:600;margin-top:12px;margin-bottom:0;display:inline-block;border:1px solid #c3e6cb}.unlock-now-button{background:var(--brand-primary);color:#fff;border:none;padding:14px 28px;border-radius:30px;font-weight:700;cursor:pointer;margin-top:15px}.blurred-text{filter:blur(8px);opacity:.3;-webkit-user-select:none;user-select:none}.report-full p{line-height:1.8;margin-bottom:1.5em;color:#333;text-align:justify}.report-note{background:#f8f9fa;border-left:4px solid #E65C5C;padding:16px 20px;margin-top:30px;border-radius:8px;display:flex;align-items:flex-start;gap:12px}.note-icon{font-size:1.3rem;flex-shrink:0}.note-text{font-size:.9rem;line-height:1.6;color:#555;margin:0}.loading-dots{display:flex;gap:5px;justify-content:center;margin-bottom:10px}.loading-dots span{width:8px;height:8px;background:#e65c5c;border-radius:50%;animation:pulse 1.5s infinite ease-in-out}@keyframes pulse{0%,80%,to{transform:scale(.6);opacity:.3}40%{transform:scale(1);opacity:1}}.messages-list-container{height:100%;background:var(--bg-app);display:flex;flex-direction:column}.messages-header{padding:calc(var(--safe-top) + 20px) 24px 10px;background:var(--bg-app)}.messages-header h2{font-size:2rem;font-weight:800;color:var(--text-primary)}.section-title{font-size:.8rem;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:1px;margin:16px 24px 8px}.matches-row{margin-bottom:10px}.matches-scroll{display:flex;overflow-x:auto;padding:0 24px;gap:16px;-webkit-overflow-scrolling:touch;scrollbar-width:none}.matches-scroll::-webkit-scrollbar{display:none}.match-avatar-item{display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer}.avatar-circle{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--bg-surface) 0%,#e0dbd0 100%);display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:800;color:var(--brand-primary);border:2px solid #fff;box-shadow:var(--shadow-sm)}.avatar-name{font-size:.8rem;font-weight:600;color:var(--text-primary)}.conversations-list{flex:1;overflow-y:auto;padding:0 16px}.conversation-item{display:flex;align-items:center;gap:16px;padding:12px;border-radius:16px;transition:background .2s;cursor:pointer}.conversation-item:active{background:var(--bg-surface)}.item-avatar{width:56px;height:56px;border-radius:50%;background:var(--bg-surface);display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:800;color:var(--brand-primary);position:relative;flex-shrink:0}.unread-dot{position:absolute;top:0;right:0;width:12px;height:12px;background:var(--brand-primary);border-radius:50%;border:2px solid var(--bg-app)}.online-status-dot{position:absolute;bottom:2px;right:2px;width:12px;height:12px;border-radius:50%;border:2px solid var(--bg-card);transition:background-color .3s ease}.online-status-dot.online{background-color:#00b894;box-shadow:0 0 0 2px #00b89433}.online-status-dot.away{background-color:#b2bec3}.item-content{flex:1;min-width:0}.item-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:4px}.item-name-row{display:flex;align-items:center;gap:6px}.item-name{font-size:1rem;font-weight:700;color:var(--text-primary)}.item-status-indicator{font-size:.85rem;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.item-time{font-size:.75rem;color:var(--text-tertiary)}.item-bottom{display:flex;justify-content:space-between;align-items:center}.item-preview{font-size:.9rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;margin-right:8px}.item-preview.unread{color:var(--text-primary);font-weight:600}.unread-badge{background:var(--brand-primary);color:#fff;font-size:.75rem;font-weight:700;min-width:20px;height:20px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 6px}.typing-text{color:var(--brand-primary);font-style:italic;font-size:.85rem}.messages-list-empty{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-tertiary);padding-bottom:80px;text-align:center;padding-left:20px;padding-right:20px}.empty-icon{font-size:4rem;margin-bottom:16px;opacity:.5}.messages-list-empty h3{font-size:1.3rem;font-weight:700;color:var(--text-primary);margin-bottom:8px}.messages-list-empty p{font-size:.95rem;color:var(--text-secondary);line-height:1.5;margin-bottom:20px}.empty-cta-btn{background:var(--brand-primary);color:#fff;border:none;padding:12px 32px;border-radius:24px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #e65c5c4d}.empty-cta-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #e65c5c66}.empty-cta-btn:active{transform:translateY(0);box-shadow:0 2px 8px #e65c5c4d}.profile-screen{height:100%;background:var(--bg-app);display:flex;flex-direction:column;overflow:hidden;position:relative}.profile-scroll-container{flex:1;overflow-y:auto;padding:calc(max(var(--safe-top),24px) + 20px) 20px calc(var(--safe-bottom) + 30px);-webkit-overflow-scrolling:touch}.profile-header-card{background:var(--bg-card);border-radius:32px;padding:32px 24px;display:flex;flex-direction:column;align-items:center;text-align:center;box-shadow:var(--shadow-md);margin-bottom:24px;border:1px solid var(--border-subtle);position:relative}.profile-avatar-wrapper{position:relative;margin-bottom:20px}.profile-avatar-large{width:100px;height:100px;background:var(--bg-surface);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:3.5rem;box-shadow:var(--shadow-sm);border:4px solid #fff}.edit-avatar-btn{position:absolute;bottom:0;right:0;background:var(--brand-primary);width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;border:2px solid #fff;box-shadow:var(--shadow-sm);font-size:.9rem}.profile-display-name{font-size:1.6rem;font-weight:800;color:var(--text-primary);margin-bottom:6px;letter-spacing:-.5px}.profile-display-bio{font-size:.95rem;color:var(--text-secondary);font-weight:500;line-height:1.5;max-width:80%}.profile-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:32px}.stat-card{background:var(--bg-card);padding:20px;border-radius:24px;display:flex;flex-direction:column;align-items:center;box-shadow:var(--shadow-sm);border:1px solid var(--border-subtle)}.stat-value{font-size:1.4rem;font-weight:800;color:var(--brand-primary);margin-bottom:4px}.stat-label{font-size:.75rem;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:1px}.settings-section{margin-bottom:32px}.section-title{font-size:.85rem;font-weight:800;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:1px;margin-left:12px;margin-bottom:12px}.settings-list{background:var(--bg-card);border-radius:24px;overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--border-subtle)}.setting-item{display:flex;justify-content:space-between;align-items:center;padding:18px 20px;border-bottom:1px solid var(--border-subtle);transition:background .2s}.setting-item:last-child{border-bottom:none}.setting-item:active{background:var(--bg-surface)}.setting-info{display:flex;align-items:center;gap:14px}.setting-icon{font-size:1.2rem;width:36px;height:36px;background:var(--bg-surface);border-radius:12px;display:flex;align-items:center;justify-content:center}.setting-label{font-size:1rem;font-weight:600;color:var(--text-primary)}.setting-arrow{color:var(--text-tertiary);font-weight:700}.toggle-switch{width:44px;height:24px;background:#dfe6e9;border-radius:12px;position:relative;transition:all .3s}.toggle-switch:after{content:"";position:absolute;left:2px;top:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:all .3s;box-shadow:0 2px 4px #0000001a}.toggle-switch.active{background:#55efc4}.toggle-switch.active:after{left:22px}.logout-area{margin-top:10px;text-align:center}.logout-btn{width:100%;padding:18px;background:#fff;color:#ff7675;border-radius:20px;font-size:1rem;font-weight:700;border:1px solid #fab1a0;margin-bottom:16px}.version-text{font-size:.75rem;color:var(--text-tertiary);font-weight:500}.edit-modal-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;display:flex;align-items:flex-end;justify-content:center}.edit-modal{background:#fff;width:100%;max-width:500px;border-top-left-radius:32px;border-top-right-radius:32px;padding:32px 24px calc(var(--safe-bottom) + 24px);animation:slideUp .3s cubic-bezier(.2,.8,.2,1);margin:0 auto}@media (min-width: 600px){.edit-modal-overlay{align-items:center}.edit-modal{border-radius:32px;padding-bottom:32px;margin:20px;max-height:90vh;overflow-y:auto}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.modal-header h3{font-size:1.3rem;font-weight:800}.close-modal{width:32px;height:32px;background:var(--bg-surface);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-secondary)}.avatar-selection{margin-bottom:24px}.avatar-selection label{display:block;font-size:.85rem;font-weight:800;color:var(--text-tertiary);text-transform:uppercase;margin-bottom:12px}.avatar-grid{display:flex;gap:12px;overflow-x:auto;padding-bottom:8px;scrollbar-width:none}.avatar-grid::-webkit-scrollbar{display:none}.avatar-option{width:56px;height:56px;background:var(--bg-surface);border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.8rem;flex-shrink:0;border:2px solid transparent;transition:all .2s}.avatar-option.selected{border-color:var(--brand-primary);background:#fff;transform:scale(1.1);box-shadow:var(--shadow-sm)}.input-group{margin-bottom:24px}.input-group label{display:block;font-size:.85rem;font-weight:800;color:var(--text-tertiary);text-transform:uppercase;margin-bottom:8px}.input-group input,.input-group textarea{width:100%;background:var(--bg-surface);border:1px solid transparent;border-radius:16px;padding:14px 16px;font-size:1rem;color:var(--text-primary);font-weight:600;font-family:inherit}.input-group input:focus,.input-group textarea:focus{background:#fff;border-color:var(--brand-primary)}.modal-actions{display:flex;gap:12px;margin-top:8px}.modal-btn{flex:1;padding:16px;border-radius:18px;font-weight:700;font-size:1rem}.modal-btn.cancel{background:var(--bg-surface);color:var(--text-secondary)}.modal-btn.save{background:var(--brand-primary);color:#fff;box-shadow:var(--shadow-floating)}.test-modal{min-height:400px;display:flex;flex-direction:column}.test-content{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center}.test-question{font-size:1.2rem;font-weight:700;color:var(--text-primary);margin-bottom:32px;line-height:1.6}.test-options{width:100%;display:flex;flex-direction:column;gap:12px}.test-option-btn{width:100%;padding:16px;background:var(--bg-surface);border-radius:16px;font-size:1rem;font-weight:600;color:var(--text-primary);transition:all .2s;border:1px solid transparent}.test-option-btn:active{background:#fff;border-color:var(--brand-primary);color:var(--brand-primary);transform:scale(.98)}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.bottom-nav{height:calc(60px + var(--safe-bottom));background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-top:1px solid var(--border-subtle);display:flex;justify-content:space-around;align-items:flex-start;padding-top:8px;position:relative;width:100%;z-index:50;flex-shrink:0}.nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;color:var(--text-tertiary);transition:all .2s;width:60px}.nav-item.active{color:var(--brand-primary);transform:translateY(-2px)}.nav-icon{font-size:1.5rem}.nav-label{font-size:.7rem;font-weight:700}.icon-wrapper{position:relative}.badge{position:absolute;top:-2px;right:-6px;background:var(--brand-primary);color:#fff;font-size:.6rem;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;border:2px solid white}.invitation-gate{height:100vh;width:100vw;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px;position:fixed;top:0;left:0;z-index:9999}.gate-content{background:#fff;padding:40px;border-radius:24px;box-shadow:0 20px 40px #0003;width:100%;max-width:400px;text-align:center}.gate-logo{font-size:24px;font-weight:700;margin-bottom:20px;color:#764ba2}.gate-content h1{font-size:24px;margin:0 0 15px;color:#1a1a1a}.gate-content p{font-size:14px;color:#666;line-height:1.6;margin-bottom:30px}.gate-content form{display:flex;flex-direction:column;gap:15px}.gate-content input{padding:15px;border:2px solid #eee;border-radius:12px;font-size:16px;transition:all .3s ease;text-align:center;letter-spacing:2px}.gate-content input:focus{border-color:#764ba2;outline:none;box-shadow:0 0 0 4px #764ba21a}.gate-content input.input-error{border-color:#ff4d4f;animation:shake .5s}.gate-content button{padding:15px;background:#764ba2;color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:700;cursor:pointer;transition:transform .2s}.gate-content button:active{transform:scale(.98)}.error-message{color:#ff4d4f;font-size:12px;margin-top:-5px}.gate-footer{margin-top:30px;font-size:12px;color:#999}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.app{width:100%;height:100%;display:flex;flex-direction:column;position:relative;background-color:var(--bg-app)}.back-button{position:absolute;top:calc(var(--safe-top) + 12px);left:20px;z-index:50;width:44px;height:44px;border-radius:50%;background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:center;color:var(--text-primary);font-size:1.2rem;transition:transform .2s var(--ease-smooth)}.back-button:active{transform:scale(.92)}.page-transition{animation:fadeIn .4s var(--ease-smooth)}.fullscreen-view{position:absolute;top:0;left:0;width:100%;height:100%;z-index:100;background-color:var(--bg-app);display:flex;flex-direction:column;overflow:hidden}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}*{margin:0;padding:0;box-sizing:border-box;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root{--brand-primary: #E65C5C;--brand-secondary: #2D3436;--brand-accent: #FF9F43;--bg-app: #FDFBF7;--bg-card: #FFFFFF;--bg-surface: #F4F1EA;--bg-chat-bubble-user: #E65C5C;--bg-chat-bubble-other: #F2F2F2;--text-primary: #2D3436;--text-secondary: #636E72;--text-tertiary: #B2BEC3;--text-on-primary: #FFFFFF;--border-subtle: rgba(0, 0, 0, .04);--border-focus: #E65C5C;--shadow-sm: 0 2px 8px rgba(45, 52, 54, .04);--shadow-md: 0 8px 24px rgba(45, 52, 54, .08);--shadow-lg: 0 16px 48px rgba(45, 52, 54, .12);--shadow-floating: 0 20px 60px rgba(230, 92, 92, .25);--glass-bg: rgba(255, 255, 255, .85);--glass-border: rgba(255, 255, 255, .5);--glass-blur: blur(12px);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--ease-smooth: cubic-bezier(.4, 0, .2, 1);--safe-top: env(safe-area-inset-top, 20px);--safe-bottom: env(safe-area-inset-bottom, 20px)}html,body{height:100%;width:100%;overflow:hidden;background-color:var(--bg-app);min-height:100vh;min-height:-webkit-fill-available}body{font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--text-primary);line-height:1.6;display:flex;justify-content:center}#root{width:100%;height:100%;position:relative;background-color:var(--bg-app);overflow:hidden}@media (min-width: 768px){body{background-color:#f0f2f5;align-items:center;min-height:100vh}#root{max-width:480px;height:90vh;border-radius:24px;box-shadow:0 20px 60px #0000001a;position:relative;background-color:var(--bg-app);overflow:hidden}}@media (max-width: 767px){#root{width:100%;height:100%;height:100dvh;overflow:hidden}}button{font-family:inherit;border:none;background:none;cursor:pointer;-webkit-tap-highlight-color:transparent}input,textarea{font-family:inherit;outline:none;-webkit-appearance:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-thumb{background:#0000001a;border-radius:3px}::-webkit-scrollbar-track{background:transparent}
