/**
 * FYFX Blitz Orbital Widget Styles
 *
 * @package fyfx-elementor-core
 * @since   1.0.0
 */

.fyfx-blitz-orbital {
	position: relative;
}

/* ── Card ───────────────────────────────────────────────────────────── */

.fyfx-orbital-card {
	background: #0D0D0D;
	border: 1px solid #2250EF4D;
	border-radius: 24px;
	padding: 40px;
	display: grid;
	grid-template-columns: 45fr 55fr;
	align-items: center;
	gap: 40px;
	box-shadow:
		0px 0px 60px 0px #2151F240,
		0px 8px 32px 0px #2151F259,
		0px 0px 0px 1px #2151F273;
}

/* ── Orbital Visual ─────────────────────────────────────────────────── */

.fyfx-orbital-visual {
	display: flex;
	align-items: center;
	justify-content: center;
}

.fyfx-orbital-ring {
	position: relative;
	width: 360px;
	height: 360px;
	max-width: 100%;
	aspect-ratio: 1 / 1;
	border-radius: 50%;
}

.fyfx-orbital-svg {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	overflow: visible;
}

.fyfx-orbital-track-circle {
	fill: none;
	stroke: var(--fyfx-orbital-track, rgba(255, 255, 255, 0.08));
	stroke-width: var(--fyfx-orbital-track-width, 3);
}

.fyfx-orbital-progress-path {
	fill: none;
	stroke: var(--fyfx-orbital-progress, #1A4FFF);
	stroke-width: var(--fyfx-orbital-progress-width, 6);
	stroke-linecap: round;
	stroke-dasharray: 100;
	stroke-dashoffset: 100;
	transition: stroke-dashoffset var(--fyfx-orbital-dur, 0.4s) ease;
}

.fyfx-orbital-dot {
	position: absolute;
	width: 30px;
	height: 30px;
	border-radius: 50%;
	transform: translate(-50%, -50%);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: #0D0D0D;
	border: 1px solid #8CA4F82E;
	color: #A7ADBE;
	font-size: 10px;
	font-weight: 700;
	cursor: pointer;
	transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.fyfx-orbital-dot:hover {
	background: #2151F2;
	border-color: #2151F2;
	color: #FFFFFF;
}

.fyfx-orbital-dot.is-passed,
.fyfx-orbital-dot.is-current {
	background: #2151F2;
	border-color: #2151F2;
	color: #FFFFFF;
	box-shadow: 0px 0px 8px 0px #2151F299;
}

.fyfx-orbital-dot.is-current {
	width: 34px;
	height: 34px;
	background: #FFFFFF;
	border-color: #FFFFFF;
	color: #0D0D0D;
	box-shadow: 0px 0px 12px 0px #2151F299;
	transform: translate(-50%, -50%) scale(1.05);
}

/* ── Orbital Inside (icon circle) ──────────────────────────────────── */

.fyfx-orbital-inside {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 55.56%;
	height: 55.56%;
	border-radius: 50%;
	transform: translate(-50%, -50%);
	display: flex;
	align-items: center;
	justify-content: center;
	background: radial-gradient(82.01% 82.01% at 50% 35%, rgba(140, 164, 248, 0.25) 0%, rgba(26, 79, 255, 0.09) 60%, rgba(0, 0, 0, 0.2) 100%);
	border: 1px solid #7A97F7;
	box-shadow:
		0px 28px 60px 0px #2151F266,
		0px -4px 0px 1px #00000073 inset,
		0px 4px 0px 1px #FFFFFF2E inset;
}

.fyfx-orbital-inside i,
.fyfx-orbital-inside svg {
	font-size: 36px;
	width: 36px;
	height: 36px;
	color: #7A97F7;
	fill: #7A97F7;
}

/* ── Content ────────────────────────────────────────────────────────── */

.fyfx-orbital-content-wrap {
	position: relative;
	min-width: 0;
}

.fyfx-orbital-content {
	display: flex;
	flex-direction: column;
	gap: 16px;
	min-width: 0;
}

.fyfx-orbital-badge {
	display: inline-flex;
	align-items: center;
	align-self: flex-start;
	padding: 6px 14px;
	border-radius: 999px;
	background: #2250EF1A;
	border: 1px solid #2250EF4D;
	color: #2151F2;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.04em;
}

.fyfx-orbital-title {
	color: #FFFFFF;
	font-size: 32px;
	font-weight: 700;
	line-height: 1.2;
	margin: 0;
}

.fyfx-orbital-compare {
	display: inline-flex;
	align-items: center;
	align-self: flex-start;
	gap: 8px;
	padding: 10px 18px;
	border-radius: 999px;
	background: #FFFFFF0A;
	border: 1px solid #FFFFFF1A;
	flex-wrap: wrap;
}

.fyfx-orbital-compare-before {
	color: #A7ADBE;
	font-size: 14px;
	text-decoration: line-through;
}

.fyfx-orbital-compare-arrow {
	color: #2151F2;
	font-size: 14px;
}

.fyfx-orbital-compare-after {
	color: #FFFFFF;
	font-size: 14px;
	font-weight: 700;
}

.fyfx-orbital-desc {
	color: #A7ADBE;
	font-size: 15px;
	line-height: 1.6;
	margin: 0;
}

/* ── Responsive ─────────────────────────────────────────────────────── */

@media (max-width: 768px) {
	.fyfx-orbital-card {
		grid-template-columns: 1fr;
		gap: 24px;
		padding: 28px;
		text-align: center;
	}

	.fyfx-orbital-visual {
		overflow: hidden;
	}

	.fyfx-orbital-ring {
		margin: 0 auto;
	}

	.fyfx-orbital-badge,
	.fyfx-orbital-compare {
		align-self: center;
	}

	.fyfx-orbital-title {
		font-size: 24px;
	}
}
