/*!
Theme Name: Imersum
Theme URI: http://underscores.me/
Author: Underscores.me
Author URI: http://underscores.me/
Description: Description
Version: 1.0.0
Tested up to: 5.4
Requires PHP: 5.6
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: imersum
Tags: custom-background, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready

This theme, like WordPress, is licensed under the GPL.
Use it to make something cool, have fun, and share what you've learned.

Imersum is based on Underscores https://underscores.me/, (C) 2012-2020 Automattic, Inc.
Underscores is distributed under the terms of the GNU GPL v2 or later.

Normalizing styles have been helped along thanks to the fine work of
Nicolas Gallagher and Jonathan Neal https://necolas.github.io/normalize.css/
*/

:root {
	--main-primary: #CB10AD;
	--main-black: #000000;
	--main-white: #ffffff;
	--main-gray: #B4B4B4;
	--main-bg-first: #232323;
	--main-bg-second: #1c1c1c;
	--main-bg-item: #2323234D;
	--fast: 0.2s;
	--slow: 0.4s;
}

* {
	box-sizing: border-box;
	margin: 0px;
	padding: 0px;
	font-family: 'Montserrat', sans-serif;
}

html {
	scroll-behavior: initial!important;
	margin-top: 0px!important;
	margin-right: 0px!important;
}

.x1, .x2, .x3, .x4, .x5, .x6, .x7, .x8 {
	opacity: 0;
	transform: translateX(-120px);
}
.x1 {
	transition: all ease .7s .1s;
}
.x2 {
	transition: all ease .7s .4s;
}
.x3 {
	transition: all ease .7s .7s;
}
.x4 {
	transition: all ease .7s 1s;
}
.x5 {
	transition: all ease .7s 1.3s;
}
.x6 {
	transition: all ease .7s 1.6s;
}
.x7 {
	transition: all ease .7s 1.8s;
}
.x8 {
	transition: all ease .7s 2s;
}
.ready .visible.x1, 
.ready .visible.x2, 
.ready .visible.x3, 
.ready .visible.x4, 
.ready .visible.x5, 
.ready .visible.x6,
.ready .visible.x7, 
.ready .visible.x8 {
	opacity: 1;
	transform: translateX(0px);
}

.y1, .y2, .y3, .y4, .y5, .y6, .y7, .y8 {
	opacity: 0;
	transform: translateY(120px);
}
.y1 {
	transition: all ease .7s .1s;
	transition: opacity 1.2s .1s, transform 1.4s;
}
.y2 {
	transition: all ease .7s .4s;
}
.y3 {
	transition: all ease .7s .7s;
}
.y4 {
	transition: all ease .7s 1s;
}
.y5 {
	transition: all ease .7s 1.3s;
}
.y6 {
	transition: all ease .7s 1.6s;
}
.y7 {
	transition: all ease .7s 1.8s;
}
.y8 {
	transition: all ease .7s 2s;
}
.ready .visible.y1, 
.ready .visible.y2, 
.ready .visible.y3, 
.ready .visible.y4, 
.ready .visible.y5, 
.ready .visible.y6, 
.ready .visible.y7, 
.ready .visible.y8 {
	opacity: 1;
	transform: translateX(0px);
}

.site#page {
	overflow: clip;
	/* background-color: var(--main-bg-first); */
}

.button {
	font-size: 1em;
	line-height: 150%;
	font-weight: 500;
	color: var(--main-white);
	padding: 12px 32px;
	background-color: var(--main-primary);
	text-decoration: none;
	border-radius: 100px;
	text-align: center;
	position: relative;
	z-index: 2;
	transition: var(--fast);
	display: flex;
	align-items: center;
	justify-content: center;
}

.button::after {
	content: '';
	width: 24px;
	min-width: 24px;
	height: 24px;
	background-position: center;
	background-repeat: no-repeat;
	background-size: 100% 100%;
	background-image: url(assets/img/button-icon.svg);
	margin-left: 8px;
}

@media screen and (min-width: 576px) {
	.button:hover {
		background-color: var(--main-primary);
		color: var(--main-white);
	}
}

header.header {
	position: fixed;
	z-index: 100;
	top: 0px;
	left: 50%;
	transform: translateX(-50%);
	width: 100%;
	max-width: 1400px;
	display: flex;
	align-items: center;
	background-color: transparent;
	padding: 40px 80px;
	user-select: none;
	pointer-events: none;
}

header.header .header-wrap {
	max-width: 1400px;
	width: 100%;
	margin: 0px auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 12px 12px 12px 32px;
	background-color: var(--main-bg-first);
	border-radius: 100px;
	user-select: auto;
	pointer-events: all;
	position: relative;
	box-shadow: 0px 0px 10px var(--main-bg-second);
}

body:not(.home) header.header .header-wrap {
	background-color: var(--main-bg-second);
}

header.header .header-wrap .logo {
	height: 24px;
	margin-right: 12px;
	z-index: 2;
	display: flex;
	align-items: center;
}

header.header .header-wrap .logo img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	object-position: left;
}

header.header .header-wrap .header-menu {
	margin-left: auto;
	margin-right: auto;
}

header.header .header-wrap .menu {
	padding: 0px;
	margin: 0px;
	list-style: none;
	display: flex;
	align-items: center;
}

header.header .header-wrap .menu > li {
	margin: 0px 14px;
}

header.header .header-wrap .menu > li.pll-parent-menu-item {
	margin: 0px;
}

header.header .header-wrap .menu > li.menu-item-has-children::after {
	position: absolute;
	content: '';
	left: 0px;
	bottom: 0px;
	height: 50%;
	width: 100%;
	opacity: 0;
	pointer-events: none;
	user-select: none;
}

@media screen and (min-width: 576px) {
	header.header .header-wrap .menu > li.menu-item-has-children:hover::after {
		pointer-events: all;
		user-select: auto;
	}
}

header.header .header-wrap .menu > li > a {
	text-decoration: none;
	color: var(--main-white);
	position: relative;
	z-index: 2;
	display: flex;
	align-items: center;
	font-size: 1em;
	line-height: 150%;
	font-weight: 500;
	transition: var(--fast);
}

header.header .header-wrap .menu > li.menu-item-has-children > a::after {
	content: '';
	width: 24px;
	min-width: 24px;
	height: 24px;
	margin-left: 8px;
	background-image: url(assets/img/menu-dropdown.svg);
	background-position: center;
	background-repeat: no-repeat;
	background-size: 100% 100%;
	transition: var(--fast);
}

@media screen and (min-width: 576px) {
	header.header .header-wrap .menu > li:hover > a {
		color: var(--main-primary);
	}

	header.header .header-wrap .menu > li.menu-item-has-children:hover > a::after {
		transform: rotate(-180deg);
	}
}

header.header .header-wrap .menu > li.current-menu-item > a {
	color: var(--main-primary);
}

header.header .header-wrap .menu > li > .sub-menu {
	position: absolute;
	z-index: -1;
	top: 100%;
	padding: 12px 16px;
	margin-left: -16px;
	list-style: none;
	background-color: var(--main-bg-first);
	opacity: 0;
	pointer-events: none;
	user-select: none;
	transition: var(--slow);
	border-radius: 0px 0px 20px 20px;
	box-shadow: 0px 0px 10px var(--main-bg-second);
}

body:not(.home) header.header .header-wrap .menu > li > .sub-menu {
	background-color: var(--main-bg-second);
}

@media screen and (min-width: 576px) {
	header.header .header-wrap .menu > li:hover > .sub-menu {
		opacity: 1;
		pointer-events: all;
		user-select: auto;
	}
}

header.header .header-wrap .menu > li > .sub-menu > li {
	display: flex;
}

header.header .header-wrap .menu > li > .sub-menu > li:not(:first-child) {
	margin-top: 8px;
}

header.header .header-wrap .menu > li > .sub-menu > li > a {
	text-decoration: none;
	color: var(--main-white);
	font-size: 1em;
	line-height: 150%;
	font-weight: 500;
}

header.header .header-wrap .menu-btn {
	display: none;
}

.mobile-menu {
	position: fixed;
	z-index: 99;
	right: 0px;
	top: 0px;
	width: 100%;
	height: 100vh;
	overflow-y: auto;
	overflow-x: clip;
	padding: 86px 15px 20px;
	box-shadow: 0px 0px 10px var(--main-bg-second);
	opacity: 0;
	pointer-events: none;
	user-select: none;
	transition: var(--fast);
	background-color: var(--main-bg-second);
}

.mobile-menu.show {
	opacity: 1;
	user-select: auto;
	pointer-events: all;
}

.mobile-menu .menus .header-menu .menu {
	padding: 0px;
	margin-bottom: 20px;
	list-style: none;
}

.mobile-menu .menus .header-menu .menu > li {
	margin-bottom: 8px;
}

.mobile-menu .menus .header-menu .menu > li > a {
	text-decoration: none;
	color: var(--main-white);
	position: relative;
	z-index: 2;
	display: flex;
	align-items: center;
	font-size: 1em;
	font-weight: 700;
}

.mobile-menu .menus .header-menu .menu > li > a span {
	font-weight: 400;
}

.mobile-menu .menus .header-menu .menu > li > .sub-menu {
	list-style: none;
	padding-left: 0px;
}

.mobile-menu .menus .header-menu .menu > li > .sub-menu > li {
	margin-top: 8px;
}

.mobile-menu .menus .header-menu .menu > li > .sub-menu > li > a {
	text-decoration: none;
	color: var(--main-white);
	position: relative;
	z-index: 2;
	display: flex;
	align-items: center;
	font-size: 1em;
	font-weight: 700;
}

.mobile-menu .menus .header-menu .menu > li > .sub-menu > li > a > span {
	font-weight: 400;
}

.mobile-menu .menus .language-menu .menu {
	padding: 0px;
	margin-bottom: 20px;
	list-style: none;
	display: flex;
}

.mobile-menu .menus .language-menu .menu > li {
	display: flex;
	align-items: center;
}

.mobile-menu .menus .language-menu .menu > li > a {
	text-decoration: none;
	color: var(--main-white);
	position: relative;
	z-index: 2;
	display: flex;
	align-items: center;
	font-size: 1em;
	font-weight: 500;
}

.mobile-menu .menus .language-menu .menu > li > .sub-menu {
	padding: 0px;
	margin: 0px;
	list-style: none;
	display: flex;
	align-items: center;
}

.mobile-menu .menus .language-menu .menu > li > .sub-menu > li {
	margin-left: 16px;
	display: flex;
	align-items: center;
}

.mobile-menu .menus .language-menu .menu > li > .sub-menu > li > a {
	text-decoration: none;
	color: var(--main-white);
	position: relative;
	z-index: 2;
	display: flex;
	align-items: center;
	font-size: 1em;
	font-weight: 500;
}

.mobile-menu .menus .socials-info span.h3 {
	font-size: 1.125em;
	margin-bottom: 14px;
	font-weight: 400;
	color: var(--main-white);
	display: flex;
}

.mobile-menu .menus .socials-info .social-menu .menu {
	padding: 0px;
	margin: 0px;
	display: flex;
	align-items: center;
}

.mobile-menu .menus .socials-info .social-menu .menu li {
	margin-right: 16px;
	display: flex;
}

.mobile-menu .menus .socials-info .social-menu .menu li a {
	font-size: 0;
	color: transparent;
	width: 40px;
	height: 40px;
	background-position: center;
	background-repeat: no-repeat;
	background-size: 55% 55%;
	border-radius: 100%;
	background-color: transparent;
}

.mobile-menu .menus .socials-info .social-menu .menu li a[href*="facebook"] {
	background-image: url(assets/img/facebook-white.svg);
}

.mobile-menu .menus .socials-info .social-menu .menu li a[href*="t.me"] {
	background-image: url(assets/img/telegram-white.svg);
}

.mobile-menu .menus .socials-info .social-menu .menu li a[href*="youtube"] {
	background-image: url(assets/img/youtube-white.svg);
}

.mobile-menu .menus .socials-info .social-menu .menu li a[href*="instagram"] {
	background-image: url(assets/img/instagram-white.svg);
}

@media screen and (min-width: 576px) {
	.mobile-menu .menus .socials-info .social-menu .menu li a:hover[href*="facebook"] {
		background-image: url(assets/img/facebook-primary.svg);
	}

	.mobile-menu .menus .socials-info .social-menu .menu li a:hover[href*="t.me"] {
		background-image: url(assets/img/telegram-primary.svg);
	}

	.mobile-menu .menus .socials-info .social-menu .menu li a:hover[href*="youtube"] {
		background-image: url(assets/img/youtube-primary.svg);
	}

	.mobile-menu .menus .socials-info .social-menu .menu li a:hover[href*="instagram"] {
		background-image: url(assets/img/instagram-primary.svg);
	}
}

.container-fluid {
	padding: 0px 80px;
	max-width: 1400px;
}

.container-fluid .row {
	margin-left: -16px;
	margin-right: -16px;
}

.container-fluid .row [class*="col-"] {
	padding-left: 16px;
	padding-right: 16px;
}

section {
	position: relative;
	z-index: 1;
	padding: 80px 0px;
}

section.main {
	background-color: var(--main-bg-second);
	padding: 0px;
}

section.main > .main-bg {
	position: absolute;
	z-index: -1;
	left: 0px;
	top: 0px;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

section.main .main-wrap {
	position: relative;
	z-index: 2;
	background-color: var(--main-bg-item);
	padding: 280px 0px 160px;
}

section.main .main-wrap .main-caption {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	padding-bottom: 80px;
}

section.main .main-wrap .main-caption h1 {
	font-size: 3.25em;
	font-weight: 600;
	line-height: 150%;
	color: var(--main-white);
	position: relative;
	margin-bottom: 32px;
}

section.main .main-wrap .col-12:has(.link.text-circle) {
	display: flex;
	align-items: flex-end;
	justify-content: flex-end;
}

section.main .main-wrap .link.text-circle {
	width: 180px;
	height: 180px;
	border-radius: 100%;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	color: var(--main-white);
	background-position: center;
	background-repeat: no-repeat;
	background-size: 100% 100%;
	transition: var(--slow);
	position: relative;
	cursor: pointer;
}

section.main .main-wrap .link.text-circle .rotate {
	font-size: 0.875em;
	line-height: 120%;
	font-weight: 400;
	text-transform: uppercase;
	width: 100%;
	height: 100%;
	position: relative;
	animation: effect 20s linear infinite;
	border-radius: 100%;
}

@keyframes effect {
	0% {
		transform: rotate(0deg)
	}

	100% {
		transform: rotate(360deg)
	}
}

section.main .main-wrap .link.text-circle .rotate span {
	position: absolute;
	left: 50%;
	transform-origin: 0 90px;
	color: var(--main-white);
}

section.main .main-wrap .link.text-circle::after {
	content: '';
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 43%;
	height: 25%;
	background-position: center;
	background-repeat: no-repeat;
	background-size: 100% 100%;
	background-image: url(assets/img/vr-icon.svg);
}

section.services {
	border-radius: 70px 70px 0px 0px;
	background-color: var(--main-bg-first);
	margin-top: -80px;
	padding-bottom: 160px;
}

section.services .main-services {
	display: flex;
	flex-wrap: wrap;
	margin: 0px -16px;
}

section.services .main-services .services-item {
	width: calc(100% / 2);
	padding: 0px 16px;
}

.services-item .item-link {
	border-radius: 40px;
	overflow: hidden;
	background-color: var(--main-bg-second);
	display: flex;
	flex-direction: column;
	align-items: center;
	position: relative;
	transition: var(--fast);
	text-decoration: none;
	height: 100%;
	z-index: 1;
}

.services-item .item-link .thumbnail {
	position: absolute;
	z-index: 1;
	left: 0px;
	top: 0px;
	width: 100%;
	height: 100%;
	display: flex;
}

.services-item .item-link .thumbnail img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.services-item .item-link .caption {
	position: relative;
	z-index: 2;
	padding: 160px 40px 40px;
	width: 100%;
	height: 100%;
	background-color: var(--main-bg-item);
	display: flex;
}

.services-item .item-link .caption::before {
	position: absolute;
	content: '';
	top: 16px;
	right: 16px;
	width: 60px;
	height: 60px;
	border-radius: 100%;
	background-position: center;
	background-repeat: no-repeat;
	background-size: 24px 24px;
	background-image: url(assets/img/button-icon.svg);
	background-color: var(--main-primary);
}

.services-item .item-link .caption p.h2 {
	font-size: 3em;
	line-height: 120%;
	font-weight: 500;
	color: var(--main-white);
	margin: auto 0px 0px;
}

section.services-tabs {
	margin-top: -80px;
	background-color: var(--main-bg-second);
	border-radius: 70px 70px 0px 0px;
}

section.services-tabs .main-services-tabs {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
}

section.services-tabs .main-services-tabs p.uppertitle {
	font-size: 1em;
	line-height: 120%;
	font-weight: 400;
	color: var(--main-white);
	display: flex;
	text-transform: uppercase;
	margin-bottom: 20px;
}

section.services-tabs .main-services-tabs p.uppertitle::before {
	content: '/';
	font-size: 1em;
	line-height: 120%;
	font-weight: 400;
	color: var(--main-primary);
	margin-right: 8px;
}

section.services-tabs .main-services-tabs .nav-wrap {
	display: flex;
	flex-direction: column;
}

section.services-tabs .main-services-tabs .nav-wrap .nav-tabs {
	display: flex;
	align-items: center;
	list-style: none;
	margin: 0px -16px 40px;
	border: none;
}

section.services-tabs .main-services-tabs .nav-wrap .nav-tabs li {
	padding: 0px 16px;
	position: relative;
}

section.services-tabs .main-services-tabs .nav-wrap .nav-tabs li button.nav-link {
	padding: 14px 16px;
	border: 1px solid transparent;
	border-radius: 100px;
	font-size: 1.125em;
	line-height: 100%;
	font-weight: 500;
	color: var(--main-white);
	background-color: transparent;
	transition: var(--fast);
}

section.services-tabs .main-services-tabs .nav-wrap .nav-tabs li button.nav-link.active {
	border-color: var(--main-primary);
}

@media screen and (min-width: 576px) {
	section.services-tabs .main-services-tabs .nav-wrap .nav-tabs li button.nav-link:hover {
		border-color: var(--main-primary);
	}
}

section.services-tabs .main-services-tabs .nav-wrap .tab-content .col-12 {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
}

section.services-tabs .main-services-tabs .nav-wrap .tab-content p.text {
	font-size: 1.25em;
	line-height: 150%;
	font-weight: 400;
	color: var(--main-white);
	margin-bottom: 36px;
}

section.services-tabs .main-services-tabs .nav-wrap .tab-content ul {
	display: flex;
	flex-wrap: wrap;
	list-style: none;
	padding: 0px;
	margin: 0px -18px;
	counter-reset: tab-counter;
}

section.services-tabs .main-services-tabs .nav-wrap .tab-content ul li {
	width: calc(100% / 2);
	padding: 0px 18px;
	font-size: 1.125em;
	line-height: 150%;
	font-weight: 500;
	color: var(--main-white);
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	counter-increment: tab-counter;
}

section.services-tabs .main-services-tabs .nav-wrap .tab-content ul li::before {
	content: '0'counter(tab-counter)'/';
	font-size: 1em;
	line-height: 150%;
	font-weight: 500;
	color: var(--main-primary);
	margin-bottom: 4px;
}

section.services-tabs .main-services-tabs .nav-wrap .tab-content ul li:nth-child(1n + 3) {
	margin-top: 28px;
}

section.banner {
	padding: 0px;
}

section.banner .banner-bg {
	position: absolute;
	z-index: -1;
	left: 0px;
	top: 0px;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

section.banner .banner-wrap {
	position: relative;
	z-index: 2;
	background-color: var(--main-bg-item);
	padding: 220px 0px;
}

section.banner .banner-wrap .banner-caption {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	max-width: 50%;
}

section.banner .banner-wrap .banner-caption h2.section-title {
	font-size: 3em;
	line-height: 120%;
	font-weight: 500;
	color: var(--main-white);
	margin-bottom: 20px;
}

section.banner .banner-wrap .banner-caption p.text {
	font-size: 1em;
	line-height: 120%;
	font-weight: 400;
	color: var(--main-white);
	margin-bottom: 32px;
}

section.about {
	margin-top: -80px;
	border-radius: 70px 70px 0px 0px;
	background-color: var(--main-bg-first);
}

section.about h2.section-title {
	font-size: 3em;
	line-height: 120%;
	font-weight: 500;
	color: var(--main-white);
	margin-bottom: 44px;
}

section.about .about-items {
	display: flex;
	flex-wrap: wrap;
	margin: 0px -5px;
}

section.about .about-items .about-item {
	width: calc(100% / 2);
	padding: 0px 5px;
}

section.about .about-items .about-item:nth-child(3n + 3) {
	width: 100%;
}

section.about .about-items .about-item:nth-child(1n + 3) {
	margin-top: 10px;
}

section.about .about-items .about-item .item-wrap {
	border-radius: 20px;
	padding: 30px;
	background-color: var(--main-bg-second);
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	height: 100%;
}

section.about .about-items .about-item .item-wrap p.number {
	font-size: 4em;
	line-height: 100%;
	font-weight: 500;
	color: var(--main-white);
	margin-bottom: 4px;
}

section.about .about-items .about-item .item-wrap p.name {
	font-size: 1.25em;
	line-height: 120%;
	font-weight: 500;
	color: var(--main-white);
	margin-bottom: 14px;
}

section.about .about-items .about-item .item-wrap p.text {
	font-size: 1em;
	line-height: 120%;
	font-weight: 400;
	color: var(--main-white);
	margin: 0px;
}

section.about .about-wrap {
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: flex-start;
}

section.about .about-wrap .about-info {
	display: flex;
	flex-direction: column
}

section.about .about-wrap .about-info p {
	font-size: 1em;
	line-height: 120%;
	font-weight: 400;
	color: var(--main-white);
	margin-bottom: 32px;
}

section.about .about-wrap .about-info p:first-child {
	font-size: 1.25em;
	font-weight: 500;
}

section.about .about-wrap a.link {
	font-size: 1em;
	line-height: 120%;
	font-weight: 400;
	color: var(--main-white);
	border-bottom: 1px solid var(--main-white);
	display: flex;
	align-items: center;
	text-decoration: none;
}

section.about .about-wrap a.link::after {
	content: '';
	width: 24px;
	min-width: 24px;
	height: 24px;
	background-position: center;
	background-repeat: no-repeat;
	background-size: 100% 100%;
	background-image: url(assets/img/button-icon.svg);
	margin-left: 8px;
}

section.cases {
	background-color: var(--main-bg-first);
	padding: 0px;
	display: flex;
	flex-direction: column;
}

section.cases .cases-item {
	position: relative;
	border-radius: 70px;
	overflow: hidden;
}

section.cases .cases-item:nth-child(1n + 2) {
	margin-top: 32px;
}

section.cases .cases-item .thumbnail {
	position: absolute;
	z-index: 1;
	left: 0px;
	top: 0px;
	width: 100%;
	height: 100%;
}

section.cases .cases-item .thumbnail img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

section.cases .cases-item .caption {
	position: relative;
	z-index: 2;
	background-color: var(--main-bg-item);
	padding: 80px 0px 180px;
}

section.cases .cases-item .caption .wrap {
	background-color: var(--main-bg-second);
	border-radius: 40px;
	padding: 40px;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	width: 60%;
}

section.cases .cases-item:nth-child(2n + 2) .caption .wrap {
	margin-left: auto;
}

section.cases .cases-item .caption .wrap p.uppertitle {
	font-size: 1em;
	line-height: 120%;
	font-weight: 400;
	color: var(--main-white);
	display: flex;
	align-items: center;
	margin-bottom: 20px;
}

section.cases .cases-item .caption .wrap p.uppertitle::before {
	content: '/';
	font-size: 1em;
	line-height: 120%;
	font-weight: 400;
	color: var(--main-primary);
	margin-right: 8px;
}

section.cases .cases-item .caption .wrap p.h2 {
	font-size: 3em;
	line-height: 120%;
	font-weight: 500;
	color: var(--main-white);
	margin-bottom: 20px;
}

section.cases .cases-item .caption .wrap p.text {
	font-size: 1em;
	line-height: 120%;
	font-weight: 400;
	color: var(--main-white);
	margin-bottom: 32px;
}

section.info {
	background-color: var(--main-bg-first);
}

section.info h2.section-title {
	font-size: 3em;
	line-height: 120%;
	font-weight: 500;
	color: var(--main-white);
	margin-bottom: 0px;
}

section.info p {
	font-size: 1em;
	line-height: 120%;
	font-weight: 400;
	color: var(--main-white);
	margin-bottom: 32px;
}

section.info p:has(a.button) {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	margin: 0px;
}

section.faq {
	background-color: var(--main-bg-first);
	padding-bottom: 160px;
}

section.faq h2.section-title {
	font-size: 3em;
	line-height: 120%;
	font-weight: 500;
	color: var(--main-white);
	margin-bottom: 40px;
}

section.faq .faq-container {
	margin-bottom: 120px;
	counter-reset: faq-counter;
}

section.faq .faq-container .card {
	border: none;
	background-color: transparent;
	counter-increment: faq-counter;
}

section.faq .faq-container .card .card-header {
	border-top: 1px solid var(--main-white);
	border-left: 1px solid var(--main-white);
	border-right: 1px solid var(--main-white);
	border-bottom: 1px solid transparent;
	box-shadow: none;
	border-radius: 100px;
	padding: 24px 36px;
	position: relative;
}

section.faq .faq-container .card .card-header::before {
	content: '';
	position: absolute;
	left: -1px;
	top: 50%;
	width: 20px;
	height: 50%;
	background-color: var(--main-bg-first);
	user-select: none;
	pointer-events: none;
}

section.faq .faq-container .card .card-header::after {
	content: '';
	position: absolute;
	right: -1px;
	top: 50%;
	width: 20px;
	height: 50%;
	background-color: var(--main-bg-first);
	user-select: none;
	pointer-events: none;
}

section.faq .faq-container .card .card-header button {
	font-size: 1.5em;
	line-height: 120%;
	font-weight: 400;
	color: var(--main-white);
}

section.faq .faq-container .card .card-header button span[itemprop="name"] {
	display: flex;
	align-items: center;
	width: 100%;
}

section.faq .faq-container .card .card-header button span[itemprop="name"]::before {
	content: '0'counter(faq-counter);
	width: 30px;
	white-space: nowrap;
	font-size: 1em;
	line-height: 120%;
	font-weight: 400;
	color: var(--main-white);
	margin-right: 30px;
}

section.faq .faq-container .card:nth-child(1n + 10) .card-header button span[itemprop="name"]::before {
	content: counter(faq-counter);
}

section.faq .faq-container .card .card-header button span.cross {
	width: 30px;
	min-width: 30px;
	height: 30px;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	margin-left: 30px;
}

section.faq .faq-container .card .card-header button span.cross::before {
	content: '';
	position: absolute;
	width: 2px;
	height: 100%;
	background-color: var(--main-white);
	transition: var(--fast);
}

section.faq .faq-container .card .card-header button span.cross::after {
	content: '';
	position: absolute;
	width: 100%;
	height: 2px;
	background-color: var(--main-white);
}

section.faq .faq-container .card .card-header button:not(.collapsed) span.cross::before {
	transform: rotate(90deg);
}

section.faq .faq-container .card .card-body {
	padding: 0px 96px 35px;
}

section.faq .faq-container .card .card-body p {
	margin: 0px;
	font-size: 1.125em;
	line-height: 120%;
	font-weight: 400;
	color: var(--main-white);
}

section.faq .show-more-wrap .page-content > *:last-child {
	margin-bottom: 0px;
}

section.faq .show-more-wrap .page-content p {
	font-size: 1.125em;
	line-height: 120%;
	font-weight: 400;
	margin-bottom: 16px;
	color: var(--main-white);
}

section.faq .show-more-wrap .page-content ul,
section.faq .show-more-wrap .page-content ol {
	padding-left: 18px;
	margin-bottom: 16px;
}

section.faq .show-more-wrap .page-content ul li,
section.faq .show-more-wrap .page-content ol li {
	font-size: 1.125em;
	line-height: 120%;
	font-weight: 400;
	margin-bottom: 8px;
	color: var(--main-white);
}

.show-more-wrap {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
}

.show-more-wrap.show .show-more-content {
	display: -webkit-box;
	overflow: hidden;
	-webkit-line-clamp: 8;
	line-clamp: 8;
	-webkit-box-orient: vertical;
    width: 100%;
}

.show-more-wrap .show-more-content > *:last-child {
	margin-bottom: 0px;
}

.show-more-wrap.open .show-more-content {
	display: block;
}

.show-more-wrap .show-more {
	display: none;
}

.show-more-wrap.show .show-more {
	display: flex;
	align-items: center;
	position: relative;
	margin-top: 16px;
	cursor: pointer;
	border-bottom: 1px solid var(--main-primary);
}

.show-more-wrap .show-more span {
	font-size: 1em;
	line-height: 120%;
	font-weight: 500;
	color: var(--main-primary);
}

.show-more-wrap .show-more span.less {
	display: none;
}

.show-more-wrap.open .show-more span.more {
	display: none;
}

.show-more-wrap.open .show-more span.less {
	display: flex;
}

.show-more-wrap .show-more::after {
	content: '';
	width: 24px;
	min-width: 24px;
	height: 24px;
	margin-left: 8px;
	background-image: url( assets/img/menu-dropdown-primary.svg);
	background-position: center;
	background-repeat: no-repeat;
	background-size: 100% 100%;
	transition: var(--fast);
}

.show-more-wrap.open .show-more::after {
	transform: rotate(-180deg);
}

footer.footer {
	position: relative;
	z-index: 1;
	background-color: var(--main-bg-second);
	margin-top: -80px;
	border-radius: 70px 70px 0px 0px;
	padding: 80px 0px;
}

footer.footer .footer-info {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
}

footer.footer .footer-info a.logo {
	height: 30px;
	margin-bottom: 40px;
}

footer.footer .footer-info a.logo img {
	height: 100%;
}

footer.footer .footer-info p.h2 {
	font-size: 3em;
	list-style: 120%;
	font-weight: 500;
	color: var(--main-white);
	margin-bottom: 24px;
}

footer.footer .footer-info p.text {
	font-size: 1em;
	line-height: 120%;
	font-weight: 400;
	color: var(--main-gray);
	margin-bottom: 40px;
}

footer.footer .footer-info p.h4 {
	font-size: 1em;
	line-height: 120%;
	font-weight: 700;
	color: var(--main-white);
	margin-bottom: 20px;
}

footer.footer .footer-info .services-menu .menu {
	list-style: none;
	padding: 0px;
	margin: 0px;
}

footer.footer .footer-info .services-menu .menu li {
	margin-bottom: 15px;
}

footer.footer .footer-info .services-menu .menu li a {
	font-size: 1em;
	line-height: 120%;
	font-weight: 400;
	color: var(--main-gray);
	text-decoration: none;
	transition: var(--fast);
}

@media screen and (min-width: 576px) {
	footer.footer .footer-info .services-menu .menu li a:hover {
		color: var(--main-primary);
	}
}

footer.footer .footer-info .social-menu {
	margin-top: 15px;
}

footer.footer .footer-info .social-menu .menu {
	list-style: none;
	padding: 0px;
	margin: 0px -6px;
	display: flex;
	align-items: center;
}

footer.footer .footer-info .social-menu .menu li {
	display: flex;
	margin: 0px 6px;
}

footer.footer .footer-info .social-menu .menu li a {
	font-size: 0;
	color: transparent;
	width: 36px;
	height: 36px;
	background-position: center;
	background-repeat: no-repeat;
	background-size: 55% 55%;
	border-radius: 100%;
	background-color: transparent;
}

footer.footer .footer-info .social-menu .menu li a[href*="facebook"] {
	background-image: url(assets/img/facebook-white.svg);
}

footer.footer .footer-info .social-menu .menu li a[href*="t.me"] {
	background-image: url(assets/img/telegram-white.svg);
}

footer.footer .footer-info .social-menu .menu li a[href*="youtube"] {
	background-image: url(assets/img/youtube-white.svg);
}

footer.footer .footer-info .social-menu .menu li a[href*="instagram"] {
	background-image: url(assets/img/instagram-white.svg);
}

footer.footer .footer-info .social-menu .menu li a[href*="linkedin"] {
	background-image: url(assets/img/linkedin-white.svg);
	background-size: 70% 70%;
}

@media screen and (min-width: 576px) {
	footer.footer .footer-info .social-menu .menu li a:hover {
		background-color: transparent;
	}

	footer.footer .footer-info .social-menu .menu li a:hover[href*="facebook"] {
		background-image: url(assets/img/facebook-primary.svg);
	}

	footer.footer .footer-info .social-menu .menu li a:hover[href*="t.me"] {
		background-image: url(assets/img/telegram-primary.svg);
	}

	footer.footer .footer-info .social-menu .menu li a:hover[href*="youtube"] {
		background-image: url(assets/img/youtube-primary.svg);
	}

	footer.footer .footer-info .social-menu .menu li a:hover[href*="instagram"] {
		background-image: url(assets/img/instagram-primary.svg);
	}

	footer.footer .footer-info .social-menu .menu li a:hover[href*="linkedin"] {
		background-image: url(assets/img/linkedin-primary.svg);
	}
}

footer.footer .footer-info .footer-menu .menu {
	list-style: none;
	padding: 0px;
	margin: 0px;
}

footer.footer .footer-info .footer-menu .menu li {
	margin-bottom: 15px;
}

footer.footer .footer-info .footer-menu .menu li a {
	font-size: 1em;
	line-height: 120%;
	font-weight: 400;
	color: var(--main-white);
	text-decoration: none;
	transition: var(--fast);
}

@media screen and (min-width: 576px) {
	footer.footer .footer-info .footer-menu .menu li a:hover {
		color: var(--main-primary);
	}
}

footer.footer .footer-info .form-wrap {
	width: 60%;
	display: flex;
}

footer.footer .footer-info .form-wrap > div {
	width: 100%;
}

form.wpcf7-form p {
	width: 100%;
	font-size: 1em;
	line-height: 120%;
	font-weight: 400;
	color: var(--main-white);
	margin-bottom: 16px;
}

form.wpcf7-form p input,
form.wpcf7-form p textarea {
	padding: 16px 32px;
	border: 1px solid var(--main-white);
	border-radius: 100px;
	font-size: 1em;
	line-height: 120%;
	font-weight: 400;
	color: var(--main-white);
	background-color: transparent;
	outline: none;
	width: 100%;
	resize: none;
	box-shadow: none;
}

form.wpcf7-form p input::placeholder {
	color: var(--main-white);
}

form.wpcf7-form p .wpcf7-not-valid-tip {
	font-size: 0.875em;
	color: var(--main-gray);
	margin-top: 4px;
}

form.wpcf7-form p:has(input[type="submit"]) {
	position: relative;
	margin-bottom: 0px;
}

form.wpcf7-form p input[type="submit"] {
	border: none;
	font-size: 1em;
	line-height: 150%;
	font-weight: 500;
	color: var(--main-white);
	padding: 12px 32px;
	background-color: var(--main-primary);
	text-decoration: none;
	border-radius: 100px;
	text-align: center;
	position: relative;
	z-index: 2;
	transition: var(--fast);
	display: flex;
	align-items: center;
	justify-content: center;
}

form.wpcf7-form p input[type="submit"]::after {
	content: '';
	width: 24px;
	min-width: 24px;
	height: 24px;
	background-position: center;
	background-repeat: no-repeat;
	background-size: 100% 100%;
	background-image: url(assets/img/button-icon.svg);
	margin-left: 8px;
}

form.wpcf7-form p .wpcf7-spinner {
	position: absolute;
	z-index: 2;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	margin: 0px;
}

form.wpcf7-form .wpcf7-response-output {
	margin: 32px 0px 0px;
	padding: 12px 32px;
	border: 1px solid var(--main-primary)!important;
	border-radius: 100px;
	font-size: 0.875em;
	line-height: 120%;
	font-weight: 400;
	color: var(--main-white);
}

.mfp-content:has(.banner-modal-wrap) {
	max-width: 800px;
	padding: 30px 0px;
}

.mfp-content .banner-modal-wrap {
	background-color: var(--main-bg-first);
	border-radius: 40px;
	overflow: hidden;
	padding: 40px 30px;
	position: relative;
}

.mfp-content .banner-modal-wrap .mfp-close {
	color: transparent;
	display: flex;
	align-items: center;
	justify-content: center;
	position: absolute;
	right: 15px;
	top: 15px;
	width: 40px;
	height: 40px;
}

.mfp-content .banner-modal-wrap .mfp-close::after,
.mfp-content .banner-modal-wrap .mfp-close::before {
	position: absolute;
	content: '';
	height: 3px;
	width: 100%;
	background-color: var(--main-primary);
	transform: rotate(45deg);
}

.mfp-content .banner-modal-wrap .mfp-close::before {
	transform: rotate(-45deg);
}

.mfp-content .banner-modal-wrap p.h3 {
	font-size: 1.5em;
	font-weight: 500;
	line-height: 120%;
	margin-bottom: 25px;
	color: var(--main-white);
	padding-right: 30px;
}

@media screen and (max-width: 1299px) {
	.button {
		padding: 10px 26px;
	}
	
	.button::after {
		width: 18px;
		min-width: 18px;
		height: 18px;
	}

	header.header {
		padding: 30px 60px;
	}

	header.header .header-wrap {
		padding: 10px 10px 10px 26px;
	}

	header.header .header-wrap .logo {
		height: 22px;
		margin-right: 8px;
	}

	header.header .header-wrap .menu > li {
		margin: 0px 10px;
	}

	header.header .header-wrap .menu > li > a {
		font-size: 0.875em;
	}

	header.header .header-wrap .menu > li.menu-item-has-children > a::after {
		width: 18px;
		min-width: 18px;
		height: 18px;
	}

	header.header .header-wrap .menu > li > .sub-menu {
		padding: 10px 12px;
		margin-left: -12px;
	}

	header.header .header-wrap .menu > li > .sub-menu > li:not(:first-child) {
		margin-top: 6px;
	}

	header.header .header-wrap .menu > li > .sub-menu > li > a {
		font-size: 0.875em;
	}

	header.header .header-wrap .button {
		font-size: 0.875em;
	}

	.container-fluid {
		padding: 0px 60px;
	}

	section {
		padding: 60px 0px;
	}

	section.main .main-wrap {
		padding: 210px 0px 120px;
	}

	section.main .main-wrap .main-caption {
		padding-bottom: 60px;
	}

	section.main .main-wrap .main-caption h1 {
		font-size: 2.5em;
		margin-bottom: 24px;
	}

	section.main .main-wrap .link.text-circle {
		width: 140px;
		height: 140px;
	}

	section.main .main-wrap .link.text-circle .rotate {
		font-size: 0.75em;
	}

	section.main .main-wrap .link.text-circle .rotate span {
		transform-origin: 0 70px;
	}
	
	section.services {
		border-radius: 50px 50px 0px 0px;
		margin-top: -60px;
		padding-bottom: 120px;
	}

	.services-item .item-link {
		border-radius: 30px;
	}

	.services-item .item-link .caption {
		padding: 120px 30px 30px;
	}

	.services-item .item-link .caption::before {
		top: 12px;
		right: 12px;
		width: 45px;
		height: 45px;
		background-size: 18px 18px;
	}

	.services-item .item-link .caption p.h2 {
		font-size: 2.25em;
	}

	section.services-tabs {
		margin-top: -60px;
		border-radius: 50px 50px 0px 0px;
	}

	section.services-tabs .main-services-tabs p.uppertitle {
		margin-bottom: 16px;
	}

	section.services-tabs .main-services-tabs .nav-wrap .nav-tabs {
		margin: 0px -12px 30px;
	}

	section.services-tabs .main-services-tabs .nav-wrap .nav-tabs li {
		padding: 0px 12px;
	}

	section.services-tabs .main-services-tabs .nav-wrap .nav-tabs li button.nav-link {
		padding: 10px 12px;
		font-size: 1em;
	}

	section.services-tabs .main-services-tabs .nav-wrap .tab-content p.text {
		font-size: 1.125em;
		margin-bottom: 26px;
	}

	section.services-tabs .main-services-tabs .nav-wrap .tab-content ul {
		margin: 0px -14px;
	}
	
	section.services-tabs .main-services-tabs .nav-wrap .tab-content ul li {
		padding: 0px 14px;
		font-size: 1em;
	}
	
	section.services-tabs .main-services-tabs .nav-wrap .tab-content ul li:nth-child(1n + 3) {
		margin-top: 20px;
	}

	section.banner .banner-wrap {
		padding: 160px 0px;
	}

	section.banner .banner-wrap .banner-caption {
		max-width: 60%;
	}

	section.banner .banner-wrap .banner-caption h2.section-title {
		font-size: 2.25em;
		margin-bottom: 16px;
	}

	section.banner .banner-wrap .banner-caption p.text {
		margin-bottom: 24px;
	}

	section.about {
		margin-top: -60px;
		border-radius: 50px 50px 0px 0px;
	}

	section.about h2.section-title {
		font-size: 2.25em;
		margin-bottom: 32px;
	}

	section.about .about-items .about-item .item-wrap {
		border-radius: 16px;
		padding: 22px;
	}

	section.about .about-items .about-item .item-wrap p.number {
		font-size: 3em;
	}
	
	section.about .about-items .about-item .item-wrap p.name {
		font-size: 1.125em;
		margin-bottom: 10px;
	}

	section.about .about-wrap .about-info p {
		margin-bottom: 24px;
	}

	section.about .about-wrap .about-info p:first-child {
		font-size: 1.125em;
	}

	section.about .about-wrap a.link::after {
		width: 18px;
		min-width: 18px;
		height: 18px;
	}

	section.cases .cases-item {
		border-radius: 50px;
	}

	section.cases .cases-item:nth-child(1n + 2) {
		margin-top: 24px;
	}

	section.cases .cases-item .caption {
		padding: 60px 0px 140px;
	}

	section.cases .cases-item .caption .wrap {
		border-radius: 30px;
		padding: 30px;
		width: 75%;
	}

	section.cases .cases-item .caption .wrap p.uppertitle {
		margin-bottom: 16px;
	}

	section.cases .cases-item .caption .wrap p.h2 {
		font-size: 2.25em;
		margin-bottom: 16px;
	}

	section.cases .cases-item .caption .wrap p.text {
		margin-bottom: 24px;
	}

	section.info h2.section-title {
		font-size: 2.25em;
	}

	section.info p {
		margin-bottom: 24px;
	}

	section.faq {
		padding-bottom: 120px;
	}

	section.faq h2.section-title {
		font-size: 2.25em;
		margin-bottom: 30px;
	}

	section.faq .faq-container {
		margin-bottom: 90px;
	}

	section.faq .faq-container .card .card-header {
		padding: 18px 26px;
	}

	section.faq .faq-container .card .card-header::before {
		width: 12px;
	}

	section.faq .faq-container .card .card-header::after {
		width: 12px;
	}

	section.faq .faq-container .card .card-header button {
		font-size: 1.25em;
	}

	section.faq .faq-container .card .card-header button span[itemprop="name"]::before {
		width: 24px;
		margin-right: 24px;
	}

	section.faq .faq-container .card .card-header button span.cross {
		width: 24px;
		min-width: 24px;
		height: 24px;
		margin-left: 24px;
	}

	section.faq .faq-container .card .card-body {
		padding: 0px 74px 26px;
	}

	section.faq .faq-container .card .card-body p {
		font-size: 1em;
	}

	section.faq .show-more-wrap .page-content p {
		font-size: 1em;
		margin-bottom: 12px;
	}

	section.faq .show-more-wrap .page-content ul,
	section.faq .show-more-wrap .page-content ol {
		margin-bottom: 12px;
	}

	section.faq .show-more-wrap .page-content ul li,
	section.faq .show-more-wrap .page-content ol li {
		font-size: 1em;
	}

	.show-more-wrap.show .show-more {
		margin-top: 12px;
	}

	.show-more-wrap .show-more::after {
		width: 18px;
		min-width: 18px;
		height: 18px;
	}

	footer.footer {
		margin-top: -60px;
		border-radius: 50px 50px 0px 0px;
		padding: 60px 0px;
	}

	footer.footer .footer-info a.logo {
		height: 24px;
		margin-bottom: 30px;
	}

	footer.footer .footer-info p.h2 {
		font-size: 2.25em;
		margin-bottom: 18px;
	}

	footer.footer .footer-info p.text {
		margin-bottom: 30px;
	}

	footer.footer .footer-info p.h4 {
		margin-bottom: 16px;
	}

	footer.footer .footer-info .services-menu .menu li {
		margin-bottom: 12px;
	}

	footer.footer .footer-info .social-menu {
		margin-top: 12px;
	}

	footer.footer .footer-info .footer-menu .menu li {
		margin-bottom: 12px;
	}

	form.wpcf7-form p {
		margin-bottom: 12px;
	}

	form.wpcf7-form p input,
	form.wpcf7-form p textarea {
		padding: 12px 24px;
	}

	form.wpcf7-form p input[type="submit"] {
		font-size: 0.875em;
		padding: 10px 26px;
	}

	form.wpcf7-form p input[type="submit"]::after {
		width: 18px;
		min-width: 18px;
		height: 18px;
	}

	form.wpcf7-form .wpcf7-response-output {
		margin: 24px 0px 0px;
		padding: 10px 24px;
	}
}

@media screen and (max-width: 1199px) {
	.button {
		padding: 8px 18px;
	}
	
	.button::after {
		width: 16px;
		min-width: 16px;
		height: 16px;
		margin-left: 4px;
	}

	header.header {
		padding: 20px 40px;
	}

	header.header .header-wrap {
		padding: 8px 8px 8px 18px;
	}

	header.header .header-wrap .logo {
		height: 20px;
		margin-right: 6px;
	}

	header.header .header-wrap .menu > li {
		margin: 0px 6px;
	}

	header.header .header-wrap .menu > li.menu-item-has-children > a::after {
		width: 16px;
		min-width: 16px;
		height: 16px;
		margin-left: 4px;
	}

	header.header .header-wrap .menu > li > .sub-menu {
		padding: 6px 8px;
		margin-left: -8px;
	}

	header.header .header-wrap .menu > li > .sub-menu > li:not(:first-child) {
		margin-top: 4px;
	}

	.container-fluid {
		padding: 0px 40px;
	}

	section {
		padding: 40px 0px;
	}

	section.main .main-wrap {
		padding: 140px 0px 80px;
	}

	section.main .main-wrap .main-caption {
		padding-bottom: 40px;
	}

	section.main .main-wrap .main-caption h1 {
		font-size: 2.25em;
		margin-bottom: 16px;
	}

	section.main .main-wrap .link.text-circle {
		width: 100px;
		height: 100px;
	}

	section.main .main-wrap .link.text-circle .rotate {
		font-size: 0.675em;
	}

	section.main .main-wrap .link.text-circle .rotate span {
		transform-origin: 0 50px;
	}
	
	section.services {
		border-radius: 34px 34px 0px 0px;
		margin-top: -40px;
		padding-bottom: 80px;
	}

	.services-item .item-link {
		border-radius: 20px;
	}

	.services-item .item-link .caption {
		padding: 80px 20px 20px;
	}

	.services-item .item-link .caption::before {
		background-size: 16px 16px;
	}

	.services-item .item-link .caption p.h2 {
		font-size: 2em;
	}

	section.services-tabs {
		margin-top: -40px;
		border-radius: 34px 34px 0px 0px;
	}

	section.services-tabs .main-services-tabs p.uppertitle {
		font-size: 0.875em;
		margin-bottom: 12px;
	}

	section.services-tabs .main-services-tabs .nav-wrap .nav-tabs {
		margin: 0px -8px 20px;
	}

	section.services-tabs .main-services-tabs .nav-wrap .nav-tabs li {
		padding: 0px 8px;
	}

	section.services-tabs .main-services-tabs .nav-wrap .nav-tabs li button.nav-link {
		padding: 8px 10px;
	}

	section.services-tabs .main-services-tabs .nav-wrap .tab-content p.text {
		font-size: 1em;
		margin-bottom: 18px;
	}

	section.services-tabs .main-services-tabs .nav-wrap .tab-content ul {
		margin: 0px -10px;
	}
	
	section.services-tabs .main-services-tabs .nav-wrap .tab-content ul li {
		padding: 0px 10px;
	}
	
	section.services-tabs .main-services-tabs .nav-wrap .tab-content ul li:nth-child(1n + 3) {
		margin-top: 14px;
	}

	section.banner .banner-wrap {
		padding: 110px 0px;
	}

	section.banner .banner-wrap .banner-caption {
		max-width: 60%;
	}

	section.banner .banner-wrap .banner-caption h2.section-title {
		font-size: 2em;
		margin-bottom: 12px;
	}

	section.banner .banner-wrap .banner-caption p.text {
		margin-bottom: 16px;
	}

	section.about {
		margin-top: -40px;
		border-radius: 34px 34px 0px 0px;
	}

	section.about h2.section-title {
		font-size: 2em;
		margin-bottom: 22px;
	}

	section.about .about-items .about-item .item-wrap {
		border-radius: 12px;
		padding: 14px;
	}

	section.about .about-items .about-item .item-wrap p.number {
		font-size: 2em;
	}
	
	section.about .about-items .about-item .item-wrap p.name {
		font-size: 1em;
		margin-bottom: 8px;
	}

	section.about .about-wrap .about-info p {
		margin-bottom: 16px;
	}

	section.about .about-wrap .about-info p:first-child {
		font-size: 1em;
	}

	section.about .about-wrap a.link::after {
		width: 16px;
		min-width: 16px;
		height: 16px;
	}

	section.cases .cases-item {
		border-radius: 34px;
	}

	section.cases .cases-item:nth-child(1n + 2) {
		margin-top: 16px;
	}

	section.cases .cases-item .caption {
		padding: 40px 0px 95px;
	}

	section.cases .cases-item .caption .wrap {
		border-radius: 20px;
		padding: 20px;
		width: 75%;
	}

	section.cases .cases-item .caption .wrap p.uppertitle {
		margin-bottom: 12px;
	}

	section.cases .cases-item .caption .wrap p.h2 {
		font-size: 2em;
		margin-bottom: 12px;
	}

	section.cases .cases-item .caption .wrap p.text {
		margin-bottom: 16px;
	}

	section.info h2.section-title {
		font-size: 2em;
	}

	section.info p {
		margin-bottom: 16px;
	}

	section.faq {
		padding-bottom: 80px;
	}

	section.faq h2.section-title {
		font-size: 2em;
		margin-bottom: 20px;
	}

	section.faq .faq-container {
		margin-bottom: 60px;
	}

	section.faq .faq-container .card .card-header {
		padding: 14px 18px;
	}

	section.faq .faq-container .card .card-header button {
		font-size: 1.125em;
	}

	section.faq .faq-container .card .card-header button span[itemprop="name"]::before {
		width: 16px;
		margin-right: 16px;
	}

	section.faq .faq-container .card .card-header button span.cross {
		width: 16px;
		min-width: 16px;
		height: 16px;
		margin-left: 16px;
	}

	section.faq .faq-container .card .card-body {
		padding: 0px 50px 18px;
	}

	section.faq .faq-container .card .card-body p {
		font-size: 1em;
	}

	section.faq .show-more-wrap .page-content p {
		font-size: 1em;
		margin-bottom: 10px;
	}

	section.faq .show-more-wrap .page-content ul,
	section.faq .show-more-wrap .page-content ol {
		margin-bottom: 10px;
	}

	section.faq .show-more-wrap .page-content ul li,
	section.faq .show-more-wrap .page-content ol li {
		font-size: 1em;
	}

	.show-more-wrap.show .show-more {
		margin-top: 10px;
	}

	.show-more-wrap .show-more::after {
		width: 16px;
		min-width: 16px;
		height: 16px;
	}

	footer.footer {
		margin-top: -40px;
		border-radius: 34px 34px 0px 0px;
		padding: 40px 0px;
	}

	footer.footer .footer-info a.logo {
		height: 22px;
		margin-bottom: 20px;
	}

	footer.footer .footer-info p.h2 {
		font-size: 2em;
		margin-bottom: 14px;
	}

	footer.footer .footer-info p.text {
		margin-bottom: 20px;
	}

	footer.footer .footer-info p.h4 {
		margin-bottom: 12px;
	}

	footer.footer .footer-info .services-menu .menu li {
		margin-bottom: 10px;
	}

	footer.footer .footer-info .social-menu {
		margin-top: 10px;
	}

	footer.footer .footer-info .footer-menu .menu li {
		margin-bottom: 10px;
	}

	form.wpcf7-form p {
		margin-bottom: 10px;
	}

	form.wpcf7-form p input,
	form.wpcf7-form p textarea {
		padding: 10px 16px;
	}

	form.wpcf7-form p input[type="submit"] {
		font-size: 0.875em;
		padding: 8px 18px;
	}

	form.wpcf7-form p input[type="submit"]::after {
		width: 16px;
		min-width: 16px;
		height: 16px;
	}

	form.wpcf7-form .wpcf7-response-output {
		margin: 16px 0px 0px;
		padding: 8px 16px;
	}

	.mfp-content .banner-modal-wrap {
		border-radius: 34px;
	}
}

@media screen and (max-width: 991px) {
	header.header {
		padding: 15px 30px;
	}

	header.header .header-wrap .menu {
		display: none;
	}

	header.header .header-wrap .button {
		font-size: 0px;
		padding: 10px;
	}

	header.header .header-wrap .button::after {
		width: 20px;
		min-width: 20px;
		height: 20px;
		margin: 0px;
		background-image: url(assets/img/phone-call.svg);
	}

	header.header .header-wrap .menu-btn {
		display: flex;
		align-items: center;
		justify-content: center;
		padding: 10px;
		border-radius: 100%;
		background-color: var(--main-bg-second);
		margin-left: 16px;
	}

	header.header .header-wrap .menu-btn::after {
		content: '';
		width: 20px;
		min-width: 20px;
		height: 20px;
		margin: 0px;
		background-position: center;
		background-repeat: no-repeat;
		background-size: 100% 100%;
		background-image: url(assets/img/menu-burger.svg);
	}

	.container-fluid {
		padding: 0px 30px;
	}

	section {
		padding: 30px 0px;
	}

	section.main .main-wrap {
		padding: 120px 0px 60px;
	}

	section.main .main-wrap .main-caption {
		padding-bottom: 30px;
	}

	section.main .main-wrap .main-caption h1 {
		font-size: 2.125em;
	}
	
	section.services {
		border-radius: 25px 25px 0px 0px;
		margin-top: -30px;
		padding-bottom: 60px;
	}

	section.services .main-services .services-item {
		width: 100%;
	}

	section.services .main-services .services-item:nth-child(1n + 2) {
		margin-top: 20px;
	}

	.services-item .item-link {
		border-radius: 15px;
	}

	.services-item .item-link .caption p.h2 {
		font-size: 1.875em;
	}

	section.services-tabs {
		margin-top: -30px;
		border-radius: 25px 25px 0px 0px;
	}

	section.services-tabs .main-services-tabs .nav-wrap .nav-tabs li {
		padding: 8px;
	}

	section.services-tabs .main-services-tabs .nav-wrap .tab-content p.text {
		margin-bottom: 16px;
	}

	section.services-tabs .main-services-tabs .nav-wrap .tab-content ul {
		margin: 20px -10px 0px;
	}

	section.banner .banner-wrap {
		padding: 80px 0px 110px;
	}

	section.banner .banner-wrap .banner-caption {
		max-width: 100%;
	}

	section.banner .banner-wrap .banner-caption h2.section-title {
		font-size: 1.875em;
	}

	section.about {
		margin-top: -30px;
		border-radius: 25px 25px 0px 0px;
	}

	section.about h2.section-title {
		font-size: 1.875em;
		margin-bottom: 16px;
	}

	section.about .about-items .about-item .item-wrap {
		border-radius: 12px;
		padding: 15px;
	}

	section.about .about-items .about-item .item-wrap p.number {
		font-size: 1.875em;
	}

	section.about .about-wrap .about-info {
		margin-top: 20px;
	}

	section.about .about-wrap a.link::after {
		margin-left: 4px;
	}

	section.cases .cases-item {
		border-radius: 25px;
	}

	section.cases .cases-item .thumbnail {
		position: relative;
		height: 320px;
	}

	section.cases .cases-item .caption {
		margin-top: -30px;
		padding: 0px;
	}

	section.cases .cases-item .caption .container-fluid {
		padding: 0px;
	}

	section.cases .cases-item .caption .wrap {
		border-radius: 25px 25px 0px 0px;
		padding: 30px;
		width: 100%;
	}

	section.cases .cases-item .caption .wrap p.h2 {
		font-size: 1.875em;
	}

	section.info h2.section-title {
		font-size: 1.875em;
		margin-bottom: 20px;
	}

	section.faq {
		padding-bottom: 60px;
	}

	section.faq h2.section-title {
		font-size: 1.875em;
	}

	section.faq .faq-container {
		margin-bottom: 60px;
	}

	section.faq .faq-container .card .card-header {
		padding: 14px 18px;
	}

	section.faq .faq-container .card .card-header button {
		font-size: 1.125em;
	}

	section.faq .faq-container .card .card-header button span[itemprop="name"]::before {
		width: 16px;
		margin-right: 16px;
	}

	section.faq .faq-container .card .card-header button span.cross {
		width: 16px;
		min-width: 16px;
		height: 16px;
		margin-left: 16px;
	}

	section.faq .faq-container .card .card-body {
		padding: 0px 50px 18px;
	}

	section.faq .faq-container .card .card-body p {
		font-size: 1em;
	}

	section.faq .show-more-wrap .page-content p {
		font-size: 1em;
		margin-bottom: 16px;
	}

	section.faq .show-more-wrap .page-content ul,
	section.faq .show-more-wrap .page-content ol {
		margin-bottom: 16px;
	}

	section.faq .show-more-wrap .page-content ul li,
	section.faq .show-more-wrap .page-content ol li {
		font-size: 1em;
	}

	.show-more-wrap.show .show-more {
		margin-top: 16px;
	}

	.show-more-wrap .show-more::after {
		width: 16px;
		min-width: 16px;
		height: 16px;
	}

	footer.footer {
		margin-top: -30px;
		border-radius: 25px 25px 0px 0px;
		padding: 30px 0px;
	}

	footer.footer .footer-info a.logo {
		height: 20px;
		margin-bottom: 20px;
	}

	footer.footer .footer-info p.h2 {
		font-size: 1.875em;
		margin-bottom: 14px;
	}

	footer.footer .footer-info p.text {
		margin-bottom: 20px;
	}

	footer.footer .footer-info p.h4 {
		margin-bottom: 12px;
	}

	footer.footer .footer-info .services-menu .menu li {
		margin-bottom: 10px;
	}

	footer.footer .footer-info .social-menu {
		margin-top: 10px;
	}

	footer.footer .footer-info .footer-menu .menu li {
		margin-bottom: 10px;
	}

	footer.footer .footer-info .form-wrap {
		width: 100%;
		margin-bottom: 25px;
	}

	form.wpcf7-form p {
		margin-bottom: 10px;
	}

	form.wpcf7-form p input,
	form.wpcf7-form p textarea {
		padding: 10px 16px;
	}

	form.wpcf7-form p input[type="submit"] {
		font-size: 0.875em;
		padding: 8px 18px;
	}

	form.wpcf7-form p input[type="submit"]::after {
		width: 16px;
		min-width: 16px;
		height: 16px;
	}

	form.wpcf7-form .wpcf7-response-output {
		margin: 16px 0px 0px;
		padding: 8px 16px;
	}
	
	.mfp-container {
		padding-left: 15px;
		padding-right: 15px;
	}

	.mfp-content:has(.banner-modal-wrap) {
		padding: 15px 0px;
	}

	.mfp-content .banner-modal-wrap {
		border-radius: 25px;
		padding: 30px 20px;
	}

	.mfp-content .banner-modal-wrap .mfp-close {
		width: 30px;
		height: 30px;
	}

	.mfp-content .banner-modal-wrap p.h3 {
		font-size: 1.25em;
		margin-bottom: 20px;
	}
}

@media screen and (max-width: 767px) {
	header.header {
		padding: 15px 20px;
	}

	.container-fluid {
		padding: 0px 20px;
	}

	section {
		padding: 30px 0px 40px;
	}

	section.main .main-wrap {
		padding: 120px 0px 40px;
	}

	section.main .main-wrap .main-caption {
		padding-bottom: 20px;
	}

	section.main .main-wrap .main-caption h1 {
		font-size: 2em;
	}

	section.services {
		margin-top: -20px;
		padding-bottom: 50px;
		border-radius: 20px 20px 0px 0px;
	}

	.services-item .item-link .caption p.h2 {
		font-size: 1.75em;
	}

	section.services-tabs {
		margin-top: -20px;
		border-radius: 20px 20px 0px 0px;
	}

	section.banner .banner-wrap {
		padding: 60px 0px 80px;
	}

	section.banner .banner-wrap .banner-caption h2.section-title {
		font-size: 1.75em;
	}

	section.about {
		margin-top: -20px;
		border-radius: 20px 20px 0px 0px;
	}

	section.about h2.section-title {
		font-size: 1.75em;
	}

	section.about .about-items .about-item .item-wrap p.number {
		font-size: 1.75em;
	}

	section.cases .cases-item .thumbnail {
		height: 260px;
	}

	section.cases .cases-item .caption {
		margin-top: -20px;
	}

	section.cases .cases-item .caption .wrap {
		border-radius: 20px 20px 0px 0px;
		padding: 30px 20px;
	}

	section.cases .cases-item .caption .wrap p.h2 {
		font-size: 1.75em;
	}

	section.info {
		padding: 30px 0px;
	}

	section.info h2.section-title {
		font-size: 1.75em;
	}

	section.faq h2.section-title {
		font-size: 1.75em;
	}

	section.faq .faq-container {
		margin-bottom: 40px;
	}

	section.faq .faq-container .card .card-header {
		border-radius: 30px;
		padding: 10px 14px;
	}

	section.faq .faq-container .card .card-header button {
		font-size: 1em;
	}

	section.faq .faq-container .card .card-body {
		padding: 0px 46px 18px;
	}

	section.faq .faq-container .card .card-body p {
		font-size: 0.875em;
	}

	footer.footer {
		margin-top: -20px;
		border-radius: 20px 20px 0px 0px;
	}

	footer.footer .footer-info p.h2 {
		font-size: 1.75em;
	}

	footer.footer .footer-info:has(.social-menu) {
		margin-top: 15px;
	}

	.mfp-content .banner-modal-wrap {
		border-radius: 20px;
		padding: 20px 15px;
	}
}

@media screen and (max-width: 575px) {
	header.header {
		padding: 15px;
	}

	header.header .header-wrap .logo {
		margin-right: 24px;
	}

	header.header .header-wrap .menu-btn {
		margin-left: 8px;
	}

	.container-fluid {
		padding: 0px 15px;
	}

	section {
		padding: 20px 0px 40px;
	}

	section.main .main-wrap .main-caption h1 {
		font-size: 1.875em;
	}

	section.services {
		padding-bottom: 40px;
	}

	.services-item .item-link .caption p.h2 {
		font-size: 1.5em;
	}

	section.services-tabs .main-services-tabs .nav-wrap .nav-tabs li {
		padding: 4px 8px;
	}

	section.about .about-items .about-item {
		width: 100%;
	}

	section.about .about-items .about-item:nth-child(1n + 2) {
		margin-top: 10px;
	}

	section.cases .cases-item .thumbnail {
		height: 200px;
	}

	section.cases .cases-item .caption .wrap p.h2 {
		font-size: 1.5em;
	}

	footer.footer .footer-info p.h2 {
		font-size: 1.5em;
	}

	form.wpcf7-form .wpcf7-response-output {
		border-radius: 30px;
	}
}

section.page-archive {
	padding-top: 160px;
	padding-bottom: 200px;
	background-color: var(--main-bg-first);
	color: var(--main-white);
}

section.page-archive .title-wrap {
	display: flex;
	flex-direction: column;
	position: relative;
	z-index: 2;
	margin-bottom: 50px;
}

.breadcrumbs-wrap {
	display: flex;
	position: relative;
	z-index: 2;
	margin-bottom: 24px;
}

.breadcrumbs-wrap ul.breadcrumbs {
	display: flex;
	align-items: center;
	list-style: none;
	padding: 0;
	margin-bottom: 0;
}

.breadcrumbs-wrap ul.breadcrumbs li {
	display: flex;
	align-items: center;
}

.breadcrumbs-wrap ul.breadcrumbs li:not(:last-child) {
	padding-right: 23px;
	position: relative;
}

.breadcrumbs-wrap ul.breadcrumbs li a {
	font-size: 1em;
	font-weight: 400;
	line-height: 150%;
	color: var(--main-gray);
	text-decoration: none;
	white-space: nowrap;
	transition: color var(--slow);
}

.breadcrumbs-wrap ul.breadcrumbs li:last-child a {
	color: var(--main-gray);
}

.breadcrumbs-wrap ul.breadcrumbs li:not(:last-child)::after {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	right: 8px;
	content: '/';
	font-size: 1em;
	font-weight: 400;
	line-height: 150%;
	color: var(--main-gray);
}

@media screen and (min-width: 576px) {
	.breadcrumbs-wrap ul.breadcrumbs li a:hover {
		color: var(--main-white);
	}
}

section.page-archive .title-wrap .title-taxonomy {
	display: flex;
	align-items: center;
}

section.page-archive .title-wrap h1 {
	font-size: 4em;
	line-height: 120%;
	font-weight: 400;
	color: var(--main-white);
	margin-bottom: 0px;
}

section.page-archive .title-wrap .taxonomy-wrap {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-left: 80px;
}

section.page-archive .title-wrap .taxonomy-wrap a {
	border: 1px solid var(--main-white);
	border-radius: 50px;
	padding: 10px 20px;
	display: flex;
	align-items: center;
	text-align: center;
	font-size: 1em;
	line-height: 150%;
	font-weight: 400;
	color: var(--main-white);
	background-color: var(--main-bg-first);
	cursor: pointer;
	text-decoration: none;
	transition: var(--fast);
}

section.page-archive .title-wrap .taxonomy-wrap a.active {
	border-color: var(--main-black);
	background-color: var(--main-black);
	color: var(--main-white);
}

@media screen and (min-width: 576px) {
	section.page-archive .title-wrap .taxonomy-wrap a:hover {
		border-color: var(--main-black);
		background-color: var(--main-black);
		color: var(--main-white);
	}
}

section.page-archive .popular-wrap {
	display: flex;
	flex-direction: column;
	margin-bottom: 90px;
	overflow: hidden;
}

section.page-archive .popular-wrap h2 {
	font-size: 3em;
	line-height: 120%;
	font-weight: 500;
	color: var(--main-white);
	margin-bottom: 44px;
	width: 100%;
}

section.page-archive .popular-wrap .popular-list {
	display: flex;
	flex-wrap: wrap;
	margin: 0px -12px;
}

section.page-archive .list-wrap {
	display: flex;
	flex-wrap: wrap;
	margin: 0px -12px;
	overflow: clip;
}

section.page-archive .list-wrap h2 {
	font-size: 3em;
	line-height: 120%;
	font-weight: 500;
	color: var(--main-white);
	padding: 0px 12px;
	margin-bottom: 44px;
	width: 100%;
}

section.page-archive .list-wrap .blog-item:nth-child(1n + 4) {
	margin-top: 40px;
}

.blog-item {
	display: flex;
	width: calc(100% / 2);
	padding: 0px 12px;
}

.blog-item .item-link {
	overflow: hidden;
	text-decoration: none;
	display: flex;
	flex-direction: column;
	height: 100%;
	width: 100%;
}

.blog-item .item-link .thumbnail {
	border-radius: 30px;
	position: relative;
	width: 100%;
	padding-top: 70%;
	display: flex;
	overflow: hidden;
}

.blog-item .item-link .thumbnail img {
	position: absolute;
	left: 0px;
	top: 0px;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.blog-item .item-link .caption {
	padding-top: 20px;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
}

.blog-item .item-link .caption .tag {
	border: 1px solid var(--main-white);
	border-radius: 50px;
	padding: 10px 20px;
	display: flex;
	align-items: center;
	text-align: center;
	font-size: 1em;
	line-height: 150%;
	font-weight: 400;
	color: var(--main-white);
	background-color: transparent;
	text-decoration: none;
	margin-bottom: 20px;
}

.blog-item .item-link .caption p.h3 {
	font-size: 1.25em;
	line-height: 120%;
	font-weight: 500;
	color: var(--main-white);
	margin-bottom: 0px;
	margin-top: auto;
}

.navigation {
	width: 100%;
	padding: 0px 12px;
	margin-top: 80px;
	display: flex;
	justify-content: center;
	align-items: center;
}

.navigation .nav-links {
	border-radius: 28px;
	background-color: var(--main-black);
	padding: 8px;
	gap: 6px;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
}

.navigation .nav-links .page-numbers {
	width: 40px;
	height: 40px;
	border-radius: 100%;
	font-size: 0.875em;
	line-height: 135%;
	font-weight: 600;
	color: var(--main-white);
	background-color: var(--main-black);
	transition: var(--fast);
	background-position: center;
	background-repeat: no-repeat;
	background-size: 55% 55%;
	display: flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
}

@media screen and (min-width: 576px) {
	.navigation .nav-links .page-numbers:hover {
		background-color: var(--main-white);
		color: var(--main-black);
	}
}

.navigation .nav-links .page-numbers.current {
	background-color: var(--main-white);
	color: var(--main-black);
}

.navigation .nav-links .page-numbers.prev {
	font-size: 0px;
	color: transparent;
	background-image: url(assets/img/pagination-prev.svg);
}

.navigation .nav-links .page-numbers.next {
	font-size: 0px;
	color: transparent;
	background-image: url(assets/img/pagination-next.svg);
}

@media screen and (min-width: 576px) {
	.navigation .nav-links .page-numbers.prev:hover,
	.navigation .nav-links .page-numbers.next:hover {
		background-color: var(--main-black);
		filter: invert(1);
	}
}

.navigation .nav-links .page-numbers.inactive {
	opacity: 0.4;
	user-select: none;
	pointer-events: none;
}

@media screen and (max-width: 1299px) {
	section.page-archive {
		padding-top: 120px;
		padding-bottom: 150px;
	}
	
	section.page-archive .title-wrap {
		margin-bottom: 38px;
	}
	
	.breadcrumbs-wrap {
		margin-bottom: 18px;
	}
	
	section.page-archive .title-wrap h1 {
		font-size: 3em;
	}
	
	section.page-archive .title-wrap .taxonomy-wrap {
		gap: 10px;
		margin-left: 60px;
	}
	
	section.page-archive .title-wrap .taxonomy-wrap a {
		padding: 8px 16px;
	}
	
	section.page-archive .popular-wrap {
		margin-bottom: 68px;
	}
	
	section.page-archive .popular-wrap h2 {
		font-size: 2.25em;
		margin-bottom: 32px;
	}
	
	section.page-archive .list-wrap h2 {
		font-size: 2.25em;
		margin-bottom: 32px;
	}
	
	section.page-archive .list-wrap .blog-item:nth-child(1n + 4) {
		margin-top: 30px;
	}
	
	.blog-item .item-link .thumbnail {
		border-radius: 24px;
	}
	
	.blog-item .item-link .caption {
		padding-top: 16px;
	}
	
	.blog-item .item-link .caption .tag {
		padding: 8px 16px;
		margin-bottom: 16px;
	}
	
	.blog-item .item-link .caption p.h3 {
		font-size: 1.125em;
	}
	
	.navigation {
		margin-top: 60px;
	}
	
	.navigation .nav-links .page-numbers {
		width: 30px;
		height: 30px;
		background-size: 55% 55%;
	}
}

@media screen and (max-width: 1199px) {
	section.page-archive {
		padding-top: 100px;
		padding-bottom: 100px;
	}
	
	section.page-archive .title-wrap {
		margin-bottom: 26px;
	}

	section.page-archive .title-wrap .taxonomy-wrap {
		margin-left: 40px;
	}
	
	.breadcrumbs-wrap {
		margin-bottom: 14px;
	}
	
	section.page-archive .title-wrap h1 {
		font-size: 2.75em;
	}

	section.page-archive .title-wrap .taxonomy-wrap a {
		font-size: 0.875em;
	}
	
	section.page-archive .popular-wrap {
		margin-bottom: 46px;
	}
	
	section.page-archive .popular-wrap h2 {
		font-size: 2em;
		margin-bottom: 22px;
	}
	
	section.page-archive .list-wrap h2 {
		font-size: 2em;
		margin-bottom: 22px;
	}
	
	section.page-archive .list-wrap .blog-item:nth-child(1n + 4) {
		margin-top: 20px;
	}
	
	.blog-item .item-link .thumbnail {
		border-radius: 18px;
	}

	.blog-item .item-link .caption .tag {
		font-size: 0.875em;
	}
	
	.blog-item .item-link .caption p.h3 {
		font-size: 1em;
	}
	
	.navigation {
		margin-top: 40px;
	}
}

@media screen and (max-width: 991px) {
	section.page-archive {
		padding-bottom: 60px;
	}

	.breadcrumbs-wrap ul.breadcrumbs li a {
		font-size: 0.875em;
	}

	section.page-archive .title-wrap .title-taxonomy {
		flex-direction: column;
		align-items: flex-start;
	}

	section.page-archive .title-wrap .taxonomy-wrap {
		margin-left: 0px;
		margin-top: 14px;
	}

	.navigation {
		margin-top: 30px;
	}

	section.page-archive .popular-wrap {
		margin-bottom: 36px;
	}

	section.page-archive .title-wrap h1 {
		font-size: 2.25em;
	}
		
	section.page-archive .popular-wrap h2 {
		font-size: 1.875em;
		margin-bottom: 16px;
	}
	
	section.page-archive .list-wrap h2 {
		font-size: 1.875em;
		margin-bottom: 16px;
	}
}

@media screen and (max-width: 767px) {
	section.page-archive .title-wrap h1 {
		font-size: 2.125em;
	}

	section.page-archive .popular-wrap h2 {
		font-size: 1.75em;
	}
	
	section.page-archive .list-wrap h2 {
		font-size: 1.75em;
	}
	
	section.page-archive .popular-wrap .popular-list .blog-item:nth-child(1n + 2) {
		margin-top: 25px;
	}

	section.page-archive .list-wrap .blog-item:nth-child(1n + 3) {
		margin-top: 25px;
	}

	.blog-item {
		width: 100%;
	}
}

@media screen and (max-width: 575px) {
	section.page-archive {
		padding-top: 90px;
	}

	section.page-archive .title-wrap h1 {
		font-size: 2em;
	}

	section.page-archive .title-wrap .taxonomy-wrap a {
		font-size: 0.75em;
		padding: 6px 12px;
	}

	.blog-item .item-link .caption .tag {
		font-size: 0.75em;
		padding: 6px 12px;
		margin-bottom: 12px;
	}
}

section.page-single {
	padding-top: 160px;
	padding-bottom: 200px;
	background-color: var(--main-bg-first);
	color: var(--main-white);
}

section.page-single .title-wrap {
	display: flex;
	flex-direction: column;
	position: relative;
	z-index: 2;
	margin-bottom: 50px;
}

section.page-single .title-wrap h1 {
	font-size: 3em;
	line-height: 120%;
	font-weight: 400;
	color: var(--main-white);
	margin-bottom: 24px;
}

section.page-single .title-wrap .meta-wrap {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	margin-bottom: 40px;
	gap: 40px;
}

section.page-single .title-wrap .meta-wrap .tag {
	border: 1px solid var(--main-white);
	border-radius: 50px;
	padding: 10px 20px;
	display: flex;
	align-items: center;
	text-align: center;
	font-size: 1em;
	line-height: 150%;
	font-weight: 400;
	color: var(--main-white);
	background-color: var(--main-bg-first);
	cursor: pointer;
	text-decoration: none;
	transition: var(--fast);
}

@media screen and (min-width: 576px) {
	section.page-single .title-wrap .meta-wrap .tag:hover {
		border-color: var(--main-black);
		background-color: var(--main-black);
		color: var(--main-white);
	}
}

section.page-single .title-wrap .meta-wrap .author {
	font-size: 1em;
	line-height: 150%;
	font-weight: 400;
	color: var(--main-white);
}

section.page-single .title-wrap .meta-wrap .author span {
	color: var(--main-white);
}

section.page-single .title-wrap .meta-wrap .date {
	font-size: 1em;
	line-height: 150%;
	font-weight: 400;
	color: var(--main-white);
}

section.page-single .title-wrap .meta-wrap .date span {
	color: var(--main-white);
}

section.page-single .title-wrap .meta-wrap .share-wrap {
	display: none;
}

section.page-single .title-wrap .thumbnail {
	width: 100%;
	padding-top: 50%;
	position: relative;
	border-radius: 30px;
	overflow: hidden;
}

section.page-single .title-wrap .thumbnail img {
	position: absolute;
	left: 0px;
	top: 0px;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

section.page-single .content-wrap {
	margin-bottom: 90px;
	position: relative;
}

section.page-single .content-wrap .page-content {
	width: 80%;
	margin-right: auto;
}

section.page-single .content-wrap .share-wrap {
	position: absolute;
	right: 0px;
	top: 0px;
	height: 100%;
}

section.page-single .content-wrap .share-wrap .addtoany_shortcode {
	position: sticky;
	top: 160px;
	display: flex;
}

section.page-single .content-wrap .share-wrap .addtoany_shortcode .addtoany_list {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

section.page-single .content-wrap .share-wrap .addtoany_shortcode .addtoany_list a {
	width: 50px;
	min-width: 50px;
	height: 50px;
	border-radius: 100%;
	background-color: var(--main-bg-second);
	background-position: center;
	background-repeat: no-repeat;
	background-size: 40% 40%;
}

section.page-single .content-wrap .share-wrap .addtoany_shortcode .addtoany_list a[class*="facebook"] {
	background-image: url(assets/img/share-facebook.svg);
}

section.page-single .content-wrap .share-wrap .addtoany_shortcode .addtoany_list a[class*="telegram"] {
	background-image: url(assets/img/share-telegram.svg);
}

section.page-single .content-wrap .share-wrap .addtoany_shortcode .addtoany_list a[class*="x"] {
	background-image: url(assets/img/share-x.svg);
}

section.page-single .content-wrap .share-wrap .addtoany_shortcode .addtoany_list a[class*="copy_link"] {
	background-image: url(assets/img/share-copy-link.svg);
}

section.page-single .content-wrap .share-wrap .addtoany_shortcode .addtoany_list a span {
	display: none;
}

section.page-single .blog-more-wrap {
	overflow: hidden;
	position: relative;
}

section.page-single .blog-more-wrap h2 {
	font-size: 3em;
	line-height: 120%;
	font-weight: 500;
	color: var(--main-white);
	margin-bottom: 44px;
}

section.page-single .blog-more-wrap .blog-more-list {
	display: flex;
	flex-wrap: wrap;
	margin: 0px -12px;
}

@media screen and (max-width: 1299px) {
	section.page-single {
		padding-top: 120px;
		padding-bottom: 150px;
	}
	
	section.page-single .title-wrap {
		margin-bottom: 38px;
	}
	
	section.page-single .title-wrap h1 {
		font-size: 2.25em;
		margin-bottom: 18px;
	}
	
	section.page-single .title-wrap .meta-wrap {
		margin-bottom: 30px;
		gap: 30px;
	}
	
	section.page-single .title-wrap .meta-wrap .tag {
		padding: 8px 16px;
	}
	
	section.page-single .title-wrap .thumbnail {
		border-radius: 24px;
	}
	
	section.page-single .content-wrap {
		margin-bottom: 68px;
	}
	
	section.page-single .content-wrap .share-wrap .addtoany_shortcode {
		top: 120px;
	}
	
	section.page-single .blog-more-wrap h2 {
		font-size: 2.25em;
		margin-bottom: 32px;
	}
}

@media screen and (max-width: 1199px) {
	section.page-single {
		padding-top: 100px;
		padding-bottom: 100px;
	}

	section.page-single .title-wrap {
		margin-bottom: 26px;
	}

	section.page-single .title-wrap h1 {
		font-size: 2em;
		margin-bottom: 14px;
	}

	section.page-single .title-wrap .meta-wrap {
		margin-bottom: 24px;
		gap: 20px;
	}

	section.page-single .title-wrap .meta-wrap .tag {
		font-size: 0.875em;
	}

	section.page-single .title-wrap .meta-wrap .author {
		font-size: 0.875em;
	}

	section.page-single .title-wrap .meta-wrap .date {
		font-size: 0.875em;
	}

	section.page-single .content-wrap {
		margin-bottom: 46px;
	}

	section.page-single .content-wrap .share-wrap .addtoany_shortcode {
		top: 100px;
	}

	section.page-single .content-wrap .share-wrap .addtoany_shortcode .addtoany_list a {
		width: 40px;
		min-width: 40px;
		height: 40px;
	}

	section.page-single .blog-more-wrap h2 {
		font-size: 2em;
		margin-bottom: 22px;
	}
}

@media screen and (max-width: 991px) {
	section.page-single {
		padding-bottom: 60px;
	}

	section.page-single .title-wrap h1 {
		font-size: 1.875em;
	}

	section.page-single .title-wrap .meta-wrap .share-wrap {
		display: flex;
	}

	section.page-single .title-wrap .meta-wrap .share-wrap .addtoany_shortcode {
		display: flex;
	}

	section.page-single .title-wrap .meta-wrap .share-wrap .addtoany_shortcode .addtoany_list {
		display: flex;
		align-items: center;
		gap: 10px;
	}

	section.page-single .title-wrap .meta-wrap .share-wrap .addtoany_shortcode .addtoany_list a {
		width: 40px;
		min-width: 40px;
		height: 40px;
		border-radius: 100%;
		background-color: var(--main-bg-second);
		background-position: center;
		background-repeat: no-repeat;
		background-size: 40% 40%;
	}
	
	section.page-single .title-wrap .meta-wrap .share-wrap .addtoany_shortcode .addtoany_list a[class*="facebook"] {
		background-image: url(assets/img/share-facebook.svg);
	}

	section.page-single .title-wrap .meta-wrap .share-wrap .addtoany_shortcode .addtoany_list a[class*="telegram"] {
		background-image: url(assets/img/share-telegram.svg);
	}

	section.page-single .title-wrap .meta-wrap .share-wrap .addtoany_shortcode .addtoany_list a[class*="x"] {
		background-image: url(assets/img/share-x.svg);
	}

	section.page-single .title-wrap .meta-wrap .share-wrap .addtoany_shortcode .addtoany_list a[class*="copy_link"] {
		background-image: url(assets/img/share-copy-link.svg);
	}

	section.page-single .title-wrap .meta-wrap .share-wrap .addtoany_shortcode .addtoany_list a span {
		display: none;
	}

	section.page-single .content-wrap {
		margin-bottom: 36px;
	}

	section.page-single .content-wrap .page-content {
		width: 100%;
	}

	section.page-single .content-wrap .share-wrap {
		display: none;
	}

	section.page-single .blog-more-wrap h2 {
		font-size: 1.875em;
		margin-bottom: 16px;
	}
}

@media screen and (max-width: 767px) {
	section.page-single .title-wrap h1 {
		font-size: 1.75em;
	}

	section.page-single .blog-more-wrap h2 {
		font-size: 1.75em;
	}

	section.page-single .blog-more-wrap .blog-more-list .blog-item:nth-child(1n + 2) {
		margin-top: 25px;
	}
}

@media screen and (max-width: 575px) {
	section.page-single {
		padding-top: 90px;
	}

	section.page-single .title-wrap h1 {
		font-size: 1.5em;
	}

	section.page-single .title-wrap .meta-wrap .tag {
		font-size: 0.75em;
		padding: 6px 12px;
	}

	section.page-single .title-wrap .meta-wrap .share-wrap {
		margin-left: auto;
	}

	section.page-single .title-wrap .meta-wrap .share-wrap .addtoany_shortcode .addtoany_list a {
		width: 34px;
		min-width: 34px;
		height: 34px;
	}

	section.page-single .title-wrap .thumbnail {
		padding-top: 70%;
	}

	.breadcrumbs-wrap {
		margin-left: -16px;
		margin-right: -16px;
		padding-left: 16px;
		padding-right: 16px;
		margin-bottom: 16px;
		overflow-x: auto;
    overflow-y: hidden;
	}

	.breadcrumbs-wrap::-webkit-scrollbar {
		width: 0;
		height: 0
	}

	.breadcrumbs-wrap ul.breadcrumbs li a {
		font-size: 0.875em;
	}

	.breadcrumbs-wrap ul.breadcrumbs li:not(:last-child) {
		padding-right: 15px;
	}

	.breadcrumbs-wrap ul.breadcrumbs li:not(:last-child)::after {
		font-size: 0.875em;
		right: 5px;
		/* top: 46%; */
	}
}

section.page-archive.cases-archive .list-wrap .archive-filters-list {
	width: 25%;
	padding-left: 12px;
	padding-right: 35px;
}

section.page-archive.cases-archive .list-wrap .archive-filters-list .widget_wpc_filters_widget {
	position: sticky;
	top: 160px;
}

section.page-archive.cases-archive .list-wrap .archive-filters-list .wpc-filters-section {
	margin-bottom: 40px;
}

section.page-archive.cases-archive .list-wrap .archive-filters-list .wpc-filters-section .wpc-filter-title {
	border-bottom: 1px solid var(--main-white);
	padding-bottom: 10px;
	font-size: 1.125em;
	line-height: 120%;
	font-weight: 400;
	margin-bottom: 16px;
	color: var(--main-white);
}

section.page-archive.cases-archive .list-wrap .archive-filters-list .wpc-filters-section .wpc-filters-ul-list {
	padding: 0px;
	margin: 0px;
}

section.page-archive.cases-archive .list-wrap .archive-filters-list .wpc-filters-section .wpc-filters-ul-list li {
	margin-bottom: 12px;
	position: relative;
}

section.page-archive.cases-archive .list-wrap .archive-filters-list .wpc-filters-section .wpc-filters-ul-list li:last-child {
	margin-bottom: 0px;
}

section.page-archive.cases-archive .list-wrap .archive-filters-list .wpc-filters-section .wpc-filters-ul-list li input {
	position: absolute;
	top: 0px;
	left: 0px;
	width: 1px;
	height: 1px;
	overflow: hidden;
	user-select: none;
	pointer-events: none;
	opacity: 0;
	margin: 0px;
}

section.page-archive.cases-archive .list-wrap .archive-filters-list .wpc-filters-section .wpc-filters-ul-list li label {
	display: flex;
	align-items: center;
	padding: 0px;
}

section.page-archive.cases-archive .list-wrap .archive-filters-list .wpc-filters-section .wpc-filters-ul-list li label a {
	font-size: 1em;
	line-height: 120%;
	font-weight: 400;
	color: var(--main-white);
	margin-left: 10px;
}

section.page-archive.cases-archive .list-wrap .archive-filters-list .wpc-filters-section .wpc-filters-ul-list li label::before {
	content: '';
	border: 1px solid var(--main-gray);
	width: 16px;
	min-width: 16px;
	height: 16px;
	background-color: transparent;
	background-image: url(assets/img/filter-check-black.svg);
	background-position: center;
	background-repeat: no-repeat;
	background-size: 110% 110%;
	transition: 0.2s;
}

section.page-archive.cases-archive .list-wrap .archive-filters-list .wpc-filters-section .wpc-filters-ul-list li label:hover::before {
	background-color: var(--main-gray);
}

section.page-archive.cases-archive .list-wrap .archive-filters-list .wpc-filters-section .wpc-filters-ul-list li input:checked ~ label::before {
	border-color: var(--main-primary);
	background-color: var(--main-primary);
	background-image: url(assets/img/filter-check-white.svg);
}

section.page-archive.cases-archive .list-wrap .archive-filters-list .wpc-edit-filter-set {
	display: none;
}

section.page-archive.cases-archive .list-wrap .archive-cases-list {
	width: 75%;
	display: flex;
	flex-wrap: wrap;
}

section.page-archive.cases-archive .list-wrap .blog-item:nth-child(1n + 3) {
	margin-top: 40px;
}

@media screen and (max-width: 1299px) {
	section.page-archive.cases-archive .list-wrap .archive-filters-list {
		padding-left: 12px;
		padding-right: 12px;
	}
	
	section.page-archive.cases-archive .list-wrap .archive-filters-list .widget_wpc_filters_widget {
		top: 120px;
	}
	
	section.page-archive.cases-archive .list-wrap .archive-filters-list .wpc-filters-section {
		margin-bottom: 30px;
	}
	
	section.page-archive.cases-archive .list-wrap .blog-item:nth-child(1n + 3) {
		margin-top: 30px;
	}
}

@media screen and (max-width: 1199px) {
	section.page-archive.cases-archive .list-wrap .archive-filters-list .widget_wpc_filters_widget {
		top: 100px;
	}

	section.page-archive.cases-archive .list-wrap .archive-filters-list .wpc-filters-section {
		margin-bottom: 20px;
	}
	
	section.page-archive.cases-archive .list-wrap .blog-item:nth-child(1n + 3) {
		margin-top: 20px;
	}
}

@media screen and (max-width: 991px) {

}

@media screen and (max-width: 768px) {
	section.page-archive.cases-archive {
		position: initial;
	}

	section.page-archive.cases-archive .list-wrap .archive-filters-list .widget_wpc_filters_widget {
		position: initial;
	}

	section.page-archive.cases-archive .list-wrap .archive-filters-list .wpc-filters-main-wrap {
		position: initial;
	}

	section.page-archive.cases-archive .title-wrap {
		margin-bottom: 14px;
	}

	section.page-archive.cases-archive .list-wrap .archive-filters-list {
		width: 100%;
		margin-bottom: 26px;
	}

	section.page-archive.cases-archive .list-wrap .archive-filters-list .wpc-filters-open-button-container {
		display: flex!important;
		align-items: center;
		justify-content: flex-start;
		margin: 0px;
	}

	section.page-archive.cases-archive .list-wrap .archive-filters-list .wpc-filters-open-button-container a.wpc-filters-open-widget {
		border: 1px solid var(--main-white);
		color: var(--main-white);
		border-radius: 50px;
		padding: 8px 16px;
		font-size: 0.875em;
		display: flex;
		align-items: center;
		text-align: center;
		line-height: 150%;
		font-weight: 400;
		background-color: var(--main-bg-first);
		cursor: pointer;
		text-decoration: none;
		transition: var(--fast);
	}

	section.page-archive.cases-archive .list-wrap .archive-filters-list .wpc-filters-open-button-container a.wpc-filters-open-widget .wpc-icon-html-wrapper span {
		background-color: var(--main-white);
	}

	section.page-archive.cases-archive .list-wrap .archive-filters-list .wpc-filters-open-button-container a.wpc-filters-open-widget .wpc-icon-html-wrapper span::after {
		border-color: var(--main-white);
	}

	.wpc_show_bottom_widget section.page-archive.cases-archive .list-wrap .archive-filters-list .wpc-filters-widget-content {
		background-color: var(--main-bg-second);
		top: 30%;
	}

	.wpc_show_bottom_widget section.page-archive.cases-archive .list-wrap .archive-filters-list .wpc-filters-widget-content .wpc-widget-popup-title {
		color: var(--main-white);
		font-size: 1.125em;
	}

	.wpc_show_bottom_widget section.page-archive.cases-archive .list-wrap .archive-filters-list .wpc-filters-widget-top-container {
		border: none;
		height: 1px;
		background-color: transparent;
		border-bottom: 1px solid var(--main-gray);
	}

	.wpc_show_bottom_widget section.page-archive.cases-archive .list-wrap .archive-filters-list .wpc-filters-widget-top-container .wpc-widget-top-inside {
		display: none;
	}

	.wpc_show_bottom_widget section.page-archive.cases-archive .list-wrap .archive-filters-list .wpc-filters-scroll-container {
		background: var(--main-bg-second);
		min-height: calc(100% - 81px);
	}

	.wpc_show_bottom_widget section.page-archive.cases-archive .list-wrap .archive-filters-list .wpc-filters-widget-controls-container {
		background-color: var(--main-bg-second);
		border-top: 1px solid var(--main-gray);
	}

	.wpc_show_bottom_widget section.page-archive.cases-archive .list-wrap .archive-filters-list .wpc-filters-widget-controls-container a.wpc-filters-apply-button {
		border-color: var(--main-primary);
		background-color: var(--main-primary);
		color: var(--main-white);
	}

	.wpc_show_bottom_widget section.page-archive.cases-archive .list-wrap .archive-filters-list .wpc-filters-widget-controls-container a.wpc-filters-close-button {
		color: var(--main-white);
	}

	.wpc_show_bottom_widget section.page-archive.cases-archive .list-wrap .archive-filters-list .wpc-spinner::after {
		border-top-color: var(--main-primary);
	}

	section.page-archive.cases-archive .list-wrap .archive-filters-list .wpc-filters-section {
		margin-bottom: 25px;
	}

	section.page-archive.cases-archive .list-wrap .archive-cases-list {
		width: 100%;
	}

	section.page-archive.cases-archive .list-wrap .blog-item {
		width: 100%;
	}

	section.page-archive.cases-archive .list-wrap .blog-item:nth-child(1n + 2) {
		margin-top: 25px;
	}
}

@media screen and (max-width: 575px) {
	.wpc_show_bottom_widget section.page-archive.cases-archive .list-wrap .archive-filters-list .wpc-filters-widget-wrapper {
		padding: 15px;
	}

	.wpc_show_bottom_widget section.page-archive.cases-archive .list-wrap .archive-filters-list .wpc-widget-close-container .wpc-icon-html-wrapper {
		left: 15px;
	}

	.wpc_show_bottom_widget section.page-archive.cases-archive .list-wrap .archive-filters-list .wpc-filters-widget-controls-wrapper {
		padding: 15px 0px;
		margin-left: 15px;
		margin-right: 15px;
	}

	.wpc_show_bottom_widget section.page-archive.cases-archive .list-wrap .archive-filters-list .wpc-filters-scroll-container {
		min-height: calc(100% - 67px);
	}

	.wpc_show_bottom_widget section.page-archive.cases-archive .list-wrap .archive-filters-list .wpc-filters-widget-controls-item {
		width: 48%;
	}

	.wpc_show_bottom_widget section.page-archive.cases-archive .list-wrap .archive-filters-list .wpc-filters-widget-controls-container a {
		font-size: 0.875em;
	}
}

section.page-single.cases-single {
	position: relative;
}

section.page-single.cases-single .thumbnail {
	position: absolute;
	left: 0px;
	top: 0px;
	width: 100%;
	height: 100%;
	display: block;
	align-items: center;
	justify-content: center;
	user-select: none;
	pointer-events: none;
}

section.page-single.cases-single .thumbnail::after {
	content: '';
	background-color: #0000004D;
	position: absolute;
	z-index: 2;
	left: 0px;
	top: 0px;
	width: 100%;
	height: 100%;
}

section.page-single.cases-single .thumbnail img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

section.page-single.cases-single .title-wrap {
	margin: 0px;
	padding-bottom: 80px;
}

section.page-single.cases-single .breadcrumbs-wrap {
	margin-bottom: 120px;
}

section.page-single.cases-single .breadcrumbs-wrap ul.breadcrumbs li a {
	color: var(--main-white);
}

section.page-single.cases-single .breadcrumbs-wrap ul.breadcrumbs li:not(:last-child)::after {
	color: var(--main-white);
}

section.page-single.cases-single .title-wrap .meta-wrap {
	margin-bottom: 24px;
}

section.page-single.cases-single .title-wrap .meta-wrap .tag:hover {
	cursor: auto;
	border-color: var(--main-white);
	background-color: var(--main-bg-first);
	color: var(--main-white);
}

section.page-single.cases-single .title-wrap h1 {
	margin: 0px;
	font-weight: 700;
}

section.page-single.cases-single .title-wrap p.text {
	font-size: 1.25em;
	line-height: 120%;
	font-weight: 400;
	color: var(--main-white);
	margin: 0px;
	margin-top: 32px;
}

section.page-single.cases-content {
	margin-top: -80px;
	border-radius: 70px 70px 0px 0px;
	padding-top: 80px;
}

section.page-single.cases-content .content-side {
	display: flex;
	margin: 0px -15px;
	margin-bottom: 80px;
}

section.page-single.cases-content .content-side .page-content {
	width: 50%;
	padding: 0px 15px;
}

section.page-single.cases-content .content-side .thumbnail-side {
	width: 50%;
	padding: 0px 15px;
}

section.page-single.cases-content .content-side .thumbnail-side .img-wrap {
	width: 100%;
	padding-top: 130%;
	position: relative;
}

section.page-single.cases-content .content-side .thumbnail-side .img-wrap img {
	position: absolute;
	left: 0px;
	top: 0px;
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 40px;
}

section.page-single.cases-content .content-gallery {
	display: flex;
	align-items: flex-start;
	margin: 80px 0px;
}

section.page-single.cases-content .content-gallery .main-content-gallery {
	width: 80%;
	padding-right: 10px;
	position: relative;
}

section.page-single.cases-content .content-gallery .main-content-gallery .slick-arrow {
	position: absolute;
	z-index: 2;
	top: 50%;
	transform: translateY(-50%);
	width: 60px;
	height: 60px;
	background-color: var(--main-primary);
	border-radius: 100%;
	background-size: 40% 40%;
	background-position: center;
	background-repeat: no-repeat;
	font-size: 0px;
	color: transparent;
	border: none;
	box-shadow: none;
}

section.page-single.cases-content .content-gallery .main-content-gallery .slick-arrow.slick-prev {
	left: 80px;
	background-image: url(assets/img/arrow-left-white.svg);
}

section.page-single.cases-content .content-gallery .main-content-gallery .slick-arrow.slick-next {
	right: 80px;
	background-image: url(assets/img/arrow-right-white.svg);
}

section.page-single.cases-content .content-gallery .main-content-gallery .img-wrap {
	width: 100%;
	padding-top: 65%;
	position: relative;
}

section.page-single.cases-content .content-gallery .main-content-gallery .img-wrap img {
	position: absolute;
	left: 0px;
	top: 0px;
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 40px;
}

section.page-single.cases-content .content-gallery .main-content-gallery .slick-track .slick-slide > div {
	display: flex;
}

section.page-single.cases-content .content-gallery .side-content-gallery {
	width: 20%;
	padding-left: 10px;
}

section.page-single.cases-content .content-gallery .side-content-gallery .img-wrap {
	width: 100%;
	padding-top: 65%;
	position: relative;
	margin-bottom: 6px;
}

section.page-single.cases-content .content-gallery .side-content-gallery .img-wrap img {
	position: absolute;
	left: 0px;
	top: 0px;
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 20px;
}

section.page-single.cases-content .content-gallery .side-content-gallery .slick-track .slick-slide {
	border: none;
}

section.page-single.cases-content .content-gallery .side-content-gallery .slick-track .slick-slide > div {
	display: flex;
}

section.page-single.cases-content .content-video {
	width: 100%;
	margin: 80px 0px;
}

section.page-single.cases-content .content-video .video-wrap {
	width: 100%;
	padding-top: 45%;
	position: relative;
	background-color: var(--main-gray);
	border-radius: 40px;
	overflow: hidden;
}

section.page-single.cases-content .content-video .video-wrap video {
	position: absolute;
	left: 0px;
	top: 0px;
	width: 100%;
	height: 100%;
}

section.page-single.cases-content .content-desc {
	margin: 80px 0px;
}

section.page-single.cases-content .content-desc .content-text {
	margin: 0px -15px;
	margin-top: 20px;
	display: flex;
}

section.page-single.cases-content .content-desc .content-text .page-content {
	width: calc(100% / 2);
	padding: 0px 15px;
}

section.page-single.cases-content .content-addon {
	margin: 80px 0px;
}

section.page-single.cases-content .content-addon .addon-gallery {
	margin-top: 20px;
	display: flex;
	flex-direction: column;
}

section.page-single.cases-content .content-addon .addon-gallery .slick-arrow {
	position: absolute;
	z-index: 2;
	top: 50%;
	transform: translateY(-50%);
	width: 60px;
	height: 60px;
	background-color: var(--main-primary);
	border-radius: 100%;
	background-size: 40% 40%;
	background-position: center;
	background-repeat: no-repeat;
	font-size: 0px;
	color: transparent;
	border: none;
	box-shadow: none;
}

section.page-single.cases-content .content-addon .addon-gallery .slick-arrow.slick-prev {
	left: 80px;
	background-image: url(assets/img/arrow-left-white.svg);
}

section.page-single.cases-content .content-addon .addon-gallery .slick-arrow.slick-next {
	right: 80px;
	background-image: url(assets/img/arrow-right-white.svg);
}

section.page-single.cases-content .content-addon .addon-gallery .img-wrap {
	width: 100%;
	padding-top: 65%;
	position: relative;
	background-color: var(--main-gray);
	border-radius: 40px;
	overflow: hidden;
}

section.page-single.cases-content .content-addon .addon-gallery .img-wrap img {
	position: absolute;
	left: 0px;
	top: 0px;
	width: 100%;
	height: 100%;
	object-fit: cover;

}

section.page-single.cases-content .content-addon .addon-gallery .slick-track .slick-slide > div {
	display: flex;
}

section .consult-order {
	margin-top: 80px;
	background-color: var(--main-primary);
	border-radius: 70px;
	padding: 80px 0px;
}

section .consult-order .consult-order-wrap {
	display: flex;
}

section .consult-order .consult-order-wrap p.h2 {
	font-size: 3em;
	line-height: 120%;
	font-weight: 400;
	color: var(--main-white);
	margin: 0px;
	width: calc(100% / 2);
	padding-right: 15px;
}

section .consult-order .consult-order-wrap .form-wrap {
	width: calc(100% / 2);
	padding-left: 15px;
}

section .consult-order .consult-order-wrap .form-wrap .wpcf7 {
	width: 65%;
	margin: 0px auto;
}

section .consult-order .consult-order-wrap .form-wrap form.wpcf7-form p input[type="submit"] {
	background-color: var(--main-black);
}

section .consult-order .consult-order-wrap .form-wrap form.wpcf7-form p .wpcf7-not-valid-tip {
	color: var(--main-white);
}

section .consult-order .consult-order-wrap .form-wrap form.wpcf7-form .wpcf7-response-output {
	border-color: var(--main-white)!important;
}

.slick-slider ul.slick-dots {
	padding: 8px 5px;
	margin: 40px auto 0px;
	display: flex;
	align-items: center;
	justify-content: center;
	list-style: none;
	border-radius: 50px;
	background-color: var(--main-bg-second);
}

.slick-slider ul.slick-dots li {
	display: flex;
	margin: 0px 3px;
}

.slick-slider ul.slick-dots li button {
	width: 10px;
	min-width: 10px;
	height: 10px;
	border-radius: 100px;
	background-color: var(--main-gray);
	font-size: 0px;
	color: transparent;
	border: none;
}

.slick-slider ul.slick-dots li.slick-active button {
	background-color: var(--main-black);
}

@media screen and (max-width: 1299px) {
	section.page-single.cases-single .breadcrumbs-wrap {
		margin-bottom: 90px;
	}

	section.page-single.cases-single .title-wrap {
		padding-bottom: 60px;
	}

	section.page-single.cases-single .title-wrap .meta-wrap {
		margin-bottom: 18px;
	}

	section.page-single.cases-single .title-wrap p.text {
		font-size: 1.125em;
		margin-top: 24px;
	}

	section.page-single.cases-content {
		margin-top: -60px;
		border-radius: 50px 50px 0px 0px;
		padding-top: 60px;
	}

	section.page-single.cases-content .content-side {
		margin-bottom: 60px;
	}

	section.page-single.cases-content .content-side .thumbnail-side .img-wrap img {
		border-radius: 30px;
	}

	section.page-single.cases-content .content-gallery {
		margin: 60px 0px;
	}

	section.page-single.cases-content .content-gallery .main-content-gallery .img-wrap img {
		border-radius: 30px;
	}

	section.page-single.cases-content .content-gallery .main-content-gallery .slick-arrow.slick-prev {
		left: 60px;
	}
	
	section.page-single.cases-content .content-gallery .main-content-gallery .slick-arrow.slick-next {
		right: 60px;
	}

	section.page-single.cases-content .content-video {
		margin: 60px 0px;
	}

	section.page-single.cases-content .content-video .video-wrap {
		border-radius: 30px;
	}

	section.page-single.cases-content .content-desc {
		margin: 60px 0px;
	}

	section.page-single.cases-content .content-addon {
		margin: 60px 0px;
	}

	section.page-single.cases-content .content-addon .addon-gallery .img-wrap {
		border-radius: 30px;
	}

	section.page-single.cases-content .content-addon .addon-gallery .slick-arrow.slick-prev {
		left: 60px;
	}
	
	section.page-single.cases-content .content-addon .addon-gallery .slick-arrow.slick-next {
		right: 60px;
	}

	.slick-slider ul.slick-dots {
		margin: 30px auto 0px;
	}

	section .consult-order {
		margin-top: 60px;
		padding: 60px 0px;
		border-radius: 50px;
	}

	section .consult-order .consult-order-wrap p.h2 {
		font-size: 2.25em;
	}
}

@media screen and (max-width: 1199px) {
	section.page-single.cases-single .breadcrumbs-wrap {
		margin-bottom: 75px;
	}

	section.page-single.cases-single .title-wrap {
		padding-bottom: 40px;
	}

	section.page-single.cases-single .title-wrap p.text {
		margin-top: 24px;
	}

	section.page-single.cases-content {
		margin-top: -40px;
		border-radius: 34px 34px 0px 0px;
		padding-top: 40px;
	}

	section.page-single.cases-content .content-side {
		margin-bottom: 40px;
	}

	section.page-single.cases-content .content-side .thumbnail-side .img-wrap img {
		border-radius: 20px;
	}

	section.page-single.cases-content .content-gallery {
		margin: 40px 0px;
	}

	section.page-single.cases-content .content-gallery .main-content-gallery .img-wrap img {
		border-radius: 20px;
	}

	section.page-single.cases-content .content-gallery .main-content-gallery .slick-arrow.slick-prev {
		left: 40px;
	}
	
	section.page-single.cases-content .content-gallery .main-content-gallery .slick-arrow.slick-next {
		right: 40px;
	}

	section.page-single.cases-content .content-video {
		margin: 40px 0px;
	}

	section.page-single.cases-content .content-video .video-wrap {
		border-radius: 20px;
	}

	section.page-single.cases-content .content-desc {
		margin: 40px 0px;
	}

	section.page-single.cases-content .content-addon {
		margin: 40px 0px;
	}

	section.page-single.cases-content .content-addon .addon-gallery .img-wrap {
		border-radius: 20px;
	}

	section.page-single.cases-content .content-addon .addon-gallery .slick-arrow.slick-prev {
		left: 40px;
	}
	
	section.page-single.cases-content .content-addon .addon-gallery .slick-arrow.slick-next {
		right: 40px;
	}

	.slick-slider ul.slick-dots {
		margin: 20px auto 0px;
	}

	section .consult-order {
		margin-top: 40px;
		padding: 40px 0px;
		border-radius: 34px;
	}

	section .consult-order .consult-order-wrap p.h2 {
		font-size: 1.75em;
	}
}

@media screen and (max-width: 991px) {
	section.page-single.cases-single .breadcrumbs-wrap {
		margin-bottom: 50px;
	}

	section.page-single.cases-single .title-wrap {
		padding-bottom: 30px;
	}

	section.page-single.cases-single .title-wrap p.text {
		font-size: 1em;
		margin-top: 16px;
	}

	section.page-single.cases-content {
		border-radius: 25px 25px 0px 0px;
		margin-top: -30px;
		padding-top: 30px;
	}

	section.page-single.cases-content .content-side {
		margin: 0px;
		margin-bottom: 30px;
		flex-direction: column;
	}

	section.page-single.cases-content .content-side .page-content {
		width: 100%;
		padding: 0px;
		margin-bottom: 20px;
	}

	section.page-single.cases-content .content-side .thumbnail-side {
		width: 100%;
		padding: 0px;
	}

	section.page-single.cases-content .content-side .thumbnail-side .img-wrap {
		padding-top: 60%;
	}
	
	section.page-single.cases-content .content-side .thumbnail-side .img-wrap img {
		border-radius: 15px;
	}

	section.page-single.cases-content .content-gallery {
		margin: 30px 0px;
	}

	section.page-single.cases-content .content-gallery .main-content-gallery {
		width: 100%;
		padding-right: 0px;
	}

	section.page-single.cases-content .content-gallery .main-content-gallery .img-wrap {
		padding-top: 60%;
	}

	section.page-single.cases-content .content-gallery .main-content-gallery .img-wrap img {
		border-radius: 15px;
	}

	section.page-single.cases-content .content-gallery .main-content-gallery .slick-arrow.slick-prev {
		left: 30px;
	}
	
	section.page-single.cases-content .content-gallery .main-content-gallery .slick-arrow.slick-next {
		right: 30px;
	}

	section.page-single.cases-content .content-gallery .side-content-gallery {
		display: none;
	}

	section.page-single.cases-content .content-video {
		margin: 30px 0px;
	}

	section.page-single.cases-content .content-video .video-wrap {
		border-radius: 15px;
	}

	section.page-single.cases-content .content-desc {
		margin: 30px 0px;
	}

	section.page-single.cases-content .content-desc .content-text {
		flex-wrap: wrap;
	}

	section.page-single.cases-content .content-desc .content-text .page-content {
		width: 100%;
	}

	section.page-single.cases-content .content-desc .content-text .page-content:nth-child(1n + 2) {
		margin-top: 20px;
	}

	section.page-single.cases-content .content-addon {
		margin: 30px 0px;
	}

	section.page-single.cases-content .content-addon .addon-gallery .img-wrap {
		border-radius: 15px;
		padding-top: 60%;
	}

	section.page-single.cases-content .content-addon .addon-gallery .slick-arrow.slick-prev {
		left: 30px;
	}
	
	section.page-single.cases-content .content-addon .addon-gallery .slick-arrow.slick-next {
		right: 30px;
	}

	section .consult-order {
		margin-top: 30px;
		padding: 30px 0px;
		border-radius: 25px;
	}

	section .consult-order .consult-order-wrap {
		flex-direction: column;
	}

	section .consult-order .consult-order-wrap p.h2 {
		width: 100%;
		padding: 0px;
		margin-bottom: 20px;
		font-size: 1.5em;
	}

	section .consult-order .consult-order-wrap .form-wrap {
		width: 100%;
		padding: 0px;
	}

	section .consult-order .consult-order-wrap .form-wrap .wpcf7 {
		width: 100%;
	}
}

@media screen and (max-width: 767px) {
	section.page-single.cases-single .title-wrap p.text {
		margin-top: 12px;
	}

	section.page-single.cases-content {
		border-radius: 20px 20px 0px 0px;
		margin-top: -20px;
	}

	section.page-single.cases-content .content-gallery .main-content-gallery .slick-arrow {
		width: 40px;
		height: 40px;
		background-size: 50% 50%;
	}

	section.page-single.cases-content .content-gallery .main-content-gallery .slick-arrow.slick-prev {
		left: 20px;
	}

	section.page-single.cases-content .content-gallery .main-content-gallery .slick-arrow.slick-next {
		right: 20px;
	}

	section.page-single.cases-content .content-addon .addon-gallery .slick-arrow {
		width: 40px;
		height: 40px;
		background-size: 50% 50%;
	}

	section.page-single.cases-content .content-addon .addon-gallery .slick-arrow.slick-prev {
		left: 20px;
	}

	section.page-single.cases-content .content-addon .addon-gallery .slick-arrow.slick-next {
		right: 20px;
	}

	section.page-single.cases-content .content-video .video-wrap {
		padding-top: 56.25%;
	}

	section .consult-order {
		border-radius: 20px;
	}

	section .consult-order .consult-order-wrap p.h2 {
		font-size: 1.375em;
	}
}

@media screen and (max-width: 575px) {
	section.page-single.cases-content .content-gallery .main-content-gallery {
		display: flex;
		flex-direction: column;
		margin-bottom: 46px;
	}

	section.page-single.cases-content .content-addon .addon-gallery {
		margin-bottom: 76px;
	}

	.slick-slider ul.slick-dots {
		position: absolute;
		bottom: -46px;
		left: 50%;
		transform: translateX(-50%);
	}
}

section.page-archive.services-archive .thumbnail {
	position: absolute;
	left: 0px;
	top: 0px;
	width: 100%;
	height: 100%;
	display: block;
	align-items: center;
	justify-content: center;
	user-select: none;
	pointer-events: none;
}

section.page-archive.services-archive .thumbnail::after {
	content: '';
	background-color: #0000004D;
	position: absolute;
	z-index: 2;
	left: 0px;
	top: 0px;
	width: 100%;
	height: 100%;
}

section.page-archive.services-archive .thumbnail img {
	width: 100%;
  height: 100%;
  object-fit: cover;
}

section.page-archive.services-archive .title-wrap {
	margin: 0px;
	padding-bottom: 80px;
}

section.page-archive.services-archive .breadcrumbs-wrap {
	margin-bottom: 120px;
}

section.page-archive.services-archive .breadcrumbs-wrap ul.breadcrumbs li a {
	color: var(--main-white);
}

section.page-archive.services-archive .breadcrumbs-wrap ul.breadcrumbs li:not(:last-child)::after {
	color: var(--main-white);
}

section.page-archive.services-list {
	margin-top: -80px;
	border-radius: 70px 70px 0px 0px;
	padding-top: 80px;
	padding-bottom: 40px;
}

section.page-archive.services-list .archive-services-list {
	width: 100%;
	display: flex;
	flex-direction: column;
}

section.page-archive.services-list .archive-services-list .blog-item.services-archive-item {
	width: 100%;
}

section.page-archive.services-list .archive-services-list .blog-item.services-archive-item:nth-child(1n + 2) {
	margin-top: 32px;
}

section.page-archive.services-list .archive-services-list .blog-item.services-archive-item .item-link {
	position: relative;
}

section.page-archive.services-list .archive-services-list .blog-item.services-archive-item .item-link .thumbnail {
	position: absolute;
	z-index: 1;
	left: 0px;
	top: 0px;
	width: 100%;
	height: 100%;
	padding: 0px;
}

section.page-archive.services-list .archive-services-list .blog-item.services-archive-item .item-link .caption {
	position: relative;
	z-index: 2;
	background-color: var(--main-bg-item);
	padding: 80px;
}

section.page-archive.services-list .archive-services-list .blog-item.services-archive-item .item-link .caption .caption-wrap {
	width: calc(100% / 2);
	background-color: var(--main-bg-second);
	border-radius: 40px;
	padding: 40px;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
}

section.page-archive.services-list .archive-services-list .blog-item.services-archive-item:nth-child(2n + 2) .item-link .caption .caption-wrap {
	margin-left: auto;
}

section.page-archive.services-list .archive-services-list .blog-item.services-archive-item .item-link .caption .caption-wrap p.uppertitle {
	font-size: 1em;
	line-height: 120%;
	font-weight: 400;
	color: var(--main-white);
	display: flex;
	align-items: center;
	margin-bottom: 20px;
}

section.page-archive.services-list .archive-services-list .blog-item.services-archive-item .item-link .caption .caption-wrap p.uppertitle::before {
	content: '/';
	font-size: 1em;
	line-height: 120%;
	font-weight: 400;
	color: var(--main-primary);
	margin-right: 8px;
}

section.page-archive.services-list .archive-services-list .blog-item.services-archive-item .item-link .caption .caption-wrap p.h2 {
	font-size: 3em;
	line-height: 120%;
	font-weight: 500;
	color: var(--main-white);
	margin-bottom: 20px;
}

section.page-archive.services-list .archive-services-list .blog-item.services-archive-item .item-link .caption .caption-wrap p.text {
	font-size: 1em;
	line-height: 120%;
	font-weight: 400;
	color: var(--main-white);
	margin-bottom: 32px;
}

section.page-archive.services-list .archive-services-list .blog-item.services-archive-item .item-link .caption .caption-wrap p.undertitle {
	font-size: 2.5em;
	line-height: 120%;
	font-weight: 400;
	color: var(--main-white);
	margin-bottom: 32px;
}

@media screen and (max-width: 1299px) {
	section.page-archive.services-archive .title-wrap {
		padding-bottom: 60px;
	}
	
	section.page-archive.services-archive .breadcrumbs-wrap {
		margin-bottom: 90px;
	}
	
	section.page-archive.services-list {
		margin-top: -60px;
		border-radius: 50px 50px 0px 0px;
		padding-top: 60px;
	}

	section.page-archive.services-list .archive-services-list .blog-item.services-archive-item:nth-child(1n + 2) {
		margin-top: 24px;
	}
	
	section.page-archive.services-list .archive-services-list .blog-item.services-archive-item .item-link .caption {
		padding: 60px;
	}
	
	section.page-archive.services-list .archive-services-list .blog-item.services-archive-item .item-link .caption .caption-wrap {
		border-radius: 30px;
		padding: 30px;
		width: 60%;
	}
	
	section.page-archive.services-list .archive-services-list .blog-item.services-archive-item .item-link .caption .caption-wrap p.uppertitle {
		margin-bottom: 16px;
	}
	
	section.page-archive.services-list .archive-services-list .blog-item.services-archive-item .item-link .caption .caption-wrap p.h2 {
		font-size: 2.25em;
		margin-bottom: 16px;
	}
	
	section.page-archive.services-list .archive-services-list .blog-item.services-archive-item .item-link .caption .caption-wrap p.text {
		margin-bottom: 24px;
	}
	
	section.page-archive.services-list .archive-services-list .blog-item.services-archive-item .item-link .caption .caption-wrap p.undertitle {
		font-size: 1.75em;
		margin-bottom: 24px;
	}
}

@media screen and (max-width: 1199px) {
	section.page-archive.services-archive .title-wrap {
		padding-bottom: 40px;
	}

	section.page-archive.services-archive .breadcrumbs-wrap {
		margin-bottom: 75px;
	}

	section.page-archive.services-list {
		margin-top: -40px;
		border-radius: 34px 34px 0px 0px;
		padding-top: 40px;
	}

	section.page-archive.services-list .archive-services-list .blog-item.services-archive-item:nth-child(1n + 2) {
		margin-top: 16px;
	}

	section.page-archive.services-list .archive-services-list .blog-item.services-archive-item .item-link .caption {
		padding: 40px;
	}

	section.page-archive.services-list .archive-services-list .blog-item.services-archive-item .item-link .caption .caption-wrap {
		border-radius: 20px;
		padding: 20px;
		width: 70%;
	}

	section.page-archive.services-list .archive-services-list .blog-item.services-archive-item .item-link .caption .caption-wrap p.uppertitle {
		margin-bottom: 12px;
	}

	section.page-archive.services-list .archive-services-list .blog-item.services-archive-item .item-link .caption .caption-wrap p.h2 {
		font-size: 2em;
		margin-bottom: 12px;
	}

	section.page-archive.services-list .archive-services-list .blog-item.services-archive-item .item-link .caption .caption-wrap p.text {
		margin-bottom: 16px;
	}
	
	section.page-archive.services-list .archive-services-list .blog-item.services-archive-item .item-link .caption .caption-wrap p.undertitle {
		font-size: 1.375em;
		margin-bottom: 16px;
	}
}

@media screen and (max-width: 991px) {
	section.page-archive.services-archive .title-wrap {
		padding-bottom: 30px;
	}

	section.page-archive.services-archive .breadcrumbs-wrap {
		margin-bottom: 50px;
	}

	section.page-archive.services-list {
		margin-top: -30px;
		border-radius: 25px 25px 0px 0px;
		padding-top: 30px;
		padding-bottom: 30px;
	}

	section.page-archive.services-list .archive-services-list .blog-item.services-archive-item .item-link {
		border-radius: 25px;
		display: block;
		width: 100%;
		height: auto;
	}

	section.page-archive.services-list .archive-services-list .blog-item.services-archive-item .item-link .thumbnail {
		position: relative;
		height: 320px;
		margin-bottom: -30px;
	}

	section.page-archive.services-list .archive-services-list .blog-item.services-archive-item .item-link .caption {
		padding: 0px;
	}

	section.page-archive.services-list .archive-services-list .blog-item.services-archive-item .item-link .caption .caption-wrap {
		border-radius: 25px 25px 0px 0px;
		padding: 30px;
		width: 100%;
	}

	section.page-archive.services-list .archive-services-list .blog-item.services-archive-item .item-link .caption .caption-wrap p.h2 {
		font-size: 1.875em;
	}

	section.page-archive.services-list .archive-services-list .blog-item.services-archive-item .item-link .caption .caption-wrap p.undertitle {
		font-size: 1.25em;
	}
}

@media screen and (max-width: 767px) {
	section.page-archive.services-list {
		border-radius: 20px 20px 0px 0px;
		margin-top: -20px;
		padding-bottom: 20px;
	}

	section.page-archive.services-list .archive-services-list .blog-item.services-archive-item .item-link .thumbnail {
		height: 260px;
	}

	section.page-archive.services-list .archive-services-list .blog-item.services-archive-item .item-link .caption .caption-wrap {
		border-radius: 20px 20px 0px 0px;
		padding: 30px 20px;
	}

	section.page-archive.services-list .archive-services-list .blog-item.services-archive-item .item-link .caption .caption-wrap p.h2 {
		font-size: 1.75em;
	}

	section.page-archive.services-list .archive-services-list .blog-item.services-archive-item .item-link .caption .caption-wrap p.undertitle {
		font-size: 1.125em;
	}
}

@media screen and (max-width: 575px) {
	section.page-archive.services-list .archive-services-list .blog-item.services-archive-item .item-link .thumbnail {
		height: 200px;
	}

	section.page-archive.services-list .archive-services-list .blog-item.services-archive-item .item-link .caption .caption-wrap p.h2 {
		font-size: 1.5em;
	}
}

section.page-single.cases-content.services-content {
	padding-bottom: 40px;
}

section.page-single.cases-content.services-content .content-desc:first-child {
	margin-top: 0px;
}

section.page-single.cases-content .content-cases {
	margin: 80px 0px;
}

section.page-single.cases-content .content-cases .cases-list {
	display: flex;
	flex-wrap: wrap;
	margin: 0px -15px;
	margin-top: 20px;
}

section.page-single.cases-content .content-cases .cases-list .cases-item {
	width: calc(100% / 2);
	padding: 0px 15px;
}

section.page-single.cases-content .content-cases .cases-list .cases-item:nth-child(1n + 3) {
	margin-top: 30px;
}

section.page-single.cases-content .content-cases .cases-list .cases-item .item-link {
	border-radius: 40px;
	border: 1px solid var(--main-white);
	display: flex;
	text-decoration: none;
}

section.page-single.cases-content .content-cases .cases-list .cases-item .item-link .thumbnail {
	border-radius: 40px;
	width: 45%;
	overflow: hidden;
	margin: -1px 0px -1px -2px;
}

section.page-single.cases-content .content-cases .cases-list .cases-item .item-link .thumbnail .img-wrap {
	width: 100%;
	padding-top: 115%;
	position: relative;
}

section.page-single.cases-content .content-cases .cases-list .cases-item .item-link .thumbnail .img-wrap img {
	position: absolute;
	left: 0px;
	top: 0px;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

section.page-single.cases-content .content-cases .cases-list .cases-item .item-link .caption {
	width: 55%;
	padding: 22px 22px 30px 30px;
	display: flex;
	flex-direction: column;
	position: relative;
}

section.page-single.cases-content .content-cases .cases-list .cases-item .item-link .caption::before {
	position: absolute;
	content: '';
	top: 16px;
	right: 16px;
	width: 60px;
	height: 60px;
	border-radius: 100%;
	background-position: center;
	background-repeat: no-repeat;
	background-size: 24px 24px;
	background-image: url(assets/img/button-icon.svg);
	background-color: var(--main-primary);
}

section.page-single.cases-content .content-cases .cases-list .cases-item .item-link .caption p.h2 {
	font-size: 1.75em;
	line-height: 120%;
	font-weight: 500;
	color: var(--main-white);
	margin: auto 0px 0px;
}

section.page-single.cases-content .content-solutions {
	position: relative;
	border-radius: 70px;
	overflow: hidden;
	margin: 80px 0px;
}

section.page-single.cases-content .content-solutions .thumbnail {
	position: absolute;
	z-index: 1;
	left: 0px;
	top: 0px;
	width: 100%;
	height: 100%;
}

section.page-single.cases-content .content-solutions .thumbnail img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

section.page-single.cases-content .content-solutions .caption {
	position: relative;
	z-index: 2;
	padding: 80px 0px;
	background-color: var(--main-bg-item);
}

section.page-single.cases-content .content-solutions .caption .caption-wrap {
	display: flex;
	flex-wrap: wrap;
	background-color: var(--main-bg-second);
	border-radius: 40px;
	padding: 40px 25px;
}

section.page-single.cases-content .content-solutions .caption .caption-wrap .page-content {
	width: calc(100% / 3);
	padding: 0px 15px;
}

section.page-single.cases-content .content-solutions .caption .caption-wrap .page-content:first-child {
	width: 100%;
}

section.page-single.cases-content .content-solutions .caption .caption-wrap .page-content:nth-child(1n + 2) {
	margin-top: 30px;
}

@media screen and (max-width: 1299px) {
	section.page-single.cases-content .content-cases {
		margin: 60px 0px;
	}
	
	section.page-single.cases-content .content-cases .cases-list .cases-item .item-link {
		border-radius: 30px;
	}
	
	section.page-single.cases-content .content-cases .cases-list .cases-item .item-link .thumbnail {
		border-radius: 30px;
	}
	
	section.page-single.cases-content .content-cases .cases-list .cases-item .item-link .caption {
		padding: 22px 22px 30px 30px;
	}
	
	section.page-single.cases-content .content-cases .cases-list .cases-item .item-link .caption::before {
		width: 45px;
		height: 45px;
		background-size: 18px 18px;
	}
	
	section.page-single.cases-content .content-cases .cases-list .cases-item .item-link .caption p.h2 {
		font-size: 1.5em;
	}
	
	section.page-single.cases-content .content-solutions {
		border-radius: 50px;
		margin: 60px 0px;
	}
	
	section.page-single.cases-content .content-solutions .caption {
		padding: 60px 0px;
	}
	
	section.page-single.cases-content .content-solutions .caption .caption-wrap {
		border-radius: 30px;
		padding: 30px 15px;
	}
}

@media screen and (max-width: 1199px) {
	section.page-single.cases-content .content-cases {
		margin: 40px 0px;
	}
	
	section.page-single.cases-content .content-cases .cases-list .cases-item .item-link {
		border-radius: 20px;
	}
	
	section.page-single.cases-content .content-cases .cases-list .cases-item .item-link .thumbnail {
		border-radius: 20px;
	}
	
	section.page-single.cases-content .content-cases .cases-list .cases-item .item-link .caption {
		padding: 15px 15px 20px 20px;
	}
	
	section.page-single.cases-content .content-cases .cases-list .cases-item .item-link .caption::before {
		background-size: 16px 16px;
	}
	
	section.page-single.cases-content .content-cases .cases-list .cases-item .item-link .caption p.h2 {
		font-size: 1.375em;
	}
	
	section.page-single.cases-content .content-solutions {
		border-radius: 34px;
		margin: 40px 0px;
	}
	
	section.page-single.cases-content .content-solutions .caption {
		padding: 40px 0px;
	}
	
	section.page-single.cases-content .content-solutions .caption .caption-wrap {
		border-radius: 20px;
		padding: 20px 5px;
	}
	
	section.page-single.cases-content .content-solutions .caption .caption-wrap .page-content:nth-child(1n + 2) {
		margin-top: 24px;
	}
}

@media screen and (max-width: 991px) {
	section.page-single.cases-content.services-content {
		padding-bottom: 30px;
	}
	
	section.page-single.cases-content .content-cases {
		margin: 30px 0px;
	}
	
	section.page-single.cases-content .content-cases .cases-list {
		margin-top: 16px;
	}
	
	section.page-single.cases-content .content-cases .cases-list .cases-item {
		width: 100%;
	}
	
	section.page-single.cases-content .content-cases .cases-list .cases-item:nth-child(1n + 2) {
		margin-top: 20px;
	}
	
	section.page-single.cases-content .content-cases .cases-list .cases-item .item-link {
		border-radius: 15px;
	}
	
	section.page-single.cases-content .content-cases .cases-list .cases-item .item-link .thumbnail {
		border-radius: 15px;
	}

	section.page-single.cases-content .content-cases .cases-list .cases-item .item-link .thumbnail .img-wrap {
		padding-top: 80%;
	}
	
	section.page-single.cases-content .content-solutions {
		border-radius: 25px;
		margin: 30px 0px;
	}

	section.page-single.cases-content .content-solutions .thumbnail {
		position: relative;
		height: 320px;
		margin-bottom: -30px;
	}
	
	section.page-single.cases-content .content-solutions .caption {
		border-radius: 25px;
		padding: 30px 0px;
		background-color: var(--main-bg-second);
	}
	
	section.page-single.cases-content .content-solutions .caption .caption-wrap {
		border-radius: 0px;
		padding: 0px;
		margin: 0px -15px;
	}
	
	section.page-single.cases-content .content-solutions .caption .caption-wrap .page-content {
		width: 100%;
	}
	
	section.page-single.cases-content .content-solutions .caption .caption-wrap .page-content:nth-child(1n + 2) {
		margin-top: 24px;
	}

	section.page-single.cases-content .content-side .thumbnail-side + .page-content {
		margin-top: 20px;
		margin-bottom: 0px;
	}
}

@media screen and (max-width: 767px) {
	section.page-single.cases-content.services-content {
		padding-bottom: 20px;
	}

	section.page-single.cases-content .content-cases .cases-list .cases-item .item-link {
		flex-direction: column;
		position: relative;
	}

	section.page-single.cases-content .content-cases .cases-list .cases-item .item-link .thumbnail {
		width: calc(100% + 2px);
		margin: -2px -1px 0px -1px;
	}

	section.page-single.cases-content .content-cases .cases-list .cases-item .item-link .thumbnail .img-wrap {
		padding-top: 50%;
	}

	section.page-single.cases-content .content-cases .cases-list .cases-item .item-link .caption {
		width: 100%;
		padding: 15px;
		position: initial;
	}

	section.page-single.cases-content .content-cases .cases-list .cases-item .item-link .caption p.h2 {
		font-size: 1.25em;
	}

	section.page-single.cases-content .content-solutions .thumbnail {
		height: 260px;
	}
}

@media screen and (max-width: 575px) {
	section.page-single.cases-content .content-solutions .thumbnail {
		height: 200px;
	}

	section.page-single.cases-content.services-content .content-cases .cases-list {
		margin-bottom: 76px;
	}
}

.page-content h2 {
  font-size: 2em;
	line-height: 120%;
	font-weight: 500;
  color: var(--main-white);
  margin-bottom: 20px;
}

.page-content h2 a {
  color: var(--main-white);
}

.page-content h3 {
  font-size: 1.5em;
	line-height: 120%;
	font-weight: 500;
  color: var(--main-white);
  margin-bottom: 18px;
}

.page-content h3 a {
  color: var(--main-white);
}

.page-content ul {
	list-style-type: square;
}

.page-content ul,
.page-content ol {
	margin-bottom: 24px;
	padding-left: 20px;
}

.page-content ul li,
.page-content ol li {
  font-size: 1.25em;
  line-height: 150%;
	font-weight: 400;
  margin-bottom: 8px;
  color: var(--main-white);
}

.page-content p {
  font-size: 1.25em;
  line-height: 150%;
	font-weight: 400;
  color: var(--main-white);
  word-break: break-word;
	margin-bottom: 24px;
}

.page-content a {
  text-decoration: underline;
  color: var(--main-white);
}

.page-content p:has(.alignright) {
  clear: both;
  margin-bottom: 0px;
}

.page-content p img {
  width: 100%;
	border-radius: 16px;
	overflow: hidden;
}

.page-content p img.alignright {
  float: right;
  width: 50%;
  margin-left: 20px;
  margin-bottom: 24px;
}

.page-content p:has(.alignleft) {
  clear: both;
  margin-bottom: 0px;
}

.page-content p img.alignleft {
  float: left;
  width: 50%;
  margin-right: 20px;
  margin-bottom: 24px;
}

.page-content p:has(.aligncenter) {
  clear: both;
}

.page-content p img.aligncenter {
  width: 80%;
  display: block;
  margin-left: auto;
  margin-right: auto;
}

.page-content p:has(iframe),
.page-content .sketchfab-embed-wrapper {
  clear: both;
  padding-top: 56.25%;
  position: relative;
}

.page-content p iframe,
.page-content .sketchfab-embed-wrapper iframe {
  position: absolute;
  left: 0px;
  top: 0px;
  width: 100%;
  height: 100%;
	border-radius: 16px;
	overflow: hidden;
}

.page-content *:last-child {
	margin-bottom: 0px;
}

.page-content * + p:has(iframe),
.page-content * + .sketchfab-embed-wrapper {
  margin-top: 24px;
  margin-bottom: 24px;
}

.page-content * + p:has(img.alignright),
.page-content * + p:has(img.alignleft),
.page-content * + p:has(img.alignnone),
.page-content * + p:has(img.aligncenter) {
  margin-top: 24px;
}

.page-content figure {
  width: 100%!important;
  position: relative;
  margin-top: 24px;
  clear: both;
}

.page-content figure img {
  width: 100%;
}

.page-content figure figcaption {
  position: absolute;
  right: 20px;
  top: 20px;
  font-size: 1em;
	line-height: 120%;
  font-weight: 400;
  color: var(--main-white);
  display: flex;
  flex-direction: column;
  text-align: end;
  align-items: flex-end;
  word-spacing: 9999rem;
}

.page-content figure.aligncenter {
  width: 80%!important;
  margin-left: auto;
  margin-right: auto;
}

.page-content figure.alignleft {
  width: 50%!important;
  margin-right: 20px;
  float: left;
}

.page-content figure.alignleft + p {
  margin-top: 24px;
}

.page-content figure.alignright {
  width: 50%!important;
  margin-left: 20px;
  float: right;
}

.page-content figure.alignright + p {
  margin-top: 24px;
}

.page-content figure.alignright:first-child,
.page-content figure.alignleft:first-child {
  margin-top: 0px;
}

.page-content figure.alignright:first-child + p,
.page-content figure.alignleft:first-child + p {
  margin-top: 0px;
}

@media screen and (max-width: 1299px) {
  .page-content h2 {
    font-size: 1.875em;
  }

	.page-content h3 {
		font-size: 1.375em;
	}

	.page-content ul li,
	.page-content ol li {
		font-size: 1.125em;
	}

	.page-content p {
		font-size: 1.125em;
	}
}

@media screen and (max-width: 991px) {
  .page-content h2 {
    font-size: 1.75em;
		margin-bottom: 16px;
  }

	.page-content h3 {
		font-size: 1.25em;
		margin-bottom: 14px;
	}

	.page-content ul,
	.page-content ol {
		margin-bottom: 20px;
	}

	.page-content ul li,
	.page-content ol li {
		margin-bottom: 6px;
		font-size: 1em;
	}

	.page-content p {
		font-size: 1em;
		margin-bottom: 20px;
	}

	.page-content p img.alignright {
		margin-left: 16px;
		margin-bottom: 20px;
	}

	.page-content p img.alignleft {
		margin-right: 16px;
		margin-bottom: 20px;
	}

	.page-content * + p:has(iframe),
	.page-content * + .sketchfab-embed-wrapper {
		margin-top: 20px;
		margin-bottom: 20px;
	}

	.page-content * + p:has(img.alignright),
	.page-content * + p:has(img.alignleft),
	.page-content * + p:has(img.alignnone),
	.page-content * + p:has(img.aligncenter) {
		margin-top: 20px;
	}

	.page-content figure {
		margin-top: 20px;
	}

	.page-content figure figcaption {
		font-size: 0.875em;
	}

	.page-content figure.alignleft {
		margin-right: 16px;
	}

	.page-content figure.alignleft + p {
		margin-top: 20px;
	}

	.page-content figure.alignright {
		margin-left: 16px;
	}

	.page-content figure.alignright + p {
		margin-top: 20px;
	}
}

@media screen and (max-width: 767px) {
	.page-content h2 {
    font-size: 1.5em;
  }

	.page-content h3 {
		font-size: 1.25em;
	}

  .page-content p img.alignright {
    float: none;
    display: block;
    width: 100%;
    max-width: 550px;
    margin-left: auto;
    margin-right: auto;
  }

  .page-content p img.alignleft {
    float: none;
    display: block;
    width: 100%;
    max-width: 550px;
    margin-left: auto;
    margin-right: auto;
  }

  .page-content .center-column {
    width: 100%;
    max-width: 500px;
  }

  .page-content p img.alignnone {
    display: block;
    width: 100%;
    max-width: 550px;
    margin-left: auto;
    margin-right: auto;
  }

  .page-content p img.aligncenter {
    width: 100%;
    max-width: 500px;
  }

  .page-content figure {
    margin-top: 20px;
    max-width: 550px;
    margin-left: auto;
    margin-right: auto;
  }

	.page-content figure figcaption {
		font-size: 0.75em;
	}

  .page-content figure.aligncenter {
    width: 100%!important;
    max-width: 500px;
  }

  .page-content figure.alignleft {
    width: 100%!important;
    margin-right: auto;
    float: none;
  }

  .page-content figure.alignright {
    width: 100%!important;
    margin-left: auto;
    float: none;
  }
}

@media screen and (max-width: 575px) {
	.page-content h2 {
    font-size: 1.375em;
		margin-bottom: 12px;
  }

	.page-content h3 {
		font-size: 1.125em;
		margin-bottom: 10px;
	}

	.page-content ul,
	.page-content ol {
		margin-bottom: 16px;
	}

	.page-content p {
		margin-bottom: 16px;
	}

	.page-content p img.alignright {
		margin-left: 12px;
		margin-bottom: 16px;
	}

	.page-content p img.alignleft {
		margin-right: 12px;
		margin-bottom: 16px;
	}

	.page-content * + p:has(iframe),
	.page-content * + .sketchfab-embed-wrapper {
		margin-top: 16px;
		margin-bottom: 16px;
	}

	.page-content * + p:has(img.alignright),
	.page-content * + p:has(img.alignleft),
	.page-content * + p:has(img.alignnone),
	.page-content * + p:has(img.aligncenter) {
		margin-top: 16px;
	}

	.page-content figure {
		margin-bottom: 16px;
	}

	.page-content figure.alignleft {
		margin-right: 12px;
	}

	.page-content figure.alignleft + p {
		margin-top: 16px;
	}

	.page-content figure.alignright {
		margin-left: 12px;
	}

	.page-content figure.alignright + p {
		margin-top: 16px;
	}
}

.top-btn {
	position: fixed;
	z-index: 5;
	left: 32px;
	bottom: 50px;
	display: flex;
	align-items: center;
	font-size: 1em;
	line-height: 100%;
	font-weight: 400;
	transform-origin: 0px 0px;
	transform: rotate(-90deg);
	color: var(--main-white);
	cursor: pointer;
}

.top-btn .line {
	position: relative;
	width: 70px;
	height: 2px;
	background-color: #C3C3C3;
	margin-right: 15px;
}

.top-btn .line::after {
	content: '';
	position: absolute;
	z-index: 2;
	top: 0px;
	right: 0px;
	width: 30%;
	height: 100%;
	background-color: #ffffff;
}

@media screen and (max-width: 1299px) {
	.top-btn {
		left: 22px;
	}
}

@media screen and (max-width: 1199px) {
	.top-btn {
		left: 13px;
		font-size: 0.875em;
	}
}

@media screen and (max-width: 991px) {
	.top-btn {
		left: 8px;
	}

	.top-btn .line {
		width: 50px;
	}
}

@media screen and (max-width: 768px) {
	.top-btn {
		display: none;
	}
}