- 超级个体:去掉首位特例;列表仅展示有头像且非微信默认昵称(vip.go) - 个人资料:居中头像、低调联系方式、点头像优先走存客宝 lead(ckbLeadToken) - 阅读页分享朋友圈复制与 toast 去重 - soul-api: miniprogram users 带 ckbLeadToken;其它 handler 与路由调整 - 脚本:content_upload、miniprogram 上传辅助等 Made-with: Cursor
184 lines
8.0 KiB
Plaintext
184 lines
8.0 KiB
Plaintext
/* 卡若创业派对 - 个人资料展示(与 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); } }
|