@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";*{box-sizing:border-box;margin:0;padding:0}body{color:#1e293b;background:#f8fafc;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;overflow-x:hidden}body:before{content:"";pointer-events:none;background:radial-gradient(circle,#6366f114 0%,#0000 60%);width:80%;height:80%;position:fixed;top:-40%;left:-20%}body:after{content:"";pointer-events:none;background:radial-gradient(circle,#ec48990f 0%,#0000 60%);width:70%;height:70%;position:fixed;bottom:-30%;right:-20%}.container{max-width:720px;margin:0 auto;padding:48px 20px 80px;position:relative}.page-header{margin-bottom:36px}h1{background:linear-gradient(135deg,#6366f1,#8b5cf6,#ec4899);-webkit-text-fill-color:transparent;letter-spacing:-.5px;background-clip:text;font-size:32px;font-weight:800}.subtitle{color:#94a3b8;margin-top:6px;font-size:14px;font-weight:500}.progress-bar-wrap{background:#e2e8f0;border-radius:20px;height:8px;margin-top:20px;position:relative;overflow:hidden}.progress-bar-clickable{cursor:pointer;transition:transform .15s,box-shadow .15s}.progress-bar-clickable:hover{transform:scaleY(1.3);box-shadow:0 2px 8px #6366f14d}.progress-bar-fill{background:linear-gradient(90deg,#6366f1,#a78bfa);border-radius:20px;height:100%;transition:width .4s;position:relative}.progress-bar-fill:after{content:"";background:linear-gradient(90deg,#0000,#ffffff80,#0000);animation:1.5s infinite shimmer;position:absolute;inset:0}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.progress-bar-layered{border-radius:20px;height:100%;display:flex;overflow:hidden}.progress-bar-today{background:linear-gradient(90deg,#f59e0b,#fbbf24);height:100%;transition:width .4s;position:relative}.progress-bar-layered{border-radius:20px;height:100%;display:flex;position:relative;overflow:hidden}.progress-bar-fill-wrap{border-radius:20px 0 0 20px;height:100%;transition:width .8s cubic-bezier(.22,1,.36,1);display:flex;position:relative;overflow:hidden}.progress-bar-fill-wrap:after{content:"";pointer-events:none;background:linear-gradient(90deg,#0000,#ffffff80,#0000);width:100%;height:100%;animation:1s infinite douyin-shimmer;position:absolute;top:0;left:0}.progress-bar-today{background:linear-gradient(90deg,#f59e0b,#fbbf24);height:100%;transition:width .4s}.progress-bar-before{background:linear-gradient(90deg,#94a3b8,#cbd5e1);height:100%;transition:width .4s}@keyframes douyin-shimmer{0%{transform:translate(-100%)skew(-15deg)}to{transform:translate(50%)skew(-15deg)}}.progress-legend{color:#64748b;white-space:nowrap;justify-content:space-between;align-items:center;margin-top:8px;font-size:12px;display:flex}.legend-left{flex-shrink:0;gap:16px;display:flex}.legend-item{align-items:center;gap:6px;display:flex}.legend-dot{border-radius:50%;width:8px;height:8px}.legend-dot.today{background:linear-gradient(135deg,#f59e0b,#fbbf24)}.legend-dot.before{background:linear-gradient(135deg,#94a3b8,#cbd5e1)}.legend-dot.total-dot{background:linear-gradient(135deg,#e2e8f0,#f1f5f9);border:1px solid #cbd5e1}.legend-item.total{color:#94a3b8;flex-shrink:0;margin-left:16px}.progress-text{color:#94a3b8;justify-content:space-between;margin-top:10px;font-size:12px;font-weight:500;display:flex}.progress-text span:first-child{color:#64748b}.error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;margin-top:16px;padding:12px 16px;font-size:13px}.leaderboard{margin-top:8px}.lb-header{color:#94a3b8;text-transform:uppercase;letter-spacing:1px;grid-template-columns:48px 1fr 180px;padding:0 8px 12px;font-size:11px;font-weight:600;display:grid}.row{border-radius:12px;grid-template-columns:48px 1fr 180px;align-items:center;margin-bottom:2px;padding:12px 8px;transition:background .2s;display:grid}.row>*{pointer-events:none}.row:hover{background:#6366f10a}.row-click{cursor:pointer}.rank-col{text-align:center;color:#cbd5e1;font-size:15px;font-weight:700}.row.top-1{background:linear-gradient(135deg,#facc151a,#fbbf240a)}.row.top-1 .rank-col{color:#f59e0b;font-size:20px}.row.top-2{background:linear-gradient(135deg,#94a3b81a,#94a3b80a)}.row.top-2 .rank-col{color:#94a3b8;font-size:18px}.row.top-3{background:linear-gradient(135deg,#d977061a,#d977060a)}.row.top-3 .rank-col{color:#d97706;font-size:18px}.name-col{align-items:center;gap:12px;min-width:0;display:flex}.avatar{object-fit:cover;border:2px solid #e2e8f0;border-radius:10px;flex-shrink:0;width:36px;height:36px}.row.top-1 .avatar{border-color:#fde68a}.row.top-2 .avatar{border-color:#cbd5e1}.row.top-3 .avatar{border-color:#fed7aa}.nick{color:#1e293b;text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:600;overflow:hidden}.row:hover .nick{color:#6366f1}.count-col{align-items:center;gap:10px;display:flex}.count-num{color:#475569;text-align:right;font-variant-numeric:tabular-nums;flex-shrink:0;min-width:28px;font-size:14px;font-weight:700}.bar-bg{background:#f1f5f9;border-radius:4px;flex:1;height:8px;overflow:hidden}.bar{background:linear-gradient(90deg,#6366f1,#8b5cf6);border-radius:4px;height:100%;transition:width .6s cubic-bezier(.22,1,.36,1);display:block}.row.top-1 .bar{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.row.top-2 .bar{background:linear-gradient(90deg,#94a3b8,#cbd5e1)}.row.top-3 .bar{background:linear-gradient(90deg,#d97706,#f59e0b)}.bar-layered{border-radius:4px;height:100%;transition:width .6s cubic-bezier(.22,1,.36,1);display:flex;overflow:hidden}.bar-today{background:linear-gradient(90deg,#f59e0b,#fbbf24);height:100%;transition:width .4s}.bar-before{background:linear-gradient(90deg,#94a3b8,#cbd5e1);height:100%;transition:width .4s}.row.top-1 .bar-today{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.row.top-1 .bar-before{background:linear-gradient(90deg,#94a3b8,#cbd5e1)}.row.top-2 .bar-today{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.row.top-2 .bar-before{background:linear-gradient(90deg,#94a3b8,#cbd5e1)}.row.top-3 .bar-today{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.row.top-3 .bar-before{background:linear-gradient(90deg,#94a3b8,#cbd5e1)}.leaderboard.skeleton{opacity:.7}.skeleton-row{background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0 50%,#f1f5f9 75%) 0 0/200% 100%;animation:1.5s infinite skeleton-loading}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-rank{background:#e2e8f0;border-radius:4px;width:20px;height:14px;display:inline-block}.skeleton-avatar{background:#e2e8f0;border-radius:10px;width:36px;height:36px;display:inline-block}.skeleton-name{background:#e2e8f0;border-radius:4px;width:80px;height:14px;display:inline-block}.skeleton-count{background:#e2e8f0;border-radius:4px;width:28px;height:14px;display:inline-block}.skeleton-bar{background:#e2e8f0;border-radius:4px;flex:1;height:8px;display:inline-block}.summary{text-align:center;color:#94a3b8;margin-top:20px;font-size:13px;font-weight:500}.modal-overlay{-webkit-backdrop-filter:blur(8px);z-index:100;background:#0f172a66;justify-content:center;align-items:center;padding:20px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:#fff;border:1px solid #e2e8f0;border-radius:16px;flex-direction:column;width:100%;max-width:520px;max-height:80vh;animation:.25s slideUp;display:flex;overflow:hidden;box-shadow:0 20px 60px #0000001f}.modal-detail{max-width:640px}.modal-chart{max-width:560px}.chart-container{height:280px;padding:20px 24px 24px}.bar-click{cursor:pointer}.bar-click:hover .bar-bg{opacity:.8}.avatar-click{cursor:zoom-in;pointer-events:auto;transition:transform .15s}.avatar-click:hover{transform:scale(1.05)}.bar-click{pointer-events:auto}.image-preview-overlay{background:#000000d9}.image-preview-container{justify-content:center;align-items:center;max-width:90vw;max-height:90vh;display:flex;position:relative}.image-preview-img{border-radius:8px;max-width:100%;max-height:90vh;box-shadow:0 20px 60px #0000004d}.image-preview-close{color:#fff;background:#ffffff1a;border:1px solid #fff3;position:absolute;top:-40px;right:0}.image-preview-close:hover{background:#fff3}.detail-content img{cursor:zoom-in;border-radius:8px;max-width:100%;margin:8px 0}.ip-tag{color:#475569!important;background:#f1f5f9!important}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-header{border-bottom:1px solid #f1f5f9;flex-shrink:0;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-user{align-items:center;gap:14px;display:flex}.avatar-lg{object-fit:cover;border:2px solid #e2e8f0;border-radius:12px;width:48px;height:48px}.modal-nick{color:#0f172a;font-size:18px;font-weight:700}.modal-count{color:#94a3b8;margin-top:2px;font-size:13px;font-weight:500}.modal-close{color:#64748b;cursor:pointer;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;transition:all .15s;display:flex}.modal-close:hover{color:#1e293b;background:#f1f5f9}.modal-list{padding:8px 12px;overflow-y:auto}.modal-post{border-radius:10px;align-items:center;gap:12px;padding:12px;transition:background .15s;display:flex}.modal-post:hover{background:#f8fafc}.post-idx{color:#94a3b8;background:#f1f5f9;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:11px;font-weight:700;display:flex}.post-title{color:#334155;text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:14px;font-weight:500;overflow:hidden}.post-date{color:#cbd5e1;font-variant-numeric:tabular-nums;flex-shrink:0;font-size:12px;font-weight:500}.post-click{cursor:pointer}.post-click:hover .post-title{color:#6366f1}.detail-title{text-overflow:ellipsis;white-space:nowrap;color:#0f172a;flex:1;padding-right:12px;font-size:17px;font-weight:700;overflow:hidden}.detail-loading{text-align:center;color:#94a3b8;padding:60px 24px;font-size:14px}.detail-body{flex:1;overflow-y:auto}.detail-meta{color:#64748b;border-bottom:1px solid #f1f5f9;flex-wrap:wrap;align-items:center;gap:8px;padding:14px 24px;font-size:13px;font-weight:500;display:flex}.detail-meta .meta-tag{color:#475569;background:#f1f5f9;border-radius:6px;align-items:center;padding:4px 10px;font-size:12px;line-height:1.4;display:inline-flex}.detail-content{color:#475569;padding:24px;font-size:15px;line-height:1.9}.detail-content img{border:1px solid #e2e8f0;border-radius:10px;max-width:100%;margin:10px 0}.detail-content p{margin-bottom:14px}.detail-content br{display:none}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#e2e8f0;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#cbd5e1}
