*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

.pf-container { max-width: 1100px; margin: 0 auto; padding: 20px 16px; }

.pf-header { border-radius: 8px; padding: 20px 24px; margin-bottom: 16px; }
.pf-header h1 { font-size: 1.5rem; font-weight: 700; margin-bottom: 8px; }
.pf-header-stats { display: flex; gap: 24px; flex-wrap: wrap; font-size: 0.875rem; }
.pf-header-stats span { display: inline-flex; align-items: center; gap: 4px; }

.pf-error-banner { padding: 10px 16px; border-radius: 6px; margin-bottom: 16px; font-size: 0.875rem; display: none; }

.pf-tabs { display: flex; gap: 4px; margin-bottom: 16px; }
.pf-tab {
	padding: 10px 24px; border: none; border-radius: 6px 6px 0 0;
	cursor: pointer; font-size: 0.9rem; font-weight: 500;
	transition: background 0.15s, color 0.15s; background: transparent;
}
.pf-tab:hover { opacity: 0.85; }

.pf-table-wrapper { border-radius: 0 8px 8px 8px; overflow-x: auto; }
.pf-table { width: 100%; border-collapse: collapse; font-size: 0.875rem; }
.pf-table thead th {
	text-align: left; padding: 12px 14px; font-weight: 600;
	white-space: nowrap; font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.03em;
}
.pf-table tbody td { padding: 10px 14px; white-space: nowrap; }
.pf-table tbody tr:last-child td { border-bottom: none; }

.pf-card { border-radius: 8px; padding: 24px; transition: transform 0.2s; }

.pf-avatar { width: 48px; height: 48px; border-radius: 50%; object-fit: cover; }
.pf-avatar-sm { width: 32px; height: 32px; border-radius: 50%; object-fit: cover; }
.pf-avatar-lg { width: 64px; height: 64px; border-radius: 50%; object-fit: cover; }
.pf-avatar-xl { width: 80px; height: 80px; border-radius: 50%; object-fit: cover; }

.pf-badge-online, .pf-badge-offline {
	display: inline-block; width: 8px; height: 8px; border-radius: 50%;
}

.pf-rank-1 td:first-child, .pf-rank-2 td:first-child, .pf-rank-3 td:first-child {
	border-left: 3px solid transparent;
}

.pf-rank-num { font-weight: 700; min-width: 36px; display: inline-block; }
.pf-player-name { font-weight: 600; }
.pf-points { font-weight: 700; }

.pf-top3-grid {
	display: grid; grid-template-columns: 1fr 1.2fr 1fr; gap: 16px; align-items: end;
}
.pf-top3-card { text-align: center; padding: 24px; border-radius: 12px; }
.pf-top3-card.rank-1 { transform: scale(1.05); }
.pf-rank-badge { font-size: 2rem; margin-bottom: 8px; display: block; }

.pf-stats-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.pf-stat-item { padding: 8px; }
.pf-stat-label { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 2px; }
.pf-stat-value { font-size: 1.1rem; font-weight: 700; }

.pf-category-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 12px; }
.pf-category-tag { padding: 2px 8px; border-radius: 12px; font-size: 0.75rem; }

.pf-theme-switch {
	position: fixed; top: 12px; right: 12px; z-index: 1000;
	padding: 6px 14px; border: none; border-radius: 20px; cursor: pointer;
	font-size: 0.8rem; font-weight: 500; transition: all 0.2s;
}

.pf-loading { text-align: center; padding: 60px 20px; font-size: 0.9rem; }

@media (max-width: 768px) {
	.pf-top3-grid { grid-template-columns: 1fr; }
	.pf-top3-card.rank-1 { transform: none; }
	.pf-stats-grid { grid-template-columns: 1fr; }
	.pf-header-stats { gap: 12px; font-size: 0.8rem; }
}

@media (max-width: 480px) {
	.pf-container { padding: 12px 8px; }
	.pf-header { padding: 16px; }
	.pf-header h1 { font-size: 1.2rem; }
	.pf-tab { padding: 8px 16px; font-size: 0.85rem; }
	.pf-table { font-size: 0.8rem; }
	.pf-table thead th, .pf-table tbody td { padding: 8px 10px; }
}
