:root {
	--text: #555555;
	--highlight: #ffcc00;
	--hover: #ffa621;
	--light: #f2f2f2;
	--semilight: #999;
	--dark: #000000;
	--transition: all .2s ease;
	--margin: 20px;
	--font-text: 'Barlow', Arial, serif;	
	--boxshadow: 0px 1px 20px 0px rgba(0, 0, 0, 0.1);

}
body {
	font-family: var(--font-text);
	font-size: 13px;
	line-height: 18px;
	color: var(--text);
	margin: 0 0;
	padding: 0px 0 0 0px;
	background-color: #FFFFFF;
}
@media (max-width: 1024px) {
	body {
		text-align: justify;
	}
}
body.blocked {
	overflow: hidden !important;
}

*, ::after, ::before {
    box-sizing: border-box;
}
a {
	color: var(--highlight);
}
@media (min-width:1024px) {
	.hide-desktop {
		display: none !important;
	}
}
@media (max-width: 1024px) {
	.hide-mobile {
		display: none !important;
	}
}
img {
	max-width: 100%;
}
/* Default styles */
a { text-decoration: none; color: var(--highlight); }
a:hover { text-decoration: none; }
h2 {
	font-size: 16px;
	line-height: 24px;
}
h4 {
    font-size: 16px;
    margin: .5em 0 0.5em
}
.flex {
	display: flex;
	flex-wrap: wrap;
}
.alert {
    font-size: 20px;
    font-weight: 600;
    padding: 35px;
}
.fluid,
.container {
	position: relative;
    width: 100%;
    padding-right: 15px;
    padding-left: 15px;
    margin-right: auto;
    margin-left: auto;
}
.row {
	display:-ms-flexbox;
	display:flex;
	-ms-flex-wrap:wrap;
	flex-wrap:wrap;
	margin-right:-15px;
	margin-left:-15px
}
.row.center {
	align-items: center;
	
}
.col {
	flex: 0 0 auto; padding: 0 15px;
}
.col-2 {
	flex: 0 0 16.666667%; max-width: 16.666667%; padding: 0 15px;
}
.col-3 {
	flex: 0 0 25%; max-width: 20%; padding: 0 15px;
}
.col-4 {
	flex: 0 0 33.333334%; max-width: 33.333334%; padding: 0 15px;
}
.col-5 {
	flex: 0 0 41.666667%; max-width:41.666667%; padding: 0 15px;
}
.col-6 {
	flex: 0 0 50%; max-width: 50%; padding: 0 15px;
}
.col-7 {
	flex: 0 0 58.333334%; max-width: 58.333334%; padding: 0 15px;
}
.col-8 {
	flex: 0 0 66.666667%; max-width: 66.666667%; padding: 0 15px;
}
.col-9 {
	flex: 0 0 75%; max-width: 75%; padding: 0 15px;
}
.col-12 {
	flex: 0 0 100%; max-width: 100%; padding: 0 15px;
}
.text-center {
	text-align: center !important;
}
.text-right {
	text-align: right !important;
}
.my-0 {
	margin-top: 0 !important;
	margin-bottom: 0 !important;
}
.pl-0 {
	padding-left: 0 !important;
}
.pb-5 {
	padding-bottom: 25px;
}
.p-3 {
	padding: 15px;
}
.p-5 {
	padding: 25px;
}
@media (min-width: 576px) {
	.container {
		max-width: 540px;
	}
}
@media (min-width: 768px) {
	.container {
		max-width: 720px;
	}
}
@media (min-width: 992px) {
	.container-lg, .container {
		max-width: 100%;
	}
}
@media (min-width: 1200px) {
	.container-lg, .container {
		max-width: 100%;
	}
}
@media (min-width: 1400px) {
	.container-lg, .container {
		max-width: 1320px;
	}
}



.contact-bar {
	background-color: var(--dark);	
	padding: 7px 0;
	position: relative;
	z-index: 1005;
}
.contact-bar .row {
	padding: 0px 15px 5px;
	justify-content: space-between;
}
.contact-bar a {
	color: #FFF;
	font-size: 16px;
	font-weight: 500;
}
.contact-bar a svg {
	fill: #FFF;
	width: 12px;
	height: 12px;
	display: inline-block;
	margin: 0 5px 0 0;
	opacity: .5;
}


header.header {
    position: fixed;
    top: 50px;
	bottom: initial;
    left: 0;
    width: 100%;
    z-index: 1000;
    transition: all .25s ease;
}
body.blocked header.header {
	top: 37px;
}
body.scrolled header.header {
	background-color: #FFFFFF;
	box-shadow: 0px 0px 15px rgba(0,0,0,.15);
	top: 0px;
	/*
	bottom: 0px;
	*/
}
header.header a.logo {
    padding-top: 0px;
    margin-left: -15px;
    display: block;
    width: 220px;
    transition: all .25s ease;
    background-color: #FFF;
    padding: 20px;
	box-shadow: 10px 10px 0 rgba(0,0,0,.15);
}
body:not(.start) a.logo {
	box-shadow: initial;
}
/*body.scrolled header.header a.logo {
	padding-top: 0px;
	padding-bottom: 0px;
}
*/
header.header .logo img {
    transition: all .25s ease;
    width: 209px;
    max-width: 100%;
}
body.scrolled header.header .logo {
	box-shadow: 0 0 rgba(0,0,0,0);
    padding-top: 12px;
    padding-bottom: 8px;
    margin-left: -30px;
}
body.scrolled header.header .logo img {
    width: 140px;
    margin-left: 10px;
}

.close-btn {
	display: none;
}
nav.main-nav {
    display: none;
	opacity: 0;
	transition: all .25s ease;
}
nav.main-nav.on {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    background-color: var(--dark);
    color: #FFF;
    z-index: 50;
	padding-top: 100px;
	opacity: 1;
}
nav.main-nav.on a.close-btn {
    display: block;
    position: absolute;
    top: 45px;
    right: 25px;
}
nav.main-nav.on a.close-btn svg {
	width: 32px;
	height: 32px;
	fill: var(--highlight);
}
nav.main-nav.on ul {
    display: flex;
    flex-direction: column;
    padding: 0 60px;
	list-style: none;
	
}
nav.main-nav.on ul.lang-select {
	flex-direction: row;
}
nav.main-nav.on ul li {
	color: var(--highlight);
}
nav.main-nav.on ul li a {
    font-size: 17px;
    color: #FFF;
    padding: 7px;
    display: block;
    margin: 2px 0;
	font-weight: 600;
	text-align: left;
	letter-spacing: .5px;
    text-transform: uppercase;
}
nav.main-nav ul.dropdown {
	padding-left: 20px;
	padding-right: 20px;
}
nav.main-nav.on ul ul li a {
	font-size: 14px;
	letter-spacing: 0;
	font-weight: 400;
	text-align: left;
}
nav.main-nav ul li.social a svg {
	width: 24px;
	height: 24px;
	fill: #FFF;
}
li.dropdown svg {
    width: 12px;
    height: 12px;
    margin-left: 5px;
    opacity: .3;
}
nav.main-nav .langs {
	display: none;
}
ul.lang-select {
    display: flex;
    list-style: none;
    margin: 0 0;
    padding: 0 0;
    position: absolute;
    top: 50px;
    right: 20px;
	z-index: 99;
}
body.scrolled ul.lang-select {
	top: -50px;
}
ul.lang-select a {
	display: inline-block;
	margin: 0 0 0 5px;
}
.contact-bar ul.lang-select a svg {
	opacity: 1;
	width: 20px;
	height: 14px;
}
.menu-call {
    display: block;
    position: absolute;
    top: 58px;
    right: 15px;
    padding: 5px;
    z-index: 8;
    transition: all .25s ease;
}
body.scrolled .menu-call {
	top: 16px;	
}
.menu-call span {
    background-color: #FFFFFF;
    width: 24px;
    height: 4px;
    margin: 3px auto 4px;
    content: "";
    display: block;
    border-radius: 2px;
	transition: all .25s ease;
}
body.scrolled .menu-call span {
	background-color: var(--dark);
}
.menu-call em {
	font-style: normal;
	position: absolute;
	color: #FFF;
	right: 40px;
	top: 8px;
	text-transform: uppercase;
	transition: all .25s ease;
}
body.scrolled .menu-call em {
	color: var(--dark);
}



.slider-wrap {
    height: 85vh;
    max-height: 800px;
    background: var(--dark);
    position: relative;
    margin-bottom: 20px;
	overflow: hidden;
}
.slider-wrap .slider {
	height: 100%;
}
.slider-wrap .slider:before {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 40vh;
	background-image: linear-gradient(180deg, rgba(0,0,0,.75) 40%, transparent);
	content: "";
	z-index: 6;
}
.slider-wrap .slider .item {
	height: 100%;
	overflow: hidden;
}
.slider-wrap .slider .item video,
.slider-wrap .slider .item picture {
	position: absolute;
	z-index: 1;
	width: 100%;
	height: 100%;
}
.slider-wrap .slider .item video,
.slider-wrap .slider .item img {
	width: 100%;
	height: 112%;
	object-fit: cover;
	opacity: .7;
	object-position: top center;
}
.slider-wrap .text {
    z-index: 8;
    position: relative;
    padding: 25px;
    top: 25%;
    font-size: 20px;
	color: #FFFFFF;
	font-weight: 300;
	line-height: 26px;
}
.slider-wrap .text h1 {
    font-size: 22px;
    line-height: 30px;
	font-weight: 400;
    color: #FFFFFF;
	letter-spacing: 0.5px;
	text-shadow: 2px 2px rgba(255,255,255,.15);
}
.slider-wrap .text h1 strong {
	font-style: normal;
	font-weight: 800;
	font-size: 34px;
}
.start-contact {
    width: 100%;
    position: absolute;
    bottom: 30px;
    z-index: 999;
    padding: 10px 0px;
    color: #FFF;
    left: 0;
    text-align: center;
}
.start-contact > div {
	position: relative;
	z-index: 5;
}
.start-contact svg {
    width: 12px;
    height: 12px;
    fill: var(--dark);    
    vertical-align: middle;    
    position: absolute;
	right: 10px;
	top: 50%;
	transform: translateY(-50%);
}
.start-contact a {
    display: inline-flex;
    width: 40%;
    background-color: var(--highlight);
    color: var(--dark);
    font-size: 11px;
    line-height: 13px;
    text-transform: uppercase;
    text-align: left;
    padding: 5px 25px 5px 10px;
    margin: 5px .5% 8px;
    font-weight: 400;
    letter-spacing: 0;
    position: relative;
    box-shadow: 5px 5px rgba(0,0,0,.25);
    height: 50px;
    align-items: center;
	vertical-align: top;
}
.start-contact a strong {
	font-weight: 700;
	letter-spacing: 1px;
}

.btn {
    background-color: var(--highlight);
    box-shadow: 7px 7px rgba(0,0,0,.25);
    display: inline-block;
    padding: 14px 25px 16px;
    color: var(--dark);
    text-transform: uppercase;
    font-weight: 600;
    margin-bottom: 20px;
    font-size: 14px;
    letter-spacing: .5px;
	border: 0;
	font-family: var(--font-text);
}
.btn svg {
	display: inline-block;
	width: 14px;
	height: 14px;
	margin-left: 20px;
	vertical-align: middle;
}

@media (max-width: 997px) {
	.order-mob-1 {
		order: 1;
	}
	.order-mob-2 {
		order: 2;
	}
}

.text-wrap {
	margin: 0px auto;
	padding: 250px 0px 25px;
	position: relative;
	background-color: var(--light);
}
.text-wrap .left-img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 230px;
	object-fit: cover;
}
.text-wrap .right-img {
	position: absolute;
	top: 0;
	right: 0;
	width: 100%;
	height: 230px;
	object-fit: cover;
}
.text-wrap .text-header {
    position: relative;
    padding: 0px 0px 1px;
    margin-bottom: 20px;
}
.text-wrap:not(.invert) .text-header {
	text-align: left;
}
.text-wrap .text-header h2 {
	font-size: 20px;
	line-height: 28px;
	color: var(--dark);
	letter-spacing: 2px;
	text-transform: uppercase;
	font-weight: 300;
}
.text-wrap .text-header h2 + h3 {
	margin-top: -15px;
	font-size: 26px;
	font-weight: 600;
	letter-spacing: .5px;
	color: var(--dark);
	text-transform: uppercase;
	line-height: 28px;
}
.text-wrap .text-header h2 + h4 {
    text-transform: uppercase;
    margin: -10px 0 20px;
    font-size: 17px;
    letter-spacing: 1px;
}
.text-wrap .text-header:after {
	position: absolute;
	left: -30px;
	width: 30%;
	height: 3px;
	bottom: 0;
	background-color: var(--highlight);
	content: "";
}
.text-wrap + .text-wrap {
	/*
	margin-top: -30px;
	*/
}





.standard {
    padding: 20px 0;
}
.standard .text-header h2 {
    font-size: 18px;
    letter-spacing: 2px;
    line-height: 26px;
	font-weight: 300;
}



.gallery-cols {
    box-shadow: inset 0px -50px 100px rgba(0,0,0,.06);	
}
.gallery-cols .content {
	padding: 30px 15px 15px;
}
.icons {
	text-align: center;
	position: relative;
	padding: 35px 0;
}
.gallery-cols .text-header {
	text-align: center;
}
.gallery-cols h2,
.news-items h2,
.icons h2 {
	color: var(--dark);
	text-transform: uppercase;
	font-weight: 300;
	letter-spacing: 2px;
	line-height: 28px;
	position: relative;
}
.gallery-cols h2 em,
.news-items h2 em,
.icons h2 em {
	font-style: normal;
	font-size: 28px;
	font-weight: 600;
	letter-spacing: .5px;
}

.news-items h2:after,
.icons h2:after {
    width: 150px;
    height: 2px;
    left: 50%;
    bottom: -15px;
    transform: translateX(-50%);
    background-color: var(--highlight);
    content: "";
    display: block;
    position: absolute;
}
.icons .flex {
	margin-top: 35px;
}
.icons .flex .item {
    flex: 0 0 50%;
	text-align: center;
	padding: 5px 15px;
	font-size: 12px;
	line-height: 14px;
	color: var(--semilight);
	position: relative;
	margin: 0 auto 35px;
}
.icons .flex .item img {
    width: 66px;
    height: 66px;
    object-fit: scale-down;
    position: relative;
    z-index: 5;
    margin-top: 30px;
}
.icons .flex .item:before {
	position: absolute;
	content: "";
	background-color: var(--light);
	width: 130px;
	height: 130px;
	border-radius: 60px;
	left: 50%;
	transform: translateX(-50%);
}
.icons .flex .item strong {
    display: block;
    font-size: 14px;
    text-transform: uppercase;
    color: var(--dark);
    letter-spacing: 1px;
    margin: 10px 0 15px;
    font-weight: 500;
	position: relative;
	z-index: 7;
}




.news-items {
	padding: 25px 0;
}
.news-items .text-header {
	text-align: center;
	margin-bottom: 40px;
}
.news-items .text {
	padding-bottom: 35px;
}
.news-items .news-item {
    margin: 6px 25px;
    background-color: var(--light);
    padding: 10px;
    position: relative;
	width: 100%;
}
.news-items .news-item img {
	width: 100%;
	height: 180px;
	object-fit: cover;
}
.news-item .content {
    position: absolute;
    bottom: 10px;
    background-color: rgba(0,0,0,.5);
    width: calc(100% - 20px);
    padding: 10px 13px;
}
.news-item .content a {
	color: #FFFFFF;
	font-size: 13px;
	font-weight: 500;
	text-transform: uppercase;
}



.small-slider {
    position: relative;
    padding: 3em 1em 5em;
    text-shadow: 1px 1px 1px rgb(0 0 0 / 50%);
    color: #FFF;
    font-size: 14px;
	background-color: var(--dark);
	text-align: left;
}
.small-slider .bg-pic {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
	opacity: .5;
}
.small-slider .container {
	position: relative;
	z-index: 5;
}
.small-slider h1 {
    font-size: 24px;
    line-height: 30px;
    margin: 10px 0 25px;
    font-weight: 700;
}
.parallax.mod-83 {
    background-color: #e4e4e6;
}






form#contact-form-web {
    position: fixed;
    top: 0px;
    left: 0px;
    width: 100%;
    height: 100%;
    z-index: 1500;
    display: none;
	background-color: rgba(0,0,0,.35);    
}
form#contact-form-web.on {
    display: flex;
    align-items: center;
    justify-content: center;
}
.contactForm .thanks,
#contact-form-web .thanks {
	position: absolute;
    z-index: 9;
    background-color: #ffffff;
    width: 100%;
    height: 100%;
    display: none;
    align-items: center;
    justify-content: center;
    top: 0;
    left: 0;
    opacity: .95;
}
.contactForm .thanks.on,
#contact-form-web .thanks.on {
	display: flex;
}
.contactForm .thanks p,
#contact-form-web .thanks p {
    font-size: 1.5em;
    max-width: 600px;
    text-align: center;
    padding: 1em;
	margin:0 auto;
    line-height: 1.5em;
}
.contactForm label,
#contact-form-web label {
    display: block;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 1px;
	padding: 0 0 3px 0;
}
#contact-form-web .container {
	padding-left: 15px;
	padding-right: 15px;
	max-width: 900px;
	width: 98%;
	margin: 0 auto;
}
#contact-form-web > div:first-of-type {
	padding: 20px 5px;
	overflow: auto;
    max-height: calc(100% - 30px);
	background-color: #FFF;
    box-shadow: 0px 0px 30px rgb(0 0 0 / 20%);
	position: relative;
	max-width: 95%;
}
#contact-form-web h3 {
    font-size: 18px;
    text-align: left;
	font-weight: 800;
    margin: 0 0 20px;
}

.contactForm .form-group,
#contact-form-web .form-group {
	padding: 3px 15px;
}
.contactForm p.reg,
#contact-form-web p.reg {
    font-size: 10px;
    line-height: 10px;
}
.contactForm input,
.contactForm textarea,
#contact-form-web input, 
#contact-form-web textarea {
    border: 0;
    width: 100%;
    background-color: #f2f2f2;
    padding: 10px;
    font-family: var(--font-text);
    font-weight: 600;
    font-size: 16px;
}
.contactForm textarea,
#contact-form-web textarea {
	height: 80px;
}
a.close-btn {
    position: absolute;
    top: 10px;
    right: 10px;
    font-size: 1.5em;
    color: var(--text);
    padding: .5em;
	z-index: 99;
}
a.close-btn:hover {
	color: var(--highlight);
}
.close-btn svg {
    fill: var(--text);
    width: 24px;
    height: 24px;
}
#contact-form-web.on a.close-btn {
	display: block;
}
.contactForm {
	margin: 30px 0 15px;
}
.ajaxInfo {
	display: none;
}




.parallax,
.section-parallax {
	min-height: 35vh;
    background-attachment: scroll;
    position: relative;
    background-attachment: fixed;
    background-position: center 0;
    background-repeat: no-repeat;
    background-size: 85vh;
}





.footer {	
	color: #FFFFFF;
	padding: 35px 0;
	background: #0f0f0f url(../img/footer-sign.png) no-repeat;
	background-position: 85% 105%;
}
.footer p,
.footer a {
	color: #8d8d8d;
}
.footer .logo {
	text-align: center;
	margin: 5px 0 15px;
}
/*
.footer ul li:not(:last-of-type):after {
	content: "/";
	color: #373737;
}
*/
.footer .contacts {
	margin: 10px auto 20px auto;
}
.footer .contacts svg {
    width: 14px;
    height: 14px;
    vertical-align: middle;
    fill: #FFFFFF;
    margin: 0 5px 0 0;
}
.footer .contacts a {
	color: var(--highlight);
	font-weight: 500;
	padding: 5px 0;
	margin: 0 8px 2px;
	font-size: 17px;
	display: inline-block;
}
.footer ul {
	padding-left: 15px;
	list-style: none;
}
.footer ul li {
	margin-bottom: 8px;
}
.footer ul li::before {
  content: "\2022";
  color: #454545;
  font-weight: bold;
  display: inline-block;
  width: 1em;
  margin-left: -1em;
}
.subfooter {
	font-size: 11px;
	opacity: .65;
	text-align: center;
	line-height: 2em;
	padding: 10px 0 25px;
}



div#cookieinfo {
    position: fixed;
    bottom: 20px;
	z-index: 999;
    background-color: var(--light);
    padding: 5px 20px;
    max-width: 70%;
    font-size: 11px;
    line-height: 15px;
	box-shadow: 0px 0px 15px rgba(0,0,0,.15);
}
div#cookieinfo .btn {
	padding: 7px 12px;
	font-size: 12px;
}



.items-gallery {
    display: flex;
    align-items: center;
    justify-content: center;
	padding: 30px 0;
	flex-wrap: wrap;
}
.items-gallery a {
	flex: 0 0 50%;
	padding: 10px;
}
.items-gallery .item img {
    display: block;
    width: 100%;
    height: 140px;
    object-fit: contain;
}
.items-gallery .item span {
	display: block;
	text-align: center;
	color: var(--text);
	font-weight: 600;
}



.standard.twocols .right-col {
    background: #f2f2f2;
    padding-top: 15px;
    padding-bottom: 15px;
}
.standard ul {
    padding-left: 25px;
}



.contact-section {
    background-color: var(--highlight);
    padding: 30px 0;
}
.contact-section p {
	font-size: 18px;
	font-weight: 600;
	margin: 5px 0 20px;
	letter-spacing: -1px;
	color: var(--dark);
}
.contact-section a {
    color: var(--dark);
    font-size: 18px;
    font-weight: 800;
	display: inline-block;
	width: 48%;
	position: relative;
}
.contact-section a em {
	font-style: normal;
	font-size: 12px;
	font-weight: 300;
	text-transform: uppercase;
	display: block;
}
.contact-section svg {
    position: absolute;
    width: 24px;
    top: -2px;
    left: -10px;
    opacity: .1;
    height: 24px;
}
.sl-overlay {
	opacity: .92;
}
.sl-wrapper .sl-image .sl-caption {
    background: #fff;
    color: var(--text);
    font-size: 14px;
	bottom: -50px;
}
	.ul-modify ul {
		display: flex;
		flex-wrap: wrap;
		align-items: stretch;
		justify-content: center;
		list-style: none;
		padding: 0 0;
		counter-reset: new-cnt;
	}
	.ul-modify ul li {
		counter-increment: new-cnt;
		flex: 0 0 95%;
		background-color: var(--light);
		padding: 10px 25px;
		margin: 10px 0 10px 0;
		box-shadow: 7px 7px rgb(0 0 0 / 25%);
		position: relative;
		overflow: hidden;
	}
	.ul-modify ul li::before {
		content: counter(new-cnt);
		color: var(--dark);
		font-size: 70px;
		position: absolute;
		bottom: 20px;
		left: 10px;
		opacity: .05;
	}
	
	
.news-detail h1 {
    text-align: left;
    line-height: 1.25em;
    font-size: 22px;
    font-weight: 700;
}
.news-detail .lead {
	margin: 10px 0 20px;
	font-size: 16px;
	line-height: 22px;
}
.carousel-gallery {
	margin: 15px auto 35px;
}
.carousel-gallery .item {
    transition: all .25s ease;
	position: relative;
}
.carousel-gallery .item:hover {
	transform: scale(1.05);
	z-index: 5;
}
.carousel-gallery .item img {
    width: 100%;
    height: 120px;
    object-fit: cover;
}
.carousel-gallery .owl-prev {
	left: -15px;
}
.carousel-gallery .owl-next {
	right: -15px;
}
.carousel-gallery .owl-prev, .carousel-gallery .owl-next {
    position: absolute;
    top: 45%;
    transform: translateY(-50%);
    font-size: 34px;
    font-weight: 700;
    z-index: 99;
    background: #FFF;
    padding: 7px 7px;
    line-height: 6px;
}
.carousel-gallery .owl-prev svg,
.carousel-gallery .owl-next svg {
	width: 12px;
	height: 12px;
}

.map-wrap {
	margin: 30px auto 40px;
}
.mod-118 {
    font-size: 16px;
    line-height: 22px;
}



.contacts .section {
    background-color: #f2f2f2;
	background-image: linear-gradient(45deg, #f5f5f5 0%, #e5e5e5 100%);
    font-size: 18px;
    border-radius: 10px;
    margin: 0 auto 15px;
    max-width: 90%;
    padding: 0 15px 25px 135px;
	position: relative;
	overflow: hidden;
	min-height: 150px;
}
.contacts .section h3 {
    text-transform: uppercase;
    font-size: 12px;
    letter-spacing: 1px;
    font-weight: 400;
    margin: 15px 0 10px;
    padding: 0 0 10px;
    position: relative;
}
.contacts .section h3:after {
	bottom: -3px;
	left: -15px;
	width: 70px;
	position: absolute;
	background-color: var(--hover);
	height: 1px;
	content: "";
}
.contacts .section h2 {
    font-size: 16px;
    font-weight: 600;
    margin: 5px 0 5px;
}
.contacts .section a {
	font-weight: 600;
	color: var(--hover);
	padding: 5px 5px 5px 0;
	margin: 2px 0;
	font-size: 15px;
	display: inline-block;
}
.contacts .section a:before {
	width: 14px;
	height: 14px;
	display: inline-block;
	margin: 0 10px 0 0;
	content: "";
}
.contacts .section a.phone:before {
	background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA1MTIgNTEyIj48IS0tIEZvbnQgQXdlc29tZSBGcmVlIDUuMTUuMyBieSBAZm9udGF3ZXNvbWUgLSBodHRwczovL2ZvbnRhd2Vzb21lLmNvbSBMaWNlbnNlIC0gaHR0cHM6Ly9mb250YXdlc29tZS5jb20vbGljZW5zZS9mcmVlIChJY29uczogQ0MgQlkgNC4wLCBGb250czogU0lMIE9GTCAxLjEsIENvZGU6IE1JVCBMaWNlbnNlKSAtLT48cGF0aCBkPSJNNDkzLjQgMjQuNmwtMTA0LTI0Yy0xMS4zLTIuNi0yMi45IDMuMy0yNy41IDEzLjlsLTQ4IDExMmMtNC4yIDkuOC0xLjQgMjEuMyA2LjkgMjhsNjAuNiA0OS42Yy0zNiA3Ni43LTk4LjkgMTQwLjUtMTc3LjIgMTc3LjJsLTQ5LjYtNjAuNmMtNi44LTguMy0xOC4yLTExLjEtMjgtNi45bC0xMTIgNDhDMy45IDM2Ni41LTIgMzc4LjEuNiAzODkuNGwyNCAxMDRDMjcuMSA1MDQuMiAzNi43IDUxMiA0OCA1MTJjMjU2LjEgMCA0NjQtMjA3LjUgNDY0LTQ2NCAwLTExLjItNy43LTIwLjktMTguNi0yMy40eiIvPjwvc3ZnPg==");
}
.contacts .section a.mail:before {
	background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA1MTIgNTEyIj48IS0tIEZvbnQgQXdlc29tZSBGcmVlIDUuMTUuMyBieSBAZm9udGF3ZXNvbWUgLSBodHRwczovL2ZvbnRhd2Vzb21lLmNvbSBMaWNlbnNlIC0gaHR0cHM6Ly9mb250YXdlc29tZS5jb20vbGljZW5zZS9mcmVlIChJY29uczogQ0MgQlkgNC4wLCBGb250czogU0lMIE9GTCAxLjEsIENvZGU6IE1JVCBMaWNlbnNlKSAtLT48cGF0aCBkPSJNNTAyLjMgMTkwLjhjMy45LTMuMSA5LjctLjIgOS43IDQuN1Y0MDBjMCAyNi41LTIxLjUgNDgtNDggNDhINDhjLTI2LjUgMC00OC0yMS41LTQ4LTQ4VjE5NS42YzAtNSA1LjctNy44IDkuNy00LjcgMjIuNCAxNy40IDUyLjEgMzkuNSAxNTQuMSAxMTMuNiAyMS4xIDE1LjQgNTYuNyA0Ny44IDkyLjIgNDcuNiAzNS43LjMgNzItMzIuOCA5Mi4zLTQ3LjYgMTAyLTc0LjEgMTMxLjYtOTYuMyAxNTQtMTEzLjd6TTI1NiAzMjBjMjMuMi40IDU2LjYtMjkuMiA3My40LTQxLjQgMTMyLjctOTYuMyAxNDIuOC0xMDQuNyAxNzMuNC0xMjguNyA1LjgtNC41IDkuMi0xMS41IDkuMi0xOC45di0xOWMwLTI2LjUtMjEuNS00OC00OC00OEg0OEMyMS41IDY0IDAgODUuNSAwIDExMnYxOWMwIDcuNCAzLjQgMTQuMyA5LjIgMTguOSAzMC42IDIzLjkgNDAuNyAzMi40IDE3My40IDEyOC43IDE2LjggMTIuMiA1MC4yIDQxLjggNzMuNCA0MS40eiIvPjwvc3ZnPg==);
}
.contacts .section .person {
	position: absolute;
	width: 120px;
	height: 100%;
	object-fit: cover;
	object-position: top center;
	top: 0;
	left: 0px;
}
.contacts .section a.mail {
	font-size: 13px;
}