
@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&family=Source+Serif+4:opsz,wght@8..60,600;8..60,700&display=swap');

:root {
	--ks-ink: #111827;
	--ks-ink-2: #1B1C5C;
	--ks-slate: #475467;
	--ks-muted: #667085;
	--ks-paper: #F7F8F5;
	--ks-paper-soft: #EEF2F0;
	--ks-white: #FCFCFA;
	--ks-line: rgba(17, 24, 39, 0.11);
	--ks-line-strong: rgba(27, 28, 92, 0.22);
	--ks-cyan: #00A8D8;
	--ks-cyan-soft: rgba(0, 168, 216, 0.14);
	--ks-navy-soft: rgba(27, 28, 92, 0.08);
	--ks-shadow: 0 18px 50px rgba(17, 24, 39, 0.10);
	--ks-shadow-soft: 0 14px 35px rgba(17, 24, 39, 0.08);
	--ks-sans: "Manrope", "Roboto", sans-serif;
	--ks-display: "Source Serif 4", Georgia, serif;
	--ks-ease: cubic-bezier(0.19, 1, 0.22, 1);
}

body {
	background: var(--ks-white);
	color: var(--ks-ink);
	font-family: "Roboto", sans-serif;
}

body.home {
	background:
		linear-gradient(180deg, var(--ks-white) 0%, #fff 34rem),
		var(--ks-white);
	overflow-x: hidden;
}

a {
	-webkit-tap-highlight-color: transparent;
}

/* ---------- NAVBAR ------------------------------------------------------ */

.navigation-bar.bg-white {
	position: fixed;
	background: rgba(252, 252, 250, 0.96) !important;
	border-bottom: 1px solid var(--ks-line);
	box-shadow: none;
	backdrop-filter: saturate(140%) blur(14px);
	-webkit-backdrop-filter: saturate(140%) blur(14px);
	transition:
		background-color 220ms var(--ks-ease),
		border-color 220ms var(--ks-ease),
		box-shadow 220ms var(--ks-ease);
}

body.is-scrolled .navigation-bar.bg-white {
	background: rgba(252, 252, 250, 0.985) !important;
	border-bottom-color: rgba(17, 24, 39, 0.16);
	box-shadow: 0 18px 36px rgba(17, 24, 39, 0.07);
}

.navigation-bar.bg-white::after {
	content: "";
	position: absolute;
	right: 0;
	bottom: -1px;
	left: 0;
	height: 1px;
	background: linear-gradient(90deg,
		transparent 0%,
		rgba(0, 168, 216, 0.45) 18%,
		rgba(27, 28, 92, 0.32) 50%,
		rgba(0, 168, 216, 0.45) 82%,
		transparent 100%);
	opacity: 0;
	pointer-events: none;
	transition: opacity 220ms var(--ks-ease);
}

body.is-scrolled .navigation-bar.bg-white::after {
	opacity: 1;
}

.navigation-bar .container.col-px {
	width: min(92vw, 1500px);
	padding-right: clamp(18px, 3vw, 44px);
	padding-left: clamp(18px, 3vw, 44px);
}

.navigation-bar .row.py-3 {
	min-height: 74px;
	padding-top: 0 !important;
	padding-bottom: 0 !important;
	position: relative;
}

.navigation-bar .brand {
	max-width: 170px;
	padding-left: 0;
}

.navigation-bar .brand a {
	display: inline-flex;
	align-items: center;
	position: relative;
	padding: 8px 0;
	transition: none;
}

.navigation-bar .brand a:hover {
	opacity: 1;
	transform: none;
}

.navigation-bar .brand img.brand-logo {
	display: block;
	width: min(154px, 36vw);
	max-height: 50px;
	object-fit: contain;
}

@media (min-width: 992px) {
	.navigation-bar .navigation {
		align-items: center;
		gap: clamp(12px, 1.7vw, 28px);
	}

	.navigation-bar .navigation .menu {
		align-items: stretch;
		gap: 2px;
	}

	.navigation-bar .navigation .menu > .menu-item,
	.navigation-bar .navigation .menu > .page_item {
		display: flex;
		align-items: stretch;
		padding: 0 !important;
		position: relative;
	}

	.navigation-bar .navigation .menu > .menu-item + .menu-item::before,
	.navigation-bar .navigation .menu > .page_item + .page_item::before {
		content: "";
		position: absolute;
		top: 50%;
		left: -1px;
		width: 1px;
		height: 20px;
		background: var(--ks-line);
		transform: translateY(-50%);
		pointer-events: none;
	}

	.navigation-bar .navigation .menu > .menu-item > a,
	.navigation-bar .navigation .menu > .page_item > a {
		position: relative;
		display: inline-flex;
		align-items: center;
		min-height: 74px;
		padding: 0 clamp(11px, 1.1vw, 18px) !important;
		font-family: var(--ks-sans) !important;
		font-size: clamp(0.72rem, 0.66rem + 0.16vw, 0.82rem) !important;
		font-weight: 700 !important;
		letter-spacing: 0.035em !important;
		line-height: 1.1;
		text-transform: uppercase;
		color: var(--ks-ink-2) !important;
		background: transparent !important;
		border: 0;
		text-decoration: none !important;
		transition:
			color 180ms var(--ks-ease),
			background-color 180ms var(--ks-ease);
	}

	.navigation-bar .navigation .menu > .menu-item > a::before,
	.navigation-bar .navigation .menu > .page_item > a::before {
		content: "";
		position: absolute;
		right: 12px;
		bottom: 17px;
		left: 12px;
		height: 2px;
		background: var(--ks-cyan);
		transform: scaleX(0);
		transform-origin: left center;
		transition: transform 260ms var(--ks-ease);
	}

	.navigation-bar .navigation .menu > .menu-item:hover > a,
	.navigation-bar .navigation .menu > .page_item:hover > a,
	.navigation-bar .navigation .menu > .current-menu-item > a,
	.navigation-bar .navigation .menu > .current_page_item > a,
	.navigation-bar .navigation .menu > .current-menu-parent > a {
		color: var(--ks-ink) !important;
		background: var(--ks-navy-soft) !important;
	}

	.navigation-bar .navigation .menu > .menu-item:hover > a::before,
	.navigation-bar .navigation .menu > .page_item:hover > a::before,
	.navigation-bar .navigation .menu > .current-menu-item > a::before,
	.navigation-bar .navigation .menu > .current_page_item > a::before,
	.navigation-bar .navigation .menu > .current-menu-parent > a::before {
		transform: scaleX(1);
	}

	.navigation-bar .navigation .menu > .menu-item-has-children > a::after {
		content: "";
		display: inline-block;
		width: 6px;
		height: 6px;
		margin-left: 8px;
		border-right: 1.5px solid currentColor;
		border-bottom: 1.5px solid currentColor;
		opacity: 0.58;
		transform: translateY(-2px) rotate(45deg);
		transition: transform 220ms var(--ks-ease), opacity 180ms var(--ks-ease);
	}

	.navigation-bar .navigation .menu > .menu-item-has-children:hover > a::after {
		opacity: 1;
		transform: translateY(1px) rotate(225deg);
	}

	.navigation-bar .navigation .menu .menu-item-has-children::after {
		content: "";
		position: absolute;
		right: 0;
		bottom: -12px;
		left: 0;
		height: 12px;
		background: transparent;
		pointer-events: auto;
	}

	.navigation-bar .navigation .menu .menu-item > ul,
	.navigation-bar .navigation .menu .page_item > ul {
		position: absolute !important;
		top: calc(100% + 8px) !important;
		left: 0 !important;
		right: auto !important;
		display: block !important;
		width: max-content;
		min-width: 260px;
		max-width: 390px;
		height: auto !important;
		margin: 0 !important;
		padding: 10px 0 !important;
		text-align: left;
		background: rgba(252, 252, 250, 0.98) !important;
		border: 1px solid var(--ks-line-strong) !important;
		border-radius: 0 !important;
		box-shadow: var(--ks-shadow);
		opacity: 0;
		visibility: hidden;
		clip-path: inset(0 0 100% 0);
		transform: translateY(-10px);
		z-index: 1052;
		transition:
			opacity 180ms var(--ks-ease),
			clip-path 260ms var(--ks-ease),
			transform 260ms var(--ks-ease),
			visibility 180ms var(--ks-ease) !important;
		will-change: clip-path, transform, opacity;
	}

	.navigation-bar .navigation .menu .menu-item > ul::before,
	.navigation-bar .navigation .menu .page_item > ul::before {
		content: "";
		position: absolute;
		top: -1px;
		right: -1px;
		left: -1px;
		height: 3px;
		background: linear-gradient(90deg, var(--ks-ink-2), var(--ks-cyan));
	}

	.navigation-bar .navigation .menu .menu-item:hover > ul,
	.navigation-bar .navigation .menu .page_item:hover > ul {
		opacity: 1 !important;
		visibility: visible !important;
		clip-path: inset(0 0 0 0);
		transform: translateY(0) !important;
	}

	.navigation-bar .navigation .menu .menu-item > ul li,
	.navigation-bar .navigation .menu .page_item > ul li {
		display: block !important;
		padding: 0 !important;
		text-align: left !important;
	}

	.navigation-bar .navigation .menu .menu-item > ul a,
	.navigation-bar .navigation .menu .page_item > ul a {
		position: relative;
		display: block !important;
		padding: 11px 22px 11px 24px !important;
		font-family: var(--ks-sans) !important;
		font-size: 0.78rem !important;
		font-weight: 650;
		letter-spacing: 0.015em;
		line-height: 1.25;
		text-transform: none;
		color: var(--ks-ink-2) !important;
		background: transparent !important;
		border: 0 !important;
		text-decoration: none !important;
		transition:
			color 160ms var(--ks-ease),
			background-color 160ms var(--ks-ease),
			padding-left 220ms var(--ks-ease);
	}

	.navigation-bar .navigation .menu .menu-item > ul a::before,
	.navigation-bar .navigation .menu .page_item > ul a::before {
		content: "";
		position: absolute;
		top: 50%;
		left: 12px;
		width: 4px;
		height: 4px;
		background: var(--ks-cyan);
		opacity: 0;
		transform: translateY(-50%);
		transition: opacity 160ms var(--ks-ease);
	}

	.navigation-bar .navigation .menu .menu-item > ul a:hover,
	.navigation-bar .navigation .menu .page_item > ul a:hover {
		color: var(--ks-ink) !important;
		background: var(--ks-cyan-soft) !important;
		padding-left: 30px !important;
	}

	.navigation-bar .navigation .menu .menu-item > ul a:hover::before,
	.navigation-bar .navigation .menu .page_item > ul a:hover::before {
		opacity: 1;
	}
}

/* ---------- CTA + SOCIALS ---------------------------------------------- */

.navigation-bar .header-button-wrapper {
	margin-left: 0 !important;
	position: relative;
}

.navigation-bar .header-button-wrapper .btn.teamviewer-download-button {
	position: relative;
	display: inline-flex !important;
	align-items: center;
	gap: 10px;
	min-height: 42px;
	margin-right: 0 !important;
	padding: 0 16px !important;
	overflow: hidden;
	font-family: var(--ks-sans) !important;
	font-size: 0.76rem !important;
	font-weight: 800 !important;
	letter-spacing: 0.05em !important;
	line-height: 1 !important;
	text-transform: uppercase;
	text-decoration: none !important;
	color: var(--ks-white) !important;
	background: var(--ks-ink-2) !important;
	border: 1px solid var(--ks-ink-2) !important;
	border-radius: 0 !important;
	box-shadow: none !important;
	white-space: nowrap;
	transition:
		color 200ms var(--ks-ease),
		background-color 200ms var(--ks-ease),
		border-color 200ms var(--ks-ease),
		transform 220ms var(--ks-ease);
}

.navigation-bar .header-button-wrapper .btn.teamviewer-download-button::before {
	content: "";
	width: 7px;
	height: 7px;
	background: var(--ks-cyan);
	box-shadow: 0 0 0 4px var(--ks-cyan-soft);
	flex: 0 0 auto;
}

.navigation-bar .header-button-wrapper .btn.teamviewer-download-button::after {
	content: "->";
	font-weight: 800;
	letter-spacing: -0.08em;
	transition: transform 220ms var(--ks-ease);
}

.navigation-bar .header-button-wrapper .btn.teamviewer-download-button:hover {
	color: var(--ks-ink-2) !important;
	background: var(--ks-white) !important;
	border-color: var(--ks-cyan) !important;
	transform: translateY(-1px);
}

.navigation-bar .header-button-wrapper .btn.teamviewer-download-button:hover::after {
	transform: translateX(4px);
}

@media (min-width: 992px) {
	.navigation-bar .social-menu {
		display: inline-flex !important;
		align-items: center;
		gap: 4px;
		margin: 0 !important;
		padding: 0 0 0 4px !important;
		border-left: 0;
		box-shadow: none !important;
	}

	.navigation-bar .social-menu li {
		display: inline-flex !important;
		margin: 0 !important;
	}

	.navigation-bar .social-menu a {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		width: 34px;
		height: 34px;
		margin: 0 !important;
		color: var(--ks-muted) !important;
		background: transparent;
		border: 1px solid transparent;
		border-radius: 0;
		font-size: 0.9rem;
		text-decoration: none !important;
		transition:
			color 160ms var(--ks-ease),
			background-color 160ms var(--ks-ease),
			border-color 160ms var(--ks-ease);
	}

	.navigation-bar .social-menu a:hover {
		color: var(--ks-ink-2) !important;
		background: var(--ks-navy-soft);
		border-color: var(--ks-line);
	}
}

/* ---------- MOBILE NAV -------------------------------------------------- */

.toggle-button {
	width: 38px !important;
	height: 38px;
	margin-right: 0;
	padding: 9px 8px !important;
	border: 1px solid var(--ks-line);
	border-radius: 0;
	background: transparent;
	transition:
		background-color 180ms var(--ks-ease),
		border-color 180ms var(--ks-ease);
}

.toggle-button:hover {
	background: var(--ks-navy-soft);
	border-color: var(--ks-line-strong);
}

.toggle-button .toggle {
	height: 2px !important;
	margin-top: 4px !important;
	background-color: var(--ks-ink-2) !important;
	border-radius: 0 !important;
}

@media (max-width: 991.98px) {
	.navigation-bar .row.py-3 {
		min-height: 68px;
	}

	.navigation-bar .brand {
		max-width: 148px;
	}

	.navigation-bar .navigation {
		top: 68px;
		background: var(--ks-white) !important;
		border-top: 1px solid var(--ks-line);
		border-bottom: 1px solid var(--ks-line-strong);
		box-shadow: var(--ks-shadow-soft) !important;
		padding: 10px 0 18px !important;
	}

	.navigation-bar .navigation .menu {
		padding-top: 0 !important;
	}

	.navigation-bar .navigation .menu .menu-item > a,
	.navigation-bar .navigation .menu .page_item > a {
		display: flex !important;
		align-items: center;
		justify-content: space-between;
		padding: 14px 24px !important;
		font-family: var(--ks-sans) !important;
		font-size: 0.88rem !important;
		font-weight: 750 !important;
		letter-spacing: 0.025em;
		text-transform: uppercase;
		color: var(--ks-ink-2) !important;
		background: transparent !important;
		border-bottom: 1px solid var(--ks-line);
	}

	.navigation-bar .navigation .menu .menu-item > a:hover,
	.navigation-bar .navigation .menu .page_item > a:hover,
	.navigation-bar .navigation .menu .current-menu-item > a,
	.navigation-bar .navigation .menu .current_page_item > a {
		color: var(--ks-ink) !important;
		background: var(--ks-cyan-soft) !important;
	}

	.navigation-bar .navigation .menu .menu-item-has-children > a {
		gap: 18px;
	}

	.navigation-bar .navigation .menu .menu-item-has-children > a::after {
		content: "";
		display: inline-block;
		width: 9px;
		height: 9px;
		margin-left: auto;
		border-right: 2px solid currentColor;
		border-bottom: 2px solid currentColor;
		opacity: 0.62;
		transform: translateY(-2px) rotate(45deg);
		transition:
			opacity 180ms var(--ks-ease),
			transform 220ms var(--ks-ease);
	}

	.navigation-bar .navigation .menu .menu-item-has-children.is-submenu-open > a::after {
		opacity: 1;
		transform: translateY(2px) rotate(225deg);
	}

	.navigation-bar .navigation .menu .menu-item ul.open,
	.navigation-bar .navigation .menu .page_item ul.open {
		margin: 0 !important;
		padding: 6px 0 !important;
		background: var(--ks-paper) !important;
		border-radius: 0 !important;
	}

	.navigation-bar .navigation .menu .menu-item ul a,
	.navigation-bar .navigation .menu .page_item ul a {
		padding: 10px 40px !important;
		font-family: var(--ks-sans) !important;
		font-size: 0.82rem !important;
		font-weight: 650;
		letter-spacing: 0.01em;
		text-transform: none;
		color: var(--ks-slate) !important;
		border-bottom: 0 !important;
	}

	.navigation-bar .navigation .menu .menu-item ul a:hover,
	.navigation-bar .navigation .menu .page_item ul a:hover {
		color: var(--ks-ink-2) !important;
		background: rgba(27, 28, 92, 0.06) !important;
	}

	.navigation-bar .navigation .header-button-wrapper {
		margin: 0 !important;
		padding: 18px 24px 10px !important;
	}

	.navigation-bar .navigation .header-button-wrapper .btn.teamviewer-download-button {
		justify-content: center;
		width: 100%;
		max-width: 280px;
		background: var(--ks-ink-2) !important;
		color: var(--ks-white) !important;
	}

	.navigation-bar .navigation .social-menu {
		display: flex !important;
		justify-content: flex-start;
		gap: 8px;
		margin: 6px 0 0 !important;
		padding: 10px 24px 0 !important;
		border-top: 1px solid var(--ks-line);
		box-shadow: none !important;
	}

	.navigation-bar .navigation .social-menu a {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		width: 38px;
		height: 38px;
		margin: 0 !important;
		color: var(--ks-muted) !important;
		background: transparent;
		border: 1px solid var(--ks-line);
		border-radius: 0;
		text-decoration: none !important;
	}

	.navigation-bar .navigation .social-menu a:hover {
		color: var(--ks-ink-2) !important;
		background: var(--ks-cyan-soft);
		border-color: var(--ks-cyan);
	}
}

/* ---------- HOMEPAGE HERO ---------------------------------------------- */

body.home .main {
	padding-top: 0 !important;
	transition: padding-top 240ms var(--ks-ease);
}

body.home #header {
	position: relative;
	isolation: isolate;
	width: 100vw;
	max-width: 100vw;
	min-height: 100vh;
	min-height: 100svh;
	height: 100vh !important;
	height: 100svh !important;
	margin-right: calc(50% - 50vw);
	margin-left: calc(50% - 50vw);
	overflow: hidden;
	background-position: center;
	background-size: cover;
	background-color: var(--ks-ink-2);
}

body.home #header::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: -2;
	background:
		linear-gradient(100deg,
			rgba(9, 18, 32, 0.90) 0%,
			rgba(17, 24, 39, 0.76) 42%,
			rgba(17, 24, 39, 0.38) 73%,
			rgba(17, 24, 39, 0.16) 100%),
		linear-gradient(180deg,
			rgba(252, 252, 250, 0.08) 0%,
			rgba(17, 24, 39, 0.44) 100%);
}

body.home #header::after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: -1;
	height: auto;
	background:
		repeating-linear-gradient(90deg,
			rgba(255, 255, 255, 0.16) 0 1px,
			transparent 1px 96px);
	opacity: 0.08;
	pointer-events: none;
}

body.home #header .container {
	width: min(92vw, 1500px);
	padding-right: clamp(18px, 3vw, 44px);
	padding-left: clamp(18px, 3vw, 44px);
	position: relative;
}

body.home #header .container::before {
	content: "ERP / MES / APS";
	position: absolute;
	top: clamp(42px, 10vh, 96px);
	right: clamp(18px, 3vw, 44px);
	display: inline-flex;
	align-items: center;
	min-height: 34px;
	padding: 0 13px;
	font-family: "Roboto", sans-serif;
	font-size: 0.72rem;
	font-weight: 800;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.82);
	background: rgba(255, 255, 255, 0.08);
	border: 0;
}

body.home #header .container::after {
	content: "";
	position: absolute;
	right: clamp(18px, 3vw, 44px);
	bottom: clamp(54px, 9vh, 92px);
	width: min(34vw, 420px);
	height: min(34vw, 420px);
	background:
		linear-gradient(90deg, rgba(255, 255, 255, 0.14) 1px, transparent 1px),
		linear-gradient(180deg, rgba(255, 255, 255, 0.14) 1px, transparent 1px);
	background-size: 42px 42px;
	opacity: 0.26;
	mask-image: linear-gradient(90deg, transparent 0%, #000 35%, #000 100%);
	pointer-events: none;
}

body.home #header .row {
	min-height: inherit;
	position: relative;
	z-index: 1;
}

body.home #header .row > [class*="col-"] {
	flex: 0 0 100%;
	max-width: min(780px, 100%);
}

body.home #header .special-heading {
	position: relative;
	max-width: 780px;
	padding-left: clamp(18px, 3vw, 34px);
	color: var(--ks-white) !important;
	animation: ks-hero-enter 820ms var(--ks-ease) 80ms both;
}

body.home #header .special-heading::before {
	content: "";
	position: absolute;
	top: 0.25em;
	bottom: 0.35em;
	left: 0;
	width: 3px;
	background: linear-gradient(180deg, var(--ks-cyan), rgba(255, 255, 255, 0.36));
}

body.home #header .special-heading::after {
	content: "Systemy dla firm produkcyjnych";
	display: inline-flex;
	align-items: center;
	margin-top: clamp(18px, 2.4vw, 28px);
	padding: 10px 14px;
	font-family: "Roboto", sans-serif;
	font-size: clamp(0.82rem, 0.75rem + 0.22vw, 0.98rem);
	font-weight: 700;
	letter-spacing: 0.03em;
	line-height: 1.35;
	color: rgba(255, 255, 255, 0.86);
	background: rgba(255, 255, 255, 0.08);
	border: 0;
}

body.home #header .special-heading small:first-child {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	margin-bottom: clamp(16px, 2vw, 24px);
	font-family: var(--ks-sans);
	font-size: clamp(0.72rem, 0.68rem + 0.18vw, 0.86rem);
	font-weight: 800;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.76);
}

body.home #header .special-heading small:first-child:empty {
	display: none;
}

body.home #header .special-heading small:first-child::before {
	content: "";
	width: 34px;
	height: 1px;
	background: var(--ks-cyan);
}

body.home #header .special-heading small:first-child:empty::before,
body.home #header .special-heading small:first-child:empty::after {
	content: none;
}

body.home #header .special-heading h1 {
	max-width: 760px;
	margin: 0;
	font-family: var(--ks-display);
	font-size: clamp(3rem, 1.8rem + 5vw, 6.8rem);
	font-weight: 700;
	line-height: 0.95;
	letter-spacing: -0.055em;
	color: var(--ks-white);
	text-wrap: balance;
	text-shadow: 0 18px 42px rgba(0, 0, 0, 0.28);
}

body.home #header .special-heading h1 .d-block:empty {
	display: none !important;
}

@keyframes ks-hero-enter {
	from {
		opacity: 0;
		transform: translateY(18px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@media (min-width: 992px) {
	body.home #header .special-heading {
		margin-top: -2vh;
	}
}

@media (max-width: 991.98px) {
	body.home #header {
		min-height: 100vh;
		min-height: 100svh;
		height: 100vh !important;
		height: 100svh !important;
		background-position: 62% center;
	}

	body.home #header::before {
		background:
			linear-gradient(100deg,
				rgba(9, 18, 32, 0.94) 0%,
				rgba(17, 24, 39, 0.82) 60%,
				rgba(17, 24, 39, 0.52) 100%);
	}

	body.home #header .container::before {
		top: 28px;
		right: auto;
		left: clamp(18px, 3vw, 44px);
	}

	body.home #header .container::after {
		display: none;
	}

	body.home #header .row {
		align-items: center !important;
	}

	body.home #header .special-heading {
		padding-left: 22px;
	}

}

@media (max-width: 575.98px) {
	body.home #header {
		min-height: 580px;
	}

	body.home #header .special-heading h1 {
		max-width: calc(100vw - 76px);
		font-size: clamp(2.25rem, 10.2vw, 3.15rem);
		letter-spacing: -0.035em;
	}

	body.home #header .special-heading::after {
		max-width: 270px;
	}
}

/* ---------- HOMEPAGE HERO STATS ---------------------------------------- */

body.home #header .container {
	height: 100%;
}

body.home #header.ks-hero-has-stats .row {
	padding-top: clamp(52px, 8vh, 96px);
	padding-bottom: clamp(142px, 17vh, 190px);
}

body.home #header.ks-hero-has-stats .special-heading {
	max-width: 720px;
}

body.home #header .ks-hero-stats {
	position: absolute;
	right: clamp(18px, 3vw, 44px);
	bottom: clamp(28px, 5vh, 54px);
	left: clamp(18px, 3vw, 44px);
	z-index: 2;
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1px;
	overflow: hidden;
	background:
		linear-gradient(90deg,
			rgba(255, 255, 255, 0.16),
			rgba(0, 168, 216, 0.38),
			rgba(255, 255, 255, 0.16));
	border: 1px solid rgba(255, 255, 255, 0.18);
	box-shadow: 0 22px 60px rgba(0, 0, 0, 0.24);
	backdrop-filter: blur(16px) saturate(130%);
	-webkit-backdrop-filter: blur(16px) saturate(130%);
	animation: ks-hero-stats-enter 720ms var(--ks-ease) 420ms both;
}

body.home #header .ks-hero-stat {
	position: relative;
	display: grid;
	grid-template-columns: auto 1fr;
	align-content: start;
	column-gap: 16px;
	min-height: 116px;
	padding: clamp(18px, 2.2vw, 28px);
	background: rgba(10, 18, 32, 0.50);
	color: var(--ks-white);
	opacity: 0;
	transform: translateY(14px);
	animation: ks-hero-stat-item 640ms var(--ks-ease) calc(560ms + (var(--ks-stat-index) * 110ms)) both;
}

body.home #header .ks-hero-stat::after {
	content: "";
	position: absolute;
	right: clamp(18px, 2vw, 28px);
	bottom: 0;
	left: clamp(18px, 2vw, 28px);
	height: 2px;
	background: linear-gradient(90deg, var(--ks-cyan), rgba(255, 255, 255, 0.10));
	transform: scaleX(0);
	transform-origin: left center;
	animation: ks-hero-stat-rule 700ms var(--ks-ease) calc(800ms + (var(--ks-stat-index) * 130ms)) both;
}

body.home #header .ks-hero-stat-marker {
	grid-row: 1 / span 2;
	width: 12px;
	height: 12px;
	margin-top: 0.48em;
	background: var(--ks-cyan);
	box-shadow: 0 0 0 8px rgba(0, 168, 216, 0.12);
}

body.home #header .ks-hero-stat-number {
	display: block;
	font-family: var(--ks-sans);
	font-size: clamp(1.32rem, 1.02rem + 1vw, 2.05rem);
	font-weight: 800;
	letter-spacing: 0;
	line-height: 1;
	color: var(--ks-white);
}

body.home #header .ks-hero-stat-label {
	display: block;
	margin-top: 9px;
	max-width: 28ch;
	font-family: var(--ks-sans);
	font-size: clamp(0.78rem, 0.72rem + 0.16vw, 0.92rem);
	font-weight: 600;
	line-height: 1.42;
	color: rgba(255, 255, 255, 0.76);
}

body.home .ks-original-stat-column {
	display: none !important;
}

body.home .ks-stats-moved-from-section {
	padding-top: clamp(36px, 5vw, 72px);
}

@keyframes ks-hero-stats-enter {
	from {
		opacity: 0;
		transform: translateY(20px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes ks-hero-stat-item {
	from {
		opacity: 0;
		transform: translateY(14px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes ks-hero-stat-rule {
	from {
		transform: scaleX(0);
	}
	to {
		transform: scaleX(1);
	}
}

@media (max-width: 991.98px) {
	body.home #header.ks-hero-has-stats .row {
		align-items: flex-start !important;
		padding-top: clamp(136px, 20vh, 170px);
		padding-bottom: clamp(246px, 32vh, 320px);
	}

	body.home #header .ks-hero-stats {
		grid-template-columns: 1fr;
		bottom: clamp(18px, 4vh, 34px);
	}

	body.home #header .ks-hero-stat {
		min-height: 0;
		padding: 16px 18px;
	}

	body.home #header .ks-hero-stat-label {
		max-width: none;
	}
}

@media (max-width: 575.98px) {
	body.home #header.ks-hero-has-stats {
		min-height: 720px;
		height: auto !important;
	}

	body.home #header.ks-hero-has-stats .row {
		min-height: 720px;
		padding-top: 122px;
		padding-bottom: 274px;
	}

	body.home #header .ks-hero-stats {
		left: 18px;
		right: 18px;
		bottom: 18px;
	}

	body.home #header .ks-hero-stat-number {
		font-size: 1.36rem;
	}

	body.home #header .ks-hero-stat-label {
		font-size: 0.76rem;
	}
}

/* ---------- FOCUS + MOTION --------------------------------------------- */

.navigation-bar a:focus-visible,
.navigation-bar .toggle-button:focus-visible,
.navigation-bar .btn:focus-visible {
	outline: 2px solid var(--ks-cyan);
	outline-offset: 3px;
}

@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		scroll-behavior: auto !important;
	}

	.navigation-bar,
	.navigation-bar *,
	.navigation-bar *::before,
	.navigation-bar *::after,
	body.home #header .special-heading,
	body.home #header .ks-hero-stats,
	body.home #header .ks-hero-stat,
	body.home #header .ks-hero-stat::after {
		animation: none !important;
		transition-duration: 1ms !important;
	}
}
