:root {
	--theme-color-1: #1E5696;
	--theme-color-2: #4796C2;

	--color-black: #3A3A3A;
	--color-black-blue: #333739;

	--color-gray-1: #525252;
	--color-gray-2: #7A7A7A;
	--color-gray-3: #D1D1D1;
	--color-gray-4: #E1E1E1;
	--color-gray-5: #F2F2F2;

	--color-gray-blue-1: #99ABB9;
	--color-gray-blue-2: #E0E6EA;

	--color-blue: #42AAC5;
	--color-blue-40: #42AAC566;
	--color-blue-light: #97E5FB;
}

::-moz-selection{background:var(--theme-color-1);color:#FFF}
::selection{background:var(--theme-color-1);color:#FFF}

html {
    background: transparent;
    color: var(--color-gray-1);
    font: normal 400 16px/1.5 Inter, Verdana, Geneva, sans-serif;
}

.svg-ico {
	flex: 0 0 auto;
}

h1,.h1,h2,.h2,h3,.h3,h4,.h4,h5,.h5,h6,.h6 {
    display: block;
    font-weight: 700;
    margin: 12px 0;
}
h1,.h1{
	font-size:1.5rem;
	font-weight: 400;
	text-transform: uppercase;
}
h2,.h2{font-size:1.375rem}
h3,.h3{font-size:1.25rem}
h4,.h4{font-size:1.125rem}
h5,.h5{font-size:1rem}
h6,.h6{font-size:1rem}

.w-full{width:100%}

.mt-5{margin-top:5px}
.mt-10{margin-top:10px}
.mt-15{margin-top:15px}
.mt-20{margin-top:20px}
.mt-25{margin-top:25px}
.mt-40{margin-top:40px}
.mt-30{margin-top:30px}
.mt-50{margin-top:50px}

.my-40{margin-top:40px;margin-bottom:40px}

.ml-5{margin-left:5px}
.ml-10{margin-left:10px}

.col-gap-5{column-gap:5px}
.col-gap-10{column-gap:10px}
.col-gap-20{column-gap:20px}
.col-gap-40{column-gap:40px}
.col-gap-50{column-gap:50px}

.row-gap-10{row-gap:10px}
.row-gap-15{row-gap:15px}
.row-gap-20{row-gap:20px}
.row-gap-25{row-gap:25px}

.ta-c{text-align:center}
.ta-j{text-align:justify}

.tw-a{text-wrap:auto;}
.tw-w{text-wrap:wrap;}
.tw-nw{text-wrap:nowrap;}

.todo {
	box-shadow: 0 0 3px 1px #ef9999;
}

.button {
	height: auto;
	padding: 8px 45px;
	border-radius: 100px;
	border: 0;
    box-sizing: border-box;
	color: inherit;
    cursor: pointer;
    display: inline-block;
	line-height: 40px;
	position: relative;
    text-align: center;
    text-decoration: none;
	user-select: none;
	white-space: nowrap;
	font-size: 1.125rem;
	font-weight: 700;
	text-transform: uppercase;
}
.button__container {
	height: 100%;
	width: 100%;
}

.button.button_theme_1 {
    background-color: var(--theme-color-1);
    color: #FFF;
}
.button.button_theme_2 {
    background-color: var(--theme-color-2);
    color: #FFF;
}
.button.button_blue {
	background-color: var(--color-blue-light);
	color: var(--color-black-blue);
}
.button.button_blue-transparent {
	background-color:transparent;
	color: var(--color-blue-light);
	border: 2px var(--color-blue-light) solid;
}
.button.button_blue-transparent-dark {
	background-color:transparent;
	color: var(--color-black-blue);
	border: 2px var(--color-blue-light) solid;
}
.button_gray {
    background-color: #ebebeb;
    box-shadow: 0 0 0 1px #cacaca, inset 0 8px 15px -1px #FFF;
    text-shadow: 0 1px 2px #FFF;
    text-transform: none;
}
.button.button_fw {
    display: block;
    width: 100%;
}

.shadow-blue {
	box-shadow: 0 10px 40px 0 var(--color-blue-40);
}

.modal-dialog {
	background-color: #FFF;
    border-radius: 8px;
    box-sizing: border-box;
    display: none;
    max-width: 100%;
	padding: 20px 40px;
    position: relative;
    width: 520px;
}
.modal-dialog > .md__close {
    background: var(--color-gray-2);
    border-radius: 50%;
	cursor: pointer;
    height: 26px;
    position: absolute;
    right: 5px;
    top: 5px;
    width: 26px;
}
.modal-dialog > .md__close::before,
.modal-dialog > .md__close::after {
    background: #FFF;
    border-radius: 2px;
    content: '';
    height: 2px;
    left: 50%;
    position: absolute;
    top: 50%;
    width: 14px;
}
.modal-dialog > .md__close::before {
    transform: translate(-50%, -50%) rotate(-45deg);
}
.modal-dialog > .md__close::after {
    transform: translate(-50%, -50%) rotate(45deg);
}
.modal-dialog > .md__title {
	font-size: 1.125rem;
    text-align: center;
	text-transform: uppercase;
}

.simple-form .sf__field {
    position: relative
}
.simple-form .sf__input,
.simple-form .sf__textarea {
    background-color: #FFF;
	border: 0;
	box-shadow: 0 0 0 1px var(--color-gray-4);
    box-sizing: border-box;
    border-radius: 10px;
	color: var(--color-gray-1);
    display: block;
    font-size: 1rem;
    line-height: 1rem;
    outline: none;
    padding: .625rem .75rem;
    width: 100%;
}
.simple-form .sf__input:focus,
.simple-form .sf__textarea:focus {
	box-shadow: 0 0 0 1px var(--color-gray-2);
}
.simple-form input::placeholder,
.simple-form textarea::placeholder {
    opacity: .7;
}
.simple-form .sf__textarea {
    height: 6.25rem;
	max-height: 15rem;
	min-height: 3.25rem;
	resize: vertical;
}
.simple-form .required {
    background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAMAAAADCAYAAABWKLW/AAAAJUlEQVR42mM4q2zUCsSfQTQTAwNDCRDzAHEeiNMDxF8ZGBgmAQDLKghpAOazgQAAAABJRU5ErkJggg==');
    background-repeat: no-repeat;
    background-position: right 6px top 6px
}
.simple-form .sf__footnote {
    color: #BBB;
    font-size: .625rem;
	letter-spacing: 1px;
	line-height: 1.2;
	text-align: justify;
}
.simple-form .sf__footnote > a {
	color: inherit;
	text-decoration: underline;
}
.simple-form .input-right{box-shadow:inset 0 0 0 1px #3F3,inset 0 0 4px 2px rgba(51,255,51,.6)!important}
.simple-form .input-wrong{box-shadow:inset 0 0 0 1px #F33,inset 0 0 4px 2px rgba(255,51,51,.6)!important}

.callback-form-static {
    background-color: #F9F9F9;
	padding: 15px 30px;
}
.callback-form-static__container {
    margin: 0 auto;
    max-width: 100%;
    width: 550px;
}
.callback-form-static__title {
	font-size: 1.5rem;
    text-align: center;
}

.user-form {
	margin: 0 auto;
	max-width: 100%;
	width: 320px;
}
.user-form__row {
	margin: 15px 0;
}
.user-form__label {
	display: block;
}
.user-form__input {
	border: 0;
	border-radius: 4px;
	box-shadow: inset 0 0 0 1px #444;
	box-sizing: border-box;
	display: block;
	font-size: .875rem;
	height: 1.75rem;
	line-height: 1.75rem;
	outline: none;
	padding: 0 8px;
	width: 100%;
}
.user-form__input:focus {
	box-shadow: inset 0 0 0 2px var(--theme-color-2);
}
.user-form .captcha {
	cursor: pointer;
	display: block;
	margin-bottom: 5px;
}
.user-form__input-captcha {
	width: 150px !important;
}
.user-form__link:not(:last-child) {
	margin-right: 10px;
}

.paginator__page {
	text-decoration: none;
}
.paginator__page.selected,
.paginator__page:hover {
	background-color: var(--theme-color-2) !important;
	color: #FFF !important;
}

.page-content {
	min-height: 100%;
	width: 100%;
}

.header,
.footer {
	flex: 0 0 auto;
	width: 100%;
	background-color: white;
	color: var(--color-black);
}
.header .text-content p,
.footer .text-content p {
	margin: 0;
}
.header__top {
	padding: 15px 0;
}
.header__bottom {
	padding: 20px 0;
}
.header__top,
.header__bottom {
	border-bottom: 1px var(--color-gray-blue-2) solid;
}
.header-logo img {
	display: block;
	object-fit: scale-down;
	max-width: 100%;
}
.header__menu-button {
	display: none;
	margin-right: 10px;
	width: 30px;
}
.header__menu-button::before,
.header__menu-button > i,
.header__menu-button::after {
	background-color: var(--theme-color-2);
	border-radius: 2px;
	content: '';
	display: block;
	height: 4px;
	width: 100%;
}
.header__menu-button > i {
	margin: 5px 0;
}

.menu_mobile {
	display: none;
}

.header-nav {
	display: flex;
	flex-wrap: wrap;
	list-style: none;
	margin: 0;
	padding: 0;
}
.menu_mobile .header-nav {
	flex-direction: column;
}
.header-nav li {
	position: relative;
}
.header-nav li a {
	color: var(--color-black);
	border-bottom: 2px transparent solid;
	display: block;
	letter-spacing: 1px;
	text-decoration: none;
	text-shadow: 1px 2px 3px rgba(0, 0, 0, .1);
	transition: .3s linear;
	-webkit-user-select: none;
	user-select: none;
}
.header-nav li.active > a,
.header-nav li > a:hover {
	border-bottom-color: #C3CCD2;
}
.header-nav > li > a {
	padding: 10px 10px;
}
.header-nav__submenu {
	background-color: var(--theme-color-1);
	margin: 0;
	min-width: 200px;
	list-style: none;
	opacity: 0;
	padding: 0;
	position: absolute;
	transform-origin: 0 0;
	transform: rotateX(-90deg);
	transition: .3s linear;
	visibility: hidden;
	z-index: 5;
}
.header-nav__submenu li a {
	border-bottom: 1px solid rgba(255, 255, 255, .3);
	font-size: .75rem;
	padding: 10px 20px;
}
.header-nav__submenu .header-nav__submenu {
	transform: rotateY(-90deg);
	left: 100%;
	top: 0;
}
.header-nav li:hover > .header-nav__submenu {
	opacity: 1;
	transform: rotate(0);
	visibility: visible;
}

.footer__top {
	padding: 60px 0;
}
.footer__bottom {
	padding: 15px 0;
}

.footer__alternate-link {
	text-decoration: none;
	color: inherit;
	font-size: .875rem;
}
.footer__alternate-link:hover {
	text-decoration: underline;
}

.footer__top,
.footer__bottom {
	border-top: 1px var(--color-gray-blue-2) solid;
}
.footer__copyright {
	text-transform: uppercase;
}

.footer-nav {
	display: flex;
	column-gap: 100px;
	align-items: start;
}
.footer-nav__column {
	display: grid;
	grid-template-rows: auto;
	margin: 0;
	padding: 0;
	list-style: none;
	row-gap: 20px;
}
.footer-nav__column:is(:first-child) {
	grid-auto-flow: row;
	grid-template-columns: auto auto;
	column-gap: 100px;
}
.footer-nav li a {
	color: var(--color-black);
	border-bottom: 2px transparent solid;
	letter-spacing: 1px;
	text-decoration: none;
	text-shadow: 1px 2px 3px rgba(0, 0, 0, .1);
	transition: .3s linear;
	-webkit-user-select: none;
	user-select: none;
}
.footer-nav li.active > a,
.footer-nav li > a:hover {
	border-bottom-color: #C3CCD2;
}

.bottom-buttons {
	display: none;
	background-color: #FFF;
	box-shadow: 0 -3px 5px -2px rgba(0, 0, 0, .15);
	bottom: 0;
	left: 0;
	padding: 5px 0;
	position: fixed;
	right: 0;
	z-index: 5;
}
.bottom-buttons__button {
	letter-spacing: 1px;
	padding: 0 8px;
	text-shadow: 2px 2px 4px rgba(0, 0, 0, .2);
}
.bottom-buttons__button:not(:last-of-type) {
	margin-right: 6px;
}

.main {
	flex: 1 0 auto;
	width: 100%;
}
.main-section:not(:first-child) {
	margin-top: 60px;
}
.main-section__title {
	text-align: center;
	font-size: 1.75rem;
	font-weight: 600;
}
.main-section__subtitle {
	color: var(--color-gray-blue-1);
}
.main-section .text-content {
	box-sizing: border-box;
	padding-left: 10%;
	padding-right: 10%;
}

.products {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(245px, 1fr));
	flex-wrap: wrap;
	row-gap: 70px;
	column-gap: 40px;
}
.product {
	text-decoration: none;
	font-size: 1.125rem;
	font-weight: 600;
	color: var(--color-black);
}
.product__image-wrapper {
	width: 100%;
	height: 245px;
	box-sizing: border-box;
	border: 1px transparent solid;
	padding: 20px;
	background-color: var(--color-gray-5);
}
.product__image {
	object-fit: scale-down;
	width: 100%;
	filter: grayscale(95%);
	opacity: 0.75;
}
.product:hover .product__image-wrapper{
	border-color: var(--color-gray-blue-2);
	background-color: transparent;
}
.product:hover .product__image{
	filter: none;
	opacity: 1;
}

.empty-list {
	font-size: 1.25rem;
	text-transform: uppercase;
}

.soc-link-btn {
	align-items: center;
	color: inherit;
	border-radius: 5px;
	display: inline-flex;
	font-size: 0;
	height: 28px;
	justify-content: center;
	text-decoration: 0;
	transition: .2s;
	width: 28px;
}
.soc-link-btn:hover {
	background-color: var(--color-gray-blue-2);
}
.soc-link-btn > svg {
	display: block;
	height: 18px;
	width: 18px;
}

.header .soc-link-btn > svg,
.footer .soc-link-btn > svg {
	fill: var(--color-gray-blue-1);
}

.footer__developer-link {
	color: inherit;
	text-decoration: none;
	border-bottom: 1px transparent solid;
}
.footer__developer-link:hover {
	border-bottom-color: var(--color-blue);
}

.text-content {
    font-size: .875rem;
}
.text-content p,
.text-content pre {
    margin: 1em 0;
}
.text-content a,
.link {
    color: var(--theme-color-2);
}
.text-content img {
	display: inline-block;
	height: auto !important;
	max-width: 100%;
}
.text-content table {
    border-collapse: collapse;
    max-width: 100%;
}
.text-content table td {
    font-size: .75rem;
    padding: 5px 10px;
    vertical-align: top;
}
.text-content blockquote {
    border-left: 2px solid var(--theme-color-2);
    font-style: italic;
    margin: 20px 0 20px 20px;
    padding: 10px 0 10px 20px;
}
.text-content hr {
    border: 0;
    border-top: 2px solid var(--theme-color-1);
    margin: 20px 0;
}
.text-content ul,
.text-content ol {
    list-style: none;
    margin: 20px 0;
    padding: 0;
}
.text-content ul li,
.text-content ol li {
    margin: 10px 0;
    padding: 0 0 0 25px;
    position: relative;
}
.text-content ul li::before {
    background-color: var(--theme-color-1);
    border-radius: 50%;
    content: '';
    display: block;
    height: 10px;
    left: 5px;
    position: absolute;
    top: 5px;
    width: 10px;
}
.text-content ol {
    counter-reset: textContentOlCounter;
}
.text-content ol li::before {
    color: var(--theme-color-1);
    counter-increment: textContentOlCounter;
    content: counter(textContentOlCounter) '.';
    font-size: 1rem;
    font-weight: 700;
    left: 5px;
    top: 0;
    position: absolute;
}

.front-widget {
	margin: 60px 0;
}
.front-widget-heading__title {
	font-size: 1.875rem;
	line-height: 1.2;
	text-transform: uppercase;
}
.front-widget-heading__readmore {
	color: #878787;
	font-size: 1rem;
	line-height: 1.2;
	text-decoration: none;
	text-transform: uppercase;
}
.front-widget-heading__readmore:hover {
	text-decoration: underline;
}
.front-widget-heading__readmore::after {
	content: '➜';
	display: inline-block;
	margin-left: 10px;
	text-decoration: none;
}

.front-banners {
    background-color: #F2F2F2;
    padding: 20px 0;
}
.front-banners__item {
    width: 250px;
}
.front-banners__item_container {
    position: relative;
}
.front-banners__item_image {
    display: block;
    margin: 0 auto;
    max-width: 100%;
}
.front-banners__item_title {
    color: var(--color-gray-1);
    font-size: 1.125rem;
    line-height: 1.2;
}
.front-banners__item_link {
    bottom: 0;
    display: block;
    left: 0;
    position: absolute;
    right: 0;
    top: 0;
    z-index: 2;
}
.front-banners__item_description {
	color: var(--color-gray-2);
	font-size: .875rem;
    margin-top: 5px;
}

.contact {
	color: var(--color-black);
	text-decoration: none;
}

.contact__ico {
	fill: var(--color-gray-blue-1);
	height: 14px;
	width: 14px;
}

.services-examples {
	column-gap: 40px;
}
.services-block {
	flex: 1 1 0;
	padding: 45px;
	border: 1px var(--color-gray-3) solid;
}
.services-block__image {
	width: 45%;
	max-width: 245px;
}
.services__list {
	display: flex;
	row-gap: 25px;
	column-gap: 60px;
}
.service {
	position: relative;
	padding-left: 32px;
	cursor: default;
}
.service::before {
	position: absolute;
	content: '';
	left: 0;
	border-radius: 12px;
	width: 24px;
	height: 24px;
	background-color: var(--color-black-blue);
	background-image: url("data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTQiIGhlaWdodD0iMTEiIHZpZXdCb3g9IjAgMCAxNCAxMSIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTIgNS4zMzMzM0w1LjMzMzMzIDguNjY2NjdMMTIgMiIgc3Ryb2tlPSIjOTdFNUZCIiBzdHJva2Utd2lkdGg9IjMiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIgc3Ryb2tlLWxpbmVqb2luPSJyb3VuZCIvPgo8L3N2Zz4K");
	background-repeat: no-repeat;
	background-position: center;
}
.service:hover {
	color: var(--color-gray-2);
}
.service:hover::before {
	background-color: var(--color-gray-2);
}
.forms-block {
	background-color: var(--color-black-blue);
	padding: 45px 20px 35px 30px;
}
.forms-block__title {
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--color-blue-light);
}
.forms-block__text {
	text-align: center;
	color: white;
}

.front-contacts {
	display: flex;
}
.front-contacts__map {
	flex: 3 3 0;
	max-height: 75vh;
	overflow: hidden;
}
.front-contacts__map pre {
	margin: 0;
}
.front-contacts__map iframe {
	width: 100%;
	border: 0 !important;
	display: block;
	max-width: 100%;
}
.front-contacts__contacts {
	padding: 60px 30px;
	flex: 2 2 0;
	background-color: var(--color-gray-5);
}
.front-contacts__title {
	font-size: 1.5rem;
	font-weight: 600;
}
.front-contacts__subtitle {
	font-weight: 600;
}
.front-contacts__subtitle,
.front-contacts__link,
.front-contacts__text {
	text-wrap: auto;
}
.front-contacts__link {
	color: inherit;
	text-decoration: none;
	border-bottom: 1px transparent solid;
}
.front-contacts__link:hover {
	border-bottom-color: var(--color-blue);
}

.partner .control-btns{
	padding-top: 5px;
}
.partner__image {
	object-fit: scale-down;
	width: 100%;
	max-width: 125px;
	filter: grayscale(100%);
	opacity: 0.8;
}
.partner__image:hover {
	filter: none;
	opacity: 1;
}

@media (max-width: 992px) {
	.header__top {
		display: none;
	}

	.menu_desktop {
		display: none;
	}

	.header.active .menu_mobile {
		display: block;
	}

	.header-nav {
		background-color: var(--theme-color-2);
		box-shadow: 0 3px 4px -1px rgba(0, 0, 0, .4);
		box-sizing: border-box;
		left: 0;
		list-style: none;
		margin: 0 auto;
		padding: 10px;
		position: absolute;
		right: 0;
		z-index: 10;
	}

	.header-nav li {
		margin: 5px 0;
	}
	.header-nav  li a {
		color: #FFF;
		display: block;
		font-size: 1rem;
		padding: 3px;
		text-decoration: none;
	}

	.header-nav__submenu {
		border-left: 1px solid rgba(255, 255, 255, .5);
		list-style: none;
		margin-left: 5px;
		padding-left: 5px;
	}

	.header__menu-button {
		display: block;
	}

	.footer__top {
		padding: 40px 0;
	}

	.footer {
		padding-bottom: 50px;
	}
	.bottom-buttons {
		display: block;
	}

	.services-examples {
		column-gap: 20px;
	}
	.services__list {
		flex-direction: column;
	}

	.products {
		grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
		row-gap: 50px;
		column-gap: 25px;
	}
	.product__image-wrapper {
		height: 220px;
	}
}

@media (max-width: 768px) {
	.footer-nav {
		flex-direction: column;
		row-gap: 40px;
	}

	.services {
		flex-wrap: wrap;
	}
	.services-examples {
		row-gap: 20px;
	}
	.services-block {
		flex-basis: 100%;
		padding: 30px;
	}
	.services__list {
		flex-basis: 100%;
		flex-direction: row;
	}
	.forms-block {
		flex-basis: 100%;
	}

	.front-contacts {
		flex-direction: column-reverse;
	}
	.front-contacts__map {
		flex-basis: 100%;
		max-height: 500px;
	}
	.front-contacts__contacts {
		padding: 60px 30px;
		flex-basis: 100%;
	}
}

@media (max-width: 576px) {
	.button {
		padding: 5px 40px;
		line-height: 36px;
		font-size: 1rem;
	}

	.bottom-buttons__button {
		padding: 0 6px;
	}

	.services__list {
		flex-direction: column;
	}

	.front-contacts__map {
		max-height: 450px;
	}

	.main-section .text-content {
		padding-left: 10px;
		padding-right: 10px;
	}

	.products {
		grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
		row-gap: 40px;
		column-gap: 20px;
	}
	.product__image-wrapper {
		height: 200px;
	}
}