/* 포인트 위젯 */
.point-widget {
    display: flex; align-items: center; gap: 1.5rem;
    padding: 1.25rem 1.5rem; margin-bottom: 1.5rem;
}
.pw-left { display: flex; flex-direction: column; gap: 0.25rem; min-width: 100px; }
.pw-level { font-size: 0.8rem; color: var(--text-muted); font-weight: 600; }
.pw-points { font-size: 1.5rem; font-weight: 800; color: var(--primary); }
.pw-bar-wrap { flex: 1; }
.pw-bar { height: 8px; background: var(--border-light); border-radius: 4px; overflow: hidden; }
.pw-bar-fill { height: 100%; background: var(--primary); border-radius: 4px; transition: width .3s; }
.pw-next { font-size: 0.75rem; color: var(--text-muted); margin-top: 0.25rem; display: block; }
/* 챌린지 그리드 */
.challenge-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 1rem; }
.challenge-card { padding: 1.25rem; display: flex; flex-direction: column; gap: 0.5rem; }
.ch-icon { font-size: 2rem; }
.ch-title { font-size: 1rem; font-weight: 700; }
.ch-desc { font-size: 0.85rem; color: var(--text-muted); line-height: 1.5; }
.ch-meta { display: flex; gap: 0.75rem; font-size: 0.8rem; color: var(--text-muted); }
.ch-meta span { background: var(--bg-soft); padding: 2px 8px; border-radius: 6px; }
.ch-footer { display: flex; justify-content: space-between; align-items: center; margin-top: auto; }
.ch-people { font-size: 0.8rem; color: var(--text-muted); }
.ch-done { opacity: 0.7; }
