/* =============================================================================
   Friends Page + Friends Dropdown Enhancements
   Uses design tokens from tokens.css
   ============================================================================= */

.friends-page {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    background: var(--surface-primary, #fff);
}

.friends-page__header {
    padding: var(--space-4);
    background: var(--surface-primary);
    border-bottom: 1px solid var(--border-default);
    flex-shrink: 0;
}

.friends-page__title {
    font-size: var(--text-xl);
    font-weight: var(--font-bold);
    color: var(--text-primary);
    margin-bottom: var(--space-3);
}

.friends-page__tabs-bar {
    padding: var(--space-2) var(--space-4);
    background: var(--surface-primary);
    border-bottom: 1px solid var(--border-default);
    flex-shrink: 0;
}

.friends-page__tabs {
    display: flex;
    gap: var(--space-1);
}

.friends-page__tab {
    display: flex;
    align-items: center;
    gap: var(--space-1);
    padding: var(--space-2) var(--space-3);
    background: none;
    border: none;
    border-radius: var(--radius-md);
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
    color: var(--text-muted);
    cursor: pointer;
    transition: all var(--duration-fast) var(--ease-default);
}

.friends-page__tab:hover {
    background: var(--interactive-hover);
    color: var(--text-primary);
}

.friends-page__tab--active {
    background: var(--accent-primary-subtle);
    color: var(--accent-primary);
}

.friends-page__tab-count {
    font-size: var(--text-xs);
    color: var(--text-muted);
}

.friends-page__tab--active .friends-page__tab-count {
    color: var(--accent-primary);
}

.friends-page__tab-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 18px;
    height: 18px;
    padding: 0 4px;
    background: var(--indicator-unread);
    color: var(--color-white);
    border-radius: var(--radius-full);
    font-size: var(--text-xs);
    font-weight: var(--font-bold);
}

.friends-page__search {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-3) var(--space-4);
    border-bottom: 1px solid var(--border-subtle);
    color: var(--text-muted);
}

.friends-page__search input {
    flex: 1;
    background: none;
    border: none;
    color: var(--text-primary);
    font-size: var(--text-sm);
    font-family: inherit;
    outline: none;
}

.friends-page__search input::placeholder {
    color: var(--text-muted);
}

.friends-page__content {
    flex: 1;
    overflow-y: auto;
}

.friends-page__section-title {
    padding: var(--space-3) var(--space-4);
    font-size: var(--text-xs);
    font-weight: var(--font-semibold);
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.friends-page__item {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-3) var(--space-4);
    border-bottom: 1px solid var(--border-subtle);
    transition: background var(--duration-fast) var(--ease-default);
}

.friends-page__item:hover {
    background: var(--interactive-hover);
}

.friends-page__item-avatar {
    flex-shrink: 0;
}

.friends-page__item-info {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.friends-page__item-name {
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    color: var(--text-primary);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.friends-page__item-handle {
    font-size: var(--text-xs);
    color: var(--text-muted);
}

.friends-page__item-status {
    font-size: var(--text-xs);
    color: var(--points-color);
    font-weight: var(--font-medium);
}

.friends-page__item-actions {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    flex-shrink: 0;
}

.friends-page__item-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: var(--size-8);
    height: var(--size-8);
    background: none;
    border: none;
    color: var(--text-muted);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all var(--duration-fast) var(--ease-default);
    text-decoration: none;
}

.friends-page__item-btn:hover {
    background: var(--interactive-hover);
    color: var(--text-primary);
}

.friends-page__item-btn--status-error:hover {
    background: var(--status-error-subtle);
    color: var(--status-error);
}

.friends-page__accept-btn {
    display: flex;
    align-items: center;
    gap: var(--space-1);
    padding: var(--space-1) var(--space-3);
    background: var(--accent-primary);
    color: var(--color-black);
    border: none;
    border-radius: var(--radius-md);
    font-size: var(--text-xs);
    font-weight: var(--font-medium);
    cursor: pointer;
    transition: background var(--duration-fast) var(--ease-default);
}

.friends-page__accept-btn:hover {
    background: var(--accent-primary-hover);
}

.friends-page__decline-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: var(--size-8);
    height: var(--size-8);
    background: none;
    border: none;
    color: var(--text-muted);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all var(--duration-fast) var(--ease-default);
}

.friends-page__decline-btn:hover {
    background: var(--status-error-subtle);
    color: var(--status-error);
}

.friends-page__empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: var(--space-12) var(--space-4);
    text-align: center;
    gap: var(--space-3);
}

.friends-page__empty-title {
    font-size: var(--text-lg);
    font-weight: var(--font-semibold);
    color: var(--text-primary);
}

.friends-page__empty-text {
    font-size: var(--text-sm);
    color: var(--text-muted);
    max-width: 280px;
}

/* Mobile */
@media (max-width: 767px) {
    .friends-page__header {
        padding: var(--space-3);
    }

    .friends-page__tabs-bar {
        padding: var(--space-2) var(--space-3);
    }

    .friends-page__tabs {
        overflow-x: auto;
    }
}
