/**
 * Forum User/Badge Styles
 * User avatars, badges, author styling, role indicators
 */

/* ============================================
   USER AVATARS
   ============================================ */

.user-avatar {
    width: clamp(36px, 5vw, 44px);
    height: clamp(36px, 5vw, 44px);
    border-radius: 50%;
    object-fit: cover;
    background: var(--bg-tertiary);
    border: 2px solid var(--border);
    flex-shrink: 0;
}

.user-avatar--small {
    width: 24px;
    height: 24px;
    border-width: 1px;
}

.user-avatar--large {
    width: clamp(48px, 7vw, 64px);
    height: clamp(48px, 7vw, 64px);
}

/* Avatar with online indicator */
.user-avatar-wrapper {
    position: relative;
    display: inline-block;
}

.user-avatar-wrapper .online-indicator {
    position: absolute;
    bottom: 2px;
    right: 2px;
    width: 12px;
    height: 12px;
    background: var(--success);
    border: 2px solid var(--bg-secondary);
    border-radius: 50%;
}

/* ============================================
   USER DISPLAY NAME
   ============================================ */

.user-name {
    font-weight: 600;
    color: var(--text-primary);
    font-size: clamp(0.9375rem, 1.5vw + 0.15rem, 1rem);
}

.user-name a {
    color: inherit;
    text-decoration: none;
    transition: color 0.2s ease;
}

.user-name a:hover {
    color: var(--accent);
}

/* User with role badge inline */
.user-name--with-role {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}

/* ============================================
   ROLE BADGES
   ============================================ */

.role-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.125rem 0.5rem;
    font-size: clamp(0.625rem, 0.9vw + 0.1rem, 0.6875rem);
    font-weight: 600;
    border-radius: var(--radius-sm);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.role-badge--admin {
    background: var(--error-bg);
    color: var(--error);
}

.role-badge--moderator {
    background: var(--accent-light);
    color: var(--accent);
}

.role-badge--member {
    background: var(--bg-tertiary);
    color: var(--text-secondary);
}

.role-badge svg {
    width: 10px;
    height: 10px;
}

/* ============================================
   USER STATS (Post count, join date, etc.)
   ============================================ */

.user-stats {
    display: flex;
    flex-wrap: wrap;
    gap: clamp(0.5rem, 1vw, 0.75rem);
    font-size: clamp(0.75rem, 1.1vw + 0.1rem, 0.8125rem);
    color: var(--text-muted);
}

.user-stats span {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
}

.user-stats svg {
    width: 12px;
    height: 12px;
    opacity: 0.7;
}

.user-stats strong {
    color: var(--text-secondary);
    font-weight: 600;
}

/* ============================================
   USER CARD (For hover profiles, etc.)
   ============================================ */

.user-card {
    display: flex;
    gap: clamp(0.75rem, 1.5vw, 1rem);
    padding: clamp(1rem, 2vw, 1.25rem);
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
}

.user-card__avatar {
    flex-shrink: 0;
}

.user-card__info {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    min-width: 0;
}

.user-card__name {
    font-weight: 600;
    color: var(--text-primary);
    font-size: clamp(0.9375rem, 1.5vw + 0.15rem, 1rem);
}

.user-card__joined {
    font-size: clamp(0.75rem, 1.1vw + 0.1rem, 0.8125rem);
    color: var(--text-muted);
}

/* ============================================
   AUTHOR BYLINE (Topic/Reply headers)
   ============================================ */

.author-byline {
    display: flex;
    align-items: center;
    gap: clamp(0.5rem, 1vw, 0.75rem);
}

.author-byline__avatar {
    flex-shrink: 0;
}

.author-byline__info {
    display: flex;
    flex-direction: column;
    gap: 0.125rem;
}

.author-byline__name {
    font-weight: 600;
    color: var(--text-primary);
    font-size: clamp(0.875rem, 1.25vw + 0.15rem, 0.9375rem);
}

.author-byline__name a {
    color: inherit;
    text-decoration: none;
    transition: color 0.2s ease;
}

.author-byline__name a:hover {
    color: var(--accent);
}

.author-byline__meta {
    font-size: clamp(0.75rem, 1.1vw + 0.1rem, 0.8125rem);
    color: var(--text-muted);
}

/* ============================================
   OP BADGE (Original Poster indicator)
   ============================================ */

.op-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.125rem 0.375rem;
    font-size: clamp(0.625rem, 0.9vw + 0.1rem, 0.6875rem);
    font-weight: 600;
    background: var(--accent-light);
    color: var(--accent);
    border-radius: var(--radius-sm);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* ============================================
   REPUTATION/KARMA DISPLAY
   ============================================ */

.user-reputation {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    font-size: clamp(0.75rem, 1.1vw + 0.1rem, 0.8125rem);
    font-weight: 600;
}

.user-reputation--positive {
    color: var(--success);
}

.user-reputation--negative {
    color: var(--error);
}

.user-reputation--neutral {
    color: var(--text-muted);
}

.user-reputation svg {
    width: 14px;
    height: 14px;
}

/* ============================================
   USER ACTIVITY INDICATOR
   ============================================ */

.activity-indicator {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    font-size: clamp(0.6875rem, 1vw + 0.1rem, 0.75rem);
    color: var(--text-muted);
}

.activity-indicator__dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
}

.activity-indicator__dot--online {
    background: var(--success);
}

.activity-indicator__dot--away {
    background: var(--warning);
}

.activity-indicator__dot--offline {
    background: var(--text-muted);
}
