*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #f97316;--primary-light: #fed7aa;--bg: #fffbeb;--text: #1c1917;--text-light: #78716c;--card-bg: #ffffff;--shadow: 0 2px 8px rgba(0, 0, 0, .08)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;min-height:100dvh;overflow:hidden}#app{height:100vh;height:100dvh;display:flex;flex-direction:column}.app-container{display:flex;flex-direction:column;height:100%;max-width:480px;margin:0 auto;background:var(--bg)}.app-header{background:var(--card-bg);box-shadow:var(--shadow);padding:10px 16px 0;position:sticky;top:0;z-index:10}.header-content{display:flex;align-items:center;gap:10px;margin-bottom:8px}.header-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;border:2px solid var(--primary-light);cursor:pointer}.header-avatar:active{transform:scale(.95)}.header-info{display:flex;align-items:center;gap:8px;flex:1}.header-info h1{font-size:16px;font-weight:600}.trip-day-badge{font-size:11px;padding:2px 8px;background:var(--primary-light);color:var(--primary);border-radius:10px;font-weight:500;white-space:nowrap}.progress-bar{margin-bottom:8px;padding:6px 0;overflow-x:auto;-webkit-overflow-scrolling:touch}.progress-spots{display:flex;gap:12px;margin-bottom:4px;min-width:max-content;padding:0 4px}.progress-dot{display:flex;flex-direction:column;align-items:center;gap:2px;cursor:pointer;transition:transform .2s}.progress-dot:active{transform:scale(1.1)}.dot-icon{font-size:14px}.dot-label{font-size:9px;color:var(--text-light)}.progress-dot.checked .dot-label{color:var(--primary);font-weight:600}.progress-dot.current .dot-label{color:#059669;font-weight:600}.progress-line{height:3px;background:#e5e5e5;border-radius:2px;margin-top:2px}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),#f59e0b);border-radius:2px;transition:width .5s ease}.tab-nav{display:flex;gap:4px}.tab-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:4px;padding:9px 6px;border:none;background:none;cursor:pointer;border-bottom:2px solid transparent;border-radius:8px 8px 0 0;transition:all .2s}.tab-btn.active{border-bottom-color:var(--primary);background:var(--primary-light)}.tab-icon{font-size:15px}.tab-label{font-size:12px;color:var(--text-light)}.tab-btn.active .tab-label{color:var(--primary);font-weight:600}.chat-area{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.welcome{display:flex;flex-direction:column;align-items:center;text-align:center;padding:30px 20px;gap:10px}.welcome-avatar{width:72px;height:72px;border-radius:50%;object-fit:cover;border:3px solid var(--primary-light);box-shadow:0 4px 12px #f9731633}.welcome-emoji{font-size:44px}.welcome h2{font-size:19px}.welcome p{font-size:13px;color:var(--text-light);white-space:pre-line}.quick-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:10px}.quick-btn{padding:7px 13px;border:1px solid var(--primary-light);border-radius:20px;background:var(--card-bg);color:var(--primary);font-size:13px;cursor:pointer}.quick-btn:active{background:var(--primary-light)}.message{display:flex;flex-direction:column}.message.user{align-items:flex-end}.message.assistant{align-items:flex-start}.message-bubble{max-width:85%;padding:12px 16px;border-radius:18px;font-size:15px;line-height:1.5;word-break:break-word}.message.user .message-bubble{background:var(--primary);color:#fff;border-bottom-right-radius:4px}.message.assistant .message-bubble{background:var(--card-bg);color:var(--text);border-bottom-left-radius:4px;box-shadow:var(--shadow)}.msg-actions{display:flex;gap:6px;margin-top:6px}.msg-action-btn{padding:3px 10px;border:1px solid var(--primary-light);border-radius:12px;background:var(--bg);color:var(--primary);font-size:11px;cursor:pointer}.msg-action-btn:active{background:var(--primary-light)}.msg-action-btn:disabled{opacity:.5;cursor:not-allowed}.surprise-popup{margin-top:8px;padding:12px 16px;background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:12px;border:1px solid #f59e0b;max-width:85%;animation:popIn .3s ease}.surprise-icon{font-size:20px}.surprise-popup p{margin-top:4px;font-size:14px;color:#92400e;font-style:italic}@keyframes popIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.loading-bubble{display:flex;gap:4px;padding:16px 20px}.dot{width:8px;height:8px;border-radius:50%;background:var(--text-light);animation:bounce 1.4s infinite ease-in-out both}.dot:nth-child(1){animation-delay:0s}.dot:nth-child(2){animation-delay:.16s}.dot:nth-child(3){animation-delay:.32s}@keyframes bounce{0%,80%,to{transform:scale(.6)}40%{transform:scale(1)}}.input-area{padding:10px 16px;padding-bottom:env(safe-area-inset-bottom,10px);background:var(--card-bg);box-shadow:0 -2px 8px #0000000d}.input-wrapper{display:flex;align-items:flex-end;gap:6px;background:#f5f5f4;border-radius:24px;padding:6px 10px}.input-wrapper textarea{flex:1;border:none;background:none;outline:none;resize:none;font-size:15px;line-height:1.4;max-height:80px;padding:4px 0;font-family:inherit}.tool-btn{width:30px;height:30px;border:none;background:none;font-size:16px;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.tool-btn:active{background:var(--primary-light)}.hold-to-talk{flex:1;height:36px;border-radius:6px;border:1px solid #ddd;background:#f7f7f7;font-size:14px;color:var(--text);cursor:pointer;transition:all .15s;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.hold-to-talk.recording{background:#e8f5e9;border-color:#4caf50;color:#2e7d32;font-weight:600;transform:scale(.97)}.hold-to-talk:active{background:#e0e0e0;transform:scale(.97)}.voice-hint{text-align:center;font-size:12px;color:#4caf50;margin-top:6px;font-weight:500}.voice-error{text-align:center;font-size:12px;color:#ef4444;margin-top:4px}.input-tools{display:flex;justify-content:center;padding-top:4px}.send-btn{width:34px;height:34px;border-radius:50%;border:none;background:var(--primary);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.send-btn:disabled{opacity:.4;cursor:not-allowed}.send-btn:active:not(:disabled){transform:scale(.95)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100;padding:20px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.profile-card{background:#fff;border-radius:20px;padding:28px 20px;text-align:center;max-width:320px;width:100%;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.profile-avatar{width:90px;height:90px;border-radius:50%;object-fit:cover;border:3px solid var(--primary-light);margin-bottom:12px}.profile-card h2{font-size:17px;margin-bottom:4px}.profile-date{color:var(--text-light);font-size:12px;margin-bottom:14px}.profile-progress{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:12px}.profile-spot{font-size:13px;display:flex;align-items:center;gap:3px}.profile-stat{font-size:13px;color:var(--primary);font-weight:600;margin-bottom:14px}.profile-close{padding:8px 24px;border:1px solid #e5e5e5;border-radius:20px;background:#fff;color:var(--text-light);cursor:pointer;font-size:14px}.share-card-wrapper{max-width:380px;width:100%;animation:slideUp .3s ease}.share-card{background:linear-gradient(135deg,#fffbeb,#fef3c7);border-radius:16px;padding:20px 16px;border:1px solid #fde68a}.share-card-header{display:flex;align-items:center;gap:10px;margin-bottom:14px}.share-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;border:2px solid var(--primary-light)}.share-name{font-size:13px;font-weight:600}.share-date{font-size:11px;color:var(--text-light)}.share-card-body{margin-bottom:14px}.share-content{font-size:12px;color:var(--text-light);font-style:italic;margin-bottom:10px;padding-left:10px;border-left:2px solid var(--primary-light)}.share-ai-text{font-size:14px;line-height:1.6}.share-card-footer{display:flex;justify-content:space-between;font-size:11px;color:var(--text-light);padding-top:10px;border-top:1px solid #fde68a}.share-actions{display:flex;gap:8px;margin-top:10px}.share-btn{flex:1;padding:10px 8px;border-radius:12px;border:none;font-size:13px;cursor:pointer}.copy-btn{background:var(--primary);color:#fff}.save-btn{background:#059669;color:#fff}.close-share{background:#e5e5e5;color:var(--text-light)}.share-btn:active{transform:scale(.97)}.export-modal{background:#fff;border-radius:20px;padding:24px;max-width:320px;width:100%;animation:slideUp .3s ease}.export-modal h3{font-size:17px;margin-bottom:14px;text-align:center}.export-options{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}.export-btn{padding:13px 16px;border:1px solid #e5e5e5;border-radius:12px;background:#fff;font-size:14px;cursor:pointer;text-align:left}.export-btn:active{background:var(--primary-light);border-color:var(--primary)}.memoir-btn{margin-top:16px;padding:14px 24px;background:linear-gradient(135deg,#f97316,#f59e0b);color:#fff;border:none;border-radius:24px;font-size:15px;font-weight:600;cursor:pointer;box-shadow:0 4px 12px #f973164d;transition:all .2s}.memoir-btn:active{transform:scale(.97);box-shadow:0 2px 8px #f9731633}.tool-btn.active{background:var(--primary-light);border-radius:50%}.photo-preview{padding:8px 16px 0;position:relative;display:inline-block}.photo-preview img{width:60px;height:60px;object-fit:cover;border-radius:8px;border:1px solid #e5e5e5}.photo-remove{position:absolute;top:4px;right:12px;width:20px;height:20px;border-radius:50%;border:none;background:#00000080;color:#fff;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center}.photo-label{cursor:pointer}.msg-photo{max-width:200px;max-height:200px;border-radius:10px;margin-bottom:6px;display:block;cursor:pointer;border:1px solid #e5e5e5}.login-screen{height:100vh;height:100dvh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#fffbeb,#fed7aa);padding:20px}.login-card{background:#fff;border-radius:24px;padding:40px 28px;text-align:center;max-width:320px;width:100%;box-shadow:0 8px 32px #f9731626}.login-avatar{width:80px;height:80px;border-radius:50%;object-fit:cover;border:3px solid var(--primary-light);margin-bottom:16px}.login-card h2{font-size:18px;margin-bottom:6px;color:var(--text)}.login-hint{font-size:13px;color:var(--text-light);margin-bottom:20px}.login-input{width:100%;padding:12px 16px;border:2px solid #e5e5e5;border-radius:12px;font-size:16px;text-align:center;outline:none;transition:border-color .2s}.login-input:focus{border-color:var(--primary)}.login-btn{width:100%;margin-top:14px;padding:12px;border:none;border-radius:12px;background:var(--primary);color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s}.login-btn:active{transform:scale(.97)}.login-btn:disabled{opacity:.6}.login-error{margin-top:10px;font-size:13px;color:#ef4444}.lightbox{cursor:zoom-out}.lightbox-img{max-width:90%;max-height:85vh;object-fit:contain;border-radius:8px;box-shadow:0 8px 32px #0000004d}.progress-bar::-webkit-scrollbar{display:none}.progress-bar{-ms-overflow-style:none;scrollbar-width:none}.change-pwd-form{margin:12px 0}.profile-actions{display:flex;gap:8px;justify-content:center;margin-top:14px;flex-wrap:wrap}.pwd-ok{font-size:13px;color:#059669}.voice-msg{display:flex;align-items:center;gap:8px;padding:4px 0;cursor:pointer;min-width:120px}.voice-icon{font-size:18px}.voice-bar{flex:1;height:4px;background:#e5e5e5;border-radius:2px;overflow:hidden}.voice-bar-fill{width:60%;height:100%;background:var(--primary);border-radius:2px}.voice-sec{font-size:12px;color:var(--text-light);white-space:nowrap}.message.user .voice-bar-fill{background:#fff}.message.user .voice-bar{background:#ffffff4d}.message.user .voice-sec{color:#fffc}
