:root {
	--navy: #061d34;
	--navy-2: #092f53;
	--blue: #0d4f9f;
	--red: #e72932;
	--red-dark: #be171f;
	--ink: #071b31;
	--muted: #607083;
	--line: #dfe7f0;
	--soft: #f4f7fb;
	--white: #fff;
	--shadow: 0 24px 70px rgba(7, 27, 49, .12);
	--radius: 24px;
}

* {
	box-sizing: border-box
}

html {
	scroll-behavior: smooth
}

body {
	margin: 0;
	font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
	background: linear-gradient(180deg, #eef3f8 0%, #fff 22%, #f5f8fc 100%);
	color: var(--ink)
}

a {
	color: inherit;
	text-decoration: none
}

img {
	max-width: 100%;
	display: block
}

.site-shell {
	max-width: 1600px;
	margin: 0 auto;
	background: rgba(255, 255, 255, .86);
	box-shadow: 0 0 0 1px rgba(6, 29, 52, .06)
}

.site-header {
	height: 96px;
	display: flex;
	align-items: center;
	gap: 34px;
	padding: 0 7vw;
	position: sticky;
	top: 0;
	background: rgba(255, 255, 255, .86);
	backdrop-filter: blur(20px);
	z-index: 50;
	border-bottom: 1px solid rgba(10, 35, 65, .08)
}

.brand img {
	width: 152px
}

.main-nav {
	display: flex;
	gap: 30px;
	margin-left: auto;
	font-size: 14px;
	font-weight: 800
}

.main-nav a {
	padding: 37px 0 32px;
	border-bottom: 3px solid transparent
}

.main-nav a:hover,
.main-nav .active {
	color: var(--blue);
	border-color: var(--red)
}

.header-actions {
	display: flex;
	align-items: center;
	gap: 16px;
}

.phone {
	display: flex;
	align-items: center;
	gap: 9px;
	font-weight: 800;
	font-size: 14px;
	white-space: nowrap
}

.phone img {
	width: 18px
}

.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	border-radius: 8px;
	padding: 14px 22px;
	font-weight: 900;
	font-size: 14px;
	border: 1px solid transparent;
	transition: .22s ease;
	cursor: pointer
}

.btn:hover {
	transform: translateY(-2px)
}

.btn-red {
	background: linear-gradient(135deg, var(--red), var(--red-dark));
	color: white;
	box-shadow: 0 14px 30px rgba(231, 41, 50, .28)
}

.btn-ghost,
.btn-outline {
	background: rgba(255, 255, 255, .72);
	border-color: #9eb0c5;
	color: var(--navy)
}

.btn-large {
	min-height: 58px;
	padding: 18px 30px;
	border-radius: 10px;
	font-size: 15px;
	line-height: 1;
	white-space: nowrap;
}

.menu-toggle {
	display: none;
	background: none;
	border: 0;
	padding: 8px
}

.menu-toggle span {
	display: block;
	width: 26px;
	height: 2px;
	background: var(--navy);
	margin: 5px 0
}

.hero {
	min-height: 610px;
	position: relative;
	display: grid;
	grid-template-columns: 1fr 1.1fr;
	align-items: center;
	overflow: hidden;
	padding: 70px 7vw 40px
}

.hero-bg {
	position: absolute;
	inset: 0;
	background:
		radial-gradient(circle at 68% 20%, rgba(231, 41, 50, .1), transparent 27%),
		linear-gradient(90deg, #fff 0%, rgba(255, 255, 255, .92) 30%, rgba(255, 255, 255, .55) 50%, rgba(255, 255, 255, .08) 72%, rgba(255, 255, 255, 0) 100%),
		url("/img/hero.webp") -34% center / cover no-repeat;
}

.hero-bg:after {
	content: "";
	position: absolute;
	inset: 0;
	background-image: linear-gradient(rgba(6, 29, 52, .05) 1px, transparent 1px), linear-gradient(90deg, rgba(6, 29, 52, .04) 1px, transparent 1px);
	background-size: 56px 56px;
	mask-image: linear-gradient(90deg, #000 0%, transparent 72%)
}

.hero-content {
	position: relative;
	z-index: 2;
	max-width: 680px
}

.eyebrow,
.kicker {
	text-transform: uppercase;
	letter-spacing: .08em;
	font-size: 13px;
	font-weight: 900;
	color: var(--red);
	display: inline-flex;
	align-items: center;
	gap: 9px
}

.eyebrow span {
	width: 34px;
	height: 2px;
	background: var(--red)
}

h1,
h2,
h3,
p {
	margin-top: 0
}

.hero h1 {
	font-size: clamp(44px, 5.4vw, 52px);
	line-height: .98;
	letter-spacing: -.06em;
	margin: 22px 0 24px;
	color: #08213d
}

.hero h1 strong {
	color: var(--red);
	display: block
}

.hero p {
	font-size: 19px;
	line-height: 1.75;
	color: #3f5267;
	max-width: 600px
}

.hero-actions {
	display: flex;
	align-items: center;
	gap: 18px;
	margin-top: 34px;
	flex-wrap: wrap;
}

.hero-actions .btn {
	min-width: 190px;
}

.hero-panel {
	position: relative;
	z-index: 1;
	align-self: stretch;
	display: flex;
	align-items: center;
	justify-content: center
}

.hero-panel:before {
	content: "";
	position: absolute;
	right: -7vw;
	top: 0;
	bottom: 0;
	width: 110%;
	background: linear-gradient(110deg, rgba(255, 255, 255, .08), rgba(8, 33, 61, .05));
	border-radius: 0 0 0 54px
}

.hero-panel img {
	width: min(800px, 100%);
	filter: drop-shadow(0 28px 50px rgba(6, 29, 52, .18))
}

.tech-badge {
	position: absolute;
	right: 8%;
	top: 17%;
	background: rgba(255, 255, 255, .92);
	border: 1px solid rgba(9, 47, 83, .12);
	box-shadow: var(--shadow);
	padding: 17px 24px;
	border-radius: 18px
}

.tech-badge span {
	font-size: 28px;
	font-weight: 900;
	color: var(--red)
}

.tech-badge small {
	display: block;
	color: var(--muted);
	font-weight: 700
}

.trust-bar {
	margin: -36px 7vw 82px;
	position: relative;
	z-index: 4;
	background: linear-gradient(135deg, #06243f, #07365f);
	border-radius: 18px;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	box-shadow: 0 30px 80px rgba(6, 29, 52, .24);
	overflow: hidden
}

.trust-bar article {
	display: flex;
	gap: 18px;
	align-items: center;
	padding: 34px;
	border-right: 1px solid rgba(255, 255, 255, .13)
}

.trust-bar img {
	width: 48px
}

.trust-bar strong {
	display: block;
	color: white;
	font-size: 17px
}

.trust-bar span {
	display: block;
	color: #b9c9d9;
	margin-top: 5px;
	font-size: 14px
}

.projects {
	padding: 0 7vw 92px;
}

.project-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 28px;
	align-items: stretch;
}

.project-card {
	background: #fff;
	border: 1px solid rgba(6, 29, 52, .09);
	border-radius: 22px;
	overflow: hidden;
	box-shadow: 0 18px 45px rgba(7, 27, 49, .08);
	transition: transform .28s ease, box-shadow .28s ease;
}

.project-card:hover {
	transform: translateY(-8px);
	box-shadow: 0 28px 70px rgba(7, 27, 49, .14);
}

.project-card > img {
  width: 100%;
  aspect-ratio: 1000 / 700;
  height: auto;
  object-fit: cover;
}

.project-card div {
	padding: 24px;
}

.project-card h3 {
	font-size: 21px;
	margin-bottom: 10px;
	color: var(--ink);
}

.project-card p {
	color: var(--muted);
	line-height: 1.55;
	margin: 0;
}

.products,
.services,
.contact {
	padding: 0 7vw 92px
}

.section-head {
	display: flex;
	justify-content: space-between;
	align-items: end;
	margin-bottom: 30px
}

.section-head h2,
.about h2,
.contact h2 {
	font-size: clamp(34px, 3.1vw, 36px);
	margin: 8px 0 0
}

.text-link {
	font-weight: 900;
	color: var(--blue)
}

.product-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 28px
}

.product-card {
	background: white;
	border: 1px solid rgba(6, 29, 52, .09);
	border-radius: 18px;
	overflow: hidden;
	box-shadow: 0 18px 45px rgba(7, 27, 49, .08);
	transition: .28s ease
}

.product-card:hover {
	transform: translateY(-8px);
	box-shadow: 0 28px 70px rgba(7, 27, 49, .14)
}

.product-card > img {
  width: 100%;
  aspect-ratio: 900 / 620;
  height: auto;
  object-fit: cover;
}

.product-card div {
	padding: 24px;
	position: relative
}

.product-card h3 {
	font-size: 21px;
	margin-bottom: 10px
}

.product-card p {
	color: var(--muted);
	line-height: 1.55;
	margin: 0
}

.product-card a {
	position: absolute;
	right: 22px;
	bottom: 22px;
	color: var(--red);
	font-size: 26px;
	font-weight: 900
}

.about {
	padding: 100px 7vw;
	display: grid;
	grid-template-columns: .9fr 1.1fr;
	gap: 70px;
	align-items: center;
	background: linear-gradient(180deg, #f6f9fc, #fff)
}

.about-copy p,
.section-head.centered p,
.contact-info p {
	font-size: 17px;
	line-height: 1.75;
	color: var(--muted)
}

.check-list {
	list-style: none;
	padding: 0;
	margin: 28px 0
}

.check-list li {
	margin: 14px 0;
	padding-left: 30px;
	position: relative;
	font-weight: 700;
	color: #304459
}

.check-list li:before {
	content: "✓";
	position: absolute;
	left: 0;
	color: var(--red);
	font-weight: 900
}

.about-visual {
	border-radius: 28px;
	overflow: hidden;
	box-shadow: var(--shadow);
	border: 1px solid rgba(6, 29, 52, .08)
}

.stats {
	margin: 0 7vw 92px;
	background: white;
	border: 1px solid rgba(6, 29, 52, .09);
	border-radius: 24px;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	box-shadow: var(--shadow)
}

.stats article {
	padding: 32px 28px;
	display: grid;
	grid-template-columns: 46px 1fr;
	grid-template-rows: auto auto;
	column-gap: 16px;
	row-gap: 2px;
	border-right: 1px solid var(--line);
	align-items: center;
}

.stats .icon {
	width: 46px;
	height: 46px;
	min-width: 46px;
	background-size: auto 46px;
	grid-row: 1 / span 2;
	transform: none;
}

.stats .icon-stat-expirience {
	background-position: -230px 0;
}

.stats .icon-stat-realized-projects {
	background-position: -276px 0;
}

.stats .icon-stat-manufacturing {
	background-position: -322px 0;
}

.stats .icon-stat-qualified-experts {
	background-position: -368px 0;
}


.stats strong {
	font-size: clamp(26px, 2vw, 34px);
	line-height: 1;
	color: var(--blue);
	letter-spacing: -.04em;
	white-space: nowrap;
}

.stats article>span:not(.icon) {
	color: var(--muted);
	font-weight: 700;
	font-size: 14px;
	line-height: 1.25;
}

.centered {
	text-align: center;
	display: block;
	max-width: 780px;
	margin-left: auto;
	margin-right: auto
}

.service-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 24px
}

.service-grid article {
	padding: 32px;
	background: linear-gradient(180deg, #fff, #f8fbff);
	border: 1px solid rgba(6, 29, 52, .09);
	border-radius: 22px;
	box-shadow: 0 14px 40px rgba(7, 27, 49, .06)
}

.service-grid img {
	width: 50px;
	margin-bottom: 22px
}

.service-grid h3 {
	font-size: 22px
}

.service-grid p {
	color: var(--muted);
	line-height: 1.65
}

.contact-band {
	margin: 0 7vw 92px;
	min-height: 142px;
	padding: 34px 48px;
	color: white;
	border-radius: 24px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 40px;
	position: relative;
	overflow: hidden;
	background:
		linear-gradient(135deg, #061d34 0%, #06243f 48%, #072d50 100%);
	box-shadow: 0 26px 70px rgba(6, 29, 52, .18);
}

.contact-band::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		url("/img/Reference_and_solutions.webp") right center / auto 112% no-repeat;
	opacity: .95;
	pointer-events: none;
	z-index: 0;

	-webkit-mask-image: linear-gradient(90deg,
			transparent 0%,
			transparent 34%,
			rgba(0, 0, 0, .18) 45%,
			rgba(0, 0, 0, .65) 58%,
			#000 72%,
			#000 100%);
	mask-image: linear-gradient(90deg,
			transparent 0%,
			transparent 34%,
			rgba(0, 0, 0, .18) 45%,
			rgba(0, 0, 0, .65) 58%,
			#000 72%,
			#000 100%);
}

.contact-band::after {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(90deg,
			rgba(6, 29, 52, .98) 0%,
			rgba(6, 29, 52, .94) 38%,
			rgba(6, 29, 52, .72) 56%,
			rgba(6, 29, 52, .34) 78%,
			rgba(6, 29, 52, .08) 100%),
		radial-gradient(circle at 72% 50%,
			rgba(231, 41, 50, .24),
			transparent 26%);
	pointer-events: none;
	z-index: 1;
}

.contact-band>div,
.contact-band>a {
	position: relative;
	z-index: 2;
}

.contact-band h2 {
	font-size: clamp(28px, 2.4vw, 32px);
	line-height: 1.12;
	letter-spacing: -.035em;
	margin: 0 0 10px;
	color: #fff;
}

.contact-band p {
	color: #d4e0ec;
	margin: 0;
	font-size: 17px;
	line-height: 1.55;
	max-width: 690px;
}

.contact-band .btn {
	min-width: 260px;
	min-height: 62px;
	border-radius: 8px;
	box-shadow: 0 18px 42px rgba(231, 41, 50, .42);
	white-space: nowrap;
}

.light {
	color: #ff8e94;
}

.contact {
	display: grid;
	grid-template-columns: .75fr 1.25fr;
	gap: 46px
}

.contact-info {
	background: #fff;
	border-radius: 24px;
	padding: 38px;
	border: 1px solid rgba(6, 29, 52, .09);
	box-shadow: var(--shadow)
}

.contact-cards {
	display: grid;
	gap: 14px;
	margin-top: 30px;
}

.contact-cards a {
	display: flex;
	align-items: center;
	gap: 14px;
	background: #f6f9fc;
	padding: 16px 18px;
	border-radius: 14px;
	font-weight: 800;
	color: var(--ink);
	transition: .22s ease;
}

.contact-cards a:hover {
	background: #eef4fa;
	transform: translateY(-2px);
}

.contact-cards .icon {
	width: 28px;
	height: 28px;
	min-width: 28px;
	background-size: auto 28px;
	transform: none;
	opacity: .95;
	filter: brightness(0) saturate(100%);
}

.contact-cards .icon:hover {
	transform: none;
}
.contact-cards .icon-contact-phone-footer {
	background-position: -279px 0;
}

.contact-cards .icon-contact-email {
	background-position: -308px 0;
}

.contact-cards .icon-contact-site {
	background-position: -336px 0;
}

.contact-form {
	background: linear-gradient(180deg, #fff, #f8fbff);
	border: 1px solid rgba(6, 29, 52, .1);
	box-shadow: var(--shadow);
	border-radius: 24px;
	padding: 38px
}

.form-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 18px
}

label {
	display: grid;
	gap: 8px;
	font-weight: 900;
	color: #253b54;
	margin-bottom: 18px
}

input,
select,
textarea {
	width: 100%;
	border: 1px solid #cfd9e5;
	border-radius: 12px;
	padding: 15px 16px;
	font: inherit;
	background: white;
	color: var(--ink);
	outline: none
}

input:focus,
select:focus,
textarea:focus {
	border-color: var(--blue);
	box-shadow: 0 0 0 4px rgba(13, 79, 159, .1)
}

form [aria-invalid="true"] {
	border-color: var(--red) !important;
	background: #fff7f8;
	box-shadow: 0 0 0 4px rgba(231, 41, 50, .12) !important;
}

form [data-field-invalid="true"] {
	color: var(--red);
}

textarea {
	resize: vertical
}

.icon {
	display: inline-block;
	width: 64px;
	height: 64px;
	background-image: url("/img/Bundle_Images.webp");
	background-repeat: no-repeat;
	background-size: auto 64px;
	transition: transform 0.2s ease;
}

.icon:hover {
	transform: scale(1.1);
}

.icon-trustbar-expirience {
	background-position: -64px 0px;
}

.icon-trustbar-high-quality {
	background-position: -128px 0px;
}

.icon-trustbar-individual-solution {
	background-position: -192px 0px;
}

.icon-trustbar-support-maintenance {
	background-position: -256px 0px;
}

.form-note {
	font-size: 13px;
	color: var(--muted);
	margin: 18px 0 0
}

.form-note.success {
	color: #0f7a3d;
	font-weight: 800
}

.site-footer {
	background: linear-gradient(135deg, #061d34, #062b4d);
	color: white;
	padding: 64px 7vw 28px
}

.footer-contact-link {
	display: flex !important;
	align-items: center;
	gap: 12px;
	margin: 14px 0;
	color: #c9d6e4;
	line-height: 1.35;
}

.footer-contact-link .icon {
	width: 20px;
	height: 20px;
	min-width: 20px;
	background-size: auto 20px;
	transform: none;
}

.footer-contact-link .icon:hover {
	transform: none;
}

.footer-contact-link .icon-contact-address {
	background-position: -180px 0;
}

.footer-contact-link .icon-contact-phone-footer {
	background-position: -200px 0;
}

.footer-contact-link .icon-contact-email {
	background-position: -220px 0;
}

.footer-contact-link .icon-contact-site {
	background-position: -240px 0;
}

.footer-grid {
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr 1fr;
	gap: 46px
}

.footer-logo {
	width: 150px;
	margin-bottom: 18px
}

.site-footer p {
	color: #b8c7d6;
	line-height: 1.7
}

.site-footer h3 {
	text-transform: uppercase;
	letter-spacing: .08em;
	font-size: 14px
}

.site-footer a {
	display: block;
	color: #c9d6e4;
	margin: 10px 0
}

.socials {
	display: flex;
	gap: 10px
}

.socials a {
	width: 34px;
	height: 34px;
	border-radius: 8px;
	background: rgba(255, 255, 255, .1);
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 900
}

.footer-bottom {
	border-top: 1px solid rgba(255, 255, 255, .12);
	margin-top: 42px;
	padding-top: 24px;
	display: flex;
	justify-content: space-between;
	color: #aebfce;
	font-size: 14px
}

section {
	scroll-margin-top: 100px;
}

.section-reveal {
	opacity: 0;
	transform: translateY(24px);
	transition: opacity .7s ease, transform .7s ease
}

.section-reveal.is-visible {
	opacity: 1;
	transform: none
}

.phone-link svg,
.contact-phone svg,
.floating-call svg,
.floating-whatsapp svg {
	width: 20px;
	height: 20px;
	flex: 0 0 auto;
}

.phone-link {
	display: flex;
	align-items: center;
	gap: 9px;
	font-weight: 800;
	font-size: 14px;
	white-space: nowrap;
	color: var(--ink);
}

.language-switcher {
	display: inline-flex;
	align-items: center;
	gap: 0;
	height: 30px;
	padding: 3px;
	border: 1px solid rgba(6, 29, 52, .12);
	border-radius: 999px;
	background: rgba(255, 255, 255, .72);
	box-shadow: 0 8px 22px rgba(6, 29, 52, .06);
	font-size: 11px;
	font-weight: 900;
	line-height: 1;
	white-space: nowrap;
}

.language-switcher a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 22px;
	min-width: 30px;
	padding: 0 8px;
	border-radius: 999px;
	color: var(--muted);
	transition: .2s ease;
}

.language-switcher a:hover {
	color: var(--blue);
}

.language-switcher a.active {
	background: var(--blue);
	color: #fff;
	box-shadow: 0 6px 14px rgba(13, 79, 159, .22);
}

.language-switcher span {
	width: 1px;
	height: 14px;
	background: rgba(6, 29, 52, .14);
	margin: 0 2px;
}

.hp-field {
	position: absolute;
	left: -9999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

.form-note {
	font-size: 13px;
	color: var(--muted);
	margin: 18px 0 0;
	min-height: 18px;
}

.form-note.is-visible {
	display: block;
}

.form-note.success,
.form-note.is-success {
	color: #0f7a3d;
	font-weight: 800;
}

.form-note.is-error {
	color: #be171f;
	font-weight: 800;
}

button.is-loading {
	opacity: .78;
	cursor: wait;
}

.turnstile-wrap {
	height: 0;
	overflow: hidden;
	opacity: 0;
	pointer-events: none;
}

.hp-field {
	position: absolute;
	left: -9999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

.honeypot {
	position: absolute;
	left: -9999px;
	opacity: 0;
	pointer-events: none;
}

.skip-link {
	position: fixed;
	left: 16px;
	top: 16px;
	z-index: 1000;
	transform: translateY(-140%);
	background: var(--navy);
	color: #fff;
	padding: 12px 16px;
	border-radius: 10px;
	font-weight: 900;
	box-shadow: 0 14px 34px rgba(6, 29, 52, .22);
	transition: transform .2s ease;
}

.skip-link:focus {
	transform: translateY(0);
	outline: 3px solid rgba(231, 41, 50, .45);
	outline-offset: 3px;
}

.section-label-contact {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  margin: 0 0 12px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(143, 22, 15, 0.08);
  color: #8f160f;
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

/* #region Privacy-Policy */
.privacy-modal {
	position: fixed;
	inset: 0;
	z-index: 200;
	display: none;
}

.privacy-modal.is-open {
	display: block;
}

.privacy-modal__backdrop {
	position: absolute;
	inset: 0;
	background: rgba(6, 29, 52, .72);
	backdrop-filter: blur(8px);
}

.privacy-modal__dialog {
	position: relative;
	width: min(920px, calc(100% - 32px));
	max-height: calc(100vh - 48px);
	margin: 24px auto;
	background: #fff;
	border-radius: 24px;
	box-shadow: 0 32px 90px rgba(0, 0, 0, .28);
	overflow: hidden;
}

.privacy-modal__content {
	max-height: calc(100vh - 48px);
	overflow-y: auto;
	overflow-x: hidden;
	padding: 48px 56px 48px 48px;
	scrollbar-gutter: stable;
}

.privacy-modal__content {
	scrollbar-width: thin;
	scrollbar-color: rgba(6, 29, 52, .22) transparent;
}

.privacy-modal__content::-webkit-scrollbar {
	width: 8px;
}

.privacy-modal__content::-webkit-scrollbar-track {
	background: transparent;
	margin: 18px 0;
}

.privacy-modal__content::-webkit-scrollbar-thumb {
	background: rgba(6, 29, 52, .18);
	border-radius: 999px;
	border: 2px solid #fff;
}

.privacy-modal__content::-webkit-scrollbar-thumb:hover {
	background: rgba(6, 29, 52, .32);
}

.privacy-modal__close {
	position: absolute;
	right: 18px;
	top: 14px;
	z-index: 2;
	width: 42px;
	height: 42px;
	border: 0;
	border-radius: 12px;
	background: #f1f5f9;
	color: var(--ink);
	font-size: 30px;
	line-height: 1;
	cursor: pointer;
}

.privacy-modal__content h2 {
	font-size: clamp(32px, 4vw, 50px);
	line-height: 1;
	letter-spacing: -.05em;
	margin: 12px 0 20px;
}

.privacy-modal__content h3 {
	font-size: 21px;
	margin: 34px 0 10px;
	color: var(--ink);
}

.privacy-modal__content p {
	font-size: 16px;
	line-height: 1.75;
	color: #405369;
}

.privacy-modal__content a {
	color: var(--blue);
	font-weight: 800;
}

.privacy-modal__note {
	margin-top: 30px;
	padding: 16px 18px;
	border-radius: 14px;
	background: #f6f9fc;
	border: 1px solid rgba(6, 29, 52, .08);
}

body.modal-open {
	overflow: hidden;
}

/* #endregion Privacy-Policy */
/* #region Signature Animation */
/* #region Scroll Crane */
.scroll-crane {
	position: fixed;
	right: 24px;
	top: 50%;
	width: 154px;
	height: 260px;
	transform: translateY(-50%) translateX(24px);
	z-index: 80;
	opacity: 0;
	pointer-events: none;
	transition: opacity .28s ease, transform .28s ease;
}

.scroll-crane.is-visible {
	opacity: 1;
	transform: translateY(-50%) translateX(0);
}

.scroll-crane__label {
	position: absolute;
	top: 0;
	right: 0;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 7px 9px;
	border-radius: 999px;
	background: rgba(6, 29, 52, .92);
	color: #fff;
	box-shadow: 0 14px 34px rgba(6, 29, 52, .22);
	font-size: 10px;
	font-weight: 900;
	letter-spacing: .08em;
}

.scroll-crane__label strong {
	display: grid;
	place-items: center;
	width: 18px;
	height: 18px;
	border-radius: 50%;
	background: var(--red);
	font-size: 13px;
	line-height: 1;
}

.scroll-crane[data-direction="up"] .scroll-crane__label strong {
	transform: rotate(180deg);
}

.scroll-crane__mast {
	position: absolute;
	right: 18px;
	top: 38px;
	width: 12px;
	height: 178px;
	border-radius: 8px;
	background: linear-gradient(180deg, #f4c21c, #e0a900);
	box-shadow:
		inset 0 -4px 0 rgba(0, 0, 0, .14),
		0 14px 28px rgba(6, 29, 52, .18);
}

.scroll-crane__mast::after {
	content: "";
	position: absolute;
	left: 50%;
	bottom: -16px;
	width: 38px;
	height: 14px;
	transform: translateX(-50%);
	border-radius: 999px 999px 4px 4px;
	background: #d8a100;
	box-shadow: 0 10px 20px rgba(6, 29, 52, .14);
}

.scroll-crane__beam {
	position: absolute;
	right: 18px;
	top: 52px;
	width: 128px;
	height: 18px;
	border-radius: 4px;
	background: linear-gradient(180deg, #ffcf22, #ebb000);
	box-shadow:
		inset 0 -3px 0 rgba(0, 0, 0, .12),
		0 12px 20px rgba(6, 29, 52, .18);
}

.scroll-crane__beam::before {
	content: "";
	position: absolute;
	inset: 4px 10px;
	background:
		repeating-linear-gradient(
			135deg,
			rgba(6, 29, 52, .38) 0 7px,
			transparent 7px 14px
		);
	opacity: .55;
}

.scroll-crane__brand {
	position: absolute;
	right: 8px;
	top: 50%;
	transform: translateY(-50%);
	color: var(--navy);
	font-size: 8px;
	font-weight: 1000;
	letter-spacing: .04em;
	z-index: 1;
}

.scroll-crane__trolley {
	position: absolute;
	top: 13px;
	left: var(--crane-trolley-x, 42px);
	width: 22px;
	height: 18px;
	border-radius: 5px;
	background: #08213d;
	box-shadow: 0 8px 14px rgba(6, 29, 52, .22);
	transition: left .12s linear;
}

.scroll-crane__trolley::before,
.scroll-crane__trolley::after {
	content: "";
	position: absolute;
	top: -4px;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: #fff;
	border: 2px solid #08213d;
}

.scroll-crane__trolley::before {
	left: 3px;
}

.scroll-crane__trolley::after {
	right: 3px;
}

.scroll-crane__cable {
	position: absolute;
	left: var(--crane-cable-x, 62px);
	top: 72px;
	width: 2px;
	height: var(--crane-cable-h, 62px);
	border-radius: 999px;
	background: linear-gradient(180deg, #8292a5, #22384e);
	box-shadow: 1px 0 0 rgba(255, 255, 255, .45);
	transition: height .12s linear, left .12s linear;
}

.scroll-crane__hook {
	position: absolute;
	left: calc(var(--crane-cable-x, 62px) - 9px);
	top: calc(72px + var(--crane-cable-h, 62px));
	width: 20px;
	height: 22px;
	transition: top .12s linear, left .12s linear;
}

.scroll-crane__hook::before {
	content: "";
	position: absolute;
	left: 50%;
	top: -6px;
	width: 12px;
	height: 12px;
	transform: translateX(-50%);
	border-radius: 50%;
	background: #f4b900;
	box-shadow: inset 0 -2px 0 rgba(0, 0, 0, .18);
}

.scroll-crane__hook span {
	position: absolute;
	left: 50%;
	top: 4px;
	width: 16px;
	height: 18px;
	transform: translateX(-50%);
	border: 4px solid #f4b900;
	border-top: 0;
	border-radius: 0 0 14px 14px;
}

.scroll-crane__hook span::after {
	content: "";
	position: absolute;
	right: -8px;
	bottom: 0;
	width: 10px;
	height: 8px;
	border-right: 4px solid #f4b900;
	border-bottom: 4px solid #f4b900;
	border-radius: 0 0 10px 0;
}

.scroll-crane__load {
	position: absolute;
	left: calc(var(--crane-cable-x, 62px) - 22px);
	top: calc(99px + var(--crane-cable-h, 62px));
	width: 48px;
	height: 34px;
	display: grid;
	place-items: center;
	border-radius: 7px;
	background:
		linear-gradient(135deg, #102c49, #061d34);
	border: 1px solid rgba(255, 255, 255, .18);
	box-shadow:
		0 18px 28px rgba(6, 29, 52, .22),
		inset 0 0 0 1px rgba(255, 255, 255, .05);
	transition: top .12s linear, left .12s linear, transform .22s ease;
}

.scroll-crane__load span {
	color: #fff;
	font-size: 8px;
	font-weight: 1000;
	letter-spacing: .08em;
}

.scroll-crane.is-moving .scroll-crane__load {
	animation: scrollCraneSwing .42s ease-in-out;
}

.scroll-crane[data-direction="up"] .scroll-crane__load {
	transform: translateY(-2px);
}

.scroll-crane[data-direction="down"] .scroll-crane__load {
	transform: translateY(2px);
}

@keyframes scrollCraneSwing {
	0%, 100% {
		rotate: 0deg;
	}

	35% {
		rotate: 3deg;
	}

	70% {
		rotate: -3deg;
	}
}

@media (max-width: 860px) {
	.scroll-crane {
		right: 12px;
		width: 118px;
		height: 210px;
		transform: translateY(-50%) translateX(18px) scale(.82);
		transform-origin: right center;
	}

	.scroll-crane.is-visible {
		transform: translateY(-50%) translateX(0) scale(.82);
	}
}

@media (max-width: 520px) {
	.scroll-crane {
		display: none;
	}
}

@media (prefers-reduced-motion: reduce) {
	.scroll-crane,
	.scroll-crane *,
	.scroll-crane::before,
	.scroll-crane::after {
		animation: none !important;
		transition: none !important;
	}
}
/* #endregion Scroll Crane */
/* #endregion Signature Animation */
@media (max-width:1180px) {
	.site-header {
		padding: 0 4vw
	}

	.hero {
		padding-left: 4vw;
		padding-right: 4vw
	}

	.trust-bar,
	.stats,
	.contact-band {
		margin-left: 4vw;
		margin-right: 4vw
	}

	.products,
	.services,
	.contact,
	.about,
	.site-footer {
		padding-left: 4vw;
		padding-right: 4vw
	}

	.product-grid,
	.service-grid {
		grid-template-columns: repeat(2, 1fr)
	}

	.hero {
		grid-template-columns: 1fr
	}

	.hero-panel {
		margin-top: 20px
	}

	.trust-bar,
	.stats {
		grid-template-columns: repeat(2, 1fr)
	}

	.project-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.projects {
		padding-left: 4vw;
		padding-right: 4vw;
	}
}

@media (max-width:860px) {
	.site-header {
		height: auto;
		min-height: 78px;
		flex-wrap: wrap
	}

	.brand img {
		width: 130px
	}

	.menu-toggle {
		display: block;
		margin-left: auto
	}

	.main-nav,
	.header-actions {
		display: none;
		flex-basis: 100%;
		margin: 0
	}

	.main-nav.open,
	.header-actions.open {
		display: grid
	}

	.main-nav {
		gap: 0
	}

	.main-nav a {
		padding: 15px 0
	}

	.header-actions {
		padding-bottom: 20px
	}

	.hero {
		padding-top: 44px
	}

	.hero h1 {
		font-size: 42px
	}

	.trust-bar,
	.stats,
	.product-grid,
	.service-grid,
	.about,
	.contact,
	.footer-grid {
		grid-template-columns: 1fr
	}

	.trust-bar {
		margin-top: 0
	}

	.about {
		gap: 32px
	}

	.contact-band {
		display: grid;
		padding: 34px 28px;
		min-height: 260px;
		background:
			linear-gradient(180deg,
				rgba(6, 29, 52, .98) 0%,
				rgba(6, 29, 52, .9) 52%,
				rgba(6, 29, 52, .68) 100%),
			url("/img/Reference_and_solutions.webp") 74% center / cover no-repeat;
	}

	.contact-band::after {
		right: 8%;
		top: 68%;
		width: 220px;
		height: 130px;
		opacity: .7;
	}

	.contact-band .btn {
		width: 100%;
		min-width: 0;
	}


	.form-row {
		grid-template-columns: 1fr
	}

	.footer-bottom {
		display: grid;
		gap: 12px
	}

	.stats article,
	.trust-bar article {
		border-right: 0;
		border-bottom: 1px solid rgba(9, 47, 83, .09)
	}
}

@media (max-width:720px) {
	.project-grid {
		grid-template-columns: 1fr;
	}

	.project-card img {
		height: 220px;
	}

	.privacy-modal__content {
		padding: 32px 30px 32px 24px;
	}

	.privacy-modal__dialog {
		border-radius: 18px;
	}
}

@media (max-width:520px) {
	.hero-actions {
		display: grid
	}

	.btn {
		width: 100%
	}

	.products,
	.services,
	.contact {
		padding-bottom: 60px
	}

	.contact-form,
	.contact-info {
		padding: 24px
	}

	.product-card img {
		height: 180px
	}

	.projects {
		padding-bottom: 60px;
	}

	.contact-band {
		margin-bottom: 60px;
		border-radius: 20px;
		background:
			linear-gradient(180deg,
				rgba(6, 29, 52, .98) 0%,
				rgba(6, 29, 52, .9) 58%,
				rgba(6, 29, 52, .72) 100%),
			url("/img/Reference_and_solutions.webp") 76% center / cover no-repeat;
	}

	.contact-band h2 {
		font-size: 27px;
	}

	.contact-band p {
		font-size: 15px;
	}
}

@media (prefers-reduced-motion: reduce) {
	html {
		scroll-behavior: auto
	}

	*,
	*::before,
	*::after {
		animation-duration: .01ms !important;
		animation-iteration-count: 1 !important;
		scroll-behavior: auto !important;
		transition-duration: .01ms !important
	}
}