/**
 * Avatar Frame Engine v5 — layered structure, sizes, hover, performance.
 */

.nx-afe,
.nx-avatar-frame {
	--nx-afe-size: 96px;
	--nx-afe-ring: 3px;
	--nx-afe-glow: 0 0 18px rgba(212, 175, 55, 0.35);
	--nx-afe-glow-hover: 0 0 28px rgba(212, 175, 55, 0.55);
	--nx-afe-scale-hover: 1.04;
	--nx-afe-reflect-opacity: 0.35;
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: var(--nx-afe-size);
	height: var(--nx-afe-size);
	flex-shrink: 0;
	isolation: isolate;
	transform: translateZ(0);
	will-change: transform, filter;
}

.nx-afe--sm,
.nx-avatar-frame--sm { --nx-afe-size: 48px; --nx-afe-ring: 2px; }
.nx-afe--md,
.nx-avatar-frame--md { --nx-afe-size: 96px; }
.nx-afe--lg,
.nx-avatar-frame--lg { --nx-afe-size: 128px; --nx-afe-ring: 4px; }
.nx-afe--xl { --nx-afe-size: 160px; --nx-afe-ring: 5px; }

.nx-afe__avatar {
	position: relative;
	z-index: 2;
	width: calc(100% - var(--nx-afe-ring) * 5);
	height: calc(100% - var(--nx-afe-ring) * 5);
	border-radius: 50%;
	overflow: hidden;
}

.nx-afe__img,
.nx-avatar-frame__img {
	display: block;
	width: 100%;
	height: 100%;
	border-radius: 50%;
	object-fit: cover;
}

.nx-afe__img--fallback {
	background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.15), rgba(255,255,255,.04));
}

.nx-afe__glow,
.nx-avatar-frame__glow {
	position: absolute;
	inset: -8%;
	border-radius: 50%;
	z-index: 0;
	pointer-events: none;
	opacity: 0.65;
	filter: blur(10px);
	background: radial-gradient(circle, var(--nx-rarity-glow, rgba(212,175,55,.45)) 0%, transparent 70%);
	transition: opacity 0.35s ease, transform 0.35s ease, filter 0.35s ease;
}

.nx-afe__border,
.nx-avatar-frame__ring {
	position: absolute;
	inset: 0;
	border-radius: 50%;
	z-index: 3;
	pointer-events: none;
	transition: transform 0.35s ease, filter 0.35s ease, opacity 0.35s ease;
}

.nx-afe__reflection {
	position: absolute;
	inset: 8%;
	border-radius: 50%;
	z-index: 4;
	pointer-events: none;
	opacity: var(--nx-afe-reflect-opacity);
	background: linear-gradient(135deg, rgba(255,255,255,.45) 0%, transparent 45%, transparent 100%);
	mix-blend-mode: soft-light;
	transition: transform 0.45s ease, opacity 0.35s ease;
}

.nx-afe__particles {
	position: absolute;
	inset: -12%;
	z-index: 1;
	pointer-events: none;
}

.nx-afe__particles i {
	position: absolute;
	width: 4px;
	height: 4px;
	border-radius: 50%;
	background: var(--nx-rarity-glow, #fff);
	opacity: 0.55;
	animation: nx-afe-particle 4s ease-in-out infinite;
}

.nx-afe__particles i:nth-child(1) { top: 8%; left: 50%; animation-delay: 0s; }
.nx-afe__particles i:nth-child(2) { top: 70%; left: 12%; animation-delay: 1.2s; }
.nx-afe__particles i:nth-child(3) { top: 22%; left: 88%; animation-delay: 2.4s; }

.nx-afe__badge {
	position: absolute;
	right: -2%;
	bottom: -2%;
	z-index: 5;
	width: calc(var(--nx-afe-size) * 0.28);
	height: calc(var(--nx-afe-size) * 0.28);
	border-radius: 50%;
	display: grid;
	place-items: center;
	background: rgba(8, 8, 12, 0.85);
	border: 1px solid rgba(255, 255, 255, 0.12);
	box-shadow: 0 4px 14px rgba(0, 0, 0, 0.45);
	font-size: calc(var(--nx-afe-size) * 0.12);
	line-height: 1;
}

.nx-afe--interactive:hover,
.nx-afe--interactive:focus-within {
	transform: scale(var(--nx-afe-scale-hover));
}

.nx-afe--interactive:hover .nx-afe__glow,
.nx-afe--interactive:focus-within .nx-afe__glow {
	opacity: 1;
	filter: blur(14px);
	transform: scale(1.08);
}

.nx-afe--interactive:hover .nx-afe__border,
.nx-afe--interactive:focus-within .nx-afe__border {
	transform: scale(1.03);
	filter: drop-shadow(var(--nx-afe-glow-hover));
}

.nx-afe--interactive:hover .nx-afe__reflection,
.nx-afe--interactive:focus-within .nx-afe__reflection {
	transform: translate(-6%, -6%) rotate(-8deg);
	opacity: calc(var(--nx-afe-reflect-opacity) + 0.15);
}

@keyframes nx-afe-particle {
	0%, 100% { transform: translate(0, 0) scale(1); opacity: 0.35; }
	50% { transform: translate(0, -6px) scale(1.2); opacity: 0.85; }
}

@media (max-width: 640px) {
	.nx-afe--lg { --nx-afe-size: 112px; }
	.nx-afe--xl { --nx-afe-size: 128px; }
}

@media (prefers-reduced-motion: reduce) {
	.nx-afe--animated .nx-afe__border,
	.nx-afe--animated .nx-afe__glow,
	.nx-afe--animated .nx-afe__reflection,
	.nx-afe__particles i {
		animation: none !important;
	}
	.nx-afe--interactive:hover { transform: none; }
}
