@import url('https://fonts.googleapis.com/css2?family=Caveat:wght@400..700&family=Nunito:ital,wght@0,200..1000;1,200..1000&family=Roboto:ital,wght@0,100..900;1,100..900&display=swap');

:root {
	--font-typeface: "Nunito", sans-serif;
	--font-headings: "Roboto", sans-serif;
	--font-special: "Caveat", sans-serif;
	--color-text: #282f49;
	--color-primary: #FF6303;
	--color-primary-hover: #ff731c;
	--color-primary-light: #ff8235;
	--color-primary-dark: #e65903;
	--color-primary-shadow: rgba(230, 89, 3, 0.3);
	--color-secondary: #cdcdc1;
	--color-secondary-hover: #e0e0d9;
	--color-secondary-shadow: rgba(56, 145, 241, 0.3);
	--color-light: #f1f6f9; /* rgb(241, 246, 249) */
	--color-dark: #1b2031;
	--color-border-light: rgba(50, 65, 141, 0.15);
	--rounded: 20px;
	--rounded-sm: 10px;
	--image-shadow: 0 20px 60px rgba(21, 24, 29, 0.3), 0 40px 60px -15px var(--color-secondary-shadow);
	--image-shadow-sm: 0 15px 30px rgba(21, 24, 29, 0.3), 0 20px 30px -10px var(--color-secondary-shadow);
}

html {
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

body {
	font-family: var(--font-typeface);
	background: #fff;
	overflow-x: hidden;
	color: var(--color-text);
	line-height: 1.4;
}

@media (min-width: 1200px) {
	.container {
		max-width: 1400px;
	}
}

a {
	color: var(--color-primary);
	transition: all 0.3s;
}

a:hover {
	color: var(--color-primary-light);
	text-decoration: none;
}

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
	font-family: var(--font-headings);
	margin-bottom: 0;
}

h1,
.h1 {
	font-size: clamp(2.25rem, 1.96rem + 1.28vw, 3.5rem);
	line-height: 1.15;
}

h2,
.h2 {
	font-size: clamp(2rem, 1.77rem + 1.03vw, 3rem);
	line-height: 1.2;
}

h3,
.h3 {
	font-size: clamp(2rem, 1.88rem + 0.51vw, 2.5rem);
	line-height: 1.25;
}

h4,
.h4 {
	font-size: 1.5rem;
	line-height: 1.25;
}

.mark,
mark {
	padding: 0 .2em .15em;
	background-color: rgba(255, 99, 3, 0.15);
	color: inherit;
	border-radius: 2px;
}

.btn {
	font-family: var(--font-headings);
	font-weight: 500;
	border-radius: var(--rounded-sm);
	transition: all 0.3s;
}

.btn-lg {
	padding: 16px 40px;
	font-size: 18px;
}

.btn-primary {
	background-color: var(--color-primary);
	border-color: transparent;
}

.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active {
	background-color: var(--color-primary-hover) !important;
	border-color: transparent !important;
}

.btn-primary-hover:hover,
.btn-primary-hover:focus {
	background: var(--color-primary-hover);
	box-shadow: 0 8px 20px var(--color-primary-shadow) !important;
	transform: translateY(5px);
}

.btn-outline-primary {
	border-color: var(--color-primary);
	color: var(--color-primary);
}

.btn-outline-primary:hover,
.btn-outline-primary:focus,
.btn-outline-primary:active {
	background-color: var(--color-primary-hover) !important;
	border-color: transparent !important;
}

.text-primary {
	color: var(--color-primary) !important;
}

.text-primary-light {
	color: var(--color-primary-light) !important;
}

.text-info {
	color: #2fc4ff !important;
}

.text-lg {
	font-size: 1.25rem !important;
}

.text-600 {
	font-weight: 600 !important;
}

.text-700 {
	font-weight: 700 !important;
}

.text-uppercase {
	text-transform: uppercase;
	letter-spacing: 0.1rem;
}

.text-special {
	font-family: var(--font-special);
	letter-spacing: -0.2rem;
	font-size: 1.625em;
	font-weight: 400;
	line-height: 0.65;
}

h4 .text-special {
	letter-spacing: -0.1rem;
}

p .text-special {
	letter-spacing: -0.05rem;
}

.bg-primary {
	background-color: var(--color-primary-dark) !important;
}

.bg-dark {
	background-color: var(--color-dark) !important;
}

.bg-dark-gradient {
	background-image: radial-gradient(circle farthest-corner at 100% 50%, #004085, #0a122b)!important;
}

.bg-info {
	background-color: #0e88b9 !important;
}

.z-index-1 {
	z-index: 1;
}

.list-marked li {
	position: relative;
	padding-left: 20px;
	margin-bottom: 10px;
}

.list-marked li:last-child {
	margin-bottom: 0;
}

.list-marked li:before {
	content: "";
	position: absolute;
	top: 10px;
	left: 0;
	width: 12px;
	height: 2px;
	background-color: var(--color-primary);
}

.text-white.list-marked li:before,
.text-white .list-marked li:before {
	background-color: #fff;
}

.section {
	padding: 80px 0;
}

.section-header {
	margin-bottom: 40px;
}

.preloader-wrap {
	width: 100%;
	height: 100%;
	position: fixed;
	top: 0;
	bottom: 0;
	background: #fff;
	z-index: 2000;
	text-align: center;
	height: 100vh
}

.preloader-wrap .inner {
	position: absolute;
	height: 170px;
	width: 170px;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	border: 1px solid var(--color-primary);
	border-top: 5px solid var(--color-primary);
	border-radius: 50%;
	-webkit-animation: spin 1s infinite linear;
	animation: spin 1s infinite linear
}

@media(max-width:991px) {
	.preloader-wrap .inner {
		height: 150px;
		width: 150px
	}
}

.preloader-wrap .percentage {
	z-index: 100;
	color: var(--color-primary);
	opacity: 1;
	font-weight: 600;
	font-family: var(--font-typeface);
	font-size: 48px;
	letter-spacing: 5px;
	line-height: 1;
	position: absolute;
	left: 50%;
	top: 50%;
	margin-top: -20px;
	margin-left: -40px;
}

@media(max-width:991px) {
	.preloader-wrap .percentage {
		font-size: 50px
	}
}

@-webkit-keyframes spin {
	0% {
		transform: translate(-50%, -50%) rotate(0)
	}

	100% {
		transform: translate(-50%, -50%) rotate(360deg)
	}
}

@keyframes spin {
	0% {
		transform: translate(-50%, -50%) rotate(0)
	}

	100% {
		transform: translate(-50%, -50%) rotate(360deg)
	}
}

.site-header {
	position: fixed;
	z-index: 100;
	top: 0;
	height: 60px;
	padding: 8px 0;
	width: 100%;
	border-bottom: 1px solid var(--color-border-light);
	overflow: hidden;
}

.site-header .btn-outline-secondary {
	height: 40px;
	border-color: var(--color-border-light);
}

.site-header .btns-link {
	font-size: 15px;
}

.site-header .btns-link a:hover {
	color: var(--color-primary-light) !important;
}

.header-address {
	font-size: 15px;
}

.soc-btn {
	display: flex;
	flex-wrap: wrap;
}

.soc-btn .btn {
	margin-right: 15px;
	width: 40px;
	height: 40px;
	padding: 0;
	display: flex;
	justify-content: center;
	align-items: center;
	border-color: var(--color-border-light);
	font-size: 24px;
}

.soc-btn .btn:last-child {
	margin-right: 0;
}

.navbar {
	z-index: 100;
	top: 60px;
	padding: 20px 0;
	background: transparent;
	transition: all .3s ease
}

@media(max-width:991px) {
	.navbar {
		background: #fff
	}
}

@media(max-width:991px) {
	.navbar {
		padding: 15px 20px;
		margin: 10px 10px 0;
		border-radius: 5px
	}
}

@media(max-width:991px) {
	.navbar .navbar-brand img {
		width: 80%
	}
}

.navbar-brand img {
	height: 50px;
}

.navbar .main-navigation {
	margin-left: 20px;
	flex-grow: 1;
}

.navbar .main-navigation .nav-item {
	padding: 0 1.25vw;
}

.navbar .main-navigation .nav-item .nav-link {
	position: relative;
	color: var(--color-text);
	padding: 4px;
	font-family: var(--font-headings);
	font-weight: 500;
	transition: all .3s ease;
}

.navbar .main-navigation .nav-item .nav-link:hover {
	color: var(--color-primary)
}

.nav-link:not(.dropdown-toggle):after {
	content: '';
	position: absolute;
	left: 0;
	bottom: 0;
	width: 0;
	background: var(--color-primary);
	border-bottom: 2px solid var(--color-primary);
	transition: width 0.3s ease-out;
}

.nav-link.active:after {
	width: 100%;
}

@media(max-width:991px) {
	.navbar .main-navigation .nav-item .nav-link {
		text-align: center;
		padding: 15px 0;
		cursor: pointer
	}
}

.navbar .hire_button {
	background: var(--color-primary);
	padding: 10px 25px;
	color: #fff;
	text-decoration: none;
	border-radius: var(--rounded-sm);
	font-family: var(--font-headings);
	font-size: 16px;
	font-weight: 500;
	border: 1px solid transparent;
	transition: all .3s ease;
}

.navbar .hire_button:hover {
	background: var(--color-primary-hover);
	box-shadow: 0 8px 20px var(--color-primary-shadow);
	transform: translateY(5px);
}

@media(max-width:991px) {
	.navbar .hire_button {
		text-align: center
	}
}

.navbar.nav__color__change {
	top: 0;
	background: #fff;
	padding: 20px 0;
	box-shadow: 0 10px 20px 0 var(--color-border-light);
}

@media(max-width:991px) {
	.navbar.nav__color__change {
		padding: 15px 20px
	}
}

@media(max-width:991px) {
	.navbar .navbar-toggler {
		outline: 0;
		padding: 0
	}

	.navbar .navbar-toggler-icon {
		height: 2px;
		width: 25px;
		transition: all .2s;
		background: var(--color-primary);
		display: block
	}

	.navbar .navbar-toggler-icon:not(:last-child) {
		margin-bottom: 5px
	}

	.navbar .navbar-toggler-icon:nth-child(1) {
		transform: rotate(45deg);
		transform-origin: 10% 10%
	}

	.navbar .navbar-toggler-icon:nth-child(2) {
		opacity: 0;
		filter: alpha(opacity=0)
	}

	.navbar .navbar-toggler-icon:nth-child(3) {
		transform: rotate(-45deg);
		transform-origin: 10% 90%
	}

	.navbar .navbar-toggler.collapsed .navbar-toggler-icon:nth-child(1) {
		transform: rotate(0)
	}

	.navbar .navbar-toggler.collapsed .navbar-toggler-icon:nth-child(2) {
		opacity: 1;
		filter: alpha(opacity=1)
	}

	.navbar .navbar-toggler.collapsed .navbar-toggler-icon:nth-child(3) {
		transform: rotate(0)
	}
}

.hero {
	padding: 200px 0 120px;
	position: relative;
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
	background-image: linear-gradient(to bottom, rgba(241, 246, 249, 1), rgba(241, 246, 249, 0.5));
}

@media(max-width:991px) {
	.hero {
		padding: 150px 0 30px 0;
	}
}

.hero_background-svg {
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
	width: 65%;
}

.hero_background-svg svg {
	width: 100%;
	height: 100%;
}

.hero_content {
	position: relative;
	z-index: 1;
}

@media(max-width:991px) {
	.hero_content {
		text-align: center;
		margin-bottom: 60px;
	}
}

.hero_blob {
	position: absolute;
	z-index: 0;
	top: -30%;
	left: -45%;
	height: 440px;
	width: 440px;
}

.hero_content .hero_blob svg {
	width: 100%;
	position: relative
}

@media(max-width:991px) {
	.hero_content .hero_blob {
		display: none
	}
}

.pretitle {
	font-size: 21px;
	font-weight: 600;
	position: relative;
	display: block;
	padding: 0 0 20px 30px
}

@media(max-width:991px) {
	.hero_content span {
		display: inline-block;
	}
}

.pretitle::before {
	position: absolute;
	content: "";
	height: 2px;
	width: 20px;
	top: 14px;
	left: 0;
	border-radius: 1px;
	background: var(--color-primary);
}

.hero_content h1 {
	margin: 0 0 30px 0;
	font-weight: 600;
	line-height: 1.15;
}

.hero_content p {
	margin: 0 0 50px 0;
	font-family: var(--font-typeface);
	color: var(--color-text);
	font-size: 20px;
	line-height: 30px
}

.intro-desc {
	font-size: 18px;
	line-height: 1.4;
}

.check-list-item {
	position: relative;
	padding: 0 50px;
	margin-bottom: 50px;
}

.check-list-item:before {
	content: '\EB7B';
	position: absolute;
	left: 0;
	top: 0;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	border: 2px solid var(--color-primary);
	display: flex;
	justify-content: center;
	align-items: center;
	font-family: 'remixicon' !important;
	font-size: 24px;
}

.hero_content a {
	display: inline-block;
	padding: 20px 40px;
	font-family: var(--font-headings);
	font-size: 18px;
	font-weight: 500;
	background: var(--color-primary);
	border-radius: var(--rounded-sm);
	color: #fff;
	text-decoration: none;
	border: 1px solid transparent;
	transition: all .3s ease;
}

.hero_content a:hover {
	background: var(--color-primary-hover);
	box-shadow: 0 8px 20px var(--color-primary-shadow);
	transform: translateY(5px);
}

.hero_figure {
	width: 90%;
	margin-left: auto;
	border-radius: 20px;
	position: relative;
}

@media(max-width:991px) {
	.hero_figure {
		width: 100%;
	}
}

.hero_figure .figure-svg {
	position: absolute;
	top: -55px;
	left: 100%;
	z-index: -1;
	height: 150px;
	-webkit-animation: move_left 5s infinite linear;
	animation: move_left 5s infinite linear;
}

.hero_figure .figure-svg img {
	height: 100%;
	width: 100%;
}

.hero_figure .single__slider {
	border-radius: var(--rounded);
	box-shadow: var(--image-shadow);
}

.hero_image {
	height: 100%;
	width: 100%;
	border-radius: var(--rounded);
	aspect-ratio: 1;
	object-fit: cover;
}

.hero_figure-badge {
	position: absolute;
	top: 90px;
	left: 0;
	transform: translateX(-50%);
	transition: all .3s ease
}

@media(max-width:991px) {
	.hero_figure-badge {
		bottom: -40px;
		left: 50%;
		transform: translateX(-50%)
	}
}

.hero_figure-badge .thumb {
	position: relative;
	padding: 30px 20px;
	border-radius: var(--rounded);
	text-align: center;
	box-shadow: 0 20px 60px rgba(21, 24, 29, 0.3), 0 30px 50px -10px var(--color-primary-shadow);
}

@-webkit-keyframes move_left {
	0% {
		transform: translateX(0)
	}

	50% {
		transform: translateX(-7%)
	}
}

@keyframes move_left {
	0% {
		transform: translateX(0)
	}

	50% {
		transform: translateX(-7%)
	}
}

@-webkit-keyframes move_top {

	0%,
	100% {
		transform: translateY(0)
	}

	50% {
		transform: translateY(15px)
	}
}

@keyframes move_top {

	0%,
	100% {
		transform: translateY(0)
	}

	50% {
		transform: translateY(15px)
	}
}

.hero_ripple {
	position: absolute;
	top: 40px;
	left: 80%;
	z-index: -1;
	width: 320px;
	height: 320px;
	opacity: 0.3;
}

.hero_btn {
	position: relative;
	display: inline-flex;
}

.hero_ripple_bottom {
	position: absolute;
	top: 50%;
	left: 50%;
	z-index: -1;
	width: 240px;
	height: 240px;
	transform: translate(-50%, -50%);
	opacity: 0.2;
}

.ripple {
	position: absolute;
	box-sizing: border-box;
	width: 100%;
	height: 100%;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}

.ripple .ripple-svg {
	position: absolute;
	width: 100%;
	height: 100%;
	opacity: 0;
}

.ripple .ripple-svg circle {
	fill: none;
	stroke: #2a96ed;
	stroke-width: 1px;
	stroke-alignment: inner;
}

.hero_ripple_bottom .ripple,
.hero_ripple_bottom .ripple .ripple-svg,
.hero_ripple_bottom .ripple .ripple-svg circle {
	animation-duration: 2.5s;
}

.hero_ripple_bottom .ripple .ripple-svg circle {
	stroke: var(--color-primary-light);
}

.ripple-1 {
	animation: ripple 2s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0s infinite;
}

.ripple-1 .ripple-svg {
	animation: fade-in-out 2s linear 0s infinite;
}

.ripple-1 .ripple-svg circle {
	animation: border 2s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0s infinite;
}

.ripple-2 {
	animation: ripple 2s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.2s infinite;
}

.ripple-2 .ripple-svg {
	animation: fade-in-out 2s linear 0.2s infinite;
}

.ripple-2 .ripple-svg circle {
	animation: border 2s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.2s infinite;
}

.ripple-3 {
	animation: ripple 2s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.4s infinite;
}

.ripple-3 .ripple-svg {
	animation: fade-in-out 2s linear 0.35s infinite;
}

.ripple-3 .ripple-svg circle {
	animation: border 2s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.4s infinite;
}

@keyframes fade-in-out {
	0% {
		opacity: 0
	}
	42% {
		opacity: 0
	}
	52% {
		opacity: 1
	}
	65% {
		opacity: 1
	}
	100% {
		opacity: 0
	}
}

@keyframes ripple {
	0% {
		transform: translate(-50%, -50%) scale3d(0.2, 0.2, 0.2)
	}
	42% {
		transform: translate(-50%, -50%) scale3d(0.2, 0.2, 0.2)
	}
	100% {
		transform: translate(-50%, -50%) scale3d(0.95, 0.95, 0.95)
	}
}

@keyframes border {
	0% {
		stroke-width: 4px
	}
	42% {
		stroke-width: 2px
	}
	100% {
		stroke-width: 0
	}
}

@media(max-width:1400px) {
	.about {
		overflow: hidden
	}
}

.about_content-thumb {
	position: relative;
	z-index: 1;
	height: 100%;
}

@media(max-width:991px) {
	.about_content-thumb {
		width: 100%
	}
}

.about_ripple {
	position: absolute;
	top: -12%;
	right: -22%;
	z-index: -1;
	width: 360px;
	height: 360px;
	opacity: 0.3;
}

@media(max-width:767px) {
	.about_ripple {
		top: -7%;
		left: -16%
	}
}

.about_content-thumb .about_content-thumb-image {
	height: 100%;
	border-radius: var(--rounded);
	box-shadow: var(--image-shadow);
}

.about_content-thumb .about_content-thumb-image img {
	height: 100%;
	width: 100%;
	object-fit: cover;
	border-radius: var(--rounded);
}

.about_content-inner {
	padding: 50px 40px;
	background: #1b2031;
	border-radius: var(--rounded);
	position: relative;
	overflow: hidden;
	z-index: 2;
}

@media(max-width:991px) {
	.about_content-inner {
		padding: 25px
	}
}

@media(max-width:991px) {
	.about_content-inner {
		width: 100%;
		margin-left: 0;
		margin-top: 30px
	}
}

.about_content-thumb-blob {
	position: absolute;
	bottom: -15%;
	left: -40%;
	z-index: -1;
	width: 400.369px;
	height: 362.909px;
	pointer-events: none;
}

.about_content-thumb-blob svg {
	width: 140%
}

@media(min-width:1400px) and (max-width:1600px) {
	.about_content-thumb-blob {
		right: -12%
	}
}

@media(max-width:767px) {
	.about_content-thumb-blob {
		display: none
	}
}

.about_content-inner h3 {
	margin: 0 0 35px 0;
	color: #fff;
	font-family: var(--font-headings);
}

.about_content-inner p {
	margin: 0 0 35px 0;
	font-size: 15px;
	font-family: var(--font-typeface);
	color: #fff;
	font-weight: 400;
	line-height: 30px
}

@media(max-width:991px) {
	.about_content-inner p {
		font-size: 14px;
		line-height: 26px
	}
}

.service {
	position: relative;
	overflow: hidden;
}

.service__background_shape {
	position: absolute;
	bottom: -10%;
	right: -7%;
	height: 465px;
	width: 410px
}

.service__background_shape svg {
	width: 100%
}

@media(max-width:991px) {
	.service__background_shape {
		display: none
	}
}

.service__background_pattern {
	position: absolute;
	bottom: 4%;
	left: 6%;
	-webkit-animation: move_top 5s infinite linear;
	animation: move_top 5s infinite linear
}

@media(max-width:991px) {
	.service__background_pattern {
		display: none
	}
}

.service__header {
	height: 100%;
	padding: 30px;
	border-radius: var(--rounded);
}

.service__header p {
	font-size: 18px;
}

.service__header_image {
	height: 100%;
}

.service__header_image img {
	width: 100%;
	height: 100%;
	border-radius: var(--rounded);
	box-shadow: var(--image-shadow-sm);
	object-fit: cover;
}

.service__header_text {
	font-size: 20px;
	font-family: var(--font-typeface);
	color: var(--color-text);
	position: relative;
	display: block;
	margin: 0 0 20px 30px
}

.service__slider_item {
	margin: 15px;
	padding: 30px;
	box-shadow: 0 20px 40px 0 rgba(50, 65, 141, 0.12);
	border-radius: 20px;
	background: #fff
}

.service__slider_item-icon {
	height: 110px;
	width: 125px;
	position: relative
}

.service__slider_item-icon .icon-background {
	position: absolute;
	top: 0;
	right: 0
}

.service__slider_item-icon .icon {
	position: absolute;
	left: 0;
	bottom: 0;
	z-index: 1
}

.service__slider_item h4 {
	font-size: 24px;
	font-family: var(--font-headings);
	color: var(--color-text);
	margin: 40px 0 30px 0
}

.service__slider_item p {
	font-family: var(--font-typeface);
	color: #7e7e8a;
	font-size: 16px;
	line-height: 30px;
	margin: 0
}

.service__slider .slick-list {
	overflow: visible
}

.service__slider .slick-dots {
	display: flex;
	align-items: center;
	margin: 0;
	padding: 0;
	justify-content: center
}

.service__slider .slick-dots li {
	margin: 0;
	list-style: none;
	height: 8px;
	width: 8px
}

.service__slider .slick-dots li:not(:last-child) {
	margin-right: 15px
}

.service__slider .slick-dots li button {
	cursor: pointer;
	height: 100%;
	width: 100%;
	background: #c2c8cc;
	border-radius: 50%;
	transition: all .3s ease;
	display: block;
	padding: 0;
	text-indent: -9999px
}

.service__slider .slick-dots li button:focus {
	outline: 0
}

.service__slider .slick-dots li button:hover {
	background: var(--color-primary)
}

.service__slider .slick-dots li.slick-active {
	height: 10px;
	width: 10px;
	border-radius: 50%
}

.service__slider .slick-dots li.slick-active button {
	background-color: var(--color-primary)
}

.service__slider .slick-slide:focus {
	outline: 0
}

.portfolio {
	padding: 100px 0 135px 0
}

@media(max-width:991px) {
	.portfolio {
		padding: 100px 0
	}
}

.portfolio__header {
	margin-bottom: 80px
}

@media(max-width:767px) {
	.portfolio__header {
		margin-bottom: 50px
	}
}

.portfolio__header span {
	display: block;
	font-size: 20px;
	font-family: var(--font-typeface);
	margin: 0 0 30px 0
}

.portfolio__header h1 {
	margin: 0 0 20px 0;
	font-size: 55px;
	font-family: var(--font-headings);
	color: var(--color-text);
	line-height: 1
}

@media(max-width:767px) {
	.portfolio__header h1 {
		font-size: 40px
	}
}

.portfolio__element {
	display: flex;
	flex-wrap: wrap
}

.portfolio__element .portfolio__element_left .portfolio__element_left-item-thumb,
.portfolio__element .portfolio__element_left .portfolio__element_right-item-thumb,
.portfolio__element .portfolio__element_right .portfolio__element_left-item-thumb,
.portfolio__element .portfolio__element_right .portfolio__element_right-item-thumb {
	border-radius: 20px;
	overflow: hidden;
	transition: all .3s ease
}

.portfolio__element .portfolio__element_left .portfolio__element_left-item-thumb img,
.portfolio__element .portfolio__element_left .portfolio__element_right-item-thumb img,
.portfolio__element .portfolio__element_right .portfolio__element_left-item-thumb img,
.portfolio__element .portfolio__element_right .portfolio__element_right-item-thumb img {
	height: 100%;
	width: 100%
}

.portfolio__element .portfolio__element_left .portfolio__element_left-item-content span,
.portfolio__element .portfolio__element_left .portfolio__element_right-item-content span,
.portfolio__element .portfolio__element_right .portfolio__element_left-item-content span,
.portfolio__element .portfolio__element_right .portfolio__element_right-item-content span {
	font-family: var(--font-typeface);
	color: #7e7e8a;
	font-size: 18px;
	line-height: 1;
	display: block;
	margin: 28px 0 20px 0
}

.portfolio__element .portfolio__element_left .portfolio__element_left-item-content h3,
.portfolio__element .portfolio__element_left .portfolio__element_right-item-content h3,
.portfolio__element .portfolio__element_right .portfolio__element_left-item-content h3,
.portfolio__element .portfolio__element_right .portfolio__element_right-item-content h3 {
	margin: 0 0 20px 0
}

.portfolio__element .portfolio__element_left .portfolio__element_left-item-content h3 a,
.portfolio__element .portfolio__element_left .portfolio__element_right-item-content h3 a,
.portfolio__element .portfolio__element_right .portfolio__element_left-item-content h3 a,
.portfolio__element .portfolio__element_right .portfolio__element_right-item-content h3 a {
	font-family: var(--font-headings);
	color: var(--color-text);
	font-size: 25px;
	line-height: 40px;
	transition: all .3s ease;
	display: block
}

.portfolio__element .portfolio__element_left .portfolio__element_left-item-content h3 a:hover,
.portfolio__element .portfolio__element_left .portfolio__element_right-item-content h3 a:hover,
.portfolio__element .portfolio__element_right .portfolio__element_left-item-content h3 a:hover,
.portfolio__element .portfolio__element_right .portfolio__element_right-item-content h3 a:hover {
	text-decoration: none;
	color: var(--color-primary)
}

.portfolio__element .portfolio__element_left .portfolio__element_left-item-content .see-more-btn,
.portfolio__element .portfolio__element_left .portfolio__element_right-item-content .see-more-btn,
.portfolio__element .portfolio__element_right .portfolio__element_left-item-content .see-more-btn,
.portfolio__element .portfolio__element_right .portfolio__element_right-item-content .see-more-btn {
	text-decoration: none;
	display: inline-block;
	font-family: var(--font-typeface);
	color: var(--color-primary);
	position: relative;
	font-size: 17px;
	margin: 0 0 0 30px;
	transform: scaleY(0);
	transform-origin: bottom center;
	transition: all .3s ease
}

.portfolio__element .portfolio__element_left .portfolio__element_left-item-content .see-more-btn::before,
.portfolio__element .portfolio__element_left .portfolio__element_right-item-content .see-more-btn::before,
.portfolio__element .portfolio__element_right .portfolio__element_left-item-content .see-more-btn::before,
.portfolio__element .portfolio__element_right .portfolio__element_right-item-content .see-more-btn::before {
	position: absolute;
	content: "";
	height: 2px;
	width: 20px;
	background: var(--color-primary);
	top: 50%;
	left: -30px;
	transform: translateY(-50%)
}

.portfolio__element_left {
	width: 50%
}

@media(max-width:767px) {
	.portfolio__element_left {
		width: 100%;
		margin-bottom: 30px
	}
}

.portfolio__element_left-item {
	padding: 0 60px 0 0;
	transition: .3s ease
}

@media(max-width:767px) {
	.portfolio__element_left-item {
		padding: 0
	}
}

.portfolio__element_left-item:not(:last-child) {
	margin-bottom: 80px
}

@media(max-width:767px) {
	.portfolio__element_left-item:not(:last-child) {
		margin-bottom: 40px
	}
}

.portfolio__element_left-item:nth-child(1) {
	width: 80%
}

@media(max-width:767px) {
	.portfolio__element_left-item:nth-child(1) {
		width: 100%
	}
}

.portfolio__element_left-item:hover .portfolio__element_left-item-thumb {
	box-shadow: 0 20px 40px 0 rgba(50, 65, 141, 0.12)
}

.portfolio__element_left-item:hover .portfolio__element_left-item-content .see-more-btn {
	transform: scaleY(1)
}

.portfolio__element_right {
	width: 50%
}

@media(max-width:767px) {
	.portfolio__element_right {
		width: 100%
	}
}

.portfolio__element_right-item {
	padding: 0 60px 0 0;
	transition: .3s ease
}

@media(max-width:767px) {
	.portfolio__element_right-item {
		padding: 0
	}
}

.portfolio__element_right-item:not(:last-child) {
	margin-bottom: 80px
}

@media(max-width:767px) {
	.portfolio__element_right-item:not(:last-child) {
		margin-bottom: 40px
	}
}

.portfolio__element_right-item:nth-child(2) {
	width: 80%;
	margin-left: auto
}

@media(max-width:767px) {
	.portfolio__element_right-item:nth-child(2) {
		width: 100%
	}
}

.portfolio__element_right-item:hover .portfolio__element_right-item-thumb {
	box-shadow: 0 20px 40px 0 rgba(50, 65, 141, 0.12)
}

.portfolio__element_right-item:hover .portfolio__element_right-item-content .see-more-btn {
	transform: scaleY(1)
}

.steps {
	position: relative;
	margin-bottom: 20px;
}

@media(max-width:991px) {
	.steps {
		margin-bottom: 40px;
		padding: 60px 0
	}
}

.steps_ripple {
	position: absolute;
	bottom: -12%;
	right: -12%;
	z-index: 0;
	width: 600px;
	height: 600px;
	opacity: 0.1;
}

.steps_ripple .ripple,
.steps_ripple .ripple .ripple-svg,
.steps_ripple .ripple .ripple-svg circle {
	animation-duration: 5s;
}

.steps_ripple .ripple-1 {
	animation-delay: 0.5s;
}

.steps_ripple .ripple-2 {
	animation-delay: 1s;
}

.steps_ripple .ripple-3 {
	animation-delay: 1.5s;
}

.steps__background {
	background: #1b2031;
	height: 100%;
	width: 100%;
	position: absolute;
	top: 0;
	left: 0;
	/*background-size: cover;
	background-repeat: no-repeat;
	background-position: 50% 0;
	background-image: url(../images/section_bg_02.jpg);*/
}

.steps__heading {
	margin-right: 100px;
	position: sticky;
	position: -webkit-sticky;
	top: 150px;
}

.steps__education_item {
	position: relative;
	display: flex;
	background: #fff;
	padding: 30px;
	border-radius: var(--rounded);
	margin-bottom: 30px;
	box-shadow: 0 20px 40px 0 rgba(50, 65, 141, 0.12)
}

.steps_image {
	margin-right: 30px;
}

.steps_image img {
	aspect-ratio: 1;
	object-fit: cover;
	border-radius: var(--rounded-sm);
	box-shadow: var(--image-shadow-sm);
}

.steps_number {
	position: absolute;
	top: 32px;
	left: 0;
	transform: translate(-50%, 0);
	width: 48px;
	height: 48px;
	padding: 2px 2px 0 0;
	border-radius: 50%;
	background-color: var(--color-primary);
	box-shadow: 0 8px 20px var(--color-primary-shadow);
	display: flex;
	justify-content: center;
	align-items: center;
	color: #fff;
	font-size: 2rem;
}

.steps__education_item span {
	color: var(--color-primary);
	display: block;
	font-size: 16px;
	font-family: var(--font-typeface);
	margin: 0 0 20px 30px;
	position: relative;
	line-height: 1
}

.steps__education_item span::before {
	position: absolute;
	content: "";
	height: 2px;
	width: 20px;
	top: 50%;
	left: -20px;
	transform: translateX(-50%);
	background: #282f49
}

.steps__education_item h4 {
	margin-bottom: 15px;
}

.steps__education_item p {
	color: #7e7e8a;
	font-size: 16px;
	margin: 0
}

.skill {
	position: relative;
	padding: 100px 0 150px 0
}

@media(max-width:991px) {
	.skill {
		padding: 100px 0
	}
}

.skill__background_shape {
	position: absolute;
	bottom: 2%;
	right: 2%;
	height: 300px;
	width: 300px
}

.skill__background_shape svg {
	width: 100%
}

@media(max-width:991px) {
	.skill__background_shape {
		display: none
	}
}

.skill__background_pattern {
	position: absolute;
	bottom: 5%;
	right: 10%;
	height: 100px;
	width: 100px;
	-webkit-animation: move_top 3s infinite linear;
	animation: move_top 3s infinite linear
}

.skill__background_pattern img {
	height: 100%;
	width: 100%
}

@media(max-width:991px) {
	.skill__background_pattern {
		display: none
	}
}

.skill__thumb {
	position: relative
}

@media(max-width:767px) {
	.skill__thumb {
		margin-bottom: 30px
	}
}

.skill__thumb_pattern {
	position: absolute;
	top: -11%;
	left: -17%;
	z-index: -1;
	height: 150px;
	-webkit-animation: move_top 4s infinite linear;
	animation: move_top 4s infinite linear
}

.skill__thumb_pattern img {
	height: 100%;
	width: 100%
}

.skill__thumb_image {
	margin-right: 7%
}

@media(max-width:991px) {
	.skill__thumb_image {
		margin-right: 0
	}
}

.skill__thumb_image img {
	height: 100%;
	width: 100%
}

.skill__progress {
	margin-left: 40px
}

@media(max-width:991px) {
	.skill__progress {
		margin-left: 0;
		margin-top: 30px
	}
}

.skill__progress_heading {
	margin-bottom: 40px
}

.skill__progress_heading span {
	font-size: 20px;
	font-family: var(--font-typeface);
	color: var(--color-text);
	position: relative;
	display: block;
	margin: 0 0 20px 30px
}

.skill__progress_heading span::before {
	position: absolute;
	content: "";
	height: 2px;
	width: 20px;
	top: 50%;
	left: -20px;
	transform: translateX(-50%);
	background: #282f49
}

.skill__progress_heading h1 {
	margin: 0 0 30px 0;
	font-size: 50px;
	font-family: var(--font-headings);
	color: var(--color-text);
	line-height: 50px
}

.skill__progress_heading p {
	margin: 0;
	font-family: var(--font-typeface);
	color: var(--color-text);
	font-size: 18px;
	line-height: 26px
}

.skill__progress_item.js-animation {
	transition: all .3s ease
}

.skill__progress_item.js-animation .progress {
	width: 100%;
	background: #e7eef2;
	height: 10px;
	border-radius: 5px
}

.skill__progress_item.js-animation .progress .progress-bar {
	border-radius: 5px;
	position: relative;
	-webkit-animation: animate-positive 3000ms;
	animation: animate-positive 3000ms;
	background: var(--color-primary)
}

.skill__progress_item:not(:last-child) {
	margin-bottom: 30px
}

.skill__progress_item h6 {
	display: inline-block;
	font-family: var(--font-typeface);
	font-weight: 400;
	font-size: 16px
}

.skill__progress_item .progress-value {
	float: right;
	font-family: var(--font-typeface);
	font-size: 16px;
	font-weight: 400
}

@-webkit-keyframes animate-positive {
	0% {
		width: 0
	}
}

@keyframes animate-positive {
	0% {
		width: 0
	}
}

.testimonial {
	background: var(--color-light);
	position: relative;
}

@media(max-width:991px) {
	.testimonial {
		padding: 100px 0
	}
}

.testimonial__background_shape {
	position: absolute;
	width: 100%;
	top: 0;
	left: 0
}

.testimonial__background_shape svg {
	height: 100%;
	width: 100%
}

.testimonial__background_shape svg path {
	fill: #fff
}

@media(max-width:400px) {
	.testimonial__background_shape {
		display: none
	}
}

.testimonial__slider {
	margin-top: 20px;
	margin-left: -15px;
}

.testimonial__slider_item {
	background: #fff;
	border-radius: 20px;
	padding: 0 30px 30px;
	margin: 60px 15px
}

@media(max-width:767px) {
	.testimonial__slider_item {
		margin: 60px 0 0;
		padding: 0 20px 20px;
	}
}

.testimonial__slider_item-image {
	margin-bottom: 20px;
	margin-top: -40px;
}

.testimonial__slider_item-image img {
	max-width: 120px;
	aspect-ratio: 1;
	border-radius: var(--rounded-sm);
	box-shadow: var(--image-shadow-sm);
}

.testimonial__slider_item-rating {
	margin: 0 0 25px 0;
	padding: 0
}

.testimonial__slider_item-rating li {
	list-style: none;
	display: inline-block
}

.testimonial__slider_item-rating li i {
	color: #ffc219
}

.testimonial__slider_item-content {
	margin-bottom: 30px;
}

.testimonial__slider_item-author {
	margin: 0 0 0 30px;
	color: #7e7e8a;
	font-size: 16px;
	line-height: 1;
	position: relative
}

.testimonial__slider_item-author span {
	font-weight: bold;
	color: var(--color-primary)
}

.testimonial__slider_item-author:before {
	position: absolute;
	content: "";
	height: 2px;
	width: 20px;
	left: -30px;
	top: 50%;
	transform: translateY(-50%);
	background: var(--color-primary)
}

.testimonial__slider .slick-dots {
	display: flex;
	align-items: center;
	margin: 0;
	padding: 0;
	justify-content: center
}

.testimonial__slider .slick-dots li {
	margin: 0;
	list-style: none;
	height: 8px;
	width: 8px
}

.testimonial__slider .slick-dots li:not(:last-child) {
	margin-right: 15px
}

.testimonial__slider .slick-dots li button {
	cursor: pointer;
	height: 100%;
	width: 100%;
	background: #c2c8cc;
	border-radius: 50%;
	transition: all .3s ease;
	display: block;
	padding: 0;
	text-indent: -9999px
}

.testimonial__slider .slick-dots li button:focus {
	outline: 0
}

.testimonial__slider .slick-dots li button:hover {
	background: var(--color-primary)
}

.testimonial__slider .slick-dots li.slick-active {
	height: 10px;
	width: 10px;
	border-radius: 50%
}

.testimonial__slider .slick-dots li.slick-active button {
	background-color: var(--color-primary)
}

.testimonial__slider .slick-slide:focus {
	outline: 0
}

.blog {
	position: relative;
	margin-bottom: 30px
}

.blog__shape {
	position: absolute;
	top: 11%;
	right: 12%;
	height: 300px;
	width: 300px
}

.blog__shape img {
	-webkit-animation: rotate 25s infinite linear;
	animation: rotate 25s infinite linear;
	height: 100%;
	width: 100%
}

@media(max-width:991px) {
	.blog__shape {
		display: none
	}
}

.blog__header span {
	font-size: 20px;
	font-family: var(--font-typeface);
	color: var(--color-text);
	position: relative;
	display: block;
	margin: 0 0 20px 30px
}

.blog__header span::before {
	position: absolute;
	content: "";
	height: 2px;
	width: 20px;
	top: 50%;
	left: -20px;
	transform: translateX(-50%);
	background: #282f49
}

.blog__header h1 {
	margin: 0 0 30px 0;
	font-size: 50px;
	font-family: var(--font-headings);
	color: var(--color-text);
	line-height: 50px
}

.blog__header p {
	margin: 0;
	font-family: var(--font-typeface);
	color: var(--color-text);
	font-size: 18px;
	line-height: 26px
}

.blog__header_button {
	position: relative;
	width: 100%;
	height: 100%
}

.blog__header_button a {
	position: absolute;
	bottom: 0;
	right: 0;
	display: inline-block;
	padding: 15px 40px;
	background: #fff;
	border: 1px solid #e4e6eb;
	border-radius: 7px;
	font-family: var(--font-typeface);
	text-decoration: none;
	font-size: 17px;
	color: var(--color-text);
	transition: all .3s ease;
	transform: scale(1)
}

@media(max-width:991px) {
	.blog__header_button a {
		position: relative;
		margin-top: 30px
	}
}

.blog__header_button a:hover {
	background: var(--color-primary);
	border: 1px solid transparent;
	color: #fff;
	transform: scale(1.03);
	box-shadow: 0 8px 20px rgba(56, 87, 241, 0.3)
}

.blog__item {
	position: relative;
	margin-bottom: 20px
}

@media(max-width:991px) {
	.blog__item {
		margin-bottom: 130px
	}
}

.blog__item-thumb {
	width: 90%;
	height: 100%;
	overflow: hidden;
	border-radius: 20px
}

@media(max-width:991px) {
	.blog__item-thumb {
		width: 80%;
		margin: 0 auto
	}
}

.blog__item-thumb img {
	height: 100%;
	width: 100%;
	transition: all .3s ease
}

.blog__item-content {
	background: #fff;
	position: absolute;
	bottom: -100px;
	left: 40px;
	padding: 30px;
	border-radius: 20px;
	box-shadow: 0 20px 40px 0 rgba(50, 65, 141, 0.12)
}

@media(max-width:991px) {
	.blog__item-content {
		left: 0
	}
}

.blog__item-content span {
	font-size: 16px;
	font-family: var(--font-typeface);
	color: var(--color-primary);
	margin: 0 0 20px 40px;
	position: relative;
	display: block;
	line-height: 1
}

.blog__item-content span::before {
	position: absolute;
	content: "";
	top: 50%;
	left: -40px;
	height: 1px;
	width: 20px;
	background: #282f49;
	transform: translateY(-50%)
}

.blog__item-content a {
	font-size: 22px;
	font-family: var(--font-headings);
	line-height: 30px;
	color: var(--color-text);
	margin: 0;
	display: block;
	text-decoration: none;
	transition: all .3s ease
}

.blog__item-content a:hover {
	color: var(--color-primary)
}

.blog__item:hover .blog__item-thumb img {
	transform: scale(1.1)
}

.blog .mobile {
	display: none
}

@media(max-width:991px) {
	.blog .desktop {
		display: none
	}

	.blog .mobile {
		display: block;
		text-align: center
	}
}

@-webkit-keyframes rotate {
	from {
		-webkit-transform: rotate(0)
	}

	to {
		-webkit-transform: rotate(360deg)
	}
}

@keyframes rotate {
	from {
		-webkit-transform: rotate(0)
	}

	to {
		-webkit-transform: rotate(360deg)
	}
}

.contact {
	background: #1b2031;
	position: relative;
	margin-top: 150px
}

.contact__background_shape {
	position: absolute;
	width: 100%;
	top: 0;
	left: 0
}

.contact__background_shape svg {
	height: 100%;
	width: 100%
}

.contact__background_shape svg path {
	fill: #fff
}

@media(max-width:575px) {
	.contact__background_shape {
		display: none
	}
}

.contact__cta {
	background: var(--color-primary);
	padding: 80px 60px;
	border-radius: 20px;
	display: flex;
	align-items: center;
	margin-top: -110px;
	flex-wrap: wrap;
	position: relative;
	overflow: hidden;
	z-index: 5
}

.contact__cta .shape-1 {
	position: absolute;
	z-index: -1;
	transform: rotate(-20deg);
	top: -43%;
	left: 2%;
	-webkit-animation: moveLeft 5s infinite linear;
	animation: moveLeft 5s infinite linear
}

.contact__cta .shape-1 svg path {
	fill: #fff;
	opacity: .07
}

.contact__cta .shape-2 {
	position: absolute;
	z-index: -1;
	transform: rotate(80deg);
	top: 12%;
	right: -9%;
	width: 235px;
	height: 208px;
	-webkit-animation: move_top 3s infinite linear;
	animation: move_top 3s infinite linear
}

.contact__cta .shape-2 svg {
	height: 100%;
	width: 100%
}

.contact__cta .shape-2 svg path {
	fill: #fff;
	opacity: .07
}

@media(max-width:991px) {
	.contact__cta {
		padding: 70px 40px
	}
}

.contact__cta_content {
	width: 60%
}

@media(max-width:991px) {
	.contact__cta_content {
		width: 100%;
		text-align: center;
		margin-bottom: 20px
	}
}

.contact__cta_content span {
	font-family: var(--font-typeface);
	color: #fff;
	font-size: 20px;
	display: block;
	line-height: 1;
	margin: 0 0 20px 40px;
	position: relative
}

@media(max-width:991px) {
	.contact__cta_content span {
		display: inline-block
	}
}

.contact__cta_content span::before {
	position: absolute;
	content: "";
	height: 2px;
	width: 20px;
	left: -40px;
	top: 50%;
	transform: translateY(-50%);
	background: #fff
}

.contact__cta_action {
	width: 40%
}

@media(max-width:991px) {
	.contact__cta_action {
		width: 100%;
		text-align: center
	}
}

.contact__widget {
	padding: 100px 0
}

@media(max-width:991px) {
	.contact__widget {
		text-align: center;
		padding: 50px 0
	}
}

.contact__widget_address h3 {
	font-family: var(--font-typeface);
	color: #fff;
	margin: 0 0 40px 0;
	line-height: 1;
	font-size: 24px
}

@media(max-width:991px) {
	.contact__widget_address h3 {
		margin: 0 0 20px 0
	}
}

.contact__widget_address ul {
	margin: 0;
	padding: 0
}

.contact__widget_address ul li {
	list-style: none
}

.contact__widget_address ul li a {
	text-decoration: none;
	display: block;
	color: #fff;
	transition: all .3s ease;
	font-family: var(--font-typeface);
	font-size: 16px
}

.contact__widget_address ul li a:hover {
	color: var(--color-primary)
}

.contact__widget_address ul li:not(:last-child) {
	margin-bottom: 10px
}

.contact__widget_address ul li p {
	color: #fff;
	margin: 0
}

.contact__widget_address ul li p i {
	margin-right: 20px;
	font-size: 17px
}

.contact__footer {
	padding: 50px 0;
	border-top: 1px solid rgba(255, 255, 255, 0.2)
}

@media(max-width:991px) {
	.contact__footer {
		text-align: center
	}
}

.contact__footer_copy p {
	color: #fff;
	font-size: 16px;
	font-family: var(--font-typeface);
	margin: 0
}

.contact__footer_social ul {
	margin: 0;
	padding: 0;
	float: right
}

@media(max-width:991px) {
	.contact__footer_social ul {
		margin: 20px auto 0;
		float: none
	}
}

.contact__footer_social ul li {
	list-style: none;
	display: inline-block
}

.contact__footer_social ul li a {
	display: block;
	text-decoration: none;
	color: #fff;
	font-size: 20px;
	transition: all .3s ease
}

.contact__footer_social ul li a:hover {
	color: var(--color-primary)
}

.contact__footer_social ul li:not(:last-child) {
	margin-right: 25px
}

@-webkit-keyframes moveLeft {

	0%,
	100% {
		transform: translateX(0) rotate(-20deg)
	}

	50% {
		transform: translateX(15px) rotate(-20deg)
	}
}

@keyframes moveLeft {

	0%,
	100% {
		transform: translateX(0) rotate(-20deg)
	}

	50% {
		transform: translateX(15px) rotate(-20deg)
	}
}

.blog__item {
	position: relative;
	margin-bottom: 120px
}

.blog__item-thumb {
	width: 90%;
	height: 100%
}

@media(max-width:991px) {
	.blog__item-thumb {
		width: 80%;
		margin: 0 auto
	}
}

.blog__item-thumb img {
	height: 100%;
	width: 100%;
	border-radius: 20px
}

.blog__item-content {
	background: #fff;
	position: absolute;
	bottom: -100px;
	left: 40px;
	padding: 30px;
	border-radius: 20px;
	box-shadow: 0 20px 40px 0 rgba(50, 65, 141, 0.12)
}

@media(max-width:991px) {
	.blog__item-content {
		left: 0;
		width: 100%
	}
}

.blog__item-content span {
	font-size: 16px;
	font-family: var(--font-typeface);
	color: var(--color-primary);
	margin: 0 0 20px 40px;
	position: relative;
	display: block;
	line-height: 1
}

.blog__item-content span::before {
	position: absolute;
	content: "";
	top: 50%;
	left: -40px;
	height: 1px;
	width: 20px;
	background: #282f49;
	transform: translateY(-50%)
}

.blog__item-content a {
	font-size: 22px;
	font-family: var(--font-headings);
	line-height: 30px;
	color: var(--color-text);
	margin: 0;
	display: block;
	text-decoration: none;
	transition: all .3s ease
}

.blog__item-content a:hover {
	color: var(--color-primary)
}

.blog__pagination {
	width: 100%;
	position: relative;
	height: 80px;
	margin-top: 40px
}

.blog__pagination .pagination {
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%)
}

.blog__pagination .pagination li {
	height: 80px;
	width: 80px;
	box-shadow: 0 20px 40px 0 rgba(50, 65, 141, 0.12);
	border-radius: 10px;
	position: relative;
	transition: all .3s ease;
	cursor: pointer
}

.blog__pagination .pagination li a {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	text-decoration: none;
	font-family: var(--font-headings);
	font-size: 20px;
	color: var(--color-text);
	transition: all .3s ease
}

.blog__pagination .pagination li a svg path {
	fill: #000
}

.blog__pagination .pagination li:hover {
	background: var(--color-primary)
}

.blog__pagination .pagination li:hover a {
	color: #fff
}

.blog__pagination .pagination li:hover a svg path {
	fill: #fff
}

.blog__pagination .pagination li:not(:last-child) {
	margin-right: 34px
}

.blog__pagination .pagination li.active {
	background: var(--color-primary)
}

.blog__pagination .pagination li.active a {
	color: #fff
}

.blog__pagination .pagination li.active a svg path {
	fill: #fff
}

@media(max-width:991px) {
	.section {
		padding: 50px 0
	}
}

.section .svg-img {
	position: absolute;
	top: 30%;
	left: -7%;
	-webkit-animation: move_top 5s infinite linear;
	animation: move_top 5s infinite linear
}

@media(max-width:991px) {
	.section .svg-img {
		display: none
	}
}

.section .animate-shape {
	position: absolute;
	top: 29%;
	right: 4%;
	height: 300px;
	width: 300px
}

.section .animate-shape svg {
	width: 100%
}

@media(max-width:991px) {
	.section .animate-shape {
		display: none
	}
}

.section .animate-pattern {
	position: absolute;
	top: 46%;
	right: 12%;
	height: 100px;
	width: 100px;
	-webkit-animation: move_top 3s infinite linear;
	animation: move_top 3s infinite linear
}

.section .animate-pattern img {
	height: 100%;
	width: 100%
}

@media(max-width:991px) {
	.section .animate-pattern {
		display: none
	}
}

.section .singleBlog__feature {
	margin: 0 100px
}

@media(max-width:991px) {
	.section .singleBlog__feature {
		margin: 0
	}
}

.section .singleBlog__feature img {
	height: 100%;
	width: 100%;
	border-radius: 20px
}

.section .singleBlog__content {
	margin: 0 200px 0 200px
}

@media(max-width:991px) {
	.section .singleBlog__content {
		margin: 0
	}
}

.section .singleBlog__content p {
	font-family: var(--font-typeface);
	font-size: 16px;
	line-height: 30px;
	margin-bottom: 40px;
	color: #7e7e8a
}

.section .singleBlog__content dl,
.section .singleBlog__content ul,
.section .singleBlog__content ol {
	margin-top: 0;
	margin-bottom: 40px;
	font-family: var(--font-typeface);
	font-size: 16px;
	line-height: 30px;
	color: #7e7e8a
}

.section .singleBlog__content blockquote {
	font-family: var(--font-typeface);
	font-size: 16px;
	line-height: 30px;
	color: var(--color-text);
	padding: 30px;
	background: #fff;
	box-shadow: 0 20px 40px 0 rgba(50, 65, 141, 0.07);
	border-radius: 5px;
	margin: 0 0 50px 0
}

.section .singleBlog__content blockquote cite {
	display: block
}

.section .singleBlog__content .blog-section {
	margin-bottom: 60px
}

@media(max-width:767px) {
	.section .singleBlog__content .blog-section img {
		width: 100%;
		float: none;
		margin-bottom: 40px
	}
}

.section .singleBlog__content .blog-section h3 {
	font-family: var(--font-headings);
	color: var(--color-text);
	font-size: 25px;
	line-height: 40px;
	margin: 0 0 20px 0
}

.breadCrumb {
	padding: 200px 0 0;
	position: relative
}

.breadCrumb .svg-img {
	position: absolute;
	bottom: -35%;
	left: -7%;
	-webkit-animation: move_top 5s infinite linear;
	animation: move_top 5s infinite linear
}

@media(max-width:991px) {
	.breadCrumb .svg-img {
		display: none
	}
}

.breadCrumb .animate-shape {
	position: absolute;
	bottom: -60%;
	right: 2%;
	height: 300px;
	width: 300px
}

.breadCrumb .animate-shape svg {
	width: 100%
}

@media(max-width:991px) {
	.breadCrumb .animate-shape {
		display: none
	}
}

.breadCrumb .animate-pattern {
	position: absolute;
	bottom: -40%;
	right: 10%;
	height: 100px;
	width: 100px;
	-webkit-animation: move_top 3s infinite linear;
	animation: move_top 3s infinite linear
}

.breadCrumb .animate-pattern img {
	height: 100%;
	width: 100%
}

@media(max-width:991px) {
	.breadCrumb .animate-pattern {
		display: none
	}
}

@media(max-width:991px) {
	.breadCrumb {
		padding: 120px 0 0
	}
}

.breadCrumb__title {
	font-size: 48px;
	font-family: var(--font-headings);
	color: var(--color-text);
	line-height: 1;
	margin: 0 0 30px 0
}

@media(max-width:767px) {
	.breadCrumb__title {
		font-size: 36px
	}
}

@media(max-width:575px) {
	.breadCrumb__title {
		font-size: 30px
	}
}

.breadCrumb .breadcrumb {
	background: 0;
	margin: 0;
	padding: 0
}

.breadCrumb .breadcrumb-item a {
	font-family: var(--font-typeface);
	color: var(--color-text);
	font-size: 17px;
	text-decoration: none
}

@media(max-width:575px) {
	.breadCrumb .breadcrumb-item a {
		font-size: 14px
	}
}

@media(max-width:400px) {
	.breadCrumb .breadcrumb-item a {
		font-size: 12px
	}
}

.breadCrumb .breadcrumb-item.active {
	font-family: var(--font-typeface);
	color: var(--color-text)
}

@media(max-width:575px) {
	.breadCrumb .breadcrumb-item.active {
		font-size: 14px
	}
}

@media(max-width:400px) {
	.breadCrumb .breadcrumb-item.active {
		font-size: 12px
	}
}

.breadCrumb .breadcrumb-item+.breadcrumb-item::before {
	content: "-";
	color: var(--color-text);
	font-size: 17px;
	padding-right: 10px
}

@media(max-width:575px) {
	.breadCrumb .breadcrumb-item+.breadcrumb-item::before {
		font-size: 14px
	}
}

@media(max-width:400px) {
	.breadCrumb .breadcrumb-item+.breadcrumb-item::before {
		padding-right: 0
	}
}

.breadCrumb .breadcrumb-item+.breadcrumb-item {
	padding-left: 10px
}

@media(max-width:400px) {
	.breadCrumb .breadcrumb-item+.breadcrumb-item {
		padding-right: 0
	}
}

.classicBlog__item {
	position: relative;
	margin-bottom: 150px
}

.classicBlog__item-thumb {
	width: 88%;
	height: 100%
}

@media(max-width:991px) {
	.classicBlog__item-thumb {
		width: 80%;
		margin: 0 auto
	}
}

.classicBlog__item-thumb img {
	height: 100%;
	width: 100%;
	border-radius: 20px
}

.classicBlog__item-content {
	margin-right: 18px;
	background: #fff;
	position: absolute;
	bottom: -100px;
	left: 40px;
	padding: 30px 50px 30px 40px;
	border-radius: 20px;
	box-shadow: 0 20px 40px 0 rgba(50, 65, 141, 0.12)
}

@media(max-width:991px) {
	.classicBlog__item-content {
		left: 0
	}
}

@media(max-width:575px) {
	.classicBlog__item-content {
		padding: 25px
	}
}

.classicBlog__item-content span {
	font-size: 16px;
	font-family: var(--font-typeface);
	color: var(--color-primary);
	margin: 0 0 20px 40px;
	position: relative;
	display: block;
	line-height: 1
}

@media(max-width:575px) {
	.classicBlog__item-content span {
		font-size: 14px
	}
}

.classicBlog__item-content span::before {
	position: absolute;
	content: "";
	top: 50%;
	left: -40px;
	height: 1px;
	width: 20px;
	background: #282f49;
	transform: translateY(-50%)
}

.classicBlog__item-content a {
	font-size: 28px;
	font-family: var(--font-headings);
	line-height: 40px;
	color: var(--color-text);
	margin: 0;
	display: block;
	text-decoration: none;
	transition: all .3s ease
}

@media(max-width:575px) {
	.classicBlog__item-content a {
		font-size: 20px;
		line-height: 28px
	}
}

.classicBlog__item-content a:hover {
	color: var(--color-primary)
}

.classicBlog__pagination {
	width: 100%;
	position: relative;
	height: 80px;
	margin-top: 40px
}

@media(max-width:991px) {
	.classicBlog__pagination {
		margin-bottom: 100px
	}
}

.classicBlog__pagination .pagination {
	position: absolute;
	top: 15px;
	left: 0
}

.classicBlog__pagination .pagination li {
	height: 80px;
	width: 80px;
	box-shadow: 0 20px 40px 0 rgba(50, 65, 141, 0.12);
	border-radius: 10px;
	position: relative;
	transition: all .3s ease;
	cursor: pointer
}

.classicBlog__pagination .pagination li a {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	text-decoration: none;
	font-family: var(--font-headings);
	font-size: 20px;
	color: var(--color-text);
	transition: all .3s ease
}

.classicBlog__pagination .pagination li a svg path {
	fill: #000
}

.classicBlog__pagination .pagination li:hover {
	background: var(--color-primary)
}

.classicBlog__pagination .pagination li:hover a {
	color: #fff
}

.classicBlog__pagination .pagination li:hover a svg path {
	fill: #fff
}

.classicBlog__pagination .pagination li:not(:last-child) {
	margin-right: 34px
}

.classicBlog__pagination .pagination li.active {
	background: var(--color-primary)
}

.classicBlog__pagination .pagination li.active a {
	color: #fff
}

.classicBlog__pagination .pagination li.active a svg path {
	fill: #fff
}

.classicBlog__sidebar:not(:first-child) {
	margin: 40px 0 20px 0
}

.classicBlog__sidebar .form-search .form-group {
	position: relative
}

.classicBlog__sidebar .form-search .form-group .form-control {
	height: 70px;
	padding: 10px 30px;
	border: 0;
	box-shadow: 0 20px 40px rgba(50, 65, 141, 0.12);
	border-radius: 10px;
	color: #7e7e8a;
	font-family: var(--font-typeface);
	font-size: 16px
}

.classicBlog__sidebar .form-search .form-group .search-icon {
	position: absolute;
	right: 30px;
	top: 50%;
	transform: translateY(-50%);
	display: block;
	line-height: 1
}

.classicBlog__sidebar .sidebar-title {
	font-size: 24px;
	color: var(--color-text);
	font-family: var(--font-headings);
	margin: 0 0 25px 0
}

.classicBlog__sidebar .list-item {
	margin: 0;
	padding: 0
}

.classicBlog__sidebar .list-item li {
	display: block;
	list-style: none
}

.classicBlog__sidebar .list-item li a {
	display: block;
	padding: 7px 0;
	font-size: 16px;
	font-family: var(--font-typeface);
	color: #7e7e8a;
	transition: all .3s ease
}

.classicBlog__sidebar .list-item li a span {
	float: right
}

.classicBlog__sidebar .list-item li a:hover {
	color: var(--color-primary);
	text-decoration: none
}

.classicBlog__sidebar .latest-post-item {
	display: flex;
	align-items: center;
	padding: 15px 0
}

.classicBlog__sidebar .latest-post-item .thumb {
	width: 100px;
	border-radius: 10px;
	overflow: hidden
}

.classicBlog__sidebar .latest-post-item .thumb img {
	height: 100%;
	width: 100%
}

.classicBlog__sidebar .latest-post-item .content {
	width: calc(100% - 100px);
	padding-left: 30px
}

.classicBlog__sidebar .latest-post-item .content span {
	display: block;
	font-family: var(--font-typeface);
	font-size: 16px;
	color: var(--color-primary);
	margin: 0 0 0 40px;
	position: relative
}

.classicBlog__sidebar .latest-post-item .content span::before {
	position: absolute;
	content: "";
	top: 50%;
	left: -40px;
	transform: translateY(-50%);
	height: 2px;
	width: 20px;
	background: #282f49
}

.classicBlog__sidebar .latest-post-item .content h5 {
	margin: 0
}

.classicBlog__sidebar .latest-post-item .content h5 a {
	font-family: var(--font-headings);
	color: var(--color-text);
	font-size: 20px;
	line-height: 30px;
	transition: all .3s ease
}

.classicBlog__sidebar .latest-post-item .content h5 a:hover {
	text-decoration: none;
	color: var(--color-primary)
}

.contact__info_item {
	overflow: hidden;
	box-shadow: 0 15px 40px 0 rgba(50, 65, 141, 0.12);
	padding: 30px;
	border-radius: var(--rounded);
	height: 100%;
	display: flex;
	flex-direction: column;
}

.contact__info_item-icon {
	position: relative;
	display: flex;
	justify-content: flex-start;
	align-items: center;
	height: 72px;
	width: 72px;
	margin: 10px 0 20px;
}

.contact__info_item-icon:before,
.contact__info_item-icon:after {
	content: '';
	position: absolute;
	z-index: 1;
	top: 50%;
	left: 50%;
	width: 72px;
	height: 72px;
	border-radius: 50%;
	background-color: var(--color-light);
	transform: translate(-30%, -70%);
	transition: 0.5s;
}

.contact__info_item:hover .contact__info_item-icon:before {
	transform: translate(-50%, -50%) scale(10);
	opacity: 0;
}

.contact__info_item-icon .icon {
	position: relative;
	z-index: 2;
	font-size: 3.5rem;
	color: var(--color-primary);
}

.contact__info_item-icon.count,
.contact__info_item-icon.count {
	justify-content: center;
}

.contact__info_item-icon.count:before,
.contact__info_item-icon.count:after {
	top: 50%;
	left: 50%;
	background-color: #ebf0f6;
	transform: translate(-50%, -50%);
}

.contact__info_text {
	position: relative;
	z-index: 2;
	flex-grow: 1;
}

.contact__info_item h4 {
	margin: 0 0 20px 0;
}

.contact__info_item p {
	font-size: 16px;
	margin: 0;
}

.contact-form {
	padding: 50px 0 100px 0
}

.contact-form-title h4 {
	font-family: var(--font-headings);
	color: var(--color-text);
	margin: 0 0 30px 0;
	font-size: 35px
}

.contact-form-input .form-group {
	margin-bottom: 30px
}

.contact-form-input .form-group .form-control,
.contact-form-input .form-group .form-select {
	border: 1px solid #aeb8be;
	border-radius: 7px;
	padding: 10px;
	font-size: 16px;
	font-family: var(--font-typeface);
	color: var(--color-text)
}

.contact-form-input .form-group .form-control::-moz-placeholder {
	color: var(--color-text)
}

.contact-form-input .form-group .form-control:-ms-input-placeholder {
	color: var(--color-text)
}

.contact-form-input .form-group .form-control::placeholder {
	color: var(--color-text)
}

.contact-form-input .form-group .form-control:-ms-input-placeholder {
	color: var(--color-text)
}

.contact-form-input .form-group .form-control::-ms-input-placeholder {
	color: var(--color-text)
}

.contact-form-input .form-group .form-control:focus,
.contact-form-input .form-group .form-select:focus {
	outline: 0;
	box-shadow: none
}

.contact-form-input .form-group input.form-control {
	height: 54px;
	border: 1px solid #aeb8be;
}

.contact-form-input .form-group .form-select {
	width: 100%;
	height: 54px;
	border: 1px solid #aeb8be;
	appearance: none;
	background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23343a40' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");
	background-repeat: no-repeat;
	background-position: right .75rem center;
	background-size: 16px 12px;
}

.contact-form-input .form-check {
	padding: 0;
	margin-bottom: 30px;
	margin-top: -10px
}

.contact-form-input .form-check-input {
	padding: 0;
	height: initial;
	width: initial;
	margin-bottom: 0;
	display: none;
	cursor: pointer
}

.contact-form-input .form-check-label {
	position: relative;
	cursor: pointer
}

.contact-form-input .form-check-label::before {
	content: "";
	-webkit-appearance: none;
	background-color: transparent;
	border: 1px solid #aeb8be;
	height: 20px;
	width: 20px;
	border-radius: 4px;
	display: inline-block;
	position: relative;
	vertical-align: middle;
	cursor: pointer;
	margin-right: 8px
}

.contact-form-input .form-check input:checked + label::after {
	content: "";
	display: block;
	position: absolute;
	top: 6px;
	left: 7px;
	width: 6px;
	height: 12px;
	border: solid var(--color-primary);
	border-width: 0 3px 3px 0;
	transform: rotate(45deg)
}

.contact-form-input button,
.contact-form-input input[type="submit"] {
	padding: 16px 40px;
	display: inline-block;
	font-size: 18px;
	transition: all .3s ease
}

.contact-form-input .contact-form-btn:hover,
.contact-form-input .contact-form-btn:focus {
	background: var(--color-primary-hover);
	box-shadow: 0 8px 20px var(--color-primary-shadow) !important;
	transform: translateY(5px);
	text-decoration: none
}

.contact-form #map {
	border-radius: 30px;
	height: 100%
}

@media(max-width:991px) {
	.contact-form #map {
		height: 400px;
		margin-top: 60px
	}
}

.case-details {
	padding: 200px 0 100px 0
}

@media(max-width:991px) {
	.case-details {
		padding: 120px 0 0
	}
}

.case-details .svg-img {
	position: absolute;
	top: 30%;
	left: -7%;
	-webkit-animation: move_top 5s infinite linear;
	animation: move_top 5s infinite linear
}

@media(max-width:991px) {
	.case-details .svg-img {
		display: none
	}
}

.case-details .animate-shape {
	position: absolute;
	top: 29%;
	right: 4%;
	height: 300px;
	width: 300px
}

.case-details .animate-shape svg {
	width: 100%
}

@media(max-width:991px) {
	.case-details .animate-shape {
		display: none
	}
}

.case-details .animate-pattern {
	position: absolute;
	top: 46%;
	right: 12%;
	height: 100px;
	width: 100px;
	-webkit-animation: move_top 3s infinite linear;
	animation: move_top 3s infinite linear
}

.case-details .animate-pattern img {
	height: 100%;
	width: 100%
}

@media(max-width:991px) {
	.case-details .animate-pattern {
		display: none
	}
}

.case-details-title {
	font-size: 50px;
	line-height: 60px;
	font-family: var(--font-headings);
	color: var(--color-text);
	margin: 0 0 50px 0
}

.case-details p {
	font-family: var(--font-typeface);
	color: #7e7e8a;
	font-size: 16px;
	line-height: 34px;
	margin: 0 0 30px 0
}

.case-details-info {
	display: flex;
	justify-content: space-around;
	background: #282f49;
	border-radius: 20px;
	padding: 65px 0;
	margin: 70px 0 80px 0
}

@media(max-width:575px) {
	.case-details-info {
		flex-direction: column;
		padding: 30px 0
	}
}

.case-details-info .case-details-info-item {
	position: relative
}

.case-details-info .case-details-info-item:not(:last-child)::before {
	position: absolute;
	content: "";
	width: 1px;
	height: 100%;
	top: 0;
	right: -80px;
	background: rgba(255, 255, 255, 0.1)
}

@media(max-width:991px) {
	.case-details-info .case-details-info-item:not(:last-child)::before {
		right: -45px
	}
}

@media(max-width:767px) {
	.case-details-info .case-details-info-item:not(:last-child)::before {
		right: -15px
	}
}

@media(max-width:575px) {
	.case-details-info .case-details-info-item:not(:last-child)::before {
		display: none
	}
}

@media(max-width:575px) {
	.case-details-info .case-details-info-item:not(:last-child) {
		margin-bottom: 30px
	}
}

.case-details-info h5 {
	margin: 0 0 10px 0;
	font-size: 20px;
	color: #fff;
	font-family: var(--font-headings);
}

.case-details-info p {
	margin: 0
}

.case-details-service {
	margin-bottom: 90px
}

.case-details-service h3 {
	font-family: var(--font-headings);
	color: var(--color-text);
	font-size: 25px;
	margin: 0 0 25px 0
}

.case-details-service p {
	margin: 0
}

.case-details-thumb {
	margin: 0 0 90px 0;
	border-radius: 30px;
	overflow: hidden
}

.case-details-thumb img {
	height: 100%;
	width: 100%
}

.case-details-nav {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-top: 50px
}

.case-details-nav .previous .icon,
.case-details-nav .next .icon {
	line-height: 0
}

.case-details-nav .previous .content span,
.case-details-nav .next .content span {
	display: block;
	font-family: var(--font-typeface);
	color: #7e7e8a;
	font-size: 15px;
	line-height: 1;
	margin-bottom: 5px
}

.case-details-nav .previous .content h5,
.case-details-nav .next .content h5 {
	font-family: var(--font-headings);
	font-size: 20px;
	margin: 0;
	line-height: 1
}

.case-details-nav .previous .content h5 a,
.case-details-nav .next .content h5 a {
	text-decoration: none;
	color: var(--color-text);
	transition: all .3s ease
}

.case-details-nav .previous .content h5 a:hover,
.case-details-nav .next .content h5 a:hover {
	color: var(--color-primary)
}

.case-details-nav .previous {
	display: flex;
	align-items: center
}

.case-details-nav .previous .icon {
	margin-right: 15px
}

@media(max-width:575px) {
	.case-details-nav .social {
		display: none
	}
}

.case-details-nav .social ul {
	margin: 0;
	padding: 0
}

.case-details-nav .social ul li {
	list-style: none;
	display: inline-block
}

.case-details-nav .social ul li a {
	display: block;
	text-decoration: none;
	color: #7e7e8a;
	font-size: 20px;
	transition: all .3s ease
}

.case-details-nav .social ul li a:hover {
	color: var(--color-primary)
}

.case-details-nav .social ul li:not(:last-child) {
	margin-right: 25px
}

.case-details-nav .next {
	display: flex;
	align-items: center
}

.case-details-nav .next .icon {
	margin-left: 15px
}

.case-details-nav .next .content {
	text-align: right
}

.calc_content-inner {
	padding: 40px;
	border-radius: var(--rounded);
	position: relative;
	z-index: 1;
}

.calc_content-thumb {
	position: relative;
	z-index: 2;
	height: 100%;
}

@media(max-width:991px) {
	.calc_content-thumb {
		width: 100%
	}
}

.calc_content-thumb .calc_content-thumb-image {
	height: 100%;
	border-radius: var(--rounded);
	box-shadow: var(--image-shadow);
}

.calc_content-thumb .calc_content-thumb-image img {
	height: 100%;
	width: 100%;
	object-fit: cover;
	border-radius: var(--rounded);
}

.calc_content-badge {
	position: absolute;
	top: 90px;
	left: 0;
	transform: translateX(-50%);
	transition: all .3s ease
}

@media(max-width:991px) {
	.calc_content-badge {
		bottom: -40px;
		left: 50%;
		transform: translateX(-50%)
	}
}

.calc_content-badge .thumb {
	position: relative;
	padding: 30px 20px;
	border-radius: var(--rounded);
	text-align: center;
	box-shadow: 0 20px 60px rgba(21, 24, 29, 0.3), 0 30px 50px -10px var(--color-secondary-shadow);
}

.calc_ripple {
	position: absolute;
	bottom: -12%;
	right: -12%;
	z-index: -1;
	width: 300px;
	height: 300px;
	opacity: 0.2;
}


/*# sourceMappingURL=maps/style.css.map */