@import "https://fonts.googleapis.com/css2?family=Nunito:wght@400;500;600;700;800&display=swap";.home-screen{height:100%;min-height:0;padding:calc(var(--safe-top) + 20px) 24px calc(var(--safe-bottom) + 30px);background:var(--bg-app);-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;flex-direction:column;display:flex;position:relative;overflow:hidden auto}.home-screen:before{content:"";filter:blur(40px);z-index:0;background:radial-gradient(circle,#e65c5c26 0%,#0000 70%);width:300px;height:300px;position:absolute;top:-10%;right:-20%}.home-header{z-index:1;flex-direction:column;flex:1;justify-content:center;align-items:flex-start;display:flex}.app-title{color:var(--brand-primary);letter-spacing:-1px;margin-bottom:8px;font-family:Nunito,sans-serif;font-size:clamp(2.5rem,10vw,3.5rem);font-weight:800;line-height:1.1}.app-subtitle{color:var(--text-primary);opacity:.8;margin-bottom:24px;font-size:clamp(1.1rem,5vw,1.5rem);font-weight:300}.app-description{color:var(--text-secondary);max-width:280px;font-size:1rem;line-height:1.6}.personalize-prompt{z-index:1;background:linear-gradient(135deg,#764ba214 0%,#667eea14 100%);border:1px solid #764ba21a;border-radius:20px;align-items:center;gap:16px;margin-bottom:24px;padding:16px;display:flex}.prompt-icon{background:#fff;border-radius:14px;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.8rem;display:flex;box-shadow:0 4px 12px #764ba21a}.prompt-content{flex:1}.prompt-title{color:#764ba2;margin-bottom:2px;font-size:.95rem;font-weight:700}.prompt-text{color:var(--text-secondary);font-size:.8rem;line-height:1.4}.mode-selection{z-index:1;flex-direction:column;gap:16px;width:100%;display:flex}.mode-button.challenge{background:linear-gradient(135deg,#ff4b81 0%,#ff8c52 100%);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{background:var(--bg-card);box-shadow:var(--shadow-sm);border:1px solid var(--border-subtle);transition:all .3s var(--ease-smooth);border-radius:24px;flex-direction:row;align-items:center;gap:20px;padding:24px;display:flex;position:relative;overflow:hidden}.mode-button:active{box-shadow:none;transform:scale(.98)}.mode-icon{background:var(--bg-surface);border-radius:16px;justify-content:center;align-items:center;width:64px;height:64px;font-size:2.5rem;display:flex}.mode-info{text-align:left;flex-direction:column;align-items:flex-start;display:flex}.mode-title{color:var(--text-primary);margin-bottom:4px;font-size:1.2rem;font-weight:700}.mode-desc{color:var(--text-secondary);font-size:.9rem}.home-footer{text-align:center;margin-top:30px}.footer-text{color:var(--text-tertiary);letter-spacing:1px;text-transform:uppercase;font-size:.8rem;font-weight:500}.challenge-dashboard{background:var(--bg-app);flex-shrink:0;min-height:0;padding:20px 16px 100px;overflow:hidden visible}.dashboard-header{text-align:center;margin-bottom:24px;position:relative}.dashboard-title{color:var(--text-primary);letter-spacing:-.02em;margin-bottom:6px;font-size:clamp(1.35rem,4vw,1.5rem);font-weight:800;line-height:1.25}.dashboard-subtitle{color:var(--text-secondary);max-width:320px;margin:0 auto;font-size:.875rem;font-weight:500}.dashboard-progress-pill{background:var(--bg-surface);color:var(--text-secondary);border-radius:20px;align-items:center;gap:6px;margin-top:12px;padding:6px 14px;font-size:.8125rem;font-weight:600;display:inline-flex}.dashboard-progress-pill .progress-count{color:var(--brand-primary)}.roadmap{flex-direction:column;gap:0;max-width:500px;margin:0 auto 24px;display:flex;position:relative}.roadmap:before{content:"";background:var(--bg-surface);pointer-events:none;z-index:0;border-radius:1px;width:2px;position:absolute;top:28px;bottom:28px;left:19px}.day-card{background:var(--bg-card);box-shadow:var(--shadow-sm);cursor:pointer;transition:transform .2s var(--ease-smooth), box-shadow .2s var(--ease-smooth), border-color .2s;z-index:1;border:2px solid #0000;border-radius:20px;align-items:flex-start;margin-bottom:12px;margin-left:0;padding:16px 16px 16px 56px;display:flex;position:relative}.day-card:last-of-type{margin-bottom:0}.day-card:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.day-card:not(.locked):hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.day-card.locked{opacity:.65;cursor:not-allowed;filter:grayscale(.85)}.day-card.active{border-color:var(--brand-primary);box-shadow:var(--shadow-floating)}.day-card.completed{background:linear-gradient(135deg, #48bb780f 0%, var(--bg-card) 100%)}.day-number{background:var(--bg-surface);border:2px solid var(--bg-card);width:40px;height:40px;box-shadow:var(--shadow-sm);transition:background .2s, color .2s, transform .2s var(--ease-spring);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.9375rem;font-weight:700;display:flex;position:absolute;top:18px;left:12px}.day-card.active .day-number{background:var(--brand-primary);color:var(--text-on-primary);border-color:var(--brand-primary);transform:scale(1.05)}.day-card.completed .day-number{color:var(--text-on-primary);background:#48bb78;border-color:#48bb78}.day-info{flex-grow:1;min-width:0}.day-title{color:var(--text-primary);margin-bottom:4px;font-size:1rem;font-weight:700;line-height:1.3}.day-goal{color:var(--text-secondary);margin-bottom:6px;font-size:.75rem;font-weight:500}.day-description{color:var(--text-secondary);margin-top:4px;margin-bottom:6px;font-size:.75rem;line-height:1.45}.day-description.muted{color:var(--text-tertiary)}.day-instructions{background:var(--bg-surface);border-left:4px solid var(--brand-primary);border-radius:12px;margin-top:12px;padding:12px 14px}.instructions-title{color:var(--text-primary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px;font-size:.6875rem;font-weight:700}.instructions-list{margin:0;padding-left:18px;list-style:none}.instructions-list li{color:var(--text-secondary);margin-bottom:4px;font-size:.8125rem;line-height:1.5;position:relative}.instructions-list li:before{content:"•";color:var(--brand-primary);font-weight:700;position:absolute;left:-14px}.day-progress-hint{color:var(--brand-primary);margin-top:8px;font-size:.6875rem;font-weight:600}.task-progress{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:8px;margin-top:12px;padding:12px;font-size:.8125rem}.progress-note{color:var(--text-secondary);border-bottom:1px solid var(--border-subtle);margin-bottom:10px;padding-bottom:8px;font-size:.75rem;font-style:italic;font-weight:500}.progress-item{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.progress-item:last-child{margin-bottom:0}.progress-label{color:var(--text-secondary);font-weight:500}.progress-value{color:var(--text-primary);font-weight:700}.status-indicator{flex-shrink:0;align-self:flex-start;margin-left:12px}.status-badge{background:var(--bg-surface);color:var(--text-secondary);white-space:nowrap;text-transform:uppercase;letter-spacing:.02em;border-radius:12px;padding:5px 10px;font-size:.6875rem;font-weight:600}.day-card.active .status-badge{color:var(--brand-primary);background:#e65c5c1f}.day-card.completed .status-badge{color:#2f855a;background:#48bb7826}.locked-icon{opacity:.8;font-size:1.25rem}.report-unlock-card{background:linear-gradient(135deg, var(--brand-primary) 0%, var(--brand-accent) 100%);color:var(--text-on-primary);text-align:center;box-shadow:var(--shadow-floating);border-radius:24px;max-width:500px;margin:28px auto 0;padding:28px 24px;position:relative;overflow:hidden}.report-unlock-card:before{content:"";pointer-events:none;background:radial-gradient(circle,#ffffff1f 0%,#0000 70%);width:80%;height:160%;position:absolute;top:-50%;right:-30%}.unlock-icon{opacity:.95;margin-bottom:8px;font-size:2rem}.unlock-title{letter-spacing:-.02em;margin-bottom:10px;font-size:1.25rem;font-weight:800;position:relative}.unlock-desc{opacity:.95;margin-bottom:20px;font-size:.8125rem;line-height:1.5;position:relative}.unlock-button{background:var(--bg-card);color:var(--brand-primary);cursor:pointer;transition:transform .2s var(--ease-smooth), box-shadow .2s;box-shadow:var(--shadow-sm);border:none;border-radius:14px;padding:14px 28px;font-size:.9375rem;font-weight:700;position:relative}.unlock-button:hover:not(.disabled){box-shadow:var(--shadow-md);transform:translateY(-2px)}.unlock-button:focus-visible{outline:2px solid var(--bg-card);outline-offset:2px}.unlock-button.disabled{opacity:.6;cursor:not-allowed;transform:none}@media (width<=480px){.challenge-dashboard{padding:16px 12px 100px}.roadmap:before{top:24px;left:15px}.day-card{border-radius:16px;margin-bottom:10px;padding:14px 14px 14px 50px}.day-number{width:34px;height:34px;font-size:.8125rem;top:16px;left:10px}.day-title{font-size:.9375rem}.day-instructions{margin-top:10px;padding:10px 12px}.instructions-list li{font-size:.75rem}.task-progress{padding:10px;font-size:.75rem}.status-badge{padding:4px 8px;font-size:.625rem}.report-unlock-card{border-radius:20px;padding:24px 20px}.unlock-title{font-size:1.125rem}.unlock-desc{font-size:.75rem}.unlock-button{padding:12px 24px;font-size:.875rem}}.auth-screen{background:var(--bg-app);-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;justify-content:center;align-items:flex-start;min-height:100dvh;padding:max(20px,5vh) 20px;display:flex;overflow:hidden auto}.auth-card{background:var(--bg-card);width:100%;max-width:400px;box-shadow:var(--shadow-md);border-radius:24px;flex-shrink:0;margin:auto;padding:40px}.auth-header{text-align:center;margin-bottom:30px}.auth-logo{color:var(--brand-primary);margin-bottom:20px;font-size:24px;font-weight:800}.auth-header h2{color:#1a1a1a;margin-bottom:8px;font-size:20px}.auth-header p{color:#666;font-size:14px}.auth-form{flex-direction:column;gap:20px;display:flex}.input-group{flex-direction:column;gap:8px;display:flex}.input-group label{color:#333;font-size:13px;font-weight:600}.input-group input{border:1px solid #ddd;border-radius:12px;padding:12px 16px;font-size:15px;transition:border-color .2s}.input-group input:focus{border-color:var(--brand-primary);outline:none}.auth-button{background:var(--brand-primary);color:#fff;cursor:pointer;border:none;border-radius:12px;margin-top:10px;padding:14px;font-size:16px;font-weight:700;transition:opacity .2s}.auth-button:disabled{opacity:.7;cursor:not-allowed}.auth-message{text-align:center;border-radius:10px;padding:12px;font-size:13px}.auth-message.success{color:#2f855a;background:#f0fff4;border:1px solid #c6f6d5}.auth-message.error{color:#c53030;background:#fff5f5;border:1px solid #fed7d7}.auth-footer{text-align:center;color:#666;margin-top:25px;font-size:14px}.auth-footer span{color:var(--brand-primary);cursor:pointer;font-weight:600}.forgot-password-link{text-align:right;margin-top:-10px;margin-bottom:-5px}.forgot-password-link span{color:var(--brand-primary);cursor:pointer;font-size:13px;font-weight:600;transition:opacity .2s}.forgot-password-link span:hover{opacity:.8}.onboarding-screen{padding:max(12px, env(safe-area-inset-top)) max(16px, env(safe-area-inset-right)) max(12px, env(safe-area-inset-bottom)) max(16px, env(safe-area-inset-left));z-index:9999;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;box-sizing:border-box;background:linear-gradient(135deg,#e65c5c 0%,#ff9f43 100%);justify-content:center;align-items:center;min-height:100dvh;display:flex;position:fixed;inset:0;overflow:hidden auto}.onboarding-container{background:var(--bg-app,#faf8f5);border-radius:var(--radius-xl,24px);box-sizing:border-box;flex-direction:column;width:100%;max-width:480px;min-height:0;max-height:min(92dvh,92vh);padding:24px 20px 20px;animation:.4s ease-out slideUp;display:flex;overflow:hidden;box-shadow:0 20px 60px #e65c5c40}@media (height>=700px){.onboarding-container{min-height:420px}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.onboarding-progress{flex-shrink:0;justify-content:center;gap:6px;margin-bottom:20px;display:flex}.progress-dot{background:#e0e0e0;border-radius:50%;width:8px;height:8px;transition:all .3s}.progress-dot.active{background:#e65c5c;border-radius:4px;width:24px}.progress-dot.completed{background:#e65c5c}.onboarding-content{text-align:center;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;flex-direction:column;flex:1;align-items:center;min-height:0;margin-bottom:20px;display:flex;overflow-y:auto}.onboarding-icon{margin-bottom:20px;font-size:4rem;animation:1s ease-in-out bounce}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.onboarding-title{color:#2d3436;letter-spacing:-.5px;margin-bottom:8px;font-size:1.75rem;font-weight:800;line-height:1.3}.onboarding-subtitle{color:#e65c5c;text-transform:uppercase;letter-spacing:1px;margin-bottom:20px;font-size:.95rem;font-weight:600}.onboarding-description{color:#636e72;max-width:400px;margin-bottom:20px;font-size:1rem;line-height:1.7}.onboarding-highlight{color:#fff;background:linear-gradient(135deg,#e65c5c 0%,#ff9f43 100%);border-radius:12px;max-width:380px;margin-bottom:24px;padding:16px 24px;font-size:.95rem;font-weight:600;line-height:1.5;box-shadow:0 4px 12px #e65c5c4d}.onboarding-features{flex-direction:column;gap:12px;width:100%;max-width:360px;margin-top:20px;display:flex}.feature-item{color:#2d3436;text-align:left;background:#f4f1ea;border-left:3px solid #e65c5c;border-radius:10px;padding:12px 16px;font-size:.9rem;font-weight:500}.onboarding-cta-badge{color:#2d3436;background:linear-gradient(135deg,#ff9f43 0%,#ffb84d 100%);border-radius:20px;margin-top:20px;padding:12px 24px;font-size:1rem;font-weight:700;animation:2s ease-in-out infinite pulse;box-shadow:0 4px 12px #ff9f434d}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.onboarding-actions{width:100%;padding-bottom:env(safe-area-inset-bottom,0);flex-shrink:0;gap:12px;min-height:48px;display:flex}.onboarding-skip{color:#636e72;cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:2px solid #e0e0e0;border-radius:12px;flex:1;min-height:48px;padding:14px 16px;font-size:1rem;font-weight:600;transition:all .2s}.onboarding-skip:hover{color:#e65c5c;border-color:#e65c5c}.onboarding-skip:active{transform:scale(.98)}.onboarding-next{color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;background:linear-gradient(135deg,#e65c5c 0%,#ff9f43 100%);border:none;border-radius:12px;flex:2;min-height:48px;padding:14px 16px;font-size:1rem;font-weight:600;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}.onboarding-next:disabled{opacity:.5;cursor:not-allowed;transform:none}.onboarding-input-section{width:100%;max-width:400px;margin-top:24px}.onboarding-input-group{flex-direction:column;gap:8px;display:flex}.onboarding-input,.onboarding-textarea{color:#2d3436;box-sizing:border-box;appearance:none;background:#fff;border:2px solid #e0e0e0;border-radius:12px;width:100%;min-height:48px;padding:14px 16px;font-family:inherit;font-size:16px;transition:all .2s}.onboarding-input:focus,.onboarding-textarea:focus{border-color:#e65c5c;outline:none;box-shadow:0 0 0 3px #e65c5c26}.onboarding-textarea{resize:vertical;min-height:120px;line-height:1.6}.onboarding-input-hint{color:#636e72;text-align:right;margin-top:4px;font-size:.85rem}@media (width<=480px),(height<=700px){.onboarding-screen{padding:max(8px, env(safe-area-inset-top)) 12px max(8px, env(safe-area-inset-bottom)) 12px;padding-top:max(20px, env(safe-area-inset-top));align-items:flex-start}.onboarding-container{border-radius:20px;max-height:min(88dvh,88vh);padding:20px 16px 16px}.onboarding-progress{gap:5px;margin-bottom:16px}.progress-dot{width:6px;height:6px}.progress-dot.active{width:18px}.onboarding-content{margin-bottom:16px}.onboarding-icon{margin-bottom:12px;font-size:2.75rem}.onboarding-title{margin-bottom:6px;font-size:1.35rem;line-height:1.25}.onboarding-subtitle{margin-bottom:12px;font-size:.8rem}.onboarding-description{margin-bottom:14px;font-size:.9rem;line-height:1.6}.onboarding-description p{margin:0}.onboarding-highlight{border-radius:10px;margin-bottom:16px;padding:12px 16px;font-size:.875rem}.onboarding-features{gap:8px;margin-top:12px}.feature-item{padding:10px 12px;font-size:.8rem}.onboarding-input-section{width:100%;margin-top:16px}.onboarding-input,.onboarding-textarea{min-height:48px;padding:12px 14px}.onboarding-textarea{min-height:100px}.onboarding-input-hint{font-size:.75rem}.onboarding-actions{padding-bottom:max(8px, env(safe-area-inset-bottom));gap:10px}.onboarding-skip,.onboarding-next{min-height:48px;padding:12px 14px;font-size:.95rem}}@media (height<=600px){.onboarding-screen{align-items:flex-start;padding-top:12px}.onboarding-container{max-height:min(96dvh,96vh);padding:16px 20px 12px}.onboarding-progress{margin-bottom:12px}.onboarding-icon{margin-bottom:8px;font-size:2.25rem}.onboarding-title{margin-bottom:4px;font-size:1.2rem}.onboarding-subtitle{margin-bottom:8px;font-size:.75rem}.onboarding-description{margin-bottom:8px;font-size:.85rem}.onboarding-highlight{margin-bottom:10px;padding:10px 14px;font-size:.8rem}.onboarding-features{gap:6px;margin-top:8px}.feature-item{padding:6px 10px;font-size:.75rem}.onboarding-input-section{margin-top:10px}.onboarding-input,.onboarding-textarea{min-height:44px;padding:10px 12px}.onboarding-textarea{min-height:80px}.onboarding-input-hint{font-size:.7rem}.onboarding-content{margin-bottom:12px}.onboarding-actions{padding-bottom:max(4px, env(safe-area-inset-bottom))}.onboarding-skip,.onboarding-next{min-height:44px;padding:10px 12px;font-size:.9rem}}.tinder-mode{background-color:var(--bg-app);-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;flex-direction:column;height:100%;min-height:0;display:flex;position:relative;overflow:hidden auto}.match-header{z-index:10;align-items:center;gap:15px;padding:20px;display:flex}.back-icon{cursor:pointer;color:#333;background:0 0;border:none;font-size:24px}.header-info{flex-direction:column;display:flex}.match-title{font-size:18px;font-weight:700}.match-subtitle{color:#888;font-size:12px}.swipe-container{margin-top:calc(var(--safe-top) + 10px);flex:1;justify-content:center;align-items:center;max-height:70vh;display:flex;position:relative}.character-card{background:var(--bg-card);width:min(100% - 40px,400px);height:90%;max-height:560px;box-shadow:var(--shadow-lg);-webkit-user-select:none;user-select:none;touch-action:none;will-change:transform, opacity;border:1px solid #00000005;border-radius:32px;flex-direction:column;display:flex;position:absolute;overflow:hidden}.card-image-area{background:var(--bg-surface);flex:1.2;justify-content:center;align-items:center;min-height:0;display:flex;position:relative;overflow:hidden}.character-avatar-image{object-fit:cover;width:100%;height:100%;display:block}.character-avatar-placeholder{background:linear-gradient(135deg, var(--brand-primary) 0%, #ff8e8e 100%);color:#fff;width:100%;height:100%;transition:transform .3s var(--ease-spring);justify-content:center;align-items:center;font-size:4rem;font-weight:800;display:flex}.character-card:active .character-avatar-placeholder{transform:scale(1.02)}.card-content-area{background:#fff;flex-direction:column;flex:1;min-height:0;padding:20px;display:flex;overflow:visible}.character-name{color:var(--text-primary);letter-spacing:-.5px;margin-bottom:4px;font-size:clamp(1.4rem,6vw,2rem);font-weight:800}.character-meta{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px;font-size:.95rem;font-weight:600}.character-bio{color:var(--text-secondary);-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;margin-bottom:20px;font-size:1rem;line-height:1.6;display:-webkit-box;overflow:hidden}.tags-container{flex-wrap:wrap;gap:8px;margin-top:auto;display:flex}.tag{background:var(--bg-surface);color:var(--text-primary);border-radius:12px;padding:6px 12px;font-size:.8rem;font-weight:600}.swipe-actions{height:120px;padding-bottom:calc(var(--safe-bottom) + 25px);justify-content:center;align-items:center;gap:40px;display:flex}.swipe-button{cursor:pointer;-webkit-tap-highlight-color:transparent;background:#fff;border:1px solid #00000008;border-radius:50%;outline:none;justify-content:center;align-items:center;width:70px;height:70px;transition:all .4s cubic-bezier(.175,.885,.32,1.275);display:flex;box-shadow:0 10px 25px #00000012}.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;height:100%;animation:fadeIn .6s var(--ease-smooth);flex-direction:column;justify-content:center;align-items:center;padding:40px 30px;display:flex}.no-more-icon{filter:drop-shadow(0 10px 15px #e65c5c33);margin-bottom:24px;font-size:4rem;animation:3s ease-in-out infinite float}.no-more-title{color:var(--text-primary);margin-bottom:16px;font-size:1.5rem;font-weight:800}.no-more-desc{color:var(--text-secondary);margin-bottom:32px;font-size:.95rem;line-height:1.8}.back-btn{background:var(--brand-primary);color:#fff;cursor:pointer;border:none;border-radius:12px;padding:12px 24px;font-weight:700}@keyframes float{0%{transform:translateY(0)}50%{transform:translateY(-15px)}to{transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.judgment-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#0006;justify-content:center;align-items:flex-end;animation:.2s fadeIn;display:flex;position:absolute;inset:0}.judgment-modal{background:var(--bg-card);width:100%;max-width:500px;padding:24px;padding-bottom:calc(var(--safe-bottom) + 20px);border-top-left-radius:24px;border-top-right-radius:24px;flex-direction:column;gap:20px;margin:0 auto;animation:.3s cubic-bezier(.2,.8,.2,1) slideUp;display:flex;box-shadow:0 -10px 40px #0000001a}@media (width>=600px){.judgment-overlay{align-items:center}.judgment-modal{border-radius:24px;max-height:90vh;margin:20px;padding-bottom:24px;overflow-y:auto}}.judgment-header{justify-content:space-between;align-items:center;display:flex}.judgment-header h3{color:var(--text-primary);font-size:1.2rem;font-weight:800}.close-button{background:var(--bg-surface);width:32px;height:32px;color:var(--text-secondary);border-radius:50%;justify-content:center;align-items:center;font-size:1.2rem;display:flex}.judgment-content{flex-direction:column;gap:16px;display:flex}.judgment-question{color:var(--text-primary);font-size:1.1rem;font-weight:600;line-height:1.4}.emotion-buttons{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.emotion-button{background:var(--bg-surface);border:2px solid #0000;border-radius:16px;flex-direction:column;align-items:center;gap:8px;padding:12px;transition:all .2s;display:flex}.emotion-button.selected{border-color:var(--brand-primary);color:var(--brand-primary);background:#fff0f0}.emotion-emoji{font-size:1.5rem}.emotion-label-text{font-size:.75rem;font-weight:700}.judgment-input-section label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:.8rem;font-weight:700;display:block}.judgment-input{background:var(--bg-surface);border:1px solid #0000;border-radius:16px;width:100%;padding:16px;font-size:1rem;transition:all .2s}.judgment-input:focus{border-color:var(--brand-primary);background:#fff;box-shadow:0 0 0 4px #e65c5c1a}.judgment-actions{gap:12px;margin-top:10px;display:flex}.judgment-button{border-radius:16px;flex:1;padding:16px;font-size:1rem;font-weight:700;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{background-color:var(--bg-surface);flex-direction:column;height:100%;min-height:0;display:flex;position:relative;overflow:hidden}.chat-header{-webkit-backdrop-filter:saturate(180%)blur(20px);padding:calc(max(var(--safe-top), 20px) + 8px) 16px 12px;z-index:100;background:#ffffffd9;border-bottom:1px solid #0000000f;flex-shrink:0;justify-content:center;align-items:center;display:flex;position:relative;top:0}.chat-header .back-button{width:40px;height:40px;color:var(--text-primary);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1.4rem;transition:all .2s;display:flex;position:absolute;top:50%;left:16px;transform:translateY(-50%)}.chat-header .header-action-btn{width:36px;height:36px;color:var(--text-primary);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1.2rem;transition:all .2s;display:flex;position:absolute;top:50%;right:16px;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{flex-direction:column;justify-content:center;align-items:center;display:flex}.chat-name{color:var(--text-primary);font-size:1.05rem;font-weight:700;line-height:1.2}.chat-status{align-items:center;gap:5px;margin-top:2px;font-size:.72rem;font-weight:600;transition:color .3s;display:flex}.chat-status:before{content:"";background-color:currentColor;border-radius:50%;width:6px;height:6px;transition:background-color .3s;display:block}.chat-status.status-online{color:#00b894}.chat-status.status-online:before{animation:2s infinite pulse}.chat-status.status-typing{color:#00b894}.chat-status.status-typing:before{animation:1s infinite pulse}.chat-status.status-away{color:#b2bec3}.chat-status.status-away:before{opacity:.6;animation:none}.chat-status.status-talking{color:#6c5ce7}.chat-status.status-talking:before{background:#6c5ce7;animation:.8s infinite pulse}.chat-status.status-in-scene{color:#fdcb6e}.chat-status.status-in-scene:before{background:#fdcb6e;animation:1.5s infinite pulse}.chat-messages{-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;padding:20px 16px;padding-bottom:calc(20px + env(safe-area-inset-bottom,0px));flex-direction:column;flex:1;gap:16px;display:flex;overflow:hidden auto}.date-divider{text-align:center;color:var(--text-tertiary);text-transform:capitalize;letter-spacing:.5px;margin:20px 0 12px;padding:0 16px;font-size:.75rem;font-weight:600;position:relative}.date-divider:before,.date-divider:after{content:"";background:var(--border-subtle);width:30%;height:1px;position:absolute;top:50%}.date-divider:before{left:0}.date-divider:after{right:0}.message{flex-direction:column;max-width:80%;display:flex;position:relative}.message-content{box-shadow:var(--shadow-sm);word-wrap:break-word;border-radius:20px;padding:12px 18px;font-size:1rem;line-height:1.5;position:relative}.character-message{align-self:flex-start}.character-message .message-content{color:var(--text-primary);background:#fff;border-bottom-left-radius:4px;box-shadow:0 1px 2px #0000000f}.user-message{align-self:flex-end}.user-message .message-content{background:var(--brand-primary);color:var(--text-on-primary);box-shadow:var(--shadow-md);border-bottom-right-radius:4px}.message-meta{align-items:center;gap:4px;margin-top:4px;padding:0 4px;display:flex}.message-meta.justify-end{justify-content:flex-end}.message-time{color:var(--text-tertiary);font-size:.7rem}.read-receipt{color:var(--text-tertiary);font-size:.7rem;font-weight:600}.read-receipt.read{color:var(--brand-primary)}.environment-message{align-self:center;max-width:90%;margin:20px auto;animation:.8s ease-out sceneTransitionIn}@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{text-align:center;background:linear-gradient(135deg,#fff8e1cc 0%,#fff3cdcc 100%);border-left:3px solid #ffa726;border-radius:12px;padding:16px 20px;box-shadow:0 2px 8px #ffa72626}.environment-icon{margin-bottom:8px;font-size:1.4rem}.environment-text{color:#6d4c00;white-space:pre-wrap;font-size:.95rem;font-style:italic;font-weight:500;line-height:1.6}.environment-time{color:#a97c00;margin-top:8px;font-size:.65rem;font-style:normal}.narrative-message{max-width:88%;animation:narrativeSlideIn .4s var(--ease-smooth);align-self:center;margin:10px auto}@keyframes narrativeSlideIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.narrative-message.scene-narrative .narrative-content{background:linear-gradient(135deg,#e6f0ff99 0%,#dcebff99 100%);border-left:2px solid #9db4ff;border-radius:10px;align-items:flex-start;gap:8px;padding:10px 14px;display:flex;box-shadow:0 1px 4px #9db4ff1a}.narrative-message.scene-narrative .narrative-icon{opacity:.7;flex-shrink:0;margin-top:1px;font-size:.9rem}.narrative-message.scene-narrative .narrative-text{color:#4a5568;flex:1;font-size:.88rem;font-style:italic;font-weight:450;line-height:1.5}.narrative-content{background:var(--bg-surface);border:1px solid var(--border-subtle);box-shadow:var(--shadow-sm);border-radius:12px;flex-direction:column;gap:6px;padding:10px 14px 8px;display:flex}.narrative-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);margin-bottom:2px;font-size:.65rem;font-weight:700;display:block}.narrative-text{color:var(--text-secondary);font-size:.875rem;font-style:italic;font-weight:500;line-height:1.5}.narrative-time{color:var(--text-tertiary);align-self:flex-end;font-size:.65rem;font-style:normal}.system-message{align-self:center;max-width:85%;margin:12px auto}.system-content{color:var(--text-secondary);text-align:center;background:#0000000a;border-radius:16px;padding:10px 16px;font-size:.85rem;line-height:1.4}.typing-bubble{background:var(--bg-card);width:fit-content;box-shadow:var(--shadow-sm);border-radius:20px 20px 20px 4px;gap:4px;padding:14px 18px;display:inline-flex}.typing-dot{background:#b2bec3;border-radius:50%;width:8px;height:8px;animation:1.4s ease-in-out infinite both typingBounce}.typing-dot:first-child{animation-delay:-.32s}.typing-dot:nth-child(2){animation-delay:-.16s}.scene-typing-text{color:#6c5ce7;font-size:.9rem;font-style:italic;font-weight:500}@keyframes typingBounce{0%,80%,to{opacity:.5;transform:scale(0)}40%{opacity:1;transform:scale(1)}}.chat-input-area{background:var(--bg-card);padding:12px 16px calc(var(--safe-bottom) + 12px);border-top:1px solid var(--border-subtle);flex-shrink:0;align-items:flex-end;gap:12px;display:flex;box-shadow:0 -4px 20px #00000005}.input-wrapper{background:var(--bg-surface);border:1px solid #0000;border-radius:24px;flex:1;align-items:center;min-height:48px;padding:8px 16px;transition:all .2s;display:flex}.input-wrapper:focus-within{border-color:var(--brand-primary);background:#fff;box-shadow:0 0 0 3px #e65c5c1a}.chat-input{resize:none;background:0 0;border:none;outline:none;width:100%;max-height:100px;padding:4px 0;font-size:1rem;line-height:1.4}.action-button{width:48px;height:48px;transition:all .2s var(--ease-spring);cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1.2rem;display:flex}.thought-btn{color:#636e72;background:#f0f3f4}.topic-btn{color:#4caf50;background:#e8f5e9}.send-btn{background:var(--brand-primary);color:#fff;opacity:.5;transform:scale(.9)}.send-btn.active{opacity:1;box-shadow:var(--shadow-sm);transform:scale(1)}.character-profile-modal{border:1px solid #e9ecef;flex-direction:column;max-height:88vh;display:flex;position:relative;overflow:hidden;background:#fff!important;border-radius:20px!important;width:90%!important;max-width:400px!important;padding:0!important;box-shadow:0 10px 30px #00000026!important}.character-profile-modal .close-modal{color:#2d3436;cursor:pointer;z-index:10;background:#f8f9fa;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.2rem;transition:all .2s;display:flex;position:absolute;top:16px;right:16px;box-shadow:0 2px 8px #00000014}.character-profile-modal .close-modal:hover{background:#e9ecef;transform:scale(1.1)}.character-profile-modal .close-modal:active{transform:scale(.95)}.character-full-profile{-webkit-overflow-scrolling:touch;flex-direction:column;flex:1;display:flex;overflow-y:auto}.profile-header-visual{display:none}.profile-main-info{text-align:center;z-index:2;padding:32px 24px 20px;position:relative}.profile-avatar-large{color:#2d3436;background:#f8f9fa;border:3px solid #e9ecef;border-radius:50%;justify-content:center;align-items:center;width:100px;height:100px;margin:0 auto 14px;font-size:3rem;font-weight:800;display:flex;box-shadow:0 4px 12px #00000014}.profile-name{color:#2d3436;letter-spacing:-.3px;margin-bottom:6px;font-size:1.5rem;font-weight:700}.profile-occ{color:#6c757d;text-transform:uppercase;letter-spacing:.8px;background:#f8f9fa;border-radius:16px;padding:5px 14px;font-size:.8rem;font-weight:600;display:inline-block}.profile-details-section{flex-direction:column;flex:1;gap:24px;padding:24px;display:flex}.detail-item{flex-direction:column;display:flex}.detail-item label{color:#6c757d;text-transform:uppercase;letter-spacing:1.2px;margin-bottom:10px;font-size:.7rem;font-weight:700}.profile-bio-text{color:#2d3436;background:#f8f9fa;border-left:3px solid #2d3436;border-radius:12px;margin:0;padding:16px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:1rem;font-style:normal;line-height:1.65}.profile-tags{flex-wrap:wrap;gap:8px;display:flex}.profile-tag{color:#495057;background:#e9ecef;border-radius:10px;padding:7px 14px;font-size:.85rem;font-weight:600}.profile-meta-row{gap:12px;display:flex}.meta-pill{background:#f8f9fa;border:1px solid #e9ecef;border-radius:12px;flex-direction:column;flex:1;align-items:center;gap:6px;padding:14px;display:flex}.meta-pill .meta-val{color:#2d3436;text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-size:1rem;font-weight:700;overflow:hidden}.meta-pill .meta-label{color:#6c757d;text-transform:uppercase;font-size:.65rem;font-weight:600}.modal-actions{background:#fff;border-top:1px solid #0000000a;flex-shrink:0;padding:16px 24px 20px}.modal-btn.save{color:#fff;cursor:pointer;background:#2d3436;border:none;border-radius:12px;width:100%;padding:14px;font-size:.95rem;font-weight:600;transition:all .2s;box-shadow:0 2px 8px #0000001f}.modal-btn.save:active{transform:scale(.97);box-shadow:0 1px 4px #0000001a}.progress-hint-banner{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);padding:16px;animation:.3s ease-out slideDown}@keyframes slideDown{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}.hint-content{flex-direction:column;gap:8px;display:flex}.hint-label{text-transform:uppercase;letter-spacing:1px;opacity:.9;font-size:.75rem;font-weight:600}.hint-bars{flex-direction:column;gap:6px;display:flex}.hint-bar{align-items:center;gap:8px;display:flex}.bar-label{min-width:32px;font-size:.8rem;font-weight:600}.bar-track{background:#fff3;border-radius:4px;flex:1;height:8px;overflow:hidden}.bar-fill{background:#fff;border-radius:4px;height:100%;transition:width .5s}.hint-tip{opacity:.95;margin:4px 0 0;font-size:.85rem;font-weight:500}.topic-suggestions-panel{border-top:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle);background:#fff;animation:.3s ease-out slideUp}.suggestions-header{border-bottom:1px solid var(--border-subtle);color:var(--text-secondary);justify-content:space-between;align-items:center;padding:12px 16px;font-size:.9rem;font-weight:600;display:flex}.suggestions-header button{width:24px;height:24px;color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1.2rem;transition:all .2s;display:flex}.suggestions-header button:hover{background:#0000000d}.suggestions-list{flex-direction:column;gap:8px;max-height:200px;padding:12px;display:flex;overflow-y:auto}.suggestion-item{color:var(--text-primary);cursor:pointer;text-align:left;background:#f8f9fa;border:1px solid #e9ecef;border-radius:12px;padding:10px 14px;font-size:.9rem;font-weight:500;transition:all .2s}.suggestion-item:hover{border-color:var(--brand-primary);background:#e9ecef;transform:translate(4px)}.suggestion-item:active{transform:scale(.98)translate(4px)}@media (width<=360px){.message{max-width:85%}.chat-input-area{padding-left:12px;padding-right:12px}.profile-name{font-size:1.4rem}.profile-details-section{gap:20px;padding:20px}.action-button{width:44px;height:44px}}.scene-status-banner{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-bottom:1px solid #fff3;justify-content:space-between;align-items:center;padding:16px;animation:.3s ease-out slideDown;display:flex}.scene-info{align-items:center;gap:12px;display:flex}.scene-icon{font-size:1.5rem}.scene-details{flex-direction:column;gap:4px;display:flex}.scene-name{font-size:.95rem;font-weight:600}.scene-location{opacity:.9;font-size:.85rem}.scene-actions{align-items:center;gap:12px;display:flex}.scene-timer{opacity:.9;font-size:.9rem;transition:all .3s}.scene-timer.urgent{font-weight:700;animation:1s infinite timerPulse}@keyframes timerPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.1)}}.scene-exit-btn{color:#fff;cursor:pointer;background:#fff3;border:1px solid #ffffff4d;border-radius:20px;padding:6px 14px;font-size:.9rem;transition:all .2s}.scene-exit-btn:hover{background:#ffffff4d}.scene-invitation-banner{color:#fff;background:linear-gradient(135deg,#f093fb 0%,#f5576c 100%);border-bottom:1px solid #fff3;justify-content:space-between;align-items:center;gap:16px;padding:20px;animation:.3s ease-out slideDown;display:flex}.invitation-content{flex:1;align-items:flex-start;gap:12px;display:flex}.invitation-icon{font-size:1.8rem;animation:2s infinite pulse}.invitation-text{flex-direction:column;gap:6px;display:flex}.invitation-title{font-size:1.05rem;font-weight:700}.invitation-desc{opacity:.95;font-size:.9rem;line-height:1.4}.invitation-duration{opacity:.85;margin-top:4px;font-size:.85rem}.invitation-actions{flex-direction:column;gap:8px;display:flex}.invitation-accept-btn{color:#f5576c;cursor:pointer;white-space:nowrap;background:#fff;border:none;border-radius:24px;padding:10px 24px;font-size:.95rem;font-weight:600;transition:all .2s}.invitation-accept-btn:hover{transform:scale(1.05);box-shadow:0 4px 12px #00000026}.scene-urgency-banner{color:#fff;text-align:center;background:linear-gradient(135deg,#ff6b6b 0%,#ff4757 100%);border-bottom:1px solid #fff3;padding:12px 16px;font-size:.9rem;font-weight:600;animation:.3s ease-out urgencySlide;box-shadow:0 2px 8px #ff47574d}@keyframes urgencySlide{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.scene-invitation-prompt{color:#fff;background:linear-gradient(135deg,#a29bfe 0%,#6c5ce7 100%);border-bottom:1px solid #fff3;padding:16px;animation:.3s ease-out slideDown}.invitation-prompt-content{flex-direction:column;gap:12px;display:flex}.invitation-prompt-title{text-align:center;font-size:1rem;font-weight:700}.invitation-prompt-hint{opacity:.95;text-align:center;font-size:.85rem;line-height:1.5}.invitation-prompt-actions{justify-content:center;gap:12px;margin-top:8px;display:flex}.invitation-btn{cursor:pointer;border:none;border-radius:24px;flex:1;max-width:140px;padding:10px 24px;font-size:.95rem;font-weight:600;transition:all .2s}.invitation-btn.accept{color:#6c5ce7;background:#fff}.invitation-btn.accept:hover{transform:scale(1.05);box-shadow:0 4px 12px #00000026}.invitation-btn.reject{color:#fff;background:#fff3;border:1px solid #fff6}.invitation-btn.reject:hover{background:#ffffff4d}.invitation-btn:active{transform:scale(.95)}.confirmation-modal{border-radius:20px!important;width:90%!important;max-width:380px!important;padding:24px!important}.confirmation-content{text-align:center;flex-direction:column;align-items:center;gap:16px;display:flex}.confirmation-icon{font-size:3rem}.confirmation-title{color:var(--text-primary);margin:0;font-size:1.3rem;font-weight:700}.confirmation-message{color:var(--text-secondary);margin:0;font-size:.95rem;line-height:1.6}.modal-btn.cancel{color:var(--text-primary);cursor:pointer;background:#f1f3f5;border:none;border-radius:12px;padding:12px 24px;font-size:.95rem;font-weight:600;transition:all .2s}.modal-btn.cancel:hover{background:#e9ecef}.modal-btn.danger{color:#fff;cursor:pointer;background:#ff6b6b;border:none;border-radius:12px;padding:12px 24px;font-size:.95rem;font-weight:600;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 (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}}.analysis-screen{background:var(--bg-app);-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;flex:1;min-height:0;display:block;overflow:hidden auto}.analysis-header{color:#fff;padding:calc(max(var(--safe-top), 24px) + 20px) 1.5rem 2.5rem;background:linear-gradient(135deg,#e65c5c 0%,#ff9f43 100%);position:relative;overflow:hidden}.analysis-title{margin-top:40px;margin-bottom:.5rem;font-size:clamp(1.4rem,6vw,1.8rem);font-weight:800}.analysis-subtitle{opacity:.9;font-size:.9rem}.analysis-content{padding:clamp(1rem,4vw,1.5rem);padding-bottom:calc(var(--safe-bottom) + 60px)}.analysis-card{background:var(--bg-card);box-shadow:var(--shadow-sm);border-radius:24px;margin-bottom:20px;padding:24px}.card-header{align-items:center;gap:10px;margin-bottom:20px;display:flex}.card-title{font-size:1.1rem;font-weight:700}.user-traits-hook{text-align:center}.trait-summary{color:#666;margin-bottom:15px;font-size:14px}.keyword-tags{flex-wrap:wrap;justify-content:center;gap:10px;margin-bottom:15px;display:flex}.keyword-tag.highlight{color:var(--brand-primary);border:1px solid var(--brand-primary);background:#e65c5c1a;border-radius:20px;padding:8px 16px;font-weight:700}.keyword-tag.placeholder{background:var(--bg-surface);color:var(--text-muted,#888);border:1px dashed #00000026;border-radius:20px;padding:8px 16px;font-weight:500}.ai-insights-section.locked-section{min-height:300px;position:relative}.insight-lock-overlay{text-align:center;padding:40px 20px}.lock-content{background:var(--bg-card);box-shadow:var(--shadow-md);border-radius:24px;margin-bottom:20px;padding:30px}.payment-note{color:#ff6b6b;margin-top:12px;margin-bottom:0;font-size:.85rem;font-weight:500}.demo-badge{color:#155724;background:#d4edda;border:1px solid #c3e6cb;border-radius:12px;margin-top:12px;margin-bottom:0;padding:8px 16px;font-size:.9rem;font-weight:600;display:inline-block}.unlock-now-button{background:var(--brand-primary);color:#fff;cursor:pointer;border:none;border-radius:30px;margin-top:15px;padding:14px 28px;font-weight:700}.blurred-text{filter:blur(8px);opacity:.3;-webkit-user-select:none;user-select:none}.report-full p{color:#333;text-align:justify;margin-bottom:1.5em;line-height:1.8}.report-note{background:#f8f9fa;border-left:4px solid #e65c5c;border-radius:8px;align-items:flex-start;gap:12px;margin-top:30px;padding:16px 20px;display:flex}.note-icon{flex-shrink:0;font-size:1.3rem}.note-text{color:#555;margin:0;font-size:.9rem;line-height:1.6}.report-feedback{text-align:center;border-top:1px solid #eee;margin-top:28px;padding-top:20px}.report-feedback-label{color:#555;margin:0 0 14px;font-size:.95rem}.report-feedback-buttons{justify-content:center;gap:20px;display:flex}.report-feedback-btn{cursor:pointer;background:#fff;border:2px solid #ddd;border-radius:50%;width:52px;height:52px;padding:0;font-size:1.6rem;transition:border-color .2s,background .2s,transform .15s}.report-feedback-btn:hover{border-color:var(--brand-primary);background:#e65c5c0f}.report-feedback-btn:active{transform:scale(.95)}.report-feedback-up:hover,.report-feedback-up:focus-visible{background:#38a16914;border-color:#38a169}.report-feedback-down:hover,.report-feedback-down:focus-visible{background:#e53e3e14;border-color:#e53e3e}.report-feedback-thanks{color:var(--brand-primary);margin:0;font-size:.95rem;font-weight:600}.loading-dots{justify-content:center;gap:5px;margin-bottom:10px;display:flex}.loading-dots span{background:#e65c5c;border-radius:50%;width:8px;height:8px;animation:1.5s ease-in-out infinite pulse}.access-status-card{border:2px solid var(--brand-primary);background:linear-gradient(135deg,#f8f9fa 0%,#e9ecef 100%)}.access-status-content{flex-direction:column;gap:20px;display:flex}.views-status{flex-direction:column;gap:12px;display:flex}.status-item{background:#fff;border-radius:12px;justify-content:space-between;align-items:center;padding:12px;display:flex}.status-item.highlight{border:1px solid var(--brand-primary);background:#e65c5c1a}.status-label{color:var(--text-secondary);font-size:14px;font-weight:600}.status-value{color:var(--brand-primary);font-size:16px;font-weight:800}.referral-section{border:2px dashed var(--brand-primary);background:#fff;border-radius:16px;padding:20px}.referral-title{color:var(--text-primary);margin-bottom:8px;font-size:16px;font-weight:700}.referral-desc{color:var(--text-secondary);margin-bottom:16px;font-size:13px;line-height:1.6}.max-reached-badge{color:#856404;background:linear-gradient(135deg,gold 0%,#ffed4e 100%);border:2px solid #ffc107;border-radius:12px;align-items:center;gap:8px;margin-bottom:12px;padding:10px 16px;font-size:14px;font-weight:700;display:flex}.badge-icon{font-size:18px}.badge-text{flex:1}.referral-link-box{gap:8px;display:flex}.referral-link-input{border:1px solid var(--bg-surface);background:var(--bg-surface);color:var(--text-primary);border-radius:12px;flex:1;padding:12px;font-size:12px}.copy-link-button{background:var(--brand-primary);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:12px;padding:12px 20px;font-size:14px;font-weight:700}.copy-link-button:active{transform:scale(.98)}.referral-cta{border-top:1px solid var(--bg-surface);text-align:center;margin-top:20px;padding-top:20px}.referral-cta p{color:var(--text-secondary);margin-bottom:12px;font-size:13px}.referral-cta-button{background:var(--bg-surface);color:var(--brand-primary);border:1px solid var(--brand-primary);cursor:pointer;border-radius:20px;padding:10px 20px;font-size:14px;font-weight:600}.referral-cta-button:active{transform:scale(.98)}.report-header-info{border-bottom:1px solid var(--bg-surface);justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;display:flex}.views-badge{color:var(--brand-primary);background:#e65c5c1a;border-radius:12px;padding:6px 12px;font-size:12px;font-weight:700}.messages-list-container{background:var(--bg-app);flex-direction:column;height:auto;min-height:100%;display:flex;overflow:hidden visible}.messages-header{padding:calc(var(--safe-top) + 20px) 24px 10px;background:var(--bg-app)}.messages-header h2{color:var(--text-primary);font-size:2rem;font-weight:800}.section-title{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:1px;margin:16px 24px 8px;font-size:.8rem;font-weight:700}.matches-row{margin-bottom:10px}.matches-scroll{-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:16px;padding:0 24px;display:flex;overflow-x:auto}.matches-scroll::-webkit-scrollbar{display:none}.match-avatar-item{cursor:pointer;flex-direction:column;align-items:center;gap:6px;display:flex}.avatar-circle{background:linear-gradient(135deg, var(--bg-surface) 0%, #e0dbd0 100%);width:64px;height:64px;color:var(--brand-primary);box-shadow:var(--shadow-sm);border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;font-size:1.5rem;font-weight:800;display:flex}.avatar-circle-image{object-fit:cover;border-radius:50%;width:100%;height:100%}.avatar-name{color:var(--text-primary);font-size:.8rem;font-weight:600}.conversations-list{flex:none;padding:0 24px;overflow:visible}.conversations-list .section-title{margin-left:0;margin-right:0}.conversation-item{cursor:pointer;border-radius:16px;align-items:center;gap:16px;padding:12px;transition:background .2s;display:flex}.conversation-item:active{background:var(--bg-surface)}.item-avatar{background:var(--bg-surface);width:56px;height:56px;color:var(--brand-primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1.2rem;font-weight:800;display:flex;position:relative}.item-avatar-image{object-fit:cover;border-radius:50%;width:100%;height:100%}.unread-dot{background:var(--brand-primary);border:2px solid var(--bg-app);border-radius:50%;width:12px;height:12px;position:absolute;top:0;right:0}.online-status-dot{border:2px solid var(--bg-card);border-radius:50%;width:12px;height:12px;transition:background-color .3s;position:absolute;bottom:2px;right:2px}.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{justify-content:space-between;align-items:baseline;margin-bottom:4px;display:flex}.item-name-row{align-items:center;gap:6px;display:flex}.item-name{color:var(--text-primary);font-size:1rem;font-weight:700}.item-status-indicator{font-size:.85rem;animation:2s ease-in-out infinite pulse}.item-time{color:var(--text-tertiary);font-size:.75rem}.item-bottom{justify-content:space-between;align-items:center;display:flex}.item-preview{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;flex:1;margin-right:8px;font-size:.9rem;overflow:hidden}.item-preview.unread{color:var(--text-primary);font-weight:600}.unread-badge{background:var(--brand-primary);color:#fff;border-radius:10px;justify-content:center;align-items:center;min-width:20px;height:20px;padding:0 6px;font-size:.75rem;font-weight:700;display:flex}.typing-text{color:var(--brand-primary);font-size:.85rem;font-style:italic}.messages-list-empty{height:100%;color:var(--text-tertiary);text-align:center;flex-direction:column;justify-content:center;align-items:center;padding-bottom:80px;padding-left:20px;padding-right:20px;display:flex}.empty-icon{opacity:.5;margin-bottom:16px;font-size:4rem}.messages-list-empty h3{color:var(--text-primary);margin-bottom:8px;font-size:1.3rem;font-weight:700}.messages-list-empty p{color:var(--text-secondary);margin-bottom:20px;font-size:.95rem;line-height:1.5}.empty-cta-btn{background:var(--brand-primary);color:#fff;cursor:pointer;border:none;border-radius:24px;padding:12px 32px;font-size:1rem;font-weight:600;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{background:var(--bg-app);flex-direction:column;height:auto;min-height:0;display:flex;position:relative;overflow:hidden}.profile-scroll-container{padding:calc(max(var(--safe-top), 24px) + 20px) 20px calc(var(--safe-bottom) + 30px);flex:none;overflow:visible}.profile-header-card{background:var(--bg-card);text-align:center;box-shadow:var(--shadow-md);border:1px solid var(--border-subtle);border-radius:32px;flex-direction:column;align-items:center;margin-bottom:24px;padding:32px 24px;display:flex;position:relative}.profile-avatar-wrapper{margin-bottom:20px;position:relative}.profile-avatar-large{background:var(--bg-surface);width:100px;height:100px;box-shadow:var(--shadow-sm);border:4px solid #fff;border-radius:50%;justify-content:center;align-items:center;font-size:3.5rem;display:flex}.edit-avatar-btn{background:var(--brand-primary);color:#fff;width:32px;height:32px;box-shadow:var(--shadow-sm);border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;font-size:.9rem;display:flex;position:absolute;bottom:0;right:0}.profile-display-name{color:var(--text-primary);letter-spacing:-.5px;margin-bottom:6px;font-size:1.6rem;font-weight:800}.profile-display-bio{color:var(--text-secondary);max-width:80%;font-size:.95rem;font-weight:500;line-height:1.5}.profile-stats-grid{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:32px;display:grid}.stat-card{background:var(--bg-card);box-shadow:var(--shadow-sm);border:1px solid var(--border-subtle);border-radius:24px;flex-direction:column;align-items:center;padding:20px;display:flex}.stat-value{color:var(--brand-primary);margin-bottom:4px;font-size:1.4rem;font-weight:800}.stat-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:1px;font-size:.75rem;font-weight:700}.settings-section{margin-bottom:32px}.section-title{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:1px;margin-bottom:12px;margin-left:12px;font-size:.85rem;font-weight:800}.settings-list{background:var(--bg-card);box-shadow:var(--shadow-sm);border:1px solid var(--border-subtle);border-radius:24px;overflow:hidden}.setting-item{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding:18px 20px;transition:background .2s;display:flex}.setting-item:last-child{border-bottom:none}.setting-item:active{background:var(--bg-surface)}.setting-info{align-items:center;gap:14px;display:flex}.setting-icon{background:var(--bg-surface);border-radius:12px;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.2rem;display:flex}.setting-label{color:var(--text-primary);font-size:1rem;font-weight:600}.setting-arrow{color:var(--text-tertiary);font-weight:700}.toggle-switch{background:#dfe6e9;border-radius:12px;width:44px;height:24px;transition:all .3s;position:relative}.toggle-switch:after{content:"";background:#fff;border-radius:50%;width:20px;height:20px;transition:all .3s;position:absolute;top:2px;left:2px;box-shadow:0 2px 4px #0000001a}.toggle-switch.active{background:#55efc4}.toggle-switch.active:after{left:22px}.logout-area{text-align:center;margin-top:10px}.logout-btn{color:#ff7675;background:#fff;border:1px solid #fab1a0;border-radius:20px;width:100%;margin-bottom:16px;padding:18px;font-size:1rem;font-weight:700}.version-text{color:var(--text-tertiary);font-size:.75rem;font-weight:500}.edit-modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#0006;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.edit-modal{-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;width:100%;max-width:500px;max-height:85vh;padding:32px 24px calc(var(--safe-bottom) + 24px);background:#fff;border-top-left-radius:32px;border-top-right-radius:32px;margin:0 auto;animation:.3s cubic-bezier(.2,.8,.2,1) slideUp;overflow-y:auto}@media (width>=600px){.edit-modal-overlay{align-items:center}.edit-modal{-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;border-radius:32px;max-height:90vh;margin:20px;padding-bottom:32px;overflow-y:auto}}.modal-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.modal-header h3{font-size:1.3rem;font-weight:800}.close-modal{background:var(--bg-surface);width:32px;height:32px;color:var(--text-secondary);border-radius:50%;justify-content:center;align-items:center;display:flex}.avatar-selection{margin-bottom:24px}.avatar-selection label{color:var(--text-tertiary);text-transform:uppercase;margin-bottom:12px;font-size:.85rem;font-weight:800;display:block}.avatar-grid{scrollbar-width:none;gap:12px;padding-bottom:8px;display:flex;overflow-x:auto}.avatar-grid::-webkit-scrollbar{display:none}.avatar-option{background:var(--bg-surface);border:2px solid #0000;border-radius:16px;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;font-size:1.8rem;transition:all .2s;display:flex}.avatar-option.selected{border-color:var(--brand-primary);box-shadow:var(--shadow-sm);background:#fff;transform:scale(1.1)}.input-group{margin-bottom:24px}.input-group label{color:var(--text-tertiary);text-transform:uppercase;margin-bottom:8px;font-size:.85rem;font-weight:800;display:block}.input-group input,.input-group textarea{background:var(--bg-surface);width:100%;color:var(--text-primary);border:1px solid #0000;border-radius:16px;padding:14px 16px;font-family:inherit;font-size:1rem;font-weight:600}.input-group input:focus,.input-group textarea:focus{border-color:var(--brand-primary);background:#fff}.modal-actions{gap:12px;margin-top:8px;display:flex}.modal-btn{border-radius:18px;flex:1;padding:16px;font-size:1rem;font-weight:700}.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{flex-direction:column;min-height:400px;display:flex}.test-content{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;display:flex}.test-question{color:var(--text-primary);margin-bottom:32px;font-size:1.2rem;font-weight:700;line-height:1.6}.test-options{flex-direction:column;gap:12px;width:100%;display:flex}.test-option-btn{background:var(--bg-surface);width:100%;color:var(--text-primary);border:1px solid #0000;border-radius:16px;padding:16px;font-size:1rem;font-weight:600;transition:all .2s}.test-option-btn:active{border-color:var(--brand-primary);color:var(--brand-primary);background:#fff;transform:scale(.98)}.analysis-screen .input-group select{width:100%;color:var(--text-primary,#1f1f1f);background:#fff;border:1px solid #0000001f;border-radius:12px;padding:12px 14px;font-size:14px}.analysis-screen .conversation-item .item-preview{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.analysis-screen .conversation-item .item-status-indicator{font-size:14px}.bottom-nav{height:calc(60px + var(--safe-bottom));background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border-top:1px solid var(--border-subtle);z-index:50;flex-shrink:0;justify-content:space-around;align-items:flex-start;width:100%;padding-top:8px;display:flex;position:relative}.nav-item{color:var(--text-tertiary);flex-direction:column;align-items:center;gap:4px;width:60px;transition:all .2s;display:flex}.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{background:var(--brand-primary);color:#fff;border:2px solid #fff;border-radius:8px;justify-content:center;align-items:center;min-width:16px;height:16px;font-size:.6rem;font-weight:700;display:flex;position:absolute;top:-2px;right:-6px}.invitation-gate{z-index:9999;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:center;align-items:center;width:100vw;height:100vh;padding:20px;display:flex;position:fixed;top:0;left:0}.gate-content{text-align:center;background:#fff;border-radius:24px;width:100%;max-width:400px;padding:40px;box-shadow:0 20px 40px #0003}.gate-logo{color:#764ba2;margin-bottom:20px;font-size:24px;font-weight:700}.gate-content h1{color:#1a1a1a;margin:0 0 15px;font-size:24px}.gate-content p{color:#666;margin-bottom:30px;font-size:14px;line-height:1.6}.gate-content form{flex-direction:column;gap:15px;display:flex}.gate-content input{text-align:center;letter-spacing:2px;border:2px solid #eee;border-radius:12px;padding:15px;font-size:16px;transition:all .3s}.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:.5s shake}.gate-content button{color:#fff;cursor:pointer;background:#764ba2;border:none;border-radius:12px;padding:15px;font-size:16px;font-weight:700;transition:transform .2s}.gate-content button:active{transform:scale(.98)}.error-message{color:#ff4d4f;margin-top:-5px;font-size:12px}.gate-footer{color:#999;margin-top:30px;font-size:12px}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.app{background-color:var(--bg-app);flex-direction:column;width:100%;height:100%;min-height:0;display:flex;position:relative;overflow:hidden}.back-button{top:calc(var(--safe-top) + 12px);z-index:50;background:var(--glass-bg);width:44px;height:44px;-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);box-shadow:var(--shadow-sm);color:var(--text-primary);transition:transform .2s var(--ease-smooth);border-radius:50%;justify-content:center;align-items:center;font-size:1.2rem;display:flex;position:absolute;left:20px}.back-button:active{transform:scale(.92)}.page-transition{animation:fadeIn .4s var(--ease-smooth)}.page-transition.scroll-area-phone{-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;flex-direction:column;flex:1;align-items:flex-start;min-height:0;display:flex;overflow:hidden auto}.page-transition.scroll-area-phone>*{flex-shrink:0;width:100%}body[data-profile-modal-open] .page-transition.scroll-area-phone{overflow:hidden}.fullscreen-view{z-index:100;background-color:var(--bg-app);flex-direction:column;width:100%;height:100%;min-height:0;display:flex;position:absolute;top:0;left:0;overflow:hidden}*{box-sizing:border-box;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;padding:0}:root{--brand-primary:#e65c5c;--brand-secondary:#2d3436;--brand-accent:#ff9f43;--bg-app:#fdfbf7;--bg-card:#fff;--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:#fff;--border-subtle:#0000000a;--border-focus:#e65c5c;--shadow-sm:0 2px 8px #2d34360a;--shadow-md:0 8px 24px #2d343614;--shadow-lg:0 16px 48px #2d34361f;--shadow-floating:0 20px 60px #e65c5c40;--glass-bg:#ffffffd9;--glass-border:#ffffff80;--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{background-color:var(--bg-app);-webkit-text-size-adjust:100%;width:100%;height:100%;min-height:100dvh;overflow:hidden}body{background-color:var(--bg-app);width:100%;height:100%;min-height:100dvh;min-height:-webkit-fill-available;color:var(--text-primary);justify-content:center;font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.6;display:flex;overflow:hidden}#root{background-color:var(--bg-app);width:100%;height:100%;position:relative;overflow:hidden}@media (width>=768px){body{background-color:#f0f2f5;align-items:center;min-height:100vh}#root{background-color:var(--bg-app);border-radius:24px;max-width:480px;height:90vh;position:relative;overflow:hidden;box-shadow:0 20px 60px #0000001a}}@media (width<=767px){html,body{height:100dvh;min-height:100dvh;position:fixed;inset:0;overflow:hidden}#root{width:100%;height:100%;min-height:100dvh;overflow:hidden}}.scroll-area-phone{-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;overflow-x:hidden}button{cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;font-family:inherit}input,textarea{-webkit-appearance:none;outline:none;font-family:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-thumb{background:#0000001a;border-radius:3px}::-webkit-scrollbar-track{background:0 0}
