*{margin:0;padding:0;box-sizing:border-box;font-family:-apple-system,BlinkMacSystemFont,'PingFang SC','Helvetica Neue',sans-serif}
body{background:#f5f5f5;max-width:480px;margin:0 auto;min-height:100vh;position:relative}
/* 桌面端显示为手机框 — transform让所有fixed元素基于body而非视口 */
@media (min-width:481px){
  html{background:#e8e8e8}
  body{max-width:430px;margin:0 auto;box-shadow:0 0 30px rgba(0,0,0,.12);transform:translateZ(0)}}
.header{background:linear-gradient(135deg,#ff7a45,#e6423e);color:#fff;padding:12px 16px;display:flex;align-items:center;gap:12px}
.header h2{font-size:16px;font-weight:600}.header .back{font-size:20px;cursor:pointer;opacity:.9}
.bottom-nav{position:fixed;bottom:0;left:0;right:0;max-width:480px;margin:0 auto;background:#fff;display:flex;border-top:1px solid #f0f0f0;z-index:100}
.bottom-nav .nav-item{flex:1;text-align:center;padding:8px 0 6px;font-size:11px;color:#999;cursor:pointer}
.bottom-nav .nav-item.active{color:#e6423e}
.bottom-nav .nav-item .icon{font-size:20px;display:inline-block;margin-bottom:2px;position:relative}
.page{padding:0;display:none}.page.active{display:block}
/* 客服聊天 - 底部弹出卡片 */
#chat-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999;display:none}
#chat-overlay.active{display:block}
#chat-mask{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.45);z-index:1}
#chat-panel{position:fixed;bottom:0;left:0;right:0;max-width:480px;margin:0 auto;z-index:2;background:#fff;border-radius:16px 16px 0 0;display:flex;flex-direction:column;height:65vh;animation:chatSlideUp .3s ease}
@keyframes chatSlideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
#chat-panel .chat-handle{width:36px;height:4px;background:#ddd;border-radius:2px;margin:8px auto 0}/* 顶部小横条 */
.page-content{padding:12px 16px 70px}
.card{background:#fff;border-radius:10px;padding:12px;margin-bottom:10px;border:1px solid #f0f0f0}
.card-row{display:flex;justify-content:space-between;align-items:center}
.tag{font-size:10px;padding:2px 6px;border-radius:4px;display:inline-block}
.tag-red{background:#fff5f0;color:#d9363e}
.tag-green{background:#f6ffed;color:#52c41a}
.tag-orange{background:#fff7e6;color:#fa8c16}
.tag-blue{background:#e6f7ff;color:#1890ff}
.tag-purple{background:#f9f0ff;color:#722ed1}
.tag-gray{background:#f5f5f5;color:#999}
.btn{display:inline-block;padding:10px 16px;border:none;border-radius:8px;font-size:14px;font-weight:500;text-align:center;cursor:pointer;transition:opacity .15s}
.btn:active{opacity:.7}
.btn-block{display:block;width:100%}
.btn-primary{background:#e6423e;color:#fff}
.btn-outline{background:#fff;color:#d9363e;border:2px solid #ff4d4f}
.btn-success{background:#52c41a;color:#fff}
.btn-gray{background:#f0f0f0;color:#666}
.btn-sm{padding:6px 12px;font-size:12px}
.btn-orange{background:linear-gradient(135deg,#ff7a2e,#ff4d4f);color:#fff;border:none;box-shadow:0 2px 8px rgba(230,66,62,0.3)}
.btn-orange:active{opacity:.85}
.form-group{margin-bottom:14px}
.form-group label{display:block;font-size:13px;color:#333;margin-bottom:6px;font-weight:500}
.form-group input{width:100%;padding:12px 14px;border:1px solid #e0e0e0;border-radius:10px;font-size:15px;outline:none;background:#fafafa;transition:border-color .2s}
.form-group input:focus{border-color:#d9363e;background:#fff}
.form-group select,.form-group textarea{width:100%;padding:10px 12px;border:1px solid #e0e0e0;border-radius:10px;font-size:14px;outline:none;background:#fafafa}
.form-group select:focus,.form-group textarea:focus{border-color:#d9363e;background:#fff}
.checkbox-item{display:block;padding:6px 0;font-size:14px;cursor:pointer}
.checkbox-item input{margin-right:6px;vertical-align:middle;width:auto}
.q-opts{display:flex;flex-wrap:wrap;gap:12px}
.q-opts .checkbox-item input{display:none}
.q-opts .checkbox-item{display:inline-flex;align-items:center;position:relative;padding:6px 10px;font-size:14px;border-radius:6px;cursor:pointer;background:#fff;gap:4px}
.q-opts .checkbox-item::before{content:'';display:inline-block;width:12px;height:12px;border:1.5px solid #bbb;border-radius:2px;flex-shrink:0;box-sizing:border-box;transition:all .15s}
.q-opts .checkbox-item:has(input:checked)::before{background:#ff4d4f;border-color:#d9363e;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath fill='%23fff' d='M3 6L5 8L9 4' stroke='%23fff' stroke-width='1.8' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-size:10px;background-position:center;background-repeat:no-repeat}
.newbie-step{display:flex;align-items:center;gap:10px;padding:8px 0;cursor:pointer}
.newbie-step .step-num{width:28px;height:28px;background:#e6423e;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;flex-shrink:0}
.newbie-step .step-body{flex:1}
.newbie-step .step-title{font-size:14px;font-weight:500}
.newbie-step .step-desc{font-size:11px;color:#999;margin-top:2px}
.tag{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;white-space:nowrap}
.tag-gray{background:#f0f0f0;color:#999}
.tag-green{background:#e8f5e9;color:#2e7d32}
.tag-blue{background:#e3f2fd;color:#1565c0}
.tag-red{background:#ffebee;color:#c62828}
.tabs{border-bottom:1px solid #f0f0f0;margin-bottom:16px}
.tab{padding:10px 16px;font-size:13px;color:#999;border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap;display:inline-block;transition:all .2s}
.tab.active{color:#5a4a1a;font-weight:600;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.08)}
/* 累计收益卡片样式已移除（原income-card/income-row） */
.upload-box{border:2px dashed #ddd;border-radius:10px;padding:24px;text-align:center;color:#999;font-size:13px;background:#fafafa;cursor:pointer}
.upload-box.has-image{border-color:#52c41a;padding:8px}
.upload-box img{max-width:100%;max-height:120px;border-radius:6px}
.nb-badge{position:absolute;top:-3px;right:-3px;width:8px;height:8px;background:#ff4d4f;border-radius:50%;border:2px solid #fff}
.alert{padding:10px 14px;border-radius:8px;font-size:13px;margin-bottom:12px;line-height:1.5}
.alert-warning{background:#fff7e6;color:#d46b08;border:1px solid #ffd591}
.alert-success{background:#f6ffed;color:#52c41a;border:1px solid #b7eb8f}
.alert-error{background:#fff5f0;color:#d9363e;border:1px solid #ffa39e}
.alert-info{background:#e6f7ff;color:#1890ff;border:1px solid #91d5ff}
.price{color:#d9363e;font-weight:600}
.gray{color:#999}.text-center{text-align:center}.text-sm{font-size:13px}.text-xs{font-size:12px}
.fwb{font-weight:600}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mb-8{margin-bottom:8px}
.flex{display:flex;align-items:center;gap:8px}.flex-wrap{flex-wrap:wrap;gap:6px}
.empty-state{text-align:center;padding:40px 20px;color:#999}
.empty-state .icon{font-size:48px;margin-bottom:12px}
.loading{text-align:center;padding:20px;color:#999;font-size:13px}
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:200;display:none;align-items:center;justify-content:center}
.modal-overlay.show{display:flex}
.modal-content{background:#fff;border-radius:16px;padding:20px;width:85%;max-width:360px;text-align:center}
.copy-btn{display:inline-block;font-size:13px;color:#d9363e;background:#fff5f0;border:1px solid #ffccc7;border-radius:6px;padding:6px 12px;cursor:pointer;margin-left:4px;margin-top:6px;line-height:1.2;white-space:nowrap;user-select:none}.copy-btn:active{background:#ffd4d0}
/* 消息通知徽标 */
.msg-badge{position:absolute;top:-5px;right:-8px;min-width:18px;height:18px;background:#fff;color:#d9363e;border-radius:9px;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 4px;box-shadow:0 1px 4px rgba(0,0,0,.12);border:1px solid #ff4d4f}
.switch{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0}.switch input{opacity:0;width:0;height:0}.switch .slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:#ccc;border-radius:24px;transition:.3s}.switch .slider:before{content:'';position:absolute;height:18px;width:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.3s}.switch input:checked+.slider{background:#ff4d4f}.switch input:checked+.slider:before{transform:translateX(20px)}
.qr-img{width:180px;height:180px;object-fit:contain;border-radius:8px;margin:10px auto;display:block}
.bd-b{border-bottom:1px solid #f5f5f5}
.p4{padding:4px 0}.p6{padding:6px 0}
@keyframes dotPulse{0%,100%{opacity:1}50%{opacity:0.3}}
/* Code input grid */
.code-grid{display:flex;gap:8px;justify-content:center;margin:8px 0}
.code-grid input{width:42px;height:50px;text-align:center;font-size:22px;font-weight:600;border:2px solid #e0e0e0;border-radius:8px;outline:none}
.code-grid input:focus{border-color:#d9363e}
.code-timer{color:#d9363e;font-size:13px;margin-top:6px}
.send-code-btn{color:#d9363e;font-size:13px;cursor:pointer;white-space:nowrap;font-weight:500;background:transparent;border:none}
.send-code-btn:disabled{color:#ccc;cursor:default}
/* Invite page */
.invite-header{background:linear-gradient(135deg,#ff7a45,#e6423e);border-radius:0 0 20px 20px;padding:16px 16px 24px;color:#fff;text-align:center}
.invite-header .big{font-size:20px;font-weight:700;margin-top:6px}
.invite-header .sub{font-size:13px;opacity:.85;margin-top:4px}
.invite-card{background:#fff;border-radius:12px;padding:14px;margin:0 12px 10px;box-shadow:0 1px 4px rgba(0,0,0,.06)}
.invite-card .ic-title{font-size:13px;font-weight:600;color:#333;margin-bottom:8px}
.invite-stats{display:flex;flex-wrap:wrap;gap:0}
.invite-stats .is-item{flex:1;min-width:33%;text-align:center;padding:10px 0}
.invite-stats .is-num{font-size:20px;font-weight:700;color:#d9363e}
.invite-stats .is-lbl{font-size:11px;color:#999;margin-top:2px}
.invite-share-box{display:flex;gap:8px;margin:10px 0}
.invite-share-box .share-btn{flex:1;text-align:center;padding:12px 6px;border-radius:10px;background:#f5f5f5;cursor:pointer;font-size:12px;color:#333;transition:all .15s}
.invite-share-box .share-btn:active{background:#e6423e;color:#fff}
.invite-share-box .share-btn .icon{font-size:24px;display:block;margin-bottom:4px}
.invite-code-box{background:#f9f9f9;border-radius:10px;padding:12px;text-align:center;margin:8px 0}
.invite-code-box .code{font-size:24px;font-weight:700;color:#d9363e;letter-spacing:4px}
.invite-code-box .hint{font-size:16px;color:#22c55e;margin-top:6px}
.team-member{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid #f5f5f5;font-size:13px}
.team-member:last-child{border-bottom:none}
.team-member .tm-left{display:flex;align-items:center;gap:8px}
.team-member .tm-avatar{width:32px;height:32px;border-radius:50%;background:#e6423e;color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}

/* Team v2 styles */
.tm-card{padding:12px;border-radius:10px;background:#fafafa;margin-bottom:8px;border:1px solid #eee}
.tm-card:active{background:#f0f0f0}
.tm-card-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.tm-card .tm-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600;color:#fff;flex-shrink:0}
.tm-status{display:inline-block;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:600;margin-left:auto;flex-shrink:0}
.tm-status-active{background:#f6ffed;color:#52c41a;border:1px solid #b7eb8f}
.tm-status-newbie{background:#fff7e6;color:#fa8c16;border:1px solid #ffd591}
.tm-status-silent{background:#f5f5f5;color:#999;border:1px solid #d9d9d9}
.tm-info{display:grid;grid-template-columns:1fr 1fr;gap:4px 12px;font-size:12px;line-height:1.8}
.tm-info-item{display:flex;justify-content:space-between}
.tm-info-item .label{color:#999}
.tm-info-item .value{color:#333;font-weight:600}
.team-section-title{font-size:14px;font-weight:600;color:#333;margin:12px 0 8px;display:flex;align-items:center;gap:6px}
.milestone-bar{display:flex;align-items:center;gap:8px;background:#fff7e6;border-radius:8px;padding:10px 12px;margin:10px 0}
.milestone-bar .track{flex:1;height:8px;background:#ffe7ba;border-radius:4px;overflow:hidden}
.milestone-bar .track-fill{height:100%;background:#fa8c16;border-radius:4px;transition:width .5s}
.growth-chart{display:flex;align-items:flex-end;gap:4px;height:50px;margin:8px 0 4px}
.growth-chart .bar{flex:1;border-radius:3px 3px 0 0;min-height:4px;background:#ff4d4f;position:relative}
.growth-chart .bar-label{position:absolute;bottom:-16px;left:50%;transform:translateX(-50%);font-size:9px;color:#999;white-space:nowrap}
.tm-detail-table{width:100%;font-size:12px;border-collapse:collapse;margin-top:6px}
.tm-detail-table td{padding:4px 0;border-bottom:1px dashed #f0f0f0}
.tm-detail-table td:last-child{text-align:right;font-weight:600}
.newbie-step{font-size:11px;padding:3px 8px;border-radius:4px;flex:1;text-align:center;font-weight:600}
.newbie-step-done{background:#f6ffed;color:#52c41a;border:1px solid #b7eb8f}
.tm-empty{padding:4px 0}
.tm-skeleton{opacity:.7}
.sk-line{height:10px;background:#e0e0e0;border-radius:5px}
.sk-badge{width:50px;height:18px;background:#e0e0e0;border-radius:10px;flex-shrink:0}
.sk-bar{height:6px;background:#e0e0e0;border-radius:3px;overflow:hidden;margin:8px 0}
.sk-bar-fill{height:100%;background:#52c41a;border-radius:3px}

.newbie-step-pending{background:#fff7e6;color:#fa8c16;border:1px solid #ffd591}
/* -- 团队优化 -- */
.tm-card{margin-bottom:10px}
.tm-bonus-badge{display:inline-block;font-size:10px;padding:2px 8px;border-radius:10px;font-weight:600;flex-shrink:0;margin-left:4px}
.tm-bonus-done{background:#f6ffed;color:#52c41a;border:1px solid #b7eb8f}
.tm-bonus-pending{background:#fff2f0;color:#ff4d4f;border:1px solid #ffccc7;animation:tm-pulse 2s infinite}
@keyframes tm-pulse{0%,100%{opacity:1}50%{opacity:.7}}
.tm-need-help{display:inline-flex;align-items:center;gap:3px;background:#fff7e6;border:1px solid #ffd591;color:#d46b08;font-size:10px;font-weight:600;padding:2px 8px;border-radius:10px;margin-left:auto;flex-shrink:0;white-space:nowrap}
.tm-steps{display:flex;gap:4px;margin:6px 0 2px}
.tm-step{font-size:11px;padding:3px 6px;border-radius:4px;flex:1;text-align:center;font-weight:600}
.tm-step-done{background:#f6ffed;color:#52c41a;border:1px solid #b7eb8f}
.tm-step-blocked{background:#fff2f0;color:#ff4d4f;border:1px solid #ffccc7}
.tm-step-pending{background:#f5f5f5;color:#bfbfbf;border:1px solid #e8e8e8}
.tm-quick-stats{display:flex;gap:8px;padding:6px 0 0;border-top:1px dashed #e8e8e8;margin-top:6px}
.tm-qstat{flex:1;text-align:center;font-size:11px}
.tm-qstat .num{font-weight:600;color:#d9363e}
.tm-qstat .lbl{color:#999;font-size:10px}

.leaderboard-item{display:flex;align-items:center;padding:10px 0;border-bottom:1px solid #f5f5f5;font-size:13px}
.leaderboard-item:last-child{border-bottom:none}
.leaderboard-item .rank{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;margin-right:10px;flex-shrink:0}
.leaderboard-item .rank.gold{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff}
.leaderboard-item .rank.silver{background:linear-gradient(135deg,#d1d5db,#9ca3af);color:#fff}
.leaderboard-item .rank.bronze{background:linear-gradient(135deg,#d97706,#b45309);color:#fff}
.leaderboard-item .rank.normal{background:#f0f0f0;color:#999}
.leaderboard-item .lb-name{flex:1}
.leaderboard-item .lb-count{color:#999;font-size:12px}
.leaderboard-item .lb-amount{color:#d9363e;font-weight:600;font-size:14px}

/* Newbie banner */
.newbie-banner{background:linear-gradient(135deg,#fce4ec,#f3e5f5);border-radius:12px;padding:16px 18px;color:#ec407a;display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;cursor:pointer;box-shadow:0 2px 8px rgba(236,64,122,.15)}
.newbie-banner .nb-left{display:flex;align-items:center;gap:12px}
.newbie-banner .nb-icon{width:44px;height:44px;background:rgba(236,64,122,.1);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}
.newbie-banner .nb-text .nb-title{font-size:18px;font-weight:700}
.newbie-banner .nb-arrow{font-size:24px;opacity:.7;color:#ec407a}

/* Float bubble (removed) */
.btn-gray{background:#d9d9d9;color:#999;border:none;cursor:not-allowed}

/* Rule card */
.rule-item{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:1px solid #f5f5f5;font-size:13px;color:#555}
.rule-item:last-child{border-bottom:none}
.rule-item .ri-icon{font-size:16px;flex-shrink:0;margin-top:1px}
.rule-item .ri-text{line-height:1.6}
.rule-item .ri-text .hl{color:#d9363e;font-weight:600}

/* 新手限时挑战样式 */
.challenge-banner{background:linear-gradient(135deg,#fff2f0,#ffe58f);border:1px solid #ffccc7;border-radius:10px;padding:14px 16px;margin:8px 0;position:relative;overflow:hidden}
.challenge-banner::before{content:'';position:absolute;top:-50%;right:-30%;width:100px;height:100px;background:rgba(230,66,62,0.06);border-radius:50%}
.challenge-banner .cb-title{font-size:15px;font-weight:700;color:#cf1322}
.challenge-banner .cb-countdown{font-size:28px;font-weight:700;color:#d9363e;margin:6px 0;display:flex;align-items:center;gap:4px}
.challenge-banner .cb-countdown .time-unit{font-size:14px;font-weight:400;color:#999}
.challenge-banner .cb-progress{display:flex;align-items:center;gap:8px;margin-top:4px}
.challenge-banner .cb-progress-bar{flex:1;height:6px;background:#f0f0f0;border-radius:3px;overflow:hidden}
.challenge-banner .cb-progress-bar div{height:100%;border-radius:3px;background:linear-gradient(90deg,#ff7a45,#e6423e);transition:width 0.5s}
.challenge-banner .cb-done{font-size:12px;color:#666;margin-left:auto}
.challenge-banner .cb-footnote{font-size:11px;color:#999;margin-top:6px}
.challenge-tag{display:inline-block;background:linear-gradient(135deg,#ff4d4f,#ff7a45);color:#fff;border-radius:10px;padding:1px 6px;font-size:10px;position:absolute;top:-4px;right:-6px;white-space:nowrap}
/* === Invite page redesign v2 — 2026-05-18 === */
.invite-vip-card{background:linear-gradient(135deg,#fff5f5,#ffe8e8);border-radius:12px;padding:10px 14px 8px;margin-bottom:6px;border:1px solid #ffd4c0;position:relative;overflow:hidden}
.invite-vip-card .vip-label{font-size:11px;color:#d9363e;font-weight:600;margin-bottom:2px}
.invite-vip-card .vip-code{font-size:22px;font-weight:700;color:#333;letter-spacing:5px;text-align:center;padding:2px 0;font-family:-apple-system,BlinkMacSystemFont,'PingFang SC','Helvetica Neue',sans-serif}
.invite-vip-card .vip-hint{font-size:11px;color:#999;text-align:center;margin-top:0}
.invite-share-row{display:flex;gap:6px;margin:6px 0}
.invite-share-row .shr-btn{flex:1;text-align:center;padding:11px 4px;border-radius:10px;cursor:pointer;font-size:13px;font-weight:500;transition:all .15s;border:none}
.invite-share-row .shr-btn:active{opacity:.8;transform:scale(.97)}
.shr-link{background:#5db898;color:#fff;position:relative}
.shr-poster{background:#5db898;color:#fff}
.shr-code{background:#5db898;color:#fff}
.shr-link .badge{position:absolute;top:-8px;right:-6px;background:#e6423e;color:#fff;font-size:10px;padding:1px 7px;border-radius:9px;font-weight:700;line-height:1.5;white-space:nowrap;box-shadow:0 1px 4px rgba(230,66,62,.35)}
.invite-core-rule{font-size:13px;color:#555;text-align:center;padding:8px 0 14px;border-bottom:1px solid #f0f0f0;margin-bottom:4px}
.invite-rules-list .ri-icon{font-size:15px;flex-shrink:0;width:22px;text-align:center}
.invite-rules-list .ri-text{font-size:12.5px;line-height:1.6;color:#444}
.invite-core-rule span{color:#d9363e;font-weight:600}
/* 邀请页折叠按钮（浅蓝色） */
.invite-collapse-buttons{display:flex;gap:6px;margin-bottom:4px}
.newbie-step{display:inline-flex;align-items:center;gap:3px;padding:2px 6px;border-radius:4px;font-size:11px}
.newbie-step-done{background:#f6ffed;color:#52c41a;border:1px solid #b7eb8f}
.tm-empty{padding:4px 0}
.tm-skeleton{opacity:.7}
.sk-line{height:10px;background:#e0e0e0;border-radius:5px}
.sk-badge{width:50px;height:18px;background:#e0e0e0;border-radius:10px;flex-shrink:0}
.sk-bar{height:6px;background:#e0e0e0;border-radius:3px;overflow:hidden;margin:8px 0}
.sk-bar-fill{height:100%;background:#52c41a;border-radius:3px}

.newbie-step-pending{background:#fffbe6;color:#fa8c16;border:1px solid #ffe58f}
.tm-card{background:#fafafa;border-radius:8px;padding:10px;margin-bottom:8px;border:1px solid #f0f0f0}
.tm-card-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.tm-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:700;flex-shrink:0}
.tm-status{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;white-space:nowrap}
.tm-status-active{background:#f6ffed;color:#52c41a}
.tm-status-newbie{background:#fffbe6;color:#fa8c16}
.tm-status-silent{background:#fff2f0;color:#ff4d4f}
.tm-info{display:grid;grid-template-columns:1fr 1fr;gap:4px 12px}
.tm-info-item{display:flex;justify-content:space-between;padding:4px 0;border-bottom:1px dashed #eee;font-size:12px}
.tm-info-item .label{color:#999}
.team-section-title{font-size:13px;font-weight:600;padding:8px 0 4px}
.coll-btn{flex:1;padding:12px 4px;border:none;border-radius:10px;background:linear-gradient(135deg,#7cb9e8,#5da5d9);text-align:center;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:4px;transition:all .2s;color:#fff;box-shadow:0 2px 6px rgba(93,165,217,.3)}
.coll-btn:active{opacity:.85;transform:scale(.97)}
.coll-arrow{font-size:10px;color:rgba(255,255,255,.8);transition:transform .2s;margin-right:2px}

/* 邀请主卡片（代码+分享+核心规则合一，搭配蓝色按钮） */
.invite-main-card{background:linear-gradient(135deg,#f0f8ff,#e6f2ff);border:1px solid #d0e4f5;border-radius:12px;padding:14px;margin-bottom:8px}
.invite-main-card .invite-vip-card{background:transparent;border:none;padding:0;margin-bottom:2px}
.invite-main-card .invite-share-row{margin:10px 0 8px}
.invite-main-card .invite-core-rule{border-bottom:none;margin-bottom:0;padding-bottom:0}


.invite-activity{padding:6px 0}
.invite-activity .act-item{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid #f5f5f5;font-size:12px}
.invite-activity .act-avatar{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;color:#fff;flex-shrink:0}
.invite-activity .act-time{color:#999;flex-shrink:0;font-size:10px}
.invite-milestone-big{background:linear-gradient(135deg,#fff7e6,#fffbe6);border-radius:10px;padding:14px;margin:8px 0 12px}
.invite-milestone-big .ms-title{font-size:13px;font-weight:600;color:#d46b08;margin-bottom:6px}
.invite-milestone-big .ms-track{display:flex;align-items:center;gap:4px;margin:8px 0 4px}
.invite-milestone-big .ms-dot{width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;flex-shrink:0;position:relative}
.invite-milestone-big .ms-dot.passed{background:#fa8c16;color:#fff}
.invite-milestone-big .ms-dot.current{background:#e6423e;color:#fff;box-shadow:0 0 0 3px rgba(230,66,62,.2)}
.invite-milestone-big .ms-dot.future{background:#f0f0f0;color:#ccc}
.invite-milestone-big .ms-label{font-size:10px;color:#999;text-align:center;margin-top:2px}
.invite-milestone-big .ms-next{margin-top:6px;padding-top:6px;border-top:1px dashed #ffd591;font-size:12px;color:#d46b08;text-align:center;font-weight:600}
.invite-income-simple{display:flex;gap:8px;margin-bottom:8px}
.invite-income-simple .inc-item{flex:1;text-align:center;padding:10px 4px;border-radius:10px}
.invite-income-simple .inc-val{font-size:22px;font-weight:700}
.invite-income-simple .inc-lbl{font-size:11px;margin-top:2px}
.invite-income-progress{margin:6px 0 10px}
.invite-income-progress .ip-bar{display:flex;align-items:center;gap:8px}
.invite-income-progress .ip-track{flex:1;height:8px;background:#f0f0f0;border-radius:4px;overflow:hidden}
.invite-income-progress .ip-fill{height:100%;border-radius:4px;background:linear-gradient(90deg,#ff7a45,#e6423e);transition:width .5s}
.invite-income-progress .ip-label{font-size:12px;color:#666;flex-shrink:0}
.invite-income-progress .ip-label strong{color:#d9363e}


.float-challenge-bar{position:fixed;bottom:60px;left:0;right:0;z-index:90;max-width:480px;margin:0 auto;padding:0 8px 8px;pointer-events:none}
.float-challenge-bar>div{pointer-events:auto;background:linear-gradient(135deg,#fff2f0,#fffbe6);border:1px solid #ffccc7;border-radius:10px;padding:10px 14px;display:flex;align-items:center;gap:10px}
.float-challenge-bar .fcb-icon{font-size:20px;flex-shrink:0}
.float-challenge-bar .fcb-text{flex:1;font-size:12px;line-height:1.4}
.float-challenge-bar .fcb-btn{flex-shrink:0;background:linear-gradient(135deg,#ff7a2e,#ff4d4f);color:#fff;border:none;border-radius:8px;padding:8px 14px;font-size:13px;cursor:pointer;font-weight:600;box-shadow:0 2px 8px rgba(230,66,62,0.3)}

.dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999;background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center}
.dialog-box{background:#fff;border-radius:12px;padding:20px;box-shadow:0 4px 24px rgba(0,0,0,.15);animation:slideUp .25s ease}

/* ---- 首页新设计 (06双层卡片+02拼多红) ---- */
.home-container{background:#FFF0ED;padding:0 12px 80px 12px}
.card-double{background:#fff;border:2px solid #e8d8d0;border-radius:16px;box-shadow:inset 0 0 0 1.5px #fff;padding:14px;margin-bottom:10px}
.home-header{display:flex;align-items:center;justify-content:space-between;padding:10px 2px 8px 2px}
.home-header-left{display:flex;align-items:center;gap:8px}
.home-header-avatar{width:36px;height:36px;border-radius:50%;border:2px solid #E02E24;display:flex;align-items:center;justify-content:center;font-size:18px;background:#fff5ed;color:#E02E24;font-weight:700}
.home-header-info{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.home-header-name{font-size:14px;font-weight:600;color:#333}
.home-header-level{font-size:10px;background:#f5f0eb;color:#8c7a6a;padding:1px 6px;border-radius:4px}
.home-header-earn{font-size:11px;background:#fff0e6;color:#E02E24;padding:1px 8px;border-radius:10px;font-weight:600}
.home-header-right{display:flex;align-items:center}
.home-header-bell{font-size:20px;position:relative}
.gold-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;padding:4px 0}
.gold-item{display:flex;flex-direction:column;align-items:center;padding:4px 0;cursor:pointer}
.gold-icon-box{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:6px}
.gold-label{font-size:11px;color:#555;text-align:center}
.gold-bg-orange{background:linear-gradient(135deg,#ffefe0,#fde5cc)}
.gold-bg-red{background:linear-gradient(135deg,#ffe8e0,#fddccf)}
.gold-bg-blue{background:linear-gradient(135deg,#e0f0ff,#cce5ff)}
.gold-bg-green{background:linear-gradient(135deg,#e0f5e8,#ccecd8)}
.gold-bg-purple{background:linear-gradient(135deg,#f0e0ff,#e5ccfd)}
.gold-bg-cyan{background:linear-gradient(135deg,#e0f5fa,#ccecf2)}
.gold-bg-pink{background:linear-gradient(135deg,#ffe0ea,#fdccdb)}
.gold-bg-yellow{background:linear-gradient(135deg,#fef5e0,#fceccc)}
.checkin-row{display:flex;align-items:center;gap:10px}
.checkin-left{flex:1}
.checkin-title{font-size:15px;font-weight:600;color:#333}
.checkin-title strong{color:#E02E24}
.checkin-right{font-size:12px;color:#E02E24;font-weight:600;background:#fff5ed;border-radius:20px;padding:4px 12px;white-space:nowrap}
.home-section-title{font-size:13px;font-weight:600;color:#333;margin-bottom:8px}
.task-cards{display:flex;gap:8px}
.task-card{flex:1;text-align:center;background:#fff0ed;border-radius:10px;padding:8px 4px;border:1px solid #f0e6dc}
.task-num{font-size:22px;font-weight:700;color:#E02E24}
.task-label{font-size:12px;color:#888;margin-top:4px}
.gift-steps{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-bottom:8px}
.gift-step{text-align:center;font-size:10px;padding:8px 2px;border-radius:8px;line-height:1.3}
.gift-step.done{background:#fbf9f7;border:1px solid #eee8e0;color:#999}
.gift-step.pend{background:#fbf9f7;border:1px solid #f0d9c5;color:#E02E24}
.gift-step.lock{background:#faf8f6;border:1px solid #e8e0d8;color:#bbb}
.gift-bar-wrap{display:flex;align-items:center;gap:8px}
.gift-bar-bg{flex:1;height:6px;border-radius:3px;background:#eee8e0;overflow:hidden}
.gift-bar-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,#E02E24,#ffad33)}
.gift-bar-text{font-size:11px;color:#E02E24;font-weight:600;white-space:nowrap}
.split-row{display:flex;gap:10px;margin-bottom:10px}
.split-half{flex:1;display:flex;flex-direction:column}
.split-half .card-double{flex:1;height:100%}
.split-card-title{font-size:13px;font-weight:600;color:#333;margin-bottom:6px}
.recruit-info{font-size:11px;color:#888;margin-bottom:6px}
.recruit-bar{height:5px;border-radius:3px;background:#eee8e0;overflow:hidden;margin-bottom:4px}
.recruit-pct{font-size:10px;color:#888;margin-bottom:6px}
.recruit-btn{font-size:11px;color:#E02E24;font-weight:600;border:1px solid #E02E24;border-radius:12px;padding:2px 10px;cursor:pointer;background:#fff;margin-top:auto}
.elite-high{font-size:13px;color:#333;margin-bottom:4px;line-height:1.3}
.elite-tag{display:inline-block;background:#fff0e6;color:#E02E24;font-size:10px;padding:1px 6px;border-radius:4px;margin-bottom:10px}
.elite-btn{font-size:11px;color:#fff;background:#E02E24;border:none;border-radius:12px;padding:2px 10px;cursor:pointer;line-height:20px;margin-top:auto}
.rank-item{font-size:12px;color:#333;line-height:1.8;display:flex;align-items:center;gap:4px}
.rank-medal{font-size:13px}
.rank-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rank-amt{color:#E02E24;font-weight:600}
.help-item{font-size:12px;color:#555;padding:4px 0;display:flex;align-items:center;gap:6px;cursor:pointer}
.help-item:active{opacity:.6}
.banner{background:linear-gradient(135deg,#fce4cc,#fad4b0);border-radius:14px;display:flex;align-items:center;padding:12px 16px;gap:12px;margin-bottom:10px}
.banner-icon{font-size:32px}
.banner-info{flex:1}
.banner-title{font-size:15px;font-weight:700;color:#8b4513}
.banner-desc{font-size:12px;color:#a0522d;margin-top:2px}
.banner-btn{background:#E02E24;color:#fff;border:none;border-radius:16px;padding:6px 16px;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap}
.banner-btn:active{opacity:.8}
.recommend-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.rec-card{text-align:center;padding:10px 4px;cursor:pointer}
.rec-card:active{opacity:.7}
.rec-icon{font-size:22px;display:block;margin-bottom:4px}
.rec-name{font-size:11px;color:#555;margin-bottom:2px}
.rec-earn{font-size:11px;color:#E02E24;font-weight:600}
.hall-btn{display:block;width:100%;background:linear-gradient(135deg,#E02E24,#FFAD33);color:#fff;font-size:13px;font-weight:600;border:none;border-radius:18px;padding:10px 32px;cursor:pointer;text-align:center}
.hall-btn:active{opacity:.85}
.recommend-bar{margin-bottom:8px}
.recommend-title{font-size:13px;font-weight:600;color:#333}
.nav-tab-home{flex:1;text-align:center;padding:4px 0 6px;cursor:pointer;position:relative}
.nav-tab-home .nav-icon{font-size:20px;display:block;margin-bottom:2px}
.nav-tab-home .nav-label{font-size:10px;color:#999}
.nav-tab-home.active .nav-label{color:#E02E24;font-weight:600}
.nav-indicator{width:16px;height:2px;background:#E02E24;border-radius:1px;margin:1px auto 0}
.recruit-btn:active,.elite-btn:active,.gold-item:active{opacity:.7}
.cn-tag{font-size:10px;padding:1px 6px;border-radius:4px;display:inline-block;background:#fff7e6;color:#fa8c16}
.mb-10{margin-bottom:10px}
.mt-10{margin-top:10px}

/* ===== 签到7天进度（方案B：奖杯阶梯） ===== */
.checkin-track{display:flex;align-items:flex-start;justify-content:space-between;gap:0;padding:4px 0 0}
.ck-item{flex:1;text-align:center;min-width:0}
.ck-dot-wrap{display:flex;align-items:center;justify-content:center;height:36px;position:relative}
.ck-line{width:100%;height:3px;background:#e8e8e8;position:absolute;top:50%;z-index:0;right:50%}
.ck-line.done{background:#E02E24}
.ck-dot{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;position:relative;z-index:1}
.ck-dot.done{background:#E02E24;color:#fff}
.ck-dot.today{background:#E02E24;color:#fff;box-shadow:0 0 0 3px rgba(224,46,36,.2)}
.ck-dot.future{background:#f5f5f5;color:#ccc;border:1px solid #e8e8e8}
.ck-dot.done-last,.ck-dot.today-last{background:linear-gradient(135deg,#E02E24,#ff7a2e);color:#fff}
.ck-dot.future-last{background:#fff;color:#E02E24;border:2px dashed #E02E24}
.ck-label{font-size:9px;color:#888;margin-top:2px}
.ck-pts{font-size:9px;color:#E02E24;font-weight:600;margin-top:1px}
.ck-pts.future-pts{color:#bbb;font-weight:400}
