/* EXO VAULT shipping meter — gold progress bar with tier celebrations.
   RTL-safe: fill scales from the logical start edge. */

.ev-meter {
	--evm-gold: #c9a227;
	--evm-gold-shadow: #8b6914;
	--evm-gold-hi: #ffe9a8;
	--evm-ease: cubic-bezier(0.22, 1, 0.36, 1);
	position: relative;
	display: grid;
	gap: 0.5rem;
	padding: 0.9rem 1rem;
	margin-block-end: 1rem;
	border: 1px solid rgba(201, 162, 39, 0.35);
	border-radius: 8px;
	background: rgba(26, 11, 46, 0.45);
}

.ev-meter__msg {
	margin: 0;
	font-size: 0.9rem;
	line-height: 1.4;
}
.ev-meter__msg .woocommerce-Price-amount {
	color: var(--evm-gold-hi);
	font-weight: 600;
}

.ev-meter__track {
	position: relative;
	height: 10px;
	border-radius: 99px;
	background: rgba(201, 162, 39, 0.14);
	box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.4);
	overflow: hidden;
}

.ev-meter__fill {
	position: absolute;
	inset: 0;
	border-radius: 99px;
	background: linear-gradient(90deg, var(--evm-gold-shadow), var(--evm-gold) 60%, var(--evm-gold-hi));
	transform-origin: 0 50%;
	transition: transform 500ms var(--evm-ease);
}
[dir="rtl"] .ev-meter__fill {
	transform-origin: 100% 50%;
	background: linear-gradient(270deg, var(--evm-gold-shadow), var(--evm-gold) 60%, var(--evm-gold-hi));
}
/* Premium sheen sweeping along the filled portion. */
.ev-meter__fill::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(100deg, transparent 20%, rgba(255, 255, 255, 0.45) 50%, transparent 80%);
	transform: translateX(-100%);
	animation: evm-sheen 2.8s var(--evm-ease) infinite;
}
@media (prefers-reduced-motion: reduce) {
	.ev-meter__fill::after { animation: none; opacity: 0; }
}
@keyframes evm-sheen {
	0% { transform: translateX(-100%); }
	60%, 100% { transform: translateX(100%); }
}

/* 50% notch on the track */
.ev-meter__notch {
	position: absolute;
	inset-block: -2px;
	inset-inline-start: 50%;
	width: 2px;
	background: rgba(255, 233, 168, 0.55);
}

/* Half tier: the bar pulses gold */
.ev-meter--half .ev-meter__fill {
	animation: evm-pulse 1.6s var(--evm-ease) infinite;
}
@keyframes evm-pulse {
	0%, 100% { filter: brightness(1); }
	50% { filter: brightness(1.35); }
}

.ev-meter__badge {
	justify-self: start;
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	padding: 0.25rem 0.6rem;
	border-radius: 3px;
	color: #0a0612;
	background: linear-gradient(160deg, var(--evm-gold-hi), var(--evm-gold) 60%, var(--evm-gold-shadow));
	box-shadow: 0 0 14px rgba(201, 162, 39, 0.45);
}

/* Free tier: full golden bar, particles handled in JS */
.ev-meter--free .ev-meter__fill {
	box-shadow: 0 0 12px rgba(255, 233, 168, 0.7);
}

.ev-meter__particle {
	position: absolute;
	width: 5px;
	height: 5px;
	border-radius: 50%;
	background: var(--evm-gold-hi);
	pointer-events: none;
	opacity: 0;
	animation: evm-burst 600ms var(--evm-ease) forwards;
}
@keyframes evm-burst {
	0% {
		opacity: 1;
		transform: translate(0, 0) scale(1);
	}
	100% {
		opacity: 0;
		transform: translate(var(--dx, 0), var(--dy, -28px)) scale(0.4);
	}
}

@media (prefers-reduced-motion: reduce) {
	.ev-meter__fill { transition: none; }
	.ev-meter--half .ev-meter__fill { animation: none; }
	.ev-meter__particle { display: none; }
}
