/* 卡若创业派对 - 个人资料展示(与 member-detail 同一视觉语言) */ .page { background: radial-gradient(120% 80% at 50% -20%, rgba(20, 80, 90, 0.35) 0%, #050B14 45%); min-height: 100vh; color: #fff; } /* —— 导航 —— */ .nav-bar { position: fixed; top: 0; left: 0; right: 0; z-index: 999; display: flex; align-items: center; justify-content: space-between; padding: 0 28rpx; height: 44px; background: rgba(5, 11, 20, 0.72); backdrop-filter: blur(20rpx); -webkit-backdrop-filter: blur(20rpx); border-bottom: 1rpx solid rgba(255, 255, 255, 0.06); } .nav-back { width: 72rpx; height: 72rpx; display: flex; align-items: center; justify-content: flex-start; } .nav-icon { font-size: 44rpx; color: #5eead4; font-weight: 300; } .nav-title { font-size: 32rpx; font-weight: 600; color: #f8fafc; letter-spacing: 4rpx; } .nav-edit { width: 72rpx; height: 72rpx; display: flex; align-items: center; justify-content: flex-end; } .scroll-wrap { box-sizing: border-box; } /* —— 首屏外壳 —— */ .shell { position: relative; margin: 28rpx 24rpx 0; padding: 40rpx 32rpx 36rpx; border-radius: 32rpx; background: linear-gradient(145deg, rgba(22, 36, 48, 0.95) 0%, rgba(12, 20, 32, 0.98) 100%); border: 1rpx solid rgba(94, 234, 212, 0.12); box-shadow: 0 24rpx 80rpx rgba(0, 0, 0, 0.45), inset 0 1rpx 0 rgba(255, 255, 255, 0.06); overflow: hidden; } .shell-glow { position: absolute; top: -40%; right: -20%; width: 70%; height: 80%; background: radial-gradient(circle, rgba(45, 212, 191, 0.12) 0%, transparent 70%); pointer-events: none; } .hero-row { position: relative; z-index: 1; display: flex; align-items: flex-start; gap: 28rpx; } .avatar-outer { position: relative; width: 168rpx; height: 168rpx; flex-shrink: 0; } .avatar-wrap { width: 100%; height: 100%; border-radius: 50%; overflow: hidden; border: 2rpx solid rgba(255, 255, 255, 0.12); box-shadow: 0 12rpx 40rpx rgba(0, 0, 0, 0.35); } .avatar-img { width: 100%; height: 100%; object-fit: cover; } .avatar-ph { width: 100%; height: 100%; background: #1a2332; display: flex; align-items: center; justify-content: center; font-size: 52rpx; color: #5eead4; font-weight: 700; } /* 右侧联系方式列 */ .link-column { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 16rpx; } .link-column-title { font-size: 26rpx; font-weight: 700; color: #f1f5f9; letter-spacing: 2rpx; } .link-chip { display: flex; align-items: center; gap: 20rpx; padding: 22rpx; border-radius: 20rpx; background: rgba(15, 23, 42, 0.65); border: 1rpx solid rgba(94, 234, 212, 0.25); } .link-chip:active { background: rgba(15, 30, 40, 0.75); } .link-chip-icon { width: 64rpx; height: 64rpx; border-radius: 16rpx; display: flex; align-items: center; justify-content: center; flex-shrink: 0; } .link-chip-icon-phone { background: rgba(45, 212, 191, 0.12); } .link-chip-icon-wx { background: rgba(52, 211, 153, 0.12); } .lc-ic { display: block; } .link-chip-main { flex: 1; min-width: 0; } .link-chip-label { display: block; font-size: 20rpx; color: #94a3b8; margin-bottom: 6rpx; } .link-chip-val { display: block; font-size: 26rpx; font-weight: 600; color: #f8fafc; line-height: 1.35; word-break: break-all; } .link-chip-val.mono { font-family: ui-monospace, monospace; letter-spacing: 1rpx; } .link-chip-action { flex-shrink: 0; font-size: 22rpx; font-weight: 600; color: #5eead4; } .link-empty { padding: 24rpx; border-radius: 20rpx; background: rgba(15, 23, 42, 0.4); border: 1rpx dashed rgba(148, 163, 184, 0.2); } .link-empty-txt { font-size: 24rpx; color: #64748b; } .profile-name { position: relative; z-index: 1; display: block; text-align: center; margin-top: 36rpx; font-size: 40rpx; font-weight: 700; color: #fff; letter-spacing: 4rpx; } .profile-tags { position: relative; z-index: 1; display: flex; align-items: center; justify-content: center; gap: 20rpx; flex-wrap: wrap; margin-top: 24rpx; } .tag { font-size: 24rpx; font-weight: 500; padding: 10rpx 26rpx; border-radius: 999rpx; } .tag-mbti { background: rgba(19, 78, 74, 0.6); color: #5eead4; border: 1rpx solid rgba(94, 234, 212, 0.25); } .tag-region { background: rgba(30, 41, 59, 0.8); color: #cbd5e1; border: 1rpx solid rgba(255, 255, 255, 0.08); display: flex; align-items: center; gap: 8rpx; } .pin-icon { color: #f87171; font-size: 22rpx; } /* —— 一体化信息卡 —— */ .mono-card { margin: 24rpx 24rpx 0; padding: 8rpx 0 32rpx; border-radius: 32rpx; background: rgba(15, 23, 34, 0.88); border: 1rpx solid rgba(255, 255, 255, 0.07); box-shadow: 0 16rpx 48rpx rgba(0, 0, 0, 0.25); } .mono-sec { padding: 28rpx 32rpx 8rpx; } .mono-sec-head { margin-bottom: 24rpx; } .mono-sec-title { font-size: 32rpx; font-weight: 700; color: #f8fafc; } .mono-divider { height: 1rpx; margin: 8rpx 32rpx; background: linear-gradient(90deg, transparent, rgba(148, 163, 184, 0.15), transparent); } .kv { margin-bottom: 28rpx; } .kv:last-child { margin-bottom: 8rpx; } .kv-k { display: block; font-size: 22rpx; color: #64748b; margin-bottom: 10rpx; } .kv-v { font-size: 28rpx; color: #e2e8f0; line-height: 1.65; font-weight: 500; } .skills-showcase .skills-quote { padding: 28rpx 28rpx 28rpx 24rpx; border-radius: 20rpx; background: linear-gradient(105deg, rgba(45, 212, 191, 0.08) 0%, rgba(15, 23, 42, 0.5) 100%); border-left: 6rpx solid #2dd4bf; box-shadow: inset 0 0 0 1rpx rgba(45, 212, 191, 0.12); } .skills-quote-text { font-size: 30rpx; color: #f1f5f9; line-height: 1.75; font-weight: 500; } .story { margin-bottom: 8rpx; } .story-gap { height: 28rpx; } .story-head { display: flex; align-items: center; gap: 12rpx; margin-bottom: 12rpx; } .story-icon { flex-shrink: 0; } .story-q { font-size: 24rpx; font-weight: 600; color: #94a3b8; } .story-a { display: block; font-size: 28rpx; color: #e2e8f0; line-height: 1.7; padding-left: 4rpx; } .help-grid { display: flex; flex-direction: column; gap: 20rpx; } .help-tile { padding: 28rpx; border-radius: 22rpx; background: rgba(23, 33, 47, 0.9); border: 1rpx solid rgba(255, 255, 255, 0.06); } .help-tile-tag { display: inline-block; font-size: 20rpx; font-weight: 700; padding: 8rpx 18rpx; border-radius: 12rpx; margin-bottom: 16rpx; } .help-give .help-tile-tag { color: #5eead4; background: rgba(6, 78, 59, 0.45); border: 1rpx solid rgba(45, 212, 191, 0.2); } .help-need .help-tile-tag.need { color: #fbbf24; background: rgba(69, 47, 8, 0.45); border: 1rpx solid rgba(251, 191, 36, 0.2); } .help-tile-txt { font-size: 28rpx; color: #f1f5f9; line-height: 1.65; } .proj-body { font-size: 28rpx; color: #cbd5e1; line-height: 1.75; padding-bottom: 8rpx; } /* —— 空态 —— */ .empty-hint { margin: 48rpx 24rpx; padding: 64rpx 32rpx; display: flex; flex-direction: column; align-items: center; gap: 24rpx; border-radius: 28rpx; background: rgba(15, 23, 34, 0.5); border: 1rpx dashed rgba(148, 163, 184, 0.15); } .empty-hint-txt { font-size: 26rpx; color: #64748b; } .scroll-pad { height: calc(80rpx + env(safe-area-inset-bottom)); } /* —— 底部 —— */ .bottom-bar { position: fixed; bottom: 0; left: 0; right: 0; z-index: 50; padding: 20rpx 24rpx; padding-bottom: calc(20rpx + env(safe-area-inset-bottom)); background: rgba(5, 11, 20, 0.92); backdrop-filter: blur(20rpx); border-top: 1rpx solid rgba(255, 255, 255, 0.06); } .vip-btn { display: flex; align-items: center; justify-content: center; gap: 12rpx; width: 100%; height: 88rpx; border-radius: 999rpx; border: none; background: linear-gradient(135deg, #5eead4 0%, #2dd4bf 50%, #14b8a6 100%); color: #0f172a; font-size: 28rpx; font-weight: 700; box-shadow: 0 8rpx 28rpx rgba(45, 212, 191, 0.35); } .vip-btn:active { opacity: 0.85; } /* —— 加载态 —— */ .state-wrap { display: flex; flex-direction: column; align-items: center; justify-content: center; min-height: 60vh; gap: 24rpx; } .state-txt { font-size: 28rpx; color: #64748b; } .loading-dot { width: 56rpx; height: 56rpx; border-radius: 50%; border: 4rpx solid rgba(94, 234, 212, 0.2); border-top-color: #5eead4; animation: spin 1s linear infinite; } @keyframes spin { to { transform: rotate(360deg); } }