body { font-family: "Noto Sans SC", sans-serif; background: linear-gradient(135deg, #fff5f5 0%, #fffbf2 50%, #f5f7ff 100%); color: #4b5563; }
.font-mono { font-family: "JetBrains Mono", monospace; }
.glass-panel { background: rgba(255, 255, 255, 0.7); backdrop-filter: blur(24px); border: 1px solid rgba(255, 255, 255, 0.5); border-radius: 20px; box-shadow: 0 8px 32px rgba(31, 38, 135, 0.04); }
@keyframes blue-breathe { 0%,100% { transform: scale(1); opacity: 0.7; box-shadow: 0 0 4px rgba(34, 211, 238, 0.4); } 50% { transform: scale(1.3); opacity: 1; box-shadow: 0 0 12px rgba(34, 211, 238, 0.8); } }
.breathe-dot { background-color: #22d3ee; animation: blue-breathe 2s infinite ease-in-out; }
.hero-warm-smooth { background: linear-gradient(110deg, #ff9d66 0%, #ff5e62 100%) !important; box-shadow: 0 10px 25px rgba(255, 94, 98, 0.2); }
.app-grid { display: grid; grid-template-columns: 168px 1fr 340px; height: 100vh; padding: 16px; gap: 16px; }
.no-scrollbar::-webkit-scrollbar { display: none; }
.rank-item { transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1); border-left: 4px solid transparent; }
.rank-item:hover { transform: translateX(8px); background: white; border-left-color: #fb923c; box-shadow: 0 4px 20px rgba(251, 146, 60, 0.08); }
.rank-item-me { border-left-color: rgba(99, 102, 241, 0.45); background: rgba(255, 255, 255, 0.88); }
.podium-1-wrap { transform: translateY(-5px) scale(1.05); z-index: 50; }
.podium-1-base { background: linear-gradient(to top, #ea580c, #fb923c); filter: drop-shadow(0 10px 20px rgba(234, 88, 12, 0.2)); }
.ranking-empty { color: #94a3b8; font-weight: 800; font-size: 14px; text-align: center; }
.ranking-personal-stat-desc { font-size: 11px; line-height: 1.25; letter-spacing: 0.02em; }
#honorBadgeIcon.ranking-honor-badge-slot { display: flex; align-items: center; justify-content: center; min-width: 4rem; min-height: 4rem; }
#honorBadgeIcon .ranking-honor-fa { font-size: 1.85rem; line-height: 1; color: #ea580c; }
#honorBadgeIcon .ranking-honor-badge-img { display: block; }
.rank-avatar { position: relative; display: inline-flex; align-items: center; justify-content: center; border-radius: 18px; overflow: hidden; background: linear-gradient(135deg, #fff 0%, #f8fafc 100%); border: 2px solid rgba(255,255,255,0.92); box-shadow: 0 8px 24px rgba(15,23,42,0.08); flex-shrink: 0; }
.rank-avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }
.rank-avatar-md { width: 42px; height: 42px; border-radius: 14px; }
.rank-avatar-lg { width: 56px; height: 56px; border-radius: 18px; }
.rank-avatar-first { width: 72px; height: 72px; border-width: 4px; border-color: #fb923c; box-shadow: 0 12px 28px rgba(251, 146, 60, 0.25); }
.rank-avatar-fallback { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; font-weight: 900; color: #ea580c; background: linear-gradient(135deg, #fff7ed 0%, #ffedd5 100%); }
/* 荣誉榜「全站总榜」筛选：与侧栏橙色系、hero-warm-smooth 统一 */
.ranking-scope-btn {
  box-shadow: 0 8px 22px rgba(234, 88, 12, 0.22);
  transition: box-shadow 0.2s ease, transform 0.15s ease, filter 0.2s ease;
}
.ranking-scope-btn:hover { box-shadow: 0 10px 26px rgba(234, 88, 12, 0.3); }
.ranking-scope-btn:active { transform: translateY(1px); }
