/* PXS Jackpot Elementor widget */

.pxs-jackpot-widget {
	position: relative;
	box-sizing: border-box;
}

.pxs-jackpot-widget__section-heading {
	margin: 0;
}

.pxs-jackpot-widget__card-outer {
	display: flex;
	width: 100%;
	box-sizing: border-box;
	justify-content: flex-start;
}

/* ---- Themed jackpot card (colors via Style → Jackpot card colors, --pxs-jk-*) ---- */
.pxs-jackpot-widget .jackpot-card {
	--pxs-jk-text: #ffffff;
	--pxs-jk-accent: #ffb86b;
	--pxs-jk-sub: #8fd19e;
	--pxs-jk-rim: #ffaa50;
	--pxs-jk-bg-a: #2a1a0f;
	--pxs-jk-bg-b: #0d0d0d;
	--pxs-jk-badge-a: #ff9a3c;
	--pxs-jk-badge-b: #ff5e00;
	/* Amount text-shadow glow (Style → Amount → Amount glow); color falls back to accent */
	--pxs-jk-amg-in: 90%;
	--pxs-jk-amg-out: 50%;

	position: relative;
	border-radius: 14px;
	padding: 24px;
	overflow: hidden;
	color: var(--pxs-jk-text);

	background-image:
		radial-gradient(
			circle at 20% 30%,
			color-mix(in srgb, var(--pxs-jk-accent) 15%, transparent) 1px,
			transparent 1px
		),
		radial-gradient(
			circle at 70% 60%,
			color-mix(in srgb, var(--pxs-jk-accent) 10%, transparent) 1px,
			transparent 1px
		),
		radial-gradient(
			circle at 40% 80%,
			color-mix(in srgb, var(--pxs-jk-accent) 10%, transparent) 1px,
			transparent 1px
		),
		radial-gradient(circle at 30% 20%, var(--pxs-jk-bg-a), var(--pxs-jk-bg-b));

	background-size:
		120px 120px,
		180px 180px,
		160px 160px,
		cover;

	border: 1px solid color-mix(in srgb, var(--pxs-jk-rim) 40%, transparent);
	box-shadow:
		0 0 0 1px color-mix(in srgb, var(--pxs-jk-rim) 15%, transparent),
		0 10px 30px rgba(0, 0, 0, 0.7),
		inset 0 0 25px color-mix(in srgb, var(--pxs-jk-accent) 8%, transparent);
}

.pxs-jackpot-widget .jackpot-card::before {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: 14px;
	pointer-events: none;
	box-shadow: 0 0 25px color-mix(in srgb, var(--pxs-jk-accent) 25%, transparent);
	z-index: 0;
}

.pxs-jackpot-widget .jackpot-card::after {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: 14px;
	pointer-events: none;
	background: linear-gradient(
		120deg,
		transparent 30%,
		color-mix(in srgb, var(--pxs-jk-text) 8%, transparent),
		transparent 70%
	);
	transform: translateX(-100%);
	animation: pxs-jk-shine 4s infinite;
	z-index: 1;
}

.pxs-jackpot-widget .jackpot-card.jackpot-card--no-bg-animation::after {
	animation: none;
	opacity: 0;
}

@keyframes pxs-jk-shine {
	to {
		transform: translateX(100%);
	}
}

@media (prefers-reduced-motion: reduce) {
	.pxs-jackpot-widget .jackpot-card::after {
		animation: none;
	}

	.pxs-jackpot-widget .jackpot-card .amount {
		animation: none;
	}
}

/*
 * Defaults use :where() so specificity is 0 — Style → LIVE badge (background, border, shadow)
 * from Elementor can override. Do not use the `background` shorthand here; it would reset
 * Elementor’s background-image / background-color.
 */
.pxs-jackpot-widget .jackpot-badge {
	position: absolute;
	top: 14px;
	left: 14px;
	z-index: 3;
	padding: 5px 12px;
	border-radius: 6px;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.5px;
	color: var(--pxs-jk-text);
}

:where(.pxs-jackpot-widget .jackpot-badge) {
	background-color: transparent;
	background-image: linear-gradient(135deg, var(--pxs-jk-badge-a), var(--pxs-jk-badge-b));
	box-shadow: 0 0 12px color-mix(in srgb, var(--pxs-jk-badge-b) 70%, transparent);
}

.pxs-jackpot-widget .jackpot-card .pxs-jackpot-widget__info-btn {
	position: absolute;
	top: 14px;
	right: 14px;
	left: auto;
	z-index: 5;
}

.pxs-jackpot-widget .jackpot-content {
	position: relative;
	z-index: 2;
	text-align: center;
}

.pxs-jackpot-widget .jackpot-card h4 {
	margin: 0;
	font-size: 20px;
	font-weight: 600;
	color: var(--pxs-jk-accent);
}

.pxs-jackpot-widget .jackpot-card .amount {
	font-size: 64px;
	font-weight: 800;
	color: var(--pxs-jk-accent);
	margin: 10px 0;
	letter-spacing: 1px;
	line-height: 1.1;
	text-shadow:
		0 0 12px
			color-mix(
				in srgb,
				var(--pxs-jk-amount-glow, var(--pxs-jk-accent)) var(--pxs-jk-amg-in, 90%),
				transparent
			),
		0 0 30px
			color-mix(
				in srgb,
				var(--pxs-jk-amount-glow, var(--pxs-jk-accent)) var(--pxs-jk-amg-out, 50%),
				transparent
			);
	animation: pxs-jk-pulseGlow 2.5s infinite ease-in-out;
}

.pxs-jackpot-widget .jackpot-card.jackpot-card--no-amount-glow .amount {
	text-shadow: none;
	animation: none;
}

@media (max-width: 480px) {
	.pxs-jackpot-widget .jackpot-card .amount {
		font-size: clamp(2rem, 14vw, 4rem);
	}
}

.pxs-jackpot-widget .jackpot-card .amount .woocommerce-Price-amount,
.pxs-jackpot-widget .jackpot-card .amount {
	display: inline-block;
}

@keyframes pxs-jk-pulseGlow {
	0%,
	100% {
		text-shadow:
			0 0 12px
				color-mix(
					in srgb,
					var(--pxs-jk-amount-glow, var(--pxs-jk-accent)) var(--pxs-jk-amg-in, 90%),
					transparent
				),
			0 0 30px
				color-mix(
					in srgb,
					var(--pxs-jk-amount-glow, var(--pxs-jk-accent)) var(--pxs-jk-amg-out, 50%),
					transparent
				);
	}
	50% {
		text-shadow:
			0 0 22px
				color-mix(
					in srgb,
					var(--pxs-jk-amount-glow, var(--pxs-jk-accent)) var(--pxs-jk-amg-in, 90%),
					transparent
				),
			0 0 45px
				color-mix(
					in srgb,
					var(--pxs-jk-amount-glow, var(--pxs-jk-accent)) var(--pxs-jk-amg-out, 50%),
					transparent
				);
	}
}

.pxs-jackpot-widget .jackpot-sub {
	margin: 8px 0 0;
}

/* :where() keeps specificity 0 so Style → Sub line can override color, type, opacity */
:where(.pxs-jackpot-widget .jackpot-sub) {
	font-size: 14px;
	color: var(--pxs-jk-sub);
	opacity: 0.9;
}

/* Information button (icon) */
.pxs-jackpot-widget .pxs-jackpot-widget__info-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin: 0;
	padding: 0.25rem;
	border: none;
	background: transparent;
	cursor: pointer;
	line-height: 1;
}

.pxs-jackpot-widget .pxs-jackpot-widget__info-btn:focus {
	outline: 2px solid currentColor;
	outline-offset: 2px;
}

.pxs-jackpot-widget .pxs-jackpot-widget__info-fallback {
	display: inline-block;
	font-weight: 700;
	font-style: italic;
	font-family: Georgia, serif;
	line-height: 1;
}

/* Modal — position:fixed; see widget inline styles + portal JS */
.pxs-jackpot-widget__modal[hidden] {
	display: none !important;
}

.pxs-jackpot-widget__modal:not([hidden]) {
	display: flex;
	align-items: center;
	justify-content: center;
	position: fixed;
	left: 0;
	top: 0;
	right: 0;
	bottom: 0;
	width: 100vw;
	min-height: 100vh;
	min-height: 100dvh;
	margin: 0;
	border: 0;
	z-index: 100000;
	padding: 1rem;
	box-sizing: border-box;
}

.pxs-jackpot-widget__modal-backdrop {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	cursor: pointer;
}

.pxs-jackpot-widget__modal-panel {
	position: relative;
	z-index: 1;
	flex: 0 1 auto;
	align-self: center;
	width: auto;
	max-width: min(36rem, calc(100vw - 2rem));
	max-height: calc(100vh - 2rem);
	max-height: calc(100dvh - 2rem);
	overflow: auto;
	box-sizing: border-box;
	padding: 1.25rem 1rem 1rem;
}

.pxs-jackpot-widget__modal-close {
	position: absolute;
	top: 0.35rem;
	right: 0.35rem;
	z-index: 2;
	margin: 0;
	padding: 0;
	border: none;
	background: transparent;
	cursor: pointer;
	line-height: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.5rem;
}

.pxs-jackpot-widget__modal-body {
	display: block;
	box-sizing: border-box;
	width: 100%;
	min-height: 2rem;
	overflow-wrap: break-word;
	word-wrap: break-word;
}

.pxs-jackpot-widget__modal-body a {
	color: var(--pxs-jackpot-modal-link, inherit);
}

.pxs-jackpot-widget__modal-body > :first-child {
	margin-top: 0;
}

.pxs-jackpot-widget__modal-body > :last-child {
	margin-bottom: 0;
}

body.pxs-jackpot-modal-open {
	overflow: hidden;
}
