:root {
	--ivf-shell-bg: #09111d;
	--ivf-ink: #102038;
	--ivf-ink-soft: #5f718a;
	--ivf-surface: rgba(255, 255, 255, 0.97);
	--ivf-surface-soft: rgba(255, 255, 255, 0.1);
	--ivf-border-soft: rgba(255, 255, 255, 0.15);
	--ivf-card-border: #d8e2ef;
	--ivf-accent: #d48f17;
	--ivf-accent-strong: #b86e0d;
	--ivf-electric: #1d76d2;
	--ivf-road-base: #2e3744;
	--ivf-road-edge: #4c5666;
	--ivf-road-lane: #e1ab42;
	--ivf-road-stop: #f0b140;
	--ivf-road-future: #46a4ff;
	--ivf-success: #21885f;
	--ivf-danger: #c03f4f;
	--ivf-shadow: 0 24px 54px rgba(4, 14, 26, 0.26);
}

html,
body {
	min-height: 100%;
}

body.body-note {
	background:
		radial-gradient(circle at top left, rgba(43, 126, 214, 0.18), transparent 24%),
		radial-gradient(circle at top right, rgba(212, 143, 23, 0.18), transparent 22%),
		linear-gradient(135deg, #08111c 0%, #102036 45%, #0c1728 100%);
	color: #ffffff;
	font-family: Poppins, Roboto, sans-serif;
	overflow-x: hidden;
	scrollbar-color: rgba(61, 98, 148, 0) transparent;
	scrollbar-width: none;
}

body.body-note:hover {
	scrollbar-color: rgba(61, 98, 148, 0.5) transparent;
	scrollbar-width: thin;
}

body.body-note::-webkit-scrollbar {
	width: 10px;
}

body.body-note::-webkit-scrollbar-track {
	background: transparent;
}

body.body-note::-webkit-scrollbar-thumb {
	background: transparent;
	border: 2px solid transparent;
	border-radius: 999px;
}

body.body-note:hover::-webkit-scrollbar-thumb {
	background: rgba(61, 98, 148, 0.45);
	background-clip: padding-box;
}

@keyframes ivf-auth-loader-orbit {
	from {
		transform: rotate(0deg);
	}

	to {
		transform: rotate(360deg);
	}
}

@keyframes ivf-auth-loader-pulse {
	0%,
	100% {
		transform: translate(-50%, -50%) scale(1);
		box-shadow: 0 18px 34px rgba(18, 42, 72, 0.2);
	}

	50% {
		transform: translate(-50%, -50%) scale(1.04);
		box-shadow: 0 22px 42px rgba(18, 42, 72, 0.28);
	}
}

@keyframes ivf-auth-loader-chip {
	0%,
	100% {
		transform: translateY(0);
		background: #edf4fc;
	}

	50% {
		transform: translateY(-3px);
		background: #ffffff;
	}
}

@keyframes ivf-auth-loader-chip-active {
	0%,
	100% {
		transform: translateY(0);
	}

	50% {
		transform: translateY(-3px);
	}
}

.ivf-auth-loader {
	align-items: center;
	background: rgba(246, 249, 253, 0.74);
	backdrop-filter: blur(10px);
	display: flex;
	inset: 0;
	justify-content: center;
	opacity: 0;
	padding: 20px;
	pointer-events: none;
	position: fixed;
	transition: opacity 0.22s ease, visibility 0.22s ease;
	visibility: hidden;
	z-index: 4000;
}

.ivf-auth-loader::before {
	background:
		radial-gradient(circle at 18% 18%, rgba(90, 184, 255, 0.16), transparent 20%),
		radial-gradient(circle at 84% 22%, rgba(240, 177, 64, 0.16), transparent 18%),
		radial-gradient(circle at 50% 78%, rgba(79, 125, 228, 0.12), transparent 22%);
	content: "";
	inset: 0;
	position: absolute;
}

.ivf-auth-loader.ivf-auth-loader-active {
	opacity: 1;
	pointer-events: auto;
	visibility: visible;
}

.ivf-auth-loader-card {
	background: rgba(255, 255, 255, 0.96);
	border: 1px solid rgba(207, 220, 236, 0.92);
	border-radius: 26px;
	box-shadow: 0 28px 70px rgba(14, 35, 60, 0.16);
	display: flex;
	flex-direction: column;
	gap: 14px;
	max-width: 420px;
	padding: 24px 24px 22px;
	position: relative;
	text-align: center;
	width: min(100%, 420px);
	z-index: 1;
}

.ivf-auth-loader-route {
	height: 92px;
	margin: 0 auto;
	position: relative;
	width: 92px;
}

.ivf-auth-loader-route::before {
	border: 3px dashed #d3ddec;
	border-radius: 50%;
	content: "";
	inset: 11px;
	position: absolute;
}

.ivf-auth-loader-ring {
	border: 3px solid rgba(42, 98, 204, 0.14);
	border-radius: 50%;
	border-right-color: #d48f17;
	border-top-color: #2a62cc;
	inset: 0;
	position: absolute;
	animation: ivf-auth-loader-orbit 1.08s linear infinite;
}

.ivf-auth-loader-core {
	align-items: center;
	animation: ivf-auth-loader-pulse 1.8s ease-in-out infinite;
	background: linear-gradient(135deg, #21497d, #12223a);
	border: 4px solid rgba(255, 255, 255, 0.94);
	border-radius: 50%;
	box-shadow: 0 18px 34px rgba(18, 42, 72, 0.2);
	color: #f5f9ff;
	display: inline-flex;
	font-size: 26px;
	height: 58px;
	inset: 50% auto auto 50%;
	justify-content: center;
	position: absolute;
	transform: translate(-50%, -50%);
	width: 58px;
}

.ivf-auth-loader-core i {
	transition: color 0.2s ease, transform 0.2s ease;
}

.ivf-auth-loader-title {
	color: #12233b;
	display: block;
	font-size: 18px;
	font-weight: 800;
	letter-spacing: -0.02em;
	line-height: 1.2;
}

.ivf-auth-loader-text {
	color: #607189;
	display: block;
	font-size: 13px;
	line-height: 1.6;
	margin: -4px auto 0;
	max-width: 290px;
	min-height: 40px;
}

.ivf-auth-loader-track {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	justify-content: center;
}

.ivf-auth-loader-chip {
	animation: ivf-auth-loader-chip 1.9s ease-in-out infinite;
	align-items: center;
	background: #edf4fc;
	border: 1px solid #dce6f3;
	border-radius: 999px;
	color: #224164;
	display: inline-flex;
	gap: 7px;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.03em;
	padding: 7px 11px;
	transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}

.ivf-auth-loader-chip i {
	font-size: 12px;
}

.ivf-auth-loader-chip-active {
	animation: ivf-auth-loader-chip-active 1.9s ease-in-out infinite;
	background: linear-gradient(135deg, #234b7e, #12233b);
	border-color: rgba(35, 75, 126, 0.26);
	box-shadow: 0 12px 24px rgba(18, 35, 59, 0.16);
	color: #ffffff;
}

.ivf-auth-loader-chip-active i,
.ivf-auth-loader-chip-active span {
	color: #ffffff;
}

.ivf-auth-loader-track span:nth-child(2) {
	animation-delay: 0.18s;
}

.ivf-auth-loader-track span:nth-child(3) {
	animation-delay: 0.36s;
}

.ivf-auth-loader-track span:nth-child(4) {
	animation-delay: 0.54s;
}

.ivf-auth-loader-track span:nth-child(5) {
	animation-delay: 0.72s;
}

.ivf-auth-loader-track span:nth-child(6) {
	animation-delay: 0.9s;
}

.ivf-auth-loader-track span:nth-child(7) {
	animation-delay: 1.08s;
}

@media (max-width: 767px) {
	.ivf-auth-loader {
		padding: 16px;
	}

	.ivf-auth-loader-card {
		border-radius: 22px;
		padding: 22px 18px 18px;
	}

	.ivf-auth-loader-route {
		height: 84px;
		width: 84px;
	}

	.ivf-auth-loader-core {
		font-size: 24px;
		height: 54px;
		width: 54px;
	}

	.ivf-auth-loader-title {
		font-size: 17px;
	}

	.ivf-auth-loader-text {
		font-size: 12px;
		min-height: 36px;
	}
}

.ivf-shell {
	min-height: 100vh;
	padding: 12px 16px 10px;
	position: relative;
}

.ivf-shell::before {
	background:
		linear-gradient(90deg, rgba(5, 13, 24, 0.7), rgba(5, 13, 24, 0.16)),
		linear-gradient(180deg, rgba(255, 255, 255, 0.015), rgba(255, 255, 255, 0));
	content: "";
	inset: 0;
	pointer-events: none;
	position: absolute;
}

.ivf-nav,
.ivf-stage,
.ivf-footer {
	margin: 0 auto;
	max-width: 1240px;
	position: relative;
	z-index: 1;
}

.ivf-shell-login .ivf-nav,
.ivf-shell-login .ivf-stage,
.ivf-shell-login .ivf-footer {
	max-width: 1820px;
}

.ivf-shell.ivf-shell-login {
	padding: 10px 12px 8px;
}

.ivf-nav {
	align-items: center;
	display: flex;
	gap: 18px;
	justify-content: space-between;
	margin-bottom: 12px;
}

.ivf-brand {
	align-items: center;
	color: #ffffff;
	display: inline-flex;
	gap: 14px;
	text-decoration: none;
}

.ivf-brand:hover,
.ivf-brand:focus {
	color: #ffffff;
	text-decoration: none;
}

.ivf-brand-badge {
	align-items: center;
	background: rgba(255, 255, 255, 0.98);
	border: 1px solid rgba(255, 255, 255, 0.28);
	border-radius: 16px;
	box-shadow: 0 12px 26px rgba(0, 0, 0, 0.16);
	display: inline-flex;
	height: 52px;
	justify-content: center;
	padding: 6px 12px;
}

.ivf-brand-badge img {
	height: 32px;
	max-width: 156px;
	object-fit: contain;
}

.ivf-brand-copy {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.ivf-brand-kicker {
	color: rgba(255, 255, 255, 0.68);
	font-size: 10px;
	font-weight: 600;
	letter-spacing: 0.18em;
	text-transform: uppercase;
}

.ivf-brand-title {
	font-size: 18px;
	font-weight: 700;
	letter-spacing: 0.02em;
}

.ivf-nav-links {
	display: inline-flex;
	flex-wrap: wrap;
	gap: 10px;
}

.ivf-nav-link {
	background: rgba(255, 255, 255, 0.08);
	box-sizing: border-box;
	border: 1px solid rgba(255, 255, 255, 0.14);
	border-radius: 999px;
	color: #ffffff;
	display: inline-flex;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.06em;
	padding: 8px 14px;
	text-decoration: none;
	text-transform: uppercase;
	transition: transform 0.2s ease, background 0.2s ease;
}

.ivf-nav-link:hover,
.ivf-nav-link:focus,
.ivf-nav-link-active {
	background: rgba(212, 143, 23, 0.18);
	color: #ffffff;
	text-decoration: none;
	transform: translateY(-1px);
}

.ivf-stage {
	display: grid;
	gap: 16px;
	grid-template-columns: minmax(0, 1.08fr) minmax(360px, 0.92fr);
}

.ivf-panel {
	border-radius: 24px;
	overflow: hidden;
	position: relative;
}

.ivf-banner {
	background:
		linear-gradient(150deg, rgba(3, 10, 18, 0.95), rgba(5, 19, 34, 0.88)),
		var(--ivf-banner-image, linear-gradient(135deg, #0c1a2b, #143453));
	background-position: center;
	background-size: cover;
	border: 1px solid rgba(255, 255, 255, 0.12);
	box-shadow: var(--ivf-shadow);
	min-height: 450px;
	padding: 20px 22px;
}

.ivf-banner::before {
	background:
		linear-gradient(rgba(255, 255, 255, 0.06) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255, 255, 255, 0.06) 1px, transparent 1px);
	background-size: 34px 34px;
	content: "";
	inset: 0;
	opacity: 0.12;
	position: absolute;
}

.ivf-banner::after {
	background:
		radial-gradient(circle at 14% 16%, rgba(43, 126, 214, 0.22), transparent 18%),
		radial-gradient(circle at 86% 86%, rgba(212, 143, 23, 0.16), transparent 16%);
	content: "";
	inset: 0;
	position: absolute;
}

.ivf-banner-content {
	display: flex;
	flex-direction: column;
	gap: 12px;
	position: relative;
	z-index: 1;
}

.ivf-pill {
	align-items: center;
	background: rgba(255, 255, 255, 0.1);
	border: 1px solid rgba(255, 255, 255, 0.16);
	border-radius: 999px;
	display: inline-flex;
	font-size: 10px;
	font-weight: 600;
	letter-spacing: 0.14em;
	padding: 7px 12px;
	text-transform: uppercase;
	width: fit-content;
}

.ivf-banner-title {
	font-size: clamp(24px, 3vw, 36px);
	font-weight: 700;
	line-height: 1.08;
	margin: 0;
	max-width: 520px;
	text-shadow: 0 10px 28px rgba(0, 0, 0, 0.42);
}

.ivf-banner-text {
	color: rgba(255, 255, 255, 0.88);
	font-size: 13px;
	line-height: 1.6;
	margin: 0;
	max-width: 560px;
	text-shadow: 0 10px 26px rgba(0, 0, 0, 0.35);
}

.ivf-product-line {
	color: rgba(255, 255, 255, 0.92);
	font-size: 10px;
	font-weight: 600;
	letter-spacing: 0.1em;
	line-height: 1.8;
	text-transform: uppercase;
	text-shadow: 0 10px 26px rgba(0, 0, 0, 0.32);
}

.ivf-product-line span {
	display: inline-block;
}

.ivf-product-line i {
	font-size: 6px;
	margin: 0 7px;
	opacity: 0.7;
	transform: translateY(-1px);
	vertical-align: middle;
}

.ivf-road-banner-content {
	gap: 10px;
}

.ivf-journey-road {
	display: flex;
	flex-direction: column;
	gap: 10px;
	padding: 6px 0 4px 4px;
	position: relative;
}

.ivf-journey-road::before {
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0.08));
	border-radius: 999px;
	content: "";
	inset: 10px auto 10px 14px;
	position: absolute;
	width: 9px;
}

.ivf-journey-road::after {
	background: repeating-linear-gradient(to bottom, rgba(255, 255, 255, 0.85) 0 10px, transparent 10px 18px);
	border-radius: 999px;
	content: "";
	inset: 16px auto 16px 17px;
	position: absolute;
	width: 2px;
}

.ivf-journey-stop {
	align-items: center;
	display: flex;
	min-height: 58px;
	padding-left: 34px;
	position: relative;
}

.ivf-journey-marker {
	align-items: center;
	background: linear-gradient(135deg, rgba(212, 143, 23, 1), rgba(29, 118, 210, 0.95));
	border: 3px solid rgba(7, 17, 30, 0.55);
	border-radius: 50%;
	box-shadow: 0 10px 24px rgba(6, 16, 28, 0.28);
	color: #ffffff;
	display: inline-flex;
	font-size: 12px;
	height: 32px;
	justify-content: center;
	left: 3px;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 32px;
	z-index: 1;
}

.ivf-journey-stop-start .ivf-journey-marker {
	background: linear-gradient(135deg, rgba(212, 143, 23, 1), rgba(240, 177, 64, 0.96));
}

.ivf-journey-stop-finish .ivf-journey-marker {
	background: linear-gradient(135deg, rgba(29, 118, 210, 1), rgba(77, 171, 247, 0.96));
}

.ivf-journey-card {
	background: rgba(255, 255, 255, 0.12);
	backdrop-filter: blur(8px);
	border: 1px solid rgba(255, 255, 255, 0.15);
	border-radius: 16px;
	box-shadow: 0 12px 28px rgba(3, 12, 21, 0.16);
	padding: 10px 12px;
	width: 100%;
}

.ivf-journey-card strong {
	display: block;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.09em;
	text-transform: uppercase;
}

.ivf-journey-card p {
	color: rgba(255, 255, 255, 0.78);
	font-size: 11px;
	line-height: 1.45;
	margin: 4px 0 0;
}

.ivf-road-caption {
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.14);
	border-radius: 16px;
	color: rgba(255, 255, 255, 0.84);
	font-size: 11px;
	line-height: 1.55;
	padding: 10px 12px;
}

.ivf-login-stage {
	grid-template-columns: 1fr;
}

.ivf-login-roadmap {
	min-height: 804px;
	padding: 10px 12px 14px;
}

.ivf-roadmap-hero {
	gap: 0;
}

.ivf-roadmap-board {
	min-height: 780px;
	position: relative;
}

.ivf-roadmap-track {
	height: 100%;
	inset: 0;
	position: absolute;
	width: 100%;
	top: -133px;
}

.ivf-roadmap-entry,
.ivf-roadmap-track-shadow,
.ivf-roadmap-track-base,
.ivf-roadmap-track-surface,
.ivf-roadmap-track-mark {
	fill: none;
	pointer-events: none;
	stroke-linecap: round;
	stroke-linejoin: round;
}

/* .ivf-roadmap-entry {
	stroke: var(--ivf-road-stop);
	stroke-width: 9;
} */

.ivf-roadmap-track-shadow {
	stroke: rgba(1, 6, 12, 0.28);
	stroke-width: 48;
	transform: translateY(10px);
}

.ivf-roadmap-track-base {
	stroke: var(--ivf-road-base);
	stroke-width: 34;
}

.ivf-roadmap-track-surface {
	opacity: 0.94;
	stroke: var(--ivf-road-edge);
	stroke-width: 24;
}

.ivf-roadmap-track-mark {
	stroke: var(--ivf-road-lane);
	stroke-dasharray: 14 18;
	stroke-width: 3.2;
}

.ivf-roadmap-track-hit {
	fill: none;
	pointer-events: stroke;
	stroke: transparent;
	stroke-width: 64;
}

.ivf-roadmap-board-active .ivf-roadmap-track-mark {
	animation: ivf-road-dash 1.25s linear infinite;
}

.ivf-roadmap-vehicle-runner {
	filter: drop-shadow(0 8px 18px rgba(2, 8, 16, 0.34));
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.2s ease;
}

.ivf-roadmap-vehicle-runner.ivf-roadmap-vehicle-visible {
	opacity: 1;
}

.ivf-roadmap-vehicle-glow {
	animation: ivf-road-pulse 2.6s ease-in-out infinite;
	fill: rgba(240, 177, 64, 0.16);
}

.ivf-roadmap-vehicle-body {
	fill: #0f1f33;
	stroke: var(--ivf-road-stop);
	stroke-width: 2.2;
}

.ivf-roadmap-vehicle-window {
	fill: rgba(240, 245, 252, 0.92);
	stroke: none;
}

.ivf-roadmap-vehicle-line {
	fill: none;
	stroke: var(--ivf-road-stop);
	stroke-linecap: round;
	stroke-width: 1.8;
}

.ivf-roadmap-vehicle-wheel {
	fill: #0a1220;
	stroke: #ffffff;
	stroke-width: 1.1;
}

.ivf-roadmap-login-panel {
	left: 0;
	max-width: 312px;
	position: absolute;
	top: 16px;
	width: 100%;
	z-index: 4;
}

.ivf-roadmap-login-card {
	background: rgba(255, 255, 255, 0.97);
	border: 1px solid rgba(216, 226, 239, 0.92);
	border-radius: 20px;
	box-shadow: 0 22px 46px rgba(7, 17, 30, 0.18);
	color: var(--ivf-ink);
	padding: 12px 12px 10px;
	position: relative;
	z-index: 1;
}

.ivf-roadmap-start-tag {
	align-items: center;
	background: linear-gradient(135deg, var(--ivf-accent) 0%, #f0b140 100%);
	border: 4px solid #ffffff;
	border-radius: 50%;
	box-shadow: 0 16px 28px rgba(10, 20, 33, 0.24);
	color: #102038;
	display: inline-flex;
	height: 44px;
	justify-content: center;
	padding: 0;
	position: absolute;
	right: -30px;
	top: -10px;
	width: 44px;
	z-index: 2;
}

.ivf-roadmap-start-arrow {
	align-items: center;
	display: inline-flex;
	font-size: 26px;
	justify-content: center;
}

.ivf-roadmap-start-copy {
	display: none;
}

.ivf-roadmap-stop {
	position: absolute;
	pointer-events: none;
	padding-top: 28px;
	transform: translateX(-50%);
	z-index: 2;
}

.ivf-roadmap-stop::before,
.ivf-roadmap-stop::after {
	content: "";
	left: 50%;
	position: absolute;
	transform: translateX(-50%);
}

.ivf-roadmap-stop::before {
	background: linear-gradient(180deg, rgba(240, 177, 64, 0.95), rgba(204, 141, 20, 0.92));
	border-radius: 999px;
	box-shadow: 0 8px 18px rgba(212, 143, 23, 0.18);
	height: 22px;
	top: 0;
	width: 2px;
}

.ivf-roadmap-stop::after {
	background: var(--ivf-road-edge);
	border: 2px solid #ffffff;
	border-radius: 50%;
	box-shadow: 0 6px 18px rgba(3, 12, 21, 0.18);
	height: 8px;
	top: 20px;
	width: 8px;
}

.ivf-roadmap-stop-up,
.ivf-roadmap-stop-down {
	padding-top: 28px;
}

.ivf-roadmap-pin {
	display: none;
}

.ivf-roadmap-stop-card {
	background: transparent;
	border: 0;
	box-shadow: none;
	color: #f3f6fb;
	display: block;
	min-height: 0;
	padding: 0;
	position: static;
	text-align: center;
	text-shadow: 0 2px 10px rgba(0, 0, 0, 0.55);
	white-space: nowrap;
}

.ivf-roadmap-stop-card strong {
	display: block;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.09em;
	margin: 0;
	text-transform: uppercase;
}

.ivf-roadmap-stop-card p {
	display: none;
}

.ivf-roadmap-stop-badge {
	display: none;
}

.ivf-roadmap-login-head {
	align-items: flex-start;
	display: flex;
	gap: 10px;
	justify-content: space-between;
	margin-bottom: 8px;
}

.ivf-roadmap-login-title {
	color: var(--ivf-ink);
	font-size: 19px;
	font-weight: 700;
	line-height: 1.08;
	margin: 4px 0 0;
}

.ivf-roadmap-login-card .ivf-inline-note {
	margin-bottom: 8px;
}

.ivf-roadmap-login-card .ivf-meta-row {
	margin-bottom: 8px;
}

.ivf-roadmap-login-card .ivf-form {
	gap: 6px;
}

.ivf-roadmap-login-card .ivf-logo-mark {
	border-radius: 12px;
	padding: 5px 8px;
}

.ivf-roadmap-login-card .ivf-field-group {
	gap: 4px;
}

.ivf-roadmap-login-card .ivf-form-note {
	padding: 8px 10px;
}

.ivf-roadmap-login-card .ivf-input {
	height: 38px;
}

.ivf-roadmap-login-card .ivf-logo-mark img {
	height: 24px;
	max-width: 118px;
}

.ivf-roadmap-stop-vehicle {
	left: 37.2%;
	top: 50px;
}

.ivf-roadmap-stop-driver {
	left: 55.3%;
	top: 50px;
}

.ivf-roadmap-stop-trip {
	left: 73.8%;
	top: 50px;
}

.ivf-roadmap-stop-fuel {
	left: 50.2%;
	top: 295px;
}

.ivf-roadmap-stop-tyre {
	left: 36.2%;
	top: 540px;
}

.ivf-roadmap-stop-battery {
	left: 54.2%;
	top: 540px;
}

.ivf-roadmap-stop-ticket {
	left: 78.5%;
	top: 295px;
}

.ivf-roadmap-stop-upcoming {
	left: 91%;
	top: 540px;
}

.ivf-roadmap-stop-upcoming .ivf-roadmap-stop-card strong {
	color: #8dc7ff;
}

.ivf-module-board {
	display: grid;
	gap: 10px;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ivf-module-card {
	align-items: flex-start;
	background: rgba(255, 255, 255, 0.12);
	backdrop-filter: blur(8px);
	border: 1px solid rgba(255, 255, 255, 0.14);
	border-radius: 16px;
	display: flex;
	gap: 10px;
	padding: 11px 11px 11px 12px;
	position: relative;
	animation: ivf-float 8s ease-in-out infinite;
}

.ivf-module-card:nth-child(2n) {
	animation-delay: 1.3s;
}

.ivf-module-card:nth-child(3n) {
	animation-delay: 2.2s;
}

.ivf-module-card::before {
	background: linear-gradient(180deg, rgba(212, 143, 23, 0.9), rgba(29, 118, 210, 0.9));
	border-radius: 999px;
	content: "";
	inset: 10px auto 10px 0;
	position: absolute;
	width: 3px;
}

.ivf-module-icon {
	align-items: center;
	background: rgba(255, 255, 255, 0.12);
	border-radius: 12px;
	display: inline-flex;
	flex-shrink: 0;
	font-size: 13px;
	height: 30px;
	justify-content: center;
	width: 30px;
}

.ivf-module-copy h3 {
	font-size: 13px;
	font-weight: 600;
	margin: 0 0 4px;
}

.ivf-module-copy p {
	color: rgba(255, 255, 255, 0.76);
	font-size: 11px;
	line-height: 1.48;
	margin: 0;
}

.ivf-lane {
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.14);
	border-radius: 16px;
	display: flex;
	gap: 8px;
	padding: 10px 12px;
	position: relative;
}

.ivf-lane::after {
	animation: ivf-flow 3.8s linear infinite;
	background: linear-gradient(90deg, rgba(43, 126, 214, 0), rgba(43, 126, 214, 1), rgba(212, 143, 23, 0));
	border-radius: 999px;
	content: "";
	height: 2px;
	left: 14px;
	position: absolute;
	right: 14px;
	top: 0;
	transform-origin: left center;
}

.ivf-lane-copy {
	color: rgba(255, 255, 255, 0.82);
	font-size: 11px;
	line-height: 1.5;
}

.ivf-stat-row {
	display: grid;
	gap: 8px;
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.ivf-stat-card {
	background: rgba(255, 255, 255, 0.09);
	border: 1px solid rgba(255, 255, 255, 0.13);
	border-radius: 14px;
	padding: 10px 12px;
}

.ivf-stat-value {
	display: block;
	font-size: 20px;
	font-weight: 700;
	line-height: 1;
	margin-bottom: 4px;
}

.ivf-stat-label {
	color: rgba(255, 255, 255, 0.72);
	font-size: 10px;
	line-height: 1.5;
}

.ivf-card {
	background: var(--ivf-surface);
	border: 1px solid rgba(255, 255, 255, 0.34);
	box-shadow: var(--ivf-shadow);
	color: var(--ivf-ink);
	padding: 20px 20px 18px;
}

.ivf-card-header {
	display: flex;
	flex-direction: column;
	gap: 10px;
	margin-bottom: 14px;
}

.ivf-card-topline {
	align-items: center;
	display: flex;
	gap: 12px;
	justify-content: space-between;
}

.ivf-mini-badge {
	background: rgba(16, 32, 56, 0.06);
	border-radius: 999px;
	color: var(--ivf-ink-soft);
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.12em;
	padding: 7px 11px;
	text-transform: uppercase;
}

.ivf-logo-mark {
	align-items: center;
	background: #ffffff;
	border: 1px solid #e2e9f2;
	border-radius: 14px;
	display: inline-flex;
	padding: 6px 10px;
}

.ivf-logo-mark img {
	height: 28px;
	max-width: 142px;
	object-fit: contain;
}

.ivf-card-title {
	font-size: 24px;
	font-weight: 700;
	line-height: 1.08;
	margin: 0;
}

.ivf-card-text {
	color: var(--ivf-ink-soft);
	font-size: 13px;
	line-height: 1.58;
	margin: 0;
}

.ivf-inline-note {
	background: linear-gradient(135deg, rgba(16, 32, 56, 0.04), rgba(212, 143, 23, 0.08));
	border: 1px solid rgba(16, 32, 56, 0.08);
	border-radius: 15px;
	color: var(--ivf-ink-soft);
	font-size: 12px;
	line-height: 1.55;
	padding: 10px 12px;
}

.ivf-inline-note strong {
	color: var(--ivf-ink);
	display: inline-block;
	margin-right: 6px;
}

.ivf-meta-row {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-bottom: 12px;
}

.ivf-meta-link {
	color: var(--ivf-electric);
	font-size: 11px;
	font-weight: 600;
	text-decoration: none;
}

.ivf-meta-link:hover,
.ivf-meta-link:focus {
	color: #165ba1;
	text-decoration: none;
}

.ivf-meta-separator {
	color: rgba(95, 113, 138, 0.45);
}

.ivf-form {
	display: flex;
	flex-direction: column;
	gap: 5px;
}

.ivf-field-group {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.ivf-field-label {
	color: var(--ivf-ink);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

.ivf-input-wrap {
	align-items: center;
	background: #f7f9fc;
	border: 1px solid #d5ddeb;
	border-radius: 14px;
	display: flex;
	gap: 10px;
	padding: 0 12px;
	transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.ivf-input-wrap:focus-within {
	border-color: rgba(29, 118, 210, 0.4);
	box-shadow: 0 0 0 4px rgba(29, 118, 210, 0.08);
	transform: translateY(-1px);
}

.ivf-input-wrap i {
	color: #8091ab;
	display: inline-flex;
	flex-shrink: 0;
	font-size: 13px;
	justify-content: center;
	min-width: 14px;
	text-align: center;
}

.ivf-input {
	background: transparent;
	border: 0;
	color: var(--ivf-ink);
	font-size: 13px;
	height: 40px;
	outline: 0;
	width: 100%;
}

.ivf-password-toggle {
	align-items: center;
	background: transparent;
	border: 0;
	color: #7d8ea8;
	cursor: pointer;
	display: inline-flex;
	font-size: 13px;
	height: 26px;
	justify-content: center;
	padding: 0;
	width: 26px;
}

.ivf-password-toggle:hover,
.ivf-password-toggle:focus {
	color: var(--ivf-electric);
	outline: 0;
}

.ivf-input::placeholder {
	color: #98a8bf;
}

.ivf-input-wrap.ivf-input-wrap-error,
.ivf-input-wrap.ivf-input-wrap-error:focus-within {
	background: #fff8f8;
	border-color: rgba(192, 63, 79, 0.46);
	box-shadow: 0 0 0 4px rgba(192, 63, 79, 0.08);
}

.ivf-input-wrap.ivf-input-wrap-error i,
.ivf-input-wrap.ivf-input-wrap-error .ivf-password-toggle {
	color: var(--ivf-danger);
}

.ivf-field-error {
	color: var(--ivf-danger);
	display: block;
	font-size: 11px;
	font-weight: 600;
	line-height: 1.35;
	margin: 0 2px;
	max-height: 0;
	opacity: 0;
	overflow: hidden;
	transform: translateY(-2px);
	transition: margin 0.2s ease, max-height 0.2s ease, opacity 0.2s ease, transform 0.2s ease;
}

.ivf-field-error.ivf-field-error-visible {
	margin-top: 1px;
	max-height: 36px;
	opacity: 1;
	transform: translateY(0);
}

.ivf-form-note {
	border-radius: 14px;
	font-size: 11px;
	font-weight: 600;
	line-height: 1.5;
	padding: 10px 12px;
}

.ivf-form-note strong {
	display: inline-block;
	margin-right: 6px;
}

.ivf-form-note-error {
	background: rgba(192, 63, 79, 0.08);
	border: 1px solid rgba(192, 63, 79, 0.18);
	color: #a43b4a;
}

.ivf-captcha-box {
	background: linear-gradient(135deg, rgba(16, 32, 56, 0.05), rgba(212, 143, 23, 0.08));
	border: 1px solid rgba(16, 32, 56, 0.08);
	border-radius: 16px;
	padding: 8px 10px;
}

.ivf-captcha-field-group {
	gap: 4px;
}

.ivf-captcha-inline {
	align-items: center;
	display: flex;
	gap: 8px;
	min-width: 0;
}

.ivf-captcha-label {
	background: rgba(16, 32, 56, 0.06);
	border-radius: 999px;
	color: var(--ivf-ink-soft);
	font-size: 9px;
	font-weight: 700;
	letter-spacing: 0.1em;
	padding: 7px 9px;
	text-transform: uppercase;
	white-space: nowrap;
}

.ivf-captcha-problem {
	align-items: center;
	background: #ffffff;
	border: 1px dashed rgba(16, 32, 56, 0.18);
	border-radius: 12px;
	display: inline-flex;
	flex: 0 0 auto;
	gap: 6px;
	height: 38px;
	margin: 0;
	min-width: 86px;
	padding: 0 10px;
}

.ivf-captcha-problem span {
	font-size: 16px;
	font-weight: 700;
	letter-spacing: 0.06em;
}

.ivf-captcha-problem small {
	color: var(--ivf-ink-soft);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.ivf-captcha-answer-wrap {
	flex: 1 1 102px;
	min-width: 0;
}

.ivf-captcha-answer-wrap .ivf-input {
	font-weight: 700;
	height: 38px;
	text-align: center;
}

.ivf-action-row {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 4px;
}

.ivf-button {
	align-items: center;
	border: 0;
	border-radius: 999px;
	cursor: pointer;
	display: inline-flex;
	font-size: 12px;
	font-weight: 700;
	justify-content: center;
	letter-spacing: 0.06em;
	min-height: 40px;
	padding: 0 17px;
	text-decoration: none;
	text-transform: uppercase;
	transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.ivf-button:hover,
.ivf-button:focus {
	text-decoration: none;
	transform: translateY(-1px);
}

.ivf-button-primary {
	background: linear-gradient(135deg, var(--ivf-accent) 0%, var(--ivf-accent-strong) 100%);
	box-shadow: 0 12px 24px rgba(184, 110, 13, 0.26);
	color: #ffffff;
}

.ivf-button-secondary {
	background: rgba(16, 32, 56, 0.08);
	color: var(--ivf-ink);
}

.ivf-helper-copy {
	color: var(--ivf-ink-soft);
	font-size: 11px;
	line-height: 1.55;
	margin-top: 2px;
}

.ivf-contact-grid {
	display: grid;
	gap: 10px;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ivf-contact-card {
	background: #f7f9fc;
	border: 1px solid var(--ivf-card-border);
	border-radius: 15px;
	padding: 11px 12px;
}

.ivf-banner .ivf-contact-card {
	background: rgba(255, 255, 255, 0.1);
	border-color: rgba(255, 255, 255, 0.14);
}

.ivf-contact-card h3 {
	font-size: 13px;
	font-weight: 700;
	margin: 0 0 5px;
}

.ivf-card .ivf-contact-card h3 {
	color: var(--ivf-ink);
}

.ivf-banner .ivf-contact-card h3 {
	color: #ffffff;
}

.ivf-contact-card p {
	font-size: 11px;
	line-height: 1.5;
	margin: 0;
}

.ivf-contact-grid-auth {
	grid-template-columns: 1fr;
	margin-top: 4px;
}

.ivf-contact-card-auth {
	align-items: flex-start;
	display: flex;
	gap: 10px;
	padding: 10px 12px;
}

.ivf-contact-card-icon {
	align-items: center;
	background: linear-gradient(180deg, #edf4ff 0%, #e3edf9 100%);
	border: 1px solid #d7e2ef;
	border-radius: 12px;
	color: #2a62cc;
	display: inline-flex;
	flex: 0 0 40px;
	font-size: 16px;
	height: 40px;
	justify-content: center;
	width: 40px;
}

.ivf-contact-card-copy {
	display: flex;
	flex-direction: column;
	gap: 3px;
	min-width: 0;
}

.ivf-contact-card-copy h3,
.ivf-contact-card-copy p {
	margin: 0;
}

.ivf-contact-card-copy p strong {
	color: var(--ivf-ink);
	font-weight: 700;
}

.ivf-contact-auth-card .ivf-action-row {
	margin-top: 8px;
}

.ivf-contact-auth-card .ivf-login-connect-card {
	margin-top: 12px;
}

.ivf-card .ivf-contact-card p {
	color: var(--ivf-ink-soft);
}

.ivf-banner .ivf-contact-card p {
	color: rgba(255, 255, 255, 0.76);
}

.ivf-placeholder-note {
	background: rgba(255, 255, 255, 0.08);
	border: 1px dashed rgba(255, 255, 255, 0.18);
	border-radius: 15px;
	color: rgba(255, 255, 255, 0.76);
	font-size: 11px;
	line-height: 1.55;
	padding: 10px 12px;
}

.ivf-page-message {
	display: none;
}

.ivf-footer {
	align-items: center;
	color: rgba(255, 255, 255, 0.72);
	display: flex;
	flex-wrap: wrap;
	font-size: 12px;
	gap: 8px 16px;
	justify-content: space-between;
	margin-top: 12px;
	padding-bottom: 6px;
	position: relative;
	z-index: 1;
}

.ivf-footer a {
	color: #ffffff;
	font-weight: 600;
	text-decoration: none;
}

.ivf-login-banner {
	background-position: center center;
}

.ivf-footer a:hover,
.ivf-footer a:focus {
	text-decoration: none;
}

.ivf-swal-popup {
	border-radius: 22px;
	padding: 12px 10px 18px;
}

.ivf-swal-button {
	background: linear-gradient(135deg, var(--ivf-accent) 0%, var(--ivf-accent-strong) 100%) !important;
	border-radius: 999px !important;
	box-shadow: 0 10px 22px rgba(184, 110, 13, 0.22) !important;
	font-weight: 700 !important;
	letter-spacing: 0.04em !important;
	padding: 10px 22px !important;
	text-transform: uppercase !important;
}

@keyframes ivf-float {
	0%,
	100% {
		transform: translateY(0);
	}
	50% {
		transform: translateY(-4px);
	}
}

@keyframes ivf-flow {
	0% {
		opacity: 0;
		transform: scaleX(0.12);
	}
	20% {
		opacity: 1;
	}
	70% {
		opacity: 1;
	}
	100% {
		opacity: 0;
		transform: scaleX(1);
	}
}

@keyframes ivf-road-dash {
	0% {
		stroke-dashoffset: 0;
	}
	100% {
		stroke-dashoffset: -64;
	}
}

@keyframes ivf-road-pulse {
	0%,
	100% {
		opacity: 0.32;
	}
	50% {
		opacity: 0.82;
	}
}

@media (max-width: 1080px) {
	.ivf-stage {
		grid-template-columns: 1fr;
	}

	.ivf-banner {
		min-height: auto;
	}

	.ivf-login-roadmap {
		min-height: auto;
	}

	.ivf-roadmap-board {
		display: flex;
		flex-direction: column;
		gap: 14px;
		min-height: auto;
	}

	.ivf-roadmap-track {
		display: none;
	}

	.ivf-roadmap-login-panel {
		left: auto;
		max-width: none;
		position: relative;
		right: auto;
		top: auto;
		width: 100%;
	}

	.ivf-roadmap-start-tag {
		display: none;
	}

	.ivf-roadmap-stop,
	.ivf-roadmap-stop-vehicle,
	.ivf-roadmap-stop-driver,
	.ivf-roadmap-stop-trip,
	.ivf-roadmap-stop-fuel,
	.ivf-roadmap-stop-tyre,
	.ivf-roadmap-stop-battery,
	.ivf-roadmap-stop-ticket,
	.ivf-roadmap-stop-upcoming {
		left: auto;
		position: relative;
		right: auto;
		top: auto;
		width: 100%;
	}

	.ivf-roadmap-stop,
	.ivf-roadmap-stop-up,
	.ivf-roadmap-stop-down {
		padding-top: 0;
		transform: none;
	}

	.ivf-roadmap-stop-card {
		display: flex;
		justify-content: flex-start;
		white-space: normal;
		width: 100%;
	}

	.ivf-roadmap-stop::before,
	.ivf-roadmap-stop::after {
		display: none;
	}

	.ivf-roadmap-stop-card,
	.ivf-roadmap-login-card {
		margin: 0;
	}
}

@media (max-width: 767px) {
	.ivf-shell {
		padding: 14px 12px 12px;
	}

	.ivf-nav {
		align-items: flex-start;
		flex-direction: column;
	}

	.ivf-brand {
		width: 100%;
	}

	.ivf-nav-links {
		width: 100%;
	}

	.ivf-nav-link {
		justify-content: center;
		width: 100%;
	}

	.ivf-banner,
	.ivf-card {
		padding: 20px 18px;
	}

	.ivf-login-roadmap {
		padding: 20px 16px 18px;
	}

	.ivf-module-board,
	.ivf-contact-grid,
	.ivf-stat-row {
		grid-template-columns: 1fr;
	}

	.ivf-card-topline,
	.ivf-footer {
		align-items: flex-start;
		flex-direction: column;
	}

	.ivf-card-title {
		font-size: 24px;
	}

	.ivf-roadmap-login-head {
		align-items: flex-start;
		flex-direction: column;
	}

	.ivf-roadmap-login-title {
		font-size: 20px;
	}

	.ivf-roadmap-stop {
		padding-left: 60px;
	}

	.ivf-roadmap-stop::before {
		left: 21px;
	}

	.ivf-roadmap-pin {
		height: 48px;
		width: 48px;
	}

	.ivf-captcha-inline {
		flex-wrap: wrap;
	}

	.ivf-captcha-answer-wrap {
		flex-basis: 100%;
	}

	.ivf-action-row {
		flex-direction: column;
	}

	.ivf-button {
		width: 100%;
	}
}

/* Login refresh */

.ivf-shell-login-refresh {
	background:
		radial-gradient(circle at top left, rgba(55, 129, 220, 0.16), transparent 26%),
		radial-gradient(circle at top right, rgba(226, 170, 71, 0.18), transparent 22%),
		linear-gradient(180deg, #eff5fb 0%, #f8fbfe 52%, #ffffff 100%);
	color: #11233b;
}

.ivf-shell-login-refresh::before {
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.32), rgba(255, 255, 255, 0)),
		radial-gradient(circle at 18% 12%, rgba(28, 118, 210, 0.08), transparent 20%);
}

.ivf-shell-login-refresh .ivf-nav,
.ivf-shell-login-refresh .ivf-stage,
.ivf-shell-login-refresh .ivf-footer {
	max-width: 1380px;
}

.ivf-shell-login-refresh .ivf-brand,
.ivf-shell-login-refresh .ivf-brand:hover,
.ivf-shell-login-refresh .ivf-brand:focus {
	color: #11233b;
}

.ivf-shell-login-refresh .ivf-brand-kicker {
	color: rgba(17, 35, 59, 0.58);
}

.ivf-shell-login-refresh .ivf-nav-link {
	background: rgba(17, 35, 59, 0.04);
	border-color: rgba(17, 35, 59, 0.08);
	color: #11233b;
}

.ivf-shell-login-refresh .ivf-nav-link:hover,
.ivf-shell-login-refresh .ivf-nav-link:focus,
.ivf-shell-login-refresh .ivf-nav-link-active {
	background: rgba(29, 118, 210, 0.08);
	color: #11233b;
}

.ivf-login-stage-refresh {
	align-items: start;
	gap: 22px;
	grid-template-columns: minmax(0, 1.48fr) minmax(360px, 420px);
}

.ivf-login-showcase,
.ivf-login-auth-card {
	background: rgba(255, 255, 255, 0.94);
	border: 1px solid rgba(186, 202, 221, 0.76);
	border-radius: 32px;
	box-shadow: 0 22px 60px rgba(11, 30, 52, 0.12);
	position: relative;
}

.ivf-login-showcase {
	overflow: hidden;
	padding: 34px 34px 28px;
}

.ivf-login-showcase::before {
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.64), rgba(255, 255, 255, 0)),
		linear-gradient(90deg, rgba(17, 35, 59, 0.035) 1px, transparent 1px),
		linear-gradient(180deg, rgba(17, 35, 59, 0.03) 1px, transparent 1px);
	background-position: 0 0, 0 0, 0 0;
	background-size: auto, 36px 36px, 36px 36px;
	content: "";
	inset: 0;
	opacity: 0.44;
	pointer-events: none;
	position: absolute;
}

.ivf-login-showcase-copy,
.ivf-login-road-scene {
	position: relative;
	z-index: 1;
}

.ivf-login-showcase-copy {
	margin: 0 auto 14px;
	max-width: 780px;
	text-align: center;
}

.ivf-login-showcase-kicker {
	color: #4f82c7;
	display: inline-block;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.18em;
	margin-bottom: 10px;
	text-transform: uppercase;
}

.ivf-login-showcase-title {
	color: #18283f;
	font-size: 46px;
	font-weight: 800;
	letter-spacing: -0.04em;
	line-height: 1.08;
	margin: 0 0 10px;
}

.ivf-login-showcase-text {
	color: #53657f;
	font-size: 20px;
	line-height: 1.55;
	margin: 0 auto 14px;
	max-width: 760px;
}

.ivf-login-showcase-hint {
	color: #73839a;
	display: inline-flex;
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

.ivf-login-road-scene {
	min-height: 620px;
}

.ivf-login-road-svg,
.ivf-login-road-image {
	height: 100%;
	inset: 0;
	position: absolute;
	width: 100%;
}

.ivf-login-road-image {
	display: block;
	object-fit: fill;
}

.ivf-login-road-shadow,
.ivf-login-road-base,
.ivf-login-road-mark {
	fill: none;
	stroke-linecap: round;
	stroke-linejoin: round;
}

.ivf-login-road-shadow {
	stroke: rgba(86, 104, 130, 0.11);
	stroke-width: 74;
	transform: translate(8px, 10px);
}

.ivf-login-road-base {
	stroke: #f6f8fc;
	stroke-width: 64;
}

.ivf-login-road-mark {
	stroke: #d4dbe5;
	stroke-dasharray: 13 18;
	stroke-width: 3.4;
}

.ivf-login-module {
	--ivf-module-accent: #2d77d4;
	--ivf-hover-glyph: "\f0d1";
	--ivf-hover-hidden-transform: translate(-14px, 12px) scale(0.94);
	--ivf-hover-visible-transform: translate(0, 0) scale(1);
	--ivf-hover-chip-shift: -22px;
	align-items: center;
	color: #11233b;
	display: inline-flex;
	gap: 12px;
	left: 0;
	max-width: 244px;
	position: absolute;
	top: 0;
	z-index: 2;
}

.ivf-login-module-node {
	align-items: center;
	background: linear-gradient(180deg, #2b3c53, #182638);
	border: 4px solid rgba(255, 255, 255, 0.92);
	border-radius: 50%;
	box-shadow: 0 18px 26px rgba(17, 35, 59, 0.16);
	color: var(--ivf-module-accent);
	display: inline-flex;
	flex: 0 0 56px;
	font-size: 24px;
	height: 56px;
	justify-content: center;
	position: relative;
	width: 56px;
}

.ivf-login-module-node::after {
	background: radial-gradient(circle, rgba(17, 35, 59, 0.22), rgba(17, 35, 59, 0));
	border-radius: 999px;
	content: "";
	height: 18px;
	left: 50%;
	position: absolute;
	top: calc(100% + 8px);
	transform: translateX(-50%);
	width: 72px;
}

.ivf-login-module-label {
	font-size: 15px;
	font-weight: 700;
	letter-spacing: -0.01em;
	line-height: 1.2;
	max-width: 160px;
}

.ivf-login-module-hover {
	background: #16263b;
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: 18px;
	box-shadow: 0 18px 44px rgba(10, 24, 42, 0.22);
	color: #ffffff;
	display: flex;
	flex-direction: column;
	gap: 5px;
	left: 16px;
	max-width: 236px;
	opacity: 0;
	padding: 14px 16px;
	pointer-events: none;
	position: absolute;
	top: calc(100% + 14px);
	transform: translateY(8px);
	transition: opacity 0.24s ease, transform 0.24s ease;
}

.ivf-login-module-hover strong {
	font-size: 14px;
	font-weight: 700;
	letter-spacing: -0.01em;
}

.ivf-login-module-hover span {
	color: rgba(240, 245, 252, 0.8);
	font-size: 12px;
	line-height: 1.55;
}

.ivf-login-module:hover .ivf-login-module-hover,
.ivf-login-module:focus .ivf-login-module-hover,
.ivf-login-module:focus-within .ivf-login-module-hover {
	opacity: 1;
	transform: translateY(0);
}

.ivf-login-module:hover .ivf-login-module-node,
.ivf-login-module:focus .ivf-login-module-node,
.ivf-login-module:focus-within .ivf-login-module-node {
	transform: translateY(-2px);
}

.ivf-login-module-vehicle {
	--ivf-module-accent: #46c2ff;
	--ivf-hover-glyph: "\f207";
	left: 80%;
	top: 90px;
}

.ivf-login-module-fuel {
	--ivf-module-accent: #5f79ff;
	--ivf-hover-glyph: "\f043";
	left: 60%;
	top: 20%;
}

.ivf-login-module-inventory {
	--ivf-module-accent: #8d63ff;
	--ivf-hover-glyph: "\f1b3";
	left: 38%;
	top: 10%;
}

.ivf-login-module-rm {
	--ivf-module-accent: #1eb8a3;
	--ivf-hover-glyph: "\f0ad";
	left: 38.5%;
	top: 42%;
}

.ivf-login-module-tickets {
	--ivf-module-accent: #ff7a70;
	--ivf-hover-glyph: "\f145";
	left: 52%;
	top: 96%;
}

.ivf-login-module-trips {
	--ivf-module-accent: #ff8757;
	--ivf-hover-glyph: "\f041";
	left: 66%;
	top: 38%;
}

.ivf-login-module-drivers {
	--ivf-module-accent: #67a2ff;
	--ivf-hover-glyph: "\f007";
	left: 74%;
	top: 50%;
}

.ivf-login-module-reports {
	--ivf-module-accent: #31c488;
	--ivf-hover-glyph: "\f1fe";
	left: 20%;
	top: 88%;
}

.ivf-login-module-accounts {
	--ivf-module-accent: #ffc84d;
	--ivf-hover-glyph: "\f156";
	left: 32%;
	top: 100%;
}

.ivf-login-auth-card {
	padding: 24px 24px 22px;
}

.ivf-login-auth-head {
	display: flex;
	flex-direction: column;
	gap: 10px;
	margin-bottom: 18px;
	text-align: center;
}

.ivf-login-auth-logo {
	align-items: center;
	background: #ffffff;
	border: 1px solid #e0e8f1;
	border-radius: 20px;
	box-shadow: 0 12px 28px rgba(14, 35, 60, 0.08);
	display: inline-flex;
	justify-content: center;
	margin: 0 auto;
	min-height: 92px;
	padding: 18px 22px;
}

.ivf-login-auth-logo img {
	height: 56px;
	max-width: 220px;
	object-fit: contain;
}

.ivf-login-auth-title {
	color: #12243d;
	font-size: 24px;
	font-weight: 800;
	letter-spacing: -0.03em;
	line-height: 1.1;
	margin: 0;
}

.ivf-login-auth-text {
	color: #607189;
	font-size: 14px;
	line-height: 1.6;
	margin: 0;
}

.ivf-auth-switcher {
	background: #edf3f8;
	border-radius: 18px;
	display: grid;
	gap: 6px;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	margin-bottom: 18px;
	padding: 4px;
}

.ivf-auth-switch {
	background: transparent;
	border: 0;
	border-radius: 14px;
	color: #5a6b84;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.04em;
	min-height: 42px;
	padding: 0 10px;
	text-transform: uppercase;
	transition: background 0.2s ease, box-shadow 0.2s ease, color 0.2s ease;
}

.ivf-auth-switch:hover,
.ivf-auth-switch:focus {
	color: #11233b;
	outline: none;
}

.ivf-auth-switch.ivf-auth-switch-active {
	background: #ffffff;
	box-shadow: 0 10px 20px rgba(15, 36, 61, 0.1);
	color: #11233b;
}

.ivf-auth-panel {
	display: none;
}

.ivf-auth-panel.ivf-auth-panel-active {
	display: block;
}

.ivf-auth-panel-copy {
	margin-bottom: 14px;
}

.ivf-auth-panel-copy h3 {
	color: #12243d;
	font-size: 22px;
	font-weight: 800;
	letter-spacing: -0.03em;
	line-height: 1.16;
	margin: 0 0 6px;
}

.ivf-auth-panel-copy p {
	color: #63728b;
	font-size: 13px;
	line-height: 1.62;
	margin: 0;
}

.ivf-auth-callout {
	align-items: flex-start;
	background: #fff8eb;
	border: 1px solid #f0dcc0;
	border-radius: 16px;
	color: #81520f;
	display: flex;
	gap: 10px;
	margin-bottom: 14px;
	padding: 12px 14px;
}

.ivf-auth-callout i {
	font-size: 16px;
	margin-top: 2px;
}

.ivf-auth-status {
	border: 1px solid transparent;
	border-radius: 16px;
	display: none;
	font-size: 12px;
	font-weight: 600;
	line-height: 1.55;
	margin-bottom: 14px;
	padding: 12px 14px;
}

.ivf-auth-status.ivf-auth-status-visible {
	display: block;
}

.ivf-auth-status.ivf-auth-status-success {
	background: #eff9f4;
	border-color: #c8ead7;
	color: #1f6d49;
}

.ivf-auth-status.ivf-auth-status-error {
	background: #fff1f3;
	border-color: #f2c7cd;
	color: #a53947;
}

.ivf-auth-status.ivf-auth-status-info {
	background: #edf5ff;
	border-color: #d4e2f8;
	color: #215d95;
}

.ivf-auth-link-row {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 10px 18px;
	justify-content: space-between;
	margin: 12px 0 14px;
}

.ivf-inline-link {
	background: none;
	border: 0;
	color: #266ec8;
	font-size: 12px;
	font-weight: 700;
	padding: 0;
}

.ivf-inline-link:hover,
.ivf-inline-link:focus {
	color: #114a8d;
	outline: none;
	text-decoration: underline;
}

.ivf-login-auth-card .ivf-action-row {
	display: flex;
	gap: 10px;
	margin-top: 4px;
}

.ivf-login-auth-card .ivf-button {
	flex: 1 1 0;
}

.ivf-meta-row-auth {
	justify-content: center;
	margin-top: 14px;
}

.ivf-shell-login-refresh .ivf-footer {
	color: #6a7a91;
	padding-top: 62px;
}

.ivf-shell-login-refresh .ivf-footer a {
	color: #236bc8;
}

@media (max-width: 1260px) {
	.ivf-login-stage-refresh {
		grid-template-columns: minmax(0, 1fr);
	}

	.ivf-login-auth-card {
		max-width: 520px;
		margin: 0 auto;
		width: 100%;
	}
}

@media (max-width: 1023px) {
	.ivf-login-showcase {
		padding: 28px 24px 24px;
	}

	.ivf-login-showcase-title {
		font-size: 38px;
	}

	.ivf-login-showcase-text {
		font-size: 18px;
	}

	.ivf-login-road-scene {
		display: grid;
		gap: 12px;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		min-height: auto;
	}

	.ivf-login-road-svg {
		display: none;
	}

	.ivf-login-module {
		align-items: flex-start;
		background: #f8fbff;
		border: 1px solid #d9e4f1;
		border-radius: 20px;
		box-shadow: 0 14px 28px rgba(15, 36, 61, 0.06);
		max-width: none;
		padding: 16px 16px 16px 72px;
		position: relative;
		width: 100%;
	}

	.ivf-login-module-node {
		left: 14px;
		position: absolute;
		top: 14px;
	}

	.ivf-login-module-node::after {
		display: none;
	}

	.ivf-login-module-label {
		font-size: 14px;
		max-width: none;
	}

	.ivf-login-module-hover {
		background: transparent;
		border: 0;
		box-shadow: none;
		color: #11233b;
		left: auto;
		max-width: none;
		opacity: 1;
		padding: 8px 0 0;
		pointer-events: auto;
		position: static;
		transform: none;
	}

	.ivf-login-module-hover strong {
		display: none;
	}

	.ivf-login-module-hover span {
		color: #63728b;
		font-size: 12px;
	}

	.ivf-login-module-vehicle {
	    left: 38%;
	    top: 60px;
	}

	.ivf-login-module-inventory{
		display: none !important;
	}

	.ivf-login-note-inspection {
	    left: 35%;
	    top: 90%;
	}
}

@media (max-width: 767px) {
	.ivf-shell-login-refresh {
		padding: 12px 12px 10px;
	}

	.ivf-login-showcase,
	.ivf-login-auth-card {
		border-radius: 24px;
	}

	.ivf-login-showcase-title {
		font-size: 30px;
	}

	.ivf-login-showcase-text {
		font-size: 15px;
	}

	.ivf-login-road-scene,
	.ivf-auth-switcher {
		grid-template-columns: 1fr;
	}

	.ivf-login-auth-card {
		padding: 20px 18px 18px;
	}

	.ivf-login-auth-logo {
		min-height: 82px;
		padding: 16px 18px;
	}

	.ivf-login-auth-logo img {
		height: 48px;
		max-width: 200px;
	}

	.ivf-login-auth-card .ivf-action-row,
	.ivf-auth-link-row {
		flex-direction: column;
	}

	.ivf-auth-link-row {
		align-items: flex-start;
	}
}

/* Login refresh refinement */

.ivf-shell-login-refresh {
	background:
		linear-gradient(180deg, #f7f9fc 0%, #ffffff 100%);
}

.ivf-shell-login-refresh::before {
	background:
		radial-gradient(circle at 18% 10%, rgba(48, 114, 202, 0.08), transparent 20%),
		linear-gradient(180deg, rgba(255, 255, 255, 0.48), rgba(255, 255, 255, 0));
}

.ivf-shell-login-refresh .ivf-nav,
.ivf-shell-login-refresh .ivf-stage,
.ivf-shell-login-refresh .ivf-footer {
	max-width: 1520px;
}

.ivf-shell-login-refresh {
	--ivf-auth-card-width: 324px;
	--ivf-auth-card-shift: -44px;
}

.ivf-shell-login-refresh .ivf-nav {
	align-items: center;
	display: grid;
	gap: 16px;
	grid-template-columns: auto minmax(0, 1fr) auto;
	margin-bottom: 4px;
}

.ivf-shell-login-refresh .ivf-brand {
	gap: 0;
}

.ivf-shell-login-refresh .ivf-brand-copy {
	display: none;
}

.ivf-shell-login-refresh .ivf-brand-badge {
	border-radius: 18px;
	height: 28px;
	padding: 7px 16px;
}

.ivf-shell-login-refresh .ivf-brand-badge img {
	height: 34px;
	max-width: 150px;
}

.ivf-nav-copy {
	align-items: flex-start;
	display: flex;
	flex-direction: column;
	gap: 1px;
	justify-self: stretch;
	min-width: 0;
	text-align: left;
	width: auto;
}

.ivf-nav-heading {
	color: #18283f;
	font-size: 15px;
	font-weight: 800;
	letter-spacing: -0.02em;
	line-height: 1.3;
}

.ivf-nav-subtext {
	color: #5b6b82;
	font-size: 11px;
	font-weight: 500;
	line-height: 1.35;
}

.ivf-shell-login-refresh .ivf-nav-links {
	justify-content: flex-start;
	justify-self: end;
	transform: translateX(var(--ivf-auth-card-shift));
	width: var(--ivf-auth-card-width);
}

.ivf-login-stage-refresh {
	align-items: start;
	column-gap: 0;
	grid-template-columns: minmax(0, 1fr) 334px;
	row-gap: 0;
}

.ivf-login-stage-copy {
	display: none;
}

.ivf-login-showcase,
.ivf-login-showcase::before {
	background: transparent;
	border: 0;
	box-shadow: none;
}

.ivf-login-showcase {
	align-self: start;
	border-radius: 0;
	overflow: visible;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 95px;
	position: relative;
	z-index: auto;
}

.ivf-login-showcase-copy {
	display: none;
}

.ivf-login-road-scene {
	margin-left: -246px;
	margin-right: -156px;
	height: clamp(360px, 30vw, 430px);
	min-height: 0;
	overflow: visible;
	position: relative;
	transform: translateY(-20px);
	z-index: auto;
}

.ivf-login-road-scene::before {
	background:
		radial-gradient(circle at 36% 46%, rgba(213, 225, 239, 0.58), transparent 34%),
		radial-gradient(circle at 61% 30%, rgba(227, 235, 245, 0.54), transparent 24%);
	content: "";
	inset: 0;
	pointer-events: none;
	position: absolute;
	z-index: 0;
}

.ivf-login-road-image {
	height: 100%;
	inset: 0 auto auto 0;
	object-fit: contain;
	object-position: 50% 50%;
	filter: drop-shadow(0 24px 34px rgba(193, 204, 219, 0.34)) brightness(1.06) saturate(1.02);
	opacity: 0.99;
	pointer-events: none;
	position: absolute;
	width: 100%;
}

.ivf-login-road-svg-guide {
	opacity: 0;
	pointer-events: none;
	z-index: 0;
}

.ivf-login-road-runner-path {
	fill: none;
	stroke: transparent;
	stroke-width: 88;
	stroke-linecap: round;
	stroke-linejoin: round;
}

.ivf-login-road-runner {
	left: 0;
	opacity: 0;
	pointer-events: none;
	position: absolute;
	top: 0;
	transform: translate(-999px, -999px);
	transition: opacity 0.18s ease;
	z-index: 18;
}

.ivf-login-road-runner-active {
	opacity: 1;
}

.ivf-login-road-runner-vehicle {
	align-items: center;
	display: inline-flex;
	height: 42px;
	justify-content: center;
	left: 0;
	min-width: 42px;
	padding: 0;
	position: absolute;
	top: 0;
	transform: translate(-50%, -50%) rotate(var(--ivf-road-angle, 0deg));
	transform-origin: center center;
}

.ivf-login-road-runner-vehicle img {
	display: block;
	filter: drop-shadow(0 4px 8px rgba(9, 18, 31, 0.22));
	height: 52px;
	object-fit: contain;
	width: 52px;
}

.ivf-login-road-runner-card {
	background: linear-gradient(180deg, #16263b 0%, #122033 100%);
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: 18px;
	box-shadow: 0 22px 44px rgba(10, 24, 42, 0.24);
	color: #ffffff;
	display: flex;
	flex-direction: column;
	gap: 6px;
	left: calc(100% + 16px);
	max-width: 288px;
	min-width: 236px;
	opacity: 0;
	padding: 14px 16px 15px;
	position: absolute;
	top: 50%;
	transform: translate(12px, -50%) scale(0.96);
	transform-origin: left center;
	transition: opacity 0.2s ease, transform 0.24s ease;
}

.ivf-login-road-runner-card strong {
	font-size: 14px;
	font-weight: 700;
	letter-spacing: -0.01em;
}

.ivf-login-road-runner-card span {
	color: rgba(240, 245, 252, 0.84);
	font-size: 12px;
	font-weight: 500;
	line-height: 1.55;
}

.ivf-login-road-runner-settled .ivf-login-road-runner-card {
	opacity: 1;
	transform: translate(0, -50%) scale(1);
}

.ivf-login-road-runner-left .ivf-login-road-runner-card {
	left: auto;
	right: calc(100% + 16px);
	transform: translate(-12px, -50%) scale(0.96);
	transform-origin: right center;
}

.ivf-login-road-runner-left.ivf-login-road-runner-settled .ivf-login-road-runner-card {
	transform: translate(0, -50%) scale(1);
}

.ivf-login-road-runner-top .ivf-login-road-runner-card {
	left: 50%;
	top: auto;
	bottom: calc(100% + 16px);
	transform: translate(-50%, 12px) scale(0.96);
	transform-origin: center bottom;
}

.ivf-login-road-runner-top.ivf-login-road-runner-settled .ivf-login-road-runner-card {
	transform: translate(-50%, 0) scale(1);
}

.ivf-login-road-runner-bottom .ivf-login-road-runner-card {
	left: 50%;
	top: calc(100% + 16px);
	transform: translate(-50%, -12px) scale(0.96);
	transform-origin: center top;
}

.ivf-login-road-runner-bottom.ivf-login-road-runner-settled .ivf-login-road-runner-card {
	transform: translate(-50%, 0) scale(1);
}

.ivf-login-road-scene.ivf-road-runner-enhanced .ivf-login-module-hover,
.ivf-login-road-scene.ivf-road-runner-enhanced .ivf-login-note-hover {
	display: none;
}

.ivf-login-module,
.ivf-login-note {
	--ivf-hover-glyph: "\f0d1";
	--ivf-hover-hidden-transform: translate(-14px, 12px) scale(0.94);
	--ivf-hover-visible-transform: translate(0, 0) scale(1);
	--ivf-hover-chip-shift: -22px;
	background: transparent;
	border: 0;
	box-shadow: none;
	color: #25344a;
	display: block;
	font-size: 11px;
	font-weight: 700;
	line-height: 1.3;
	min-height: 56px;
	padding: 0;
	position: absolute;
	text-align: center;
	white-space: normal;
	z-index: 2;
}

.ivf-login-module:hover,
.ivf-login-module:focus,
.ivf-login-module:focus-within {
	z-index: 12;
}

.ivf-login-note:hover,
.ivf-login-note:focus,
.ivf-login-note:focus-within {
	z-index: 12;
}

.ivf-login-module-node,
.ivf-login-note-icon {
	align-items: center;
	background: linear-gradient(180deg, #27405e 0%, #17283f 100%);
	border: 4px solid rgba(255, 255, 255, 0.92);
	border-radius: 50%;
	box-shadow:
		0 18px 28px rgba(17, 35, 59, 0.14),
		0 6px 14px rgba(17, 35, 59, 0.08),
		0 0 0 1px rgba(104, 136, 181, 0.08);
	color: #2a62cc;
	display: inline-flex;
	flex: 0 0 56px;
	font-size: 24px;
	height: 56px;
	justify-content: center;
	margin: 0 auto;
	position: relative;
	width: 56px;
}

.ivf-login-module-node {
	color: var(--ivf-module-accent, #2a62cc);
}

.ivf-login-note-icon {
	color: var(--ivf-note-accent, #2a62cc);
}

.ivf-login-module-node i,
.ivf-login-note-icon i {
	text-shadow:
		0 1px 0 rgba(255, 255, 255, 0.1),
		0 4px 10px rgba(18, 36, 60, 0.18);
}

.ivf-login-module-node::after,
.ivf-login-note-icon::after {
	background: radial-gradient(circle, rgba(17, 35, 59, 0.2), rgba(17, 35, 59, 0));
	border-radius: 999px;
	content: "";
	height: 16px;
	left: 50%;
	position: absolute;
	top: calc(100% + 7px);
	transform: translateX(-50%);
	width: 68px;
}

.ivf-login-module-label,
.ivf-login-note-copy {
	color: #1c293d;
	display: block;
	font-size: 11px;
	font-weight: 800;
	line-height: 1.2;
	letter-spacing: -0.01em;
	left: 50%;
	margin-top: 0;
	max-width: 160px;
	min-width: 88px;
	position: absolute;
	top: calc(100% + 16px);
	transform: translateX(-50%);
	width: max-content;
}

.ivf-login-note-copy span {
	display: block;
}

.ivf-login-module-hover,
.ivf-login-note-hover {
	background: linear-gradient(180deg, #16263b 0%, #122033 100%);
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: 18px;
	box-shadow: 0 20px 44px rgba(10, 24, 42, 0.22);
	color: #ffffff;
	display: flex;
	flex-direction: column;
	gap: 6px;
	left: 14px;
	max-width: 292px;
	min-width: 236px;
	opacity: 0;
	padding: 14px 16px 15px;
	pointer-events: none;
	position: absolute;
	top: calc(100% + 12px);
	transform: var(--ivf-hover-hidden-transform);
	transform-origin: 22px 22px;
	transition: opacity 0.24s ease, transform 0.28s cubic-bezier(0.22, 1, 0.36, 1);
	white-space: normal;
	z-index: 14;
}

.ivf-login-module-hover::before,
.ivf-login-note-hover::before {
	align-items: center;
	background: linear-gradient(180deg, #24374f 0%, #142236 100%);
	border: 3px solid rgba(255, 255, 255, 0.92);
	border-radius: 50%;
	box-shadow: 0 14px 24px rgba(10, 24, 42, 0.22);
	color: var(--ivf-module-accent, var(--ivf-note-accent, #2a62cc));
	content: var(--ivf-hover-glyph);
	display: inline-flex;
	font-family: FontAwesome;
	font-size: 14px;
	height: 32px;
	justify-content: center;
	left: 14px;
	opacity: 0;
	position: absolute;
	top: -16px;
	transform: translateX(var(--ivf-hover-chip-shift)) scale(0.84);
	transition: opacity 0.22s ease, transform 0.3s cubic-bezier(0.22, 1, 0.36, 1);
	width: 32px;
}

.ivf-login-module-hover strong,
.ivf-login-note-hover strong {
	font-size: 14px;
	font-weight: 700;
	letter-spacing: -0.01em;
}

.ivf-login-module-hover span,
.ivf-login-note-hover span {
	color: rgba(240, 245, 252, 0.8);
	font-size: 12px;
	font-weight: 500;
	line-height: 1.55;
}

.ivf-login-module:hover .ivf-login-module-hover,
.ivf-login-module:focus .ivf-login-module-hover,
.ivf-login-module:focus-within .ivf-login-module-hover,
.ivf-login-note:hover .ivf-login-note-hover,
.ivf-login-note:focus .ivf-login-note-hover,
.ivf-login-note:focus-within .ivf-login-note-hover {
	opacity: 1;
	transform: var(--ivf-hover-visible-transform);
}

.ivf-login-module:hover .ivf-login-module-hover::before,
.ivf-login-module:focus .ivf-login-module-hover::before,
.ivf-login-module:focus-within .ivf-login-module-hover::before,
.ivf-login-note:hover .ivf-login-note-hover::before,
.ivf-login-note:focus .ivf-login-note-hover::before,
.ivf-login-note:focus-within .ivf-login-note-hover::before {
	opacity: 1;
	transform: translateX(0) scale(1);
}

.ivf-login-note-reminders {
	--ivf-hover-glyph: "\f0f3";
	--ivf-note-accent: #4f7cff;
	left: 30%;
	top: 31%;
}

.ivf-login-note-indent {
	--ivf-hover-glyph: "\f07a";
	--ivf-note-accent: #f59e0b;
	left: 48%;
	top: 20%;
	width: 118px;
}

.ivf-login-note-documents {
	--ivf-hover-glyph: "\f24e";
	--ivf-note-accent: #6f79ff;
	left: 72%;
	top: 14%;
}

.ivf-login-note-tyre {
	--ivf-hover-glyph: "\f10c";
	--ivf-note-accent: #35a7ff;
	left: 60%;
	top: 47%;
}

.ivf-login-note-facility {
	--ivf-hover-glyph: "\f291";
	--ivf-note-accent: #2ea6bf;
	left: 61%;
	top: 79%;
}

.ivf-login-note-inspection {
	--ivf-hover-glyph: "\f00c";
	--ivf-note-accent: #24bb74;
	left: 30%;
	top: 56%;
}

.ivf-login-note-vendor {
	--ivf-hover-glyph: "\f0f7";
	--ivf-note-accent: #7f90ab;
	left: 20%;
	top: 58%;
}

.ivf-login-note-hrms {
	--ivf-hover-glyph: "\f007";
	--ivf-note-accent: #d46dff;
	left: 41%;
	top: 83%;
	width: 96px;
}

.ivf-login-module-vehicle .ivf-login-module-label,
.ivf-login-note-documents .ivf-login-note-copy,
.ivf-login-note-indent .ivf-login-note-copy, .ivf-login-note-vendor .ivf-login-note-copy {
	bottom: calc(100% + 1px);
	top: auto;
	transform: translateX(-50%);
}

.ivf-login-module-trips .ivf-login-module-label,
.ivf-login-module-inventory .ivf-login-module-label {
	left: calc(100% + 14px);
	max-width: 162px;
	min-width: 0;
	text-align: left;
	top: 50%;
	transform: translateY(-50%);
	width: 156px;
}

.ivf-login-note-reminders .ivf-login-note-copy {
	left: auto;
	max-width: 118px;
	min-width: 0;
	right: calc(100% + 14px);
	text-align: right;
	top: 50%;
	transform: translateY(-50%);
	width: 118px;
}

.ivf-login-module-inventory .ivf-login-module-label {
	max-width: 124px;
	width: 124px;
}

.ivf-login-note-tyre .ivf-login-note-copy {
	max-width: 118px;
	width: 118px;
}

.ivf-login-note-vendor .ivf-login-note-hover,
.ivf-login-note-inspection .ivf-login-note-hover,
.ivf-login-note-hrms .ivf-login-note-hover,
.ivf-login-note-facility .ivf-login-note-hover {
	--ivf-hover-hidden-transform: translate(-10px, 12px) scale(0.94);
	--ivf-hover-visible-transform: translate(0, 0) scale(1);
	bottom: calc(100% + 10px);
	top: auto;
}

.ivf-login-module-tickets .ivf-login-module-hover,
.ivf-login-module-reports .ivf-login-module-hover,
.ivf-login-module-accounts .ivf-login-module-hover {
	--ivf-hover-hidden-transform: translate(-10px, 14px) scale(0.94);
	--ivf-hover-visible-transform: translate(0, 0) scale(1);
	bottom: calc(100% + 12px);
	top: auto;
}

.ivf-login-module-vehicle .ivf-login-module-hover,
.ivf-login-module-drivers .ivf-login-module-hover,
.ivf-login-note-documents .ivf-login-note-hover {
	--ivf-hover-hidden-transform: translate(18px, calc(-50% + 8px)) scale(0.94);
	--ivf-hover-visible-transform: translate(0, -50%) scale(1);
	--ivf-hover-chip-shift: 22px;
	left: auto;
	right: calc(100% + 16px);
	top: 50%;
	transform-origin: calc(100% - 22px) 22px;
}

.ivf-login-module-vehicle:hover .ivf-login-module-hover,
.ivf-login-module-vehicle:focus .ivf-login-module-hover,
.ivf-login-module-vehicle:focus-within .ivf-login-module-hover,
.ivf-login-module-drivers:hover .ivf-login-module-hover,
.ivf-login-module-drivers:focus .ivf-login-module-hover,
.ivf-login-module-drivers:focus-within .ivf-login-module-hover,
.ivf-login-note-documents:hover .ivf-login-note-hover,
.ivf-login-note-documents:focus .ivf-login-note-hover,
.ivf-login-note-documents:focus-within .ivf-login-note-hover {
	transform: var(--ivf-hover-visible-transform);
}

.ivf-login-module-vehicle .ivf-login-module-hover::before,
.ivf-login-module-drivers .ivf-login-module-hover::before,
.ivf-login-note-documents .ivf-login-note-hover::before {
	left: auto;
	right: 14px;
}

.ivf-login-auth-card {
	align-self: start;
	background: rgba(255, 255, 255, 0.98);
	box-sizing: border-box;
	border: 1px solid #dbe4ef;
	border-radius: 22px;
	box-shadow: 0 16px 42px rgba(17, 35, 59, 0.12);
	margin-left: var(--ivf-auth-card-shift, -44px);
	margin-top: 8px;
	max-width: var(--ivf-auth-card-width, 324px);
	overflow: visible;
	padding: 12px 14px 12px;
	position: relative;
	width: 100%;
	z-index: 5;
}

.ivf-login-auth-head {
	margin-bottom: 12px;
	text-align: center;
}

.ivf-login-auth-logo {
	background: transparent;
	border: 0;
	box-shadow: none;
	min-height: 0;
	padding: 0;
}

.ivf-login-auth-logo img {
	height: 52px;
	max-width: 180px;
}

.ivf-login-auth-title {
	color: #1b2b41;
	display: block;
	font-size: 18px;
	font-weight: 800;
	letter-spacing: -0.03em;
	line-height: 1.12;
	margin: 6px 0 4px;
}

.ivf-login-auth-text {
	color: #64768e;
	display: block;
	font-size: 11px;
	font-weight: 500;
	line-height: 1.4;
	margin: 0;
}

.ivf-auth-switcher,
.ivf-auth-panel[data-ivf-auth-panel='login'] .ivf-auth-panel-copy {
	display: none;
}

.ivf-login-auth-card .ivf-field-group {
	margin-bottom: 6px;
}

.ivf-login-auth-card .ivf-field-label {
	display: none;
}

.ivf-login-auth-card .ivf-input-wrap {
	border-color: #d2dbe6;
	border-radius: 8px;
	min-height: 34px;
}

.ivf-login-auth-card .ivf-input-wrap i {
	color: #8b9ab0;
	font-size: 13px;
	left: 12px;
	top: 10px;
}

.ivf-login-auth-card .ivf-input {
	font-size: 12px;
	height: 34px;
}

.ivf-login-auth-card .ivf-password-toggle {
	font-size: 13px;
	height: 34px;
	width: 34px;
}

.ivf-login-auth-card .ivf-auth-link-row {
	align-items: center;
	justify-content: space-between;
	margin: 2px 0 6px;
}

.ivf-login-auth-card .ivf-inline-link {
	font-size: 12px;
	font-weight: 700;
}

.ivf-login-auth-card .ivf-button-primary {
	background: #2a62cc;
	border-radius: 8px;
	box-shadow: none;
	font-size: 13px;
	letter-spacing: 0.02em;
	min-height: 36px;
}

.ivf-login-auth-card .ivf-button-secondary {
	display: none;
}

.ivf-login-auth-card .ivf-action-row {
	margin-top: 10px;
}

.ivf-login-auth-card .ivf-form-note {
	border-radius: 12px;
	font-size: 10px;
	margin-bottom: 6px;
	padding: 7px 9px;
}

.ivf-login-auth-card .ivf-auth-callout {
	border-radius: 12px;
	font-size: 10px;
	margin-bottom: 6px;
	padding: 7px 9px;
}

.ivf-login-auth-card .ivf-captcha-box {
	margin-bottom: 6px;
	padding: 4px 6px;
}

.ivf-login-auth-card .ivf-captcha-inline {
	gap: 6px;
}

.ivf-login-auth-card .ivf-captcha-label {
	font-size: 8px;
	padding: 5px 8px;
}

.ivf-login-auth-card .ivf-captcha-problem {
	border-radius: 10px;
	gap: 5px;
	height: 32px;
	min-width: 78px;
	padding: 0 8px;
}

.ivf-login-auth-card .ivf-captcha-problem span {
	font-size: 14px;
}

.ivf-login-auth-card .ivf-captcha-problem small {
	font-size: 10px;
}

.ivf-login-auth-card .ivf-captcha-answer-wrap .ivf-input {
	font-size: 12px;
	height: 32px;
}

.ivf-login-connect-card {
	background: linear-gradient(180deg, #f9fbff 0%, #f4f8fd 100%);
	border: 1px solid #dbe5ef;
	border-radius: 16px;
	box-shadow: 0 12px 24px rgba(17, 35, 59, 0.07);
	margin-top: 10px;
	padding: 10px;
	position: relative;
	z-index: 1;
}

.ivf-login-follow-title {
	color: #2a3342;
	display: block;
	font-size: 11px;
	font-weight: 700;
	margin: 0;
	white-space: nowrap;
}

.ivf-login-connect-head {
	align-items: center;
	display: flex;
	gap: 10px;
	justify-content: space-between;
	margin-bottom: 10px;
}

.ivf-login-social-row,
.ivf-login-store-row {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

.ivf-login-social-row {
	margin-bottom: 0;
	flex-wrap: nowrap;
}

.ivf-login-store-row {
	align-items: center;
	gap: 8px;
}

.ivf-login-store-row-card {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ivf-login-social {
	align-items: center;
	border: 1px solid rgba(210, 221, 234, 0.95);
	border-radius: 11px;
	box-shadow: 0 10px 18px rgba(17, 35, 59, 0.08);
	display: inline-flex;
	font-size: 17px;
	height: 36px;
	justify-content: center;
	text-decoration: none;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
	width: 36px;
}

.ivf-login-social:hover,
.ivf-login-social:focus {
	box-shadow: 0 10px 20px rgba(23, 46, 74, 0.12);
	text-decoration: none;
	transform: translateY(-1px);
}

.ivf-login-social-linkedin {
	background: #e8f0ff;
	color: #0a66c2;
}

.ivf-login-social-instagram {
	background: #fff0fb;
	color: #db4ea1;
}

.ivf-login-social-facebook {
	background: #edf2ff;
	color: #1877f2;
}

.ivf-login-social-youtube {
	background: #fff1ee;
	color: #ff3d2e;
}

.ivf-login-store-badge {
	align-items: center;
	background: rgba(255, 255, 255, 0.98);
	border: 1px solid #d7e0eb;
	border-radius: 10px;
	box-shadow: 0 10px 18px rgba(17, 35, 59, 0.08);
	color: #213046;
	display: inline-flex;
	font-size: 11px;
	font-weight: 600;
	gap: 8px;
	padding: 7px 10px;
	text-decoration: none;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.ivf-login-store-badge i {
	font-size: 18px;
}

.ivf-login-store-badge span {
	line-height: 1.3;
	max-width: none;
	white-space: nowrap;
}

.ivf-login-store-badge:hover,
.ivf-login-store-badge:focus {
	box-shadow: 0 12px 22px rgba(13, 28, 48, 0.2);
	color: #213046;
	text-decoration: none;
	transform: translateY(-1px);
}

.ivf-login-store-row-card .ivf-login-store-badge {
	justify-content: center;
	min-height: 42px;
	padding: 8px 10px;
}

.ivf-login-store-row-card .ivf-login-store-badge span {
	text-align: center;
	white-space: normal;
}

.ivf-meta-row-auth {
	justify-content: center;
	margin-bottom: 0;
	margin-top: 0;
}

.ivf-meta-row-card {
	justify-content: flex-end;
	margin-top: 6px;
	padding-right: 2px;
	position: relative;
	z-index: 2;
}

.ivf-meta-row-card .ivf-meta-link {
	font-size: 10px;
	font-weight: 700;
	white-space: nowrap;
}

.ivf-integration-band {
	align-items: flex-start;
	background: rgba(255, 255, 255, 0.88);
	border: 1px solid rgba(210, 223, 238, 0.95);
	border-radius: 22px;
	box-shadow: 0 16px 34px rgba(17, 35, 59, 0.08);
	grid-column: 1;
	align-self: start;
	display: flex;
	gap: 12px;
	justify-content: flex-start;
	margin: 18px 0 8px 6px;
	max-width: none;
	min-width: 0;
	padding: 28px 18px 16px;
	position: relative;
	width: calc(100% - 100px);
	z-index: 1;
	flex-direction: column;
}

.ivf-integration-intro {
	align-items: center;
	background: rgba(248, 251, 255, 0.97);
	border: 1px solid rgba(210, 223, 238, 0.95);
	border-radius: 999px;
	box-shadow: 0 10px 24px rgba(17, 35, 59, 0.08);
	display: flex;
	flex-direction: column;
	gap: 2px;
	left: 50%;
	max-width: min(100% - 28px, 360px);
	padding: 7px 18px 8px;
	position: absolute;
	text-align: center;
	top: 0;
	transform: translate(-50%, -50%);
	width: max-content;
	z-index: -1;
}

.ivf-integration-intro-mark {
	color: #2a62cc;
	font-size: 18px;
	line-height: 1;
	margin-bottom: 2px;
}

.ivf-integration-intro strong {
	color: #1c2a3f;
	font-size: 15px;
	font-weight: 800;
	letter-spacing: -0.02em;
	line-height: 1.15;
}

.ivf-integration-intro > span {
	color: #667891;
	font-size: 12px;
	font-weight: 500;
	line-height: 1.45;
}

.ivf-integration-track {
	align-items: flex-start;
	display: flex;
	flex: 1 1 auto;
	gap: 10px;
	justify-content: space-between;
	width: 100%;
	position: relative;
}

.ivf-integration-track::before {
	background: repeating-linear-gradient(90deg, rgba(61, 108, 176, 0.34) 0 4px, transparent 4px 12px);
	content: "";
	height: 2px;
	left: 26px;
	position: absolute;
	right: 26px;
	top: 28px;
	z-index: 0;
}

.ivf-integration-node {
	align-items: center;
	cursor: default;
	display: flex;
	flex-direction: column;
	gap: 8px;
	min-width: 82px;
	outline: none;
	position: relative;
	z-index: 1;
}

.ivf-integration-node::before,
.ivf-integration-node::after {
	left: 50%;
	opacity: 0;
	pointer-events: none;
	position: absolute;
	transform: translate(-50%, 6px);
	transition: opacity 0.18s ease, transform 0.18s ease;
	z-index: 5;
}

.ivf-integration-node::before {
	border-left: 6px solid transparent;
	border-right: 6px solid transparent;
	border-top: 6px solid #162336;
	content: "";
	top: -8px;
}

.ivf-integration-node::after {
	background: #162336;
	border-radius: 10px;
	box-shadow: 0 14px 28px rgba(17, 35, 59, 0.22);
	color: #ffffff;
	content: attr(data-ivf-integration-title);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.01em;
	line-height: 1;
	padding: 8px 10px;
	top: -40px;
	white-space: nowrap;
}

.ivf-integration-node:hover::before,
.ivf-integration-node:hover::after,
.ivf-integration-node:focus-visible::before,
.ivf-integration-node:focus-visible::after {
	opacity: 1;
	transform: translate(-50%, 0);
}

.ivf-integration-node-badge {
	align-items: center;
	background: rgba(255, 255, 255, 0.98);
	border: 1px solid #dbe5ef;
	border-radius: 14px;
	box-shadow: 0 10px 18px rgba(17, 35, 59, 0.08);
	color: #2a62cc;
	display: inline-flex;
	font-size: 18px;
	height: 42px;
	justify-content: center;
	width: 42px;
}

.ivf-integration-node-label {
	background: #f7f9fd;
	border: 1px solid #dee6ef;
	border-radius: 12px;
	color: #2a3342;
	font-size: 12px;
	font-weight: 700;
	line-height: 1;
	padding: 8px 12px;
	white-space: nowrap;
}

.ivf-integration-node-fastag .ivf-integration-node-badge,
.ivf-integration-node-fuel-card .ivf-integration-node-badge {
	color: #d48f17;
}

.ivf-integration-node-obd .ivf-integration-node-badge,
.ivf-integration-node-vahan .ivf-integration-node-badge {
	color: #365f9f;
}

.ivf-integration-node-tally .ivf-integration-node-badge {
	color: #54607a;
}

.ivf-integration-node-whatsapp .ivf-integration-node-badge {
	color: #22b45a;
}

.ivf-integration-node-fastag .ivf-integration-node-label {
	color: #b97710;
}

.ivf-integration-node-whatsapp .ivf-integration-node-label {
	color: #16954a;
}

@media (max-width: 1420px) {
	.ivf-integration-band {
		margin-top: 16px;
		padding: 24px 14px 14px;
		width: calc(100% - 100px);
	}

	.ivf-integration-intro {
		max-width: calc(100% - 24px);
		padding: 6px 14px 7px;
	}

	.ivf-integration-intro-mark {
		font-size: 16px;
	}

	.ivf-integration-intro strong {
		font-size: 13px;
	}

	.ivf-integration-intro > span {
		font-size: 10px;
		line-height: 1.35;
	}

	.ivf-integration-track {
		gap: 8px;
	}

	.ivf-integration-node-badge {
		font-size: 17px;
		height: 40px;
		width: 40px;
	}

	.ivf-integration-node-label {
		font-size: 11px;
		padding: 6px 9px;
	}

	.ivf-integration-node {
		gap: 7px;
		min-width: 68px;
	}
}

@media (max-width: 1260px) {
	.ivf-shell-login-refresh {
		--ivf-auth-card-width: 312px;
		--ivf-auth-card-shift: -20px;
	}

	.ivf-login-stage-refresh {
		grid-template-columns: minmax(0, 1fr) 320px;
	}

	.ivf-login-auth-card {
		max-width: var(--ivf-auth-card-width);
	}

	.ivf-brand-note {
		max-width: 300px;
	}

	.ivf-login-module,
	.ivf-login-note {
		font-size: 10px;
	}

	.ivf-login-module-node,
	.ivf-login-note-icon {
		flex-basis: 48px;
		font-size: 18px;
		height: 48px;
		width: 48px;
	}

	.ivf-login-module-label,
	.ivf-login-note-copy {
		font-size: 10px;
		max-width: 122px;
		min-width: 72px;
	}

	.ivf-login-module-hover,
	.ivf-login-note-hover {
		max-width: 248px;
		min-width: 208px;
	}

	.ivf-integration-band {
		margin-top: 14px;
		padding: 22px 12px 12px;
		width: calc(100% - 60px);
	}

	.ivf-integration-intro {
		max-width: none;
		min-width: 0;
	}

	.ivf-integration-track {
		gap: 6px;
	}

	.ivf-integration-track::before {
		left: 18px;
		right: 18px;
		top: 24px;
	}

	.ivf-integration-node {
		gap: 6px;
		min-width: 56px;
	}

	.ivf-integration-node-badge {
		font-size: 15px;
		height: 36px;
		width: 36px;
	}

	.ivf-integration-node-label {
		font-size: 9px;
		line-height: 1.15;
		max-width: 58px;
		padding: 5px 6px;
		text-align: center;
		white-space: normal;
	}
}

@media (max-width: 1023px) {
	.ivf-shell-login-refresh {
		--ivf-auth-card-width: 332px;
		--ivf-auth-card-shift: 0px;
	}

	.ivf-shell-login-refresh .ivf-nav {
		grid-template-columns: auto minmax(0, 1fr) auto;
	}

	.ivf-nav-copy {
		display: none;
	}

	.ivf-brand-note {
		display: none;
	}

	.ivf-login-stage-refresh {
		column-gap: 14px;
		grid-template-columns: minmax(0, 1fr) minmax(300px, 332px);
		min-height: auto;
		row-gap: 0;
	}

	.ivf-login-showcase {
		display: block;
		padding: 24px 20px 18px;
	}

	.ivf-login-road-scene {
		height: 332px;
		margin-left: -158px;
		margin-right: -88px;
		transform: translateY(-8px);
	}

	.ivf-login-road-image {
		object-position: 50% 50%;
	}

	.ivf-login-module,
	.ivf-login-note {
		font-size: 10px;
	}

	.ivf-login-module-node,
	.ivf-login-note-icon {
		border-width: 3px;
		flex-basis: 48px;
		font-size: 19px;
		height: 48px;
		width: 48px;
	}

	.ivf-login-module-label,
	.ivf-login-note-copy {
		font-size: 10px;
		max-width: 122px;
		min-width: 72px;
		top: calc(100% + 12px);
	}

	.ivf-login-module-hover,
	.ivf-login-note-hover {
		max-width: 236px;
		min-width: 198px;
		padding: 12px 14px;
	}

	.ivf-login-module-trips,
	.ivf-login-module-tickets,
	.ivf-login-module-reports,
	.ivf-login-module-accounts,
	.ivf-login-note-facility,
	.ivf-login-note-hrms {
		display: none;
	}

	.ivf-login-note-vendor {
		display: inline-flex;
		left: 16%;
		top: 71%;
	}

	.ivf-login-auth-card {
		margin: 0;
		max-width: 332px;
		position: relative;
		z-index: 2;
	}

	.ivf-shell-login-refresh .ivf-nav-links {
		justify-content: flex-end;
	}

	.ivf-meta-row-card {
		justify-content: flex-start;
		padding-right: 0;
	}

	.ivf-login-store-row {
		align-items: stretch;
		flex-wrap: wrap;
		gap: 8px;
	}

	.ivf-login-connect-head {
		align-items: flex-start;
		flex-direction: column;
	}

	.ivf-login-social-row {
		flex-wrap: wrap;
	}

	.ivf-login-store-row-card {
		grid-template-columns: 1fr;
	}

	.ivf-integration-band {
		display: none;
	}
}

@media (max-width: 900px) {
	.ivf-login-stage-refresh {
		grid-template-columns: 1fr;
		min-height: calc(100vh - 96px);
	}

	.ivf-login-auth-card {
		max-width: 380px;
		margin: 0 auto;
	}

	.ivf-login-showcase,
	.ivf-integration-band,
	.ivf-login-module,
	.ivf-login-note {
		display: none;
	}
}

@media (max-width: 767px) {
	.ivf-shell-login-refresh .ivf-nav {
		grid-template-columns: 1fr;
		gap: 10px;
	}

	.ivf-shell-login-refresh .ivf-brand {
		display: none;
	}

	.ivf-nav-copy {
		align-items: center;
		display: flex;
		text-align: center;
	}

	.ivf-nav-heading {
		font-size: 13px;
		line-height: 1.25;
	}

	.ivf-nav-subtext {
		font-size: 10px;
		line-height: 1.3;
	}

	.ivf-shell-login-refresh .ivf-nav-links {
		box-sizing: border-box;
		display: grid;
		gap: 6px;
		grid-template-columns: repeat(3, minmax(0, 1fr));
		justify-self: stretch;
		max-width: 100%;
		padding: 0 2px;
		transform: none;
		width: 100%;
	}

	.ivf-shell-login-refresh .ivf-nav-link {
		align-items: center;
		font-size: 9px;
		justify-content: center;
		letter-spacing: 0.02em;
		line-height: 1.15;
		min-width: 0;
		padding: 8px 6px;
		text-align: center;
		white-space: normal;
		width: 100%;
	}

	.ivf-login-stage-refresh {
		min-height: auto;
	}

	.ivf-login-showcase {
		inset: 40px 0 0;
	}

	.ivf-login-road-scene {
		margin: 0 -18px;
	}

	.ivf-login-auth-card {
		border-radius: 20px;
		max-width: none;
		margin: 0;
		padding: 18px 16px 16px;
		width: 100%;
	}

	.ivf-login-auth-logo img {
		height: 58px;
	}

	.ivf-login-social-row,
	.ivf-login-store-row,
	.ivf-login-auth-card .ivf-auth-link-row {
		gap: 8px;
	}

	.ivf-login-store-badge {
		width: 100%;
	}
}

@media (max-width: 600px) {
	.ivf-shell-login-refresh .ivf-nav-links {
		grid-template-columns: 1fr;
		padding: 0 4px;
	}

	.ivf-shell-login-refresh .ivf-nav-link {
		width: 100%;
	}
}

@media (prefers-reduced-motion: reduce) {
	.ivf-module-card,
	.ivf-nav-link,
	.ivf-button,
	.ivf-roadmap-vehicle-glow,
	.ivf-roadmap-track-mark {
		animation: none;
		transition: none;
	}

	.ivf-roadmap-vehicle-runner {
		display: none;
	}

	.ivf-lane::after {
		animation: none;
	}
}
