@import url("//hello.myfonts.net/count/383d05");

body {
	overflow-x: hidden;
	overflow-y: scroll;
    font-family: "Manrope", sans-serif;
    line-height: 1.3;
}

.BehindTheScenesModule .content,
.disableSelection,
.InDepthSectionComponent .container .grid .col-2,
.ParallaxGridComponent .entry,
.ServicesModule .section .favorites .entry {
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
	-webkit-user-drag: none;
	-webkit-touch-callout: none;
	-webkit-user-select: none;
	-webkit-app-region: no-drag
}

.container {
	width: 100%;
	padding-left: 4.88281%;
	padding-right: 4.88281%
}

.container .grid,
.container .innerContainer {
	max-width: 1670px;
	margin: 0 auto;
	position: relative;
	width: 100%
}

.container .grid {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap
}

.container .grid .ml-half,
.container .innerContainer .ml-half {
	margin-left: 14.67066%
}

.container .grid .ml-1,
.container .innerContainer .ml-1 {
	margin-left: 0
}

.container .grid .col-1,
.container .innerContainer .col-1 {
	width: 11.67665%
}

.container .grid .col-2,
.container .innerContainer .col-2 {
	width: 29.34132%
}

.container .grid .col-2-5,
.container .innerContainer .col-2-5 {
	width: 35.32934%
}

.container .grid .col-3,
.container .innerContainer .col-3 {
	width: 47.00599%
}

.container .grid .col-4,
.container .innerContainer .col-4 {
	width: 64.67066%
}

.container .grid .ml-1,
.container .innerContainer .ml-1 {
	margin-left: 17.66467%
}


h1,
h2,
h3,
h4,
h5,
h6 {
    font-weight: 400;
}

h1 {
	font-size: 20px;
	line-height: 1.13
}



a {
	color: #000
}

input,
select,
textarea {
    font-family: "Manrope", sans-serif;
	font-size: 12px;
	color: #fff;
	padding: 3px 20px;
	width: 100%;
	height: 40px;
	font-size: 1.063rem;
	font-weight: 500;
	border: none;
	border-bottom: 2px solid #fefefe;
	background-color: #000;
	outline: 0;
}

textarea {
	height: 150px;
}


#TemplateLayer {
	position: relative;
	z-index: 2;
	background-color: #fff
}

* {
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	-webkit-box-sizing: border-box;
	box-sizing: border-box
}

a,
a:active,
a:hover,
a:visited {
	text-decoration: none
}

a,
abbr,
acronym,
address,
applet,
article,
aside,
audio,
big,
blockquote,
body,
canvas,
caption,
center,
cite,
code,
dd,
del,
details,
dfn,
div,
dl,
dt,
em,
embed,
fieldset,
figcaption,
figure,
footer,
form,
h1,
h2,
h3,
h4,
h5,
h6,
header,
hgroup,
html,
i,
iframe,
img,
ins,
kbd,
label,
legend,
li,
mark,
menu,
nav,
object,
ol,
output,
p,
pre,
q,
ruby,
s,
samp,
section,
small,
span,
strike,
sub,
summary,
sup,
table,
tbody,
td,
tfoot,
th,
thead,
time,
tr,
tt,
u,
ul,
var,
video {
	margin: 0;
	padding: 0
}

.disable-hover,
.disable-hover * {
	pointer-events: none !important
}

body.busy,
body.busy * {
	cursor: progress !important
}

.scroll-container {
	position: relative;
}

.back-to-top {
  position: fixed;
  bottom: 40px;
  right: 40px;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 18px;
  background-color: black;
  color: white;
  text-transform: uppercase;
  text-decoration: none;
  border-radius: 100px;
  font-size: 14px;
  font-weight: 500;
  opacity: 0;
  transform: translateY(100%);
  pointer-events: none;
  transition: all 0.4s ease;
  z-index: 1000;
}

.back-to-top .arrow {
  font-size: 16px;
  line-height: 1;
}

.back-to-top.show {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

::-webkit-scrollbar {
    display: none;
}


.viewport {
  opacity: 0;
  transition: opacity 1s ease-in-out;
}

.viewport.visible {
  opacity: 1;
}



.wave-container {
			position: absolute;
			bottom: -2px;
			left: 50%;
			transform: translate(-50%, 100%);
			width: 500px;
			height: 56px;
			display: block;
			transition: 0.3s ease-in-out;
		}

		.wave-text {
			position: absolute;
			top: 50%;
			left: 52%;
			transform: translate(-50%, -50%);
			color: black;
			font-size: 16px;
			z-index: 1;
		}

		.wave-container svg {
			width: 100%;
			height: 100%;
		}
		
		.wave-container.visible {
            transform: translate(-50%, 0%);
        }



        .close:hover, .close:active {
            background-color: unset;
        }
        


.HeroModule {
	padding-top: 20px;
	width: 100%;
	background-color: #fff;
	margin-bottom: 20px;
}

.HeroModule .countdown {
	position: absolute;
	display: none;
	right: 0;
	top: 34px;
	z-index: 10
}

.HeroModule .countdown .circle {
	width: 25px;
	height: 22px;
	display: inline-block;
	margin-right: 8px;
	-webkit-transform: translate3d(0, 5px, 0);
	transform: translate3d(0, 5px, 0)
}


.HeroModule .animationContainer {
	width: calc(100% - 3px);
	height: 100%;
	position: relative;
	overflow: hidden
}

.HeroModule .animationContainer video {
	width: calc(100% + 6px);
	margin-left: -3px;
	pointer-events: none
}

.HeroModule .animationContainer img {
	margin-left: -3px
}

.HeroModule .animationContainer .content {
	position: relative
}

.HeroModule .animationContainer .content video {
	mix-blend-mode: multiply
}

.HeroModule .animationContainer .content .blobCanvas {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	mix-blend-mode: multiply
}

.HeroModule .title {
	font-size: 14px;
	font-weight: 400;
	line-height: 1.57;
	margin-bottom: 15px
}

.HeroModule .headline,
.HeroModule .title {
	font-style: normal;
	font-stretch: normal;
	letter-spacing: normal;
	color: #000;
	width: 100%;
	text-align: center
}

.HeroModule .headline {
	font-size: 40px;
	font-weight: 300;
	line-height: .8
}

.HeroModule a:before {
	position: absolute;
	left: -25px;
	top: 5px;
	content: " ";
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background-color: #000
}

.HeroModule a {
	position: relative;
	width: 109px;
	height: 22px;
	font-size: 14px;
	font-weight: 400;
	font-style: normal;
	font-stretch: normal;
	line-height: 1.57;
	letter-spacing: normal;
	color: #000;
	border-bottom: 1px solid #000
}

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

.HeroModule .scrollIndicator {
	position: absolute;
	top: 0;
	left: calc(50% - 6px);
	width: 24px;
	height: 55px;
	overflow: hidden
}

@media (min-width:1025px) {
	.HeroModule .animationContainer {
		width: 100%
	}

	.HeroModule .headline {
		font-size: 80px
	}

	.HeroModule .countdown {
		display: block;
		right: unset;
		left: 88.32335%;
		width: 200px
	}
}


.header {
	padding-top: 20px;
	padding-bottom: 20px;
	position: relative;
	z-index: 19;
	width: 100%;
}

.header-menu {
  padding-top: 80px;
  padding-bottom: 80px;
  position: fixed;
  top: 0;
  right: 0;
  z-index: 10;
  width: 100%;
  height: 100vh;
  overflow-y: auto;
  transform: translateX(100%);
  transition: transform 0.5s ease;
  background-color: #000;
}

.header-menu.active {
  transform: translateX(0);
}



.js-hamburger-menu {
  position: fixed;
  right: 0;
  top: 20px;
  z-index: 1000;
  transition: transform 0.3s ease, top 0.3s ease;
  transform: translate(0, 0); /* start position */
}

.js-hamburger-menu.hidden-on-scroll {
  /* this is now controlled via JS, so you may not need this class unless for fallback */
}


.js-hamburger-menu.centered {
  top: 50%;
  transform: translate(0, -50%);
}

.js-hamburger-menu.hidden-on-scroll {
  transform: translateX(200%);
}

.js-hamburger-menu.reveal-on-hover {
  transform: translateX(0);
}



.shape-overlays {
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9999;
  pointer-events: none;
}

.shape-overlays__path {
  fill: url(#gradient1);
}

.heder-wrap {
	position: relative;
	z-index: 5;
}

.header-menu-logo { 
    margin-bottom: 40px;
}


.header-logo img {
    width: 110px;
    height: 40px;
}

.header-nav {
	margin-bottom: 80px;
}


.header-nav li {
    position: relative;
    z-index: 12;
    margin-bottom: 10px;
}

.header-nav>li>a {
	position: relative;
	display: inline-block;
	color: #fff;
	font-size: 35px;
	transition: all 0.3s;
	transition: 0.4s;
}

.header-nav>li>a::before {
	position: absolute;
	top: 0;
	left: 0;
	width: 0;
	height: 0;
	border-radius: 10px;
	background-color: #fff;
	transition: all 0.4s;
	content: '';
}

.header-nav li>a:focus,
.header-nav li>a:hover {
	padding-left: 20px;
}

.header-nav li>a:focus::before,
.header-nav li>a:hover::before {
	top: 50%;
	width: 6px;
	height: 6px;
	transform: translateY(-50%);
}

.header-social-media {
	display: flex;
	flex-wrap: wrap;
}

.header-social-media>li {
	margin-right: 50px;
}

.header-social-media>li:last-of-type {
	margin-right: 0;
}

.header-social-media>li>a {
	font-size: 14px;
	color: #fff;
	opacity: 0.5;
	transition: all 0.4s;
}

.header-social-media>li>a:focus,
.header-social-media>li>a:hover {
	opacity: 1;
}

.hamburger {
	position: fixed;
	top: 50%;
	right: 0;
	z-index: 8;
	transform: translateY(-50%);
	transition: all 0.4s;
	display: none;
}

.hamburger.close {
	z-index: 11;
	right: -15px;
	opacity: 0;
	visibility: hidden;
}

.hamburger.active {
	opacity: 1;
	visibility: visible;
}

body.active .hamburger.close {
	opacity: 1;
	visibility: visible;
}


body.menu-active .mobile-menu span::before,
body.menu-active .mobile-menu span::after {
	 background-color: #fff;
	 width: 100%;
}


body.menu-active .mobile-menu span::before {
     transform: rotate(45deg);
     top: 0;
}


body.menu-active .mobile-menu span::after {
     transform: rotate(-45deg);
     bottom: 0;
}


.mobile-menu {
    align-items: center;
    position: fixed;
    top: 25px;
    right: 15px;
    z-index: 20;
    display: block;
    width: 30px;
    height: 30px;
    display: flex;
    justify-content: center;
}

.mobile-menu span {
    width: 20px;
    height: 2px;
    display: block;
    background-color: #000;
    position: relative;
}

.mobile-menu span::before,
.mobile-menu span::after {
    width: 100%;
    height: 2px;
    display: block;
    background-color: #000;
    position: absolute;
    content: '';
}


.mobile-menu span::before {
    top: -5px;
}

.mobile-menu span::after {
    bottom: -5px;
    width: 70%;
}



@media (min-width:768px) {
	.header-menu {
		display: flex;
		align-items: center;
	}

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

	.header-nav>li>a {
		font-size: 60px;
	}

	.header-menu-logo {
		width: 50%;
	}

	.header-navigation {
		width: 50%;
	}
	
	
	
	.hamburger {
        display: block;
    }
    
    .mobile-menu {
        display: none;
    }
}

.case {
	margin-bottom: 80px;
}

.case-holder {
	display: grid;
	grid-template-columns: repeat(1, 1fr);
	grid-column-gap: 50px;

}


@media (min-width:430px) {
	.case-holder {
		grid-template-columns: repeat(3, 1fr);
		grid-column-gap: 80px;

	}
}


@media (min-width:768px) {
	.case {
		margin-bottom: 80px;
	}

	.case-holder {
		grid-template-columns: repeat(3, 1fr);
		grid-column-gap: 80px;

	}
}

.about {
	margin-bottom: 50px;
	margin-top: -150px;
}

.about-image {
	height: 95vh;
}

.about-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.about-text {
	padding-top: 50px;
	padding-bottom: 50px;
	margin-top: -20px;
}

.about-text h2 {
	font-size: 50px;
	margin-bottom: 20px;
}

.about-text-intro {
	max-width: 1000px;
	margin-left: auto;
	margin-bottom: 80px;
}

.about-text p {
	margin-bottom: 30px;
	font-size: 20px;
	font-weight: 300;
}

.about-text ul {
	margin: 0;
	padding: 0;
	list-style: none;
}

.about-text ul li {
	margin-bottom: 15px;
	font-size: 20px;
	color: #000;
	margin-bottom: 50px;
	position: relative;
}

.about-text ul li::before {
	position: absolute;
	top: -10px;
	left: 0;
	width: 100%;
	content: '';
	background-color: #a9a9a9;
	height: 1px;
}

.about-text ul span {
	display: block;
	font-size: 40px;
	font-weight: 500;
	line-height: 1.2;
}

@media (min-width:768px) {
    
.about {
	margin-bottom: 50px;
}


	.about-text h2 {
		font-size: 100px;
		margin-bottom: 30px;
	}


	.about-text p {
		font-size: 22px;
		font-weight: 300;
	}
	
	.about-text p br {
		display: none;
	}

	.about-text ul {
		display: flex;
		flex-wrap: wrap;
		max-width: 1250px;
		margin: 100px auto 0;
	}

	.about-text ul li {
		padding: 0 30px;
		width: 50%;
		display: flex;
		justify-content: space-between;
	}
	
	
    .about-text ul li::before {
	   left: 30px;
       width: 80%;
	   content: '';
    }
    
    
.about-text ul span {
	display: block;
	font-size: 40px;
	font-weight: 500;
	line-height: 1.2;
	margin-right: 65px;
}
}


.map iframe {
	width: 100%;
	height: 350px;
}

@media (min-width:768px) {
	.map iframe {
		height: 500px;
	}
}


.service {
    margin-top: -120px;
	padding-bottom: 0px;
}

/*.service-top {*/
/*	margin-bottom: 200px;*/
/*}*/

.service-top-title h2 {
	font-size: 50px;
	text-align: center;
}

.service-top-image {
	margin-bottom: 30px;
	height: 90vh;
}

.work-top-image {
	margin-bottom: 30px;
	height: 30vh;
}

.service-top-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.service-image img {
	margin-bottom: 20px;
	width: 100%;
}

.service-text span {
	margin-bottom: 25px;
	display: block;
	color: #000;
	font-size: 13px;
	opacity: 0.5;
}

.service-text h2 {
	margin-bottom: 20px;
	font-size: 35px;
	line-height: 1.2;
}

.service-text p {
	margin-bottom: 30px;
	font-size: 20px;
	font-weight: 300;
}

.service-text .link {
	color: #000;
	font-size: 20px;
	text-decoration: underline;
}

.service-text .link:hover {
	text-decoration: none;
}

.service-holder {
	margin-bottom: 100px;
}

.service-holder:last-of-type {
	margin-bottom: 0;
}

.service-wrap {
	padding-top: 50px;
}

.service .card-service {
	margin-bottom: 40px;
}

.service .card-service:last-child {
	margin-bottom: 0;
}


.work-top-image {
	margin-bottom: 0;
	height: 100%;
}

@media (min-width:768px) {
	.service {
		padding-bottom: 0px;
	}

.work-top-image {
	margin-bottom: 30px;
	height: 100%;
}

	.service p {
    font-family: "Manrope", sans-serif;
	   	line-height: 1.4;
	   	font-weight: 300;
	}


	.service-text h2 {
		margin-bottom: 50px;
		font-size: 40px;
	}

	.service-text p {
		margin-bottom: 50px;
		font-size: 22px;
		font-weight: 300;
	}

	.service .card-service {
		margin-bottom: 0;
	}
}

@media (min-width:1024px) {
	.service-top-title h2 {
		font-size: 80px;
	}

	.service-holder {
		margin: 0 -30px 150px;
		display: flex;
		justify-content: space-between;
	}
	
	
	.service-holder::first-child {
		margin-top: 150px;
	}
	
	
	.service-image {
		width: 50%;
		padding: 0 30px;
	}
	
	.service-text {
	    width: 50%;
	    padding: 0 30px;
	}


	.service-text-right {
		margin-top: 20px;
		width: 100%;
	}


	.service-text h2 {
		font-size: 35px;
		margin-bottom: 30px;
		line-height: 1.1;
	}
}

@media (min-width:1200px) {

	.service-text-right {
		margin-top: 30px;
	}

	.service-text h2 {
		font-size: 50px;
	}
}

.card-service {
	margin-bottom: 80px;
	display: block;
	width: 100%;
	text-decoration: none;
}


.card-service-img {
	margin-bottom: 10px;
}

.card-service-img img {
	width: 100%;
}

.card-service-ttl {
	font-size: 22px;
	font-weight: 400;
	line-height: 1.2;
}

.card-service-text ul {
	margin-bottom: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	list-style: none;

}

.card-service-text li {
	margin-right: 10px;
	font-size: 15px;
	color: #afadad;
}

.card-service-text li:last-of-type {
	margin-right: 0;
}




/* ### work ### */
.service .work-holder:first-child {
margin-top: 200px
}
.work-holder {
	margin-bottom: 100px;
}

.work-image {
	margin-bottom: 20px;
}

.work-image img {
	width: 100%;
	object-fit: cover;
}


.work-content-top {
	margin-bottom: 30px;
}

.work-content-top h2 {
	font-size: 35px;
	margin-bottom: 30px;
	line-height: 1;
}

.work-content-top ul {
	margin-bottom: 50px;
}

.work-content-top li {
	font-size: 20px !important;
	list-style: none;
	margin-bottom: 10px;
}

.work-content-top p {
	font-size: 20px;
	margin-bottom: 20px;
	font-weight: 300;
}

.work-content-bottom h2 {
	margin-bottom: 10px;
}

.work-content-bottom h3 {
	font-size: 30px;
}

.work-content-bottom p{
    font-family: "Manrope", sans-serif;
	margin-bottom: 30px;
	font-size: 18px;
	font-weight: 300;
	line-height: 1.4;
}

.work-content-bottom p strong{
    display: block;
    margin-bottom: 5px;
    font-weight: 600;
}


.work-content-bottom li {
	font-size: 20px;
	list-style: none;
	margin-bottom: 20px;
}

.work-content-bottom li strong {
	display: block;
	margin-bottom: 5px;
	font-size: 25px;
}

.work-link {
	text-decoration: underline;
	font-size: 20px;
	margin-top: 40px;
	display: block;
}

.work-link:hover {
	text-decoration: none;
}


.work-content-description h3 {
    font-size: 30px;
    margin-bottom: 20px;
    font-weight: 500;
    margin-top: 60px;
    line-height: 1.3;
}


@media (min-width:767px) {
   .work-content-bottom p{
      font-size: 22px;
    }
}


@media (min-width:1025px) {
	.work-holder {
		display: flex;
		margin: 0 -30px 150px;
	}

	.work-holder.is-alt {
		flex-direction: row-reverse;
	}

	.work-image {
		width: 50%;
		padding: 0 30px;
		margin-bottom: 0;
	}

	.work-content {
		width: 50%;
		padding: 0 30px;
	}
	
	
    .work-content-top {
	    margin-bottom: 50px;
    }


	.work-content-top h2 {
		font-size: 50px;
		margin-bottom: 30px;
	}

	.work-content-bottom h3 {
		font-size: 40px;
		margin-bottom: 10px;
	}
}




/* ### service-item ### */
.service-item {
  margin-top: -120px;
}


.service-item .work-holder {
  display: block;
}

.service-item .work-image,
.service-item .work-content {
  width: 100%;
  padding-left: 0;
  padding-right: 0;
}

.service-item .work-image {
  margin-bottom: 30px;
  display: block;
}


.service-item .work-image img {
  height: 100%;
}


.service-item .work-content-description ul{
  margin-left: 0 !important;
  display: block;
  margin: 0 0 50px 0;
  padding: 0;
}

.service-item .work-content-description li{
  padding: 0 !important;
  width: 100% !important;
  font-weight: 300;

}



@media (min-width:767px) {
    .service-item .work-image {
       height: 90vh;
    }
    
    
    .service-item .work-holder {
       display: flex;
    }
}


@media (min-width:991px) {
  .service-item .work-content-top ul{
    max-width: 1170px;
    margin-left: auto;
    display: flex;
    flex-wrap: wrap;
  }
  
  .service-item .work-content-top li{
      padding: 0 10px;
      width: 50%;
  }
}



/* ### card-form ### */
.contact {
	padding-top: 100px;
	padding-bottom: 80px;
}

.contact button {
	padding: 15px 35px;
	background-color: transparent;
	border: 1px solid #fff;
	color: #fff;
	font-size: 20px;
	font-weight: 500;
	border-radius: 5px;
	transition: 0.3s all ease-in-out
}

.contact button:focus,
.contact button:hover {
	background-color: #fff;
	color: #000;
}

.contact button:focus input,
.contact button:hover input {
	color: #000;
}

.contact button input {
    padding: 0;
    height: unset;
    border: 0;
    background-color: unset;
    font-weight: 600;
}

.contact button span {
    display: none;
}

.contact button br {
    display: none;
}

.card-form {
	padding: 30px;
	border-radius: 10px;
	background-color: #000;
	overflow: hidden;
	max-width: 800px;
	margin: 0 auto;
}

.card-form-title {
	margin-bottom: 50px;
	font-size: 50px;
	text-align: center;
	font-weight: 500;
	color: #fff;
}

.card-form-group {
	margin-bottom: 33px;
}

.card-form-group label {
	font-size: 20px;
	color: #fff;
	transition: 0.3s all ease-in;
}

.card-form-group label span {
	color: #c90a0a;
	font-size: 14px;
}

.card-form button {
	margin-left: auto;
	display: block;
}

.card-form-group.active label {
	font-size: 16px;
}


.card-form-group.active input {
	border-bottom: 2px solid #fff;
}

.card-form ul,
.card-form ul li,
.card-form ul li a {
    color: #fff;
}

.card-form ul {
    list-style: none;
}

.card-form li {
    font-size: 25px;
    margin-bottom: 20px;
    font-weight: 300;
}

.card-form li strong {
    margin-right: 10px;
    display: inline-block;
}

.card-form li a:hover {
    text-decoration: underline;
}


@media (min-width:767px) {
	.card-form {
		padding: 60px 100px;
	}
}





/* tab */
.partners {
  margin-bottom: 100px;
}

.partners h1 {
  font-size: 50px;
  margin-bottom: 50px;
  text-align: center;
}

.tab-body {
  display: none;
}

.tab-body.active {
  display: block;
}

.tabs-links {
  width: 100%;
  overflow-x: scroll;
}

.tab-head {
  list-style: none;
  display: flex;
  border-bottom: 1px solid #323030;
  margin-bottom: 30px;
}

.tab-head li {
  margin-bottom: 20px;
}

.tab-head li:first-child {
  margin-right: 10px;
}

.tab-head a {
  font-size: 25px;
  display: block;
  padding: 10px 35px;
}

.tab-link {
  transition: 0.3s all ease-in-out;
  border-radius: 30px;
}

.tab-link.active {
  font-weight: 500;
  background-color: #000;
  color: #fff;
}

.partners-logo {
  display: grid;
  grid-template-columns: auto auto;
  gap: 30px;
}

.partners-item {
  display: flex;
  justify-content: center;
  align-items: center;
  background: #efefef;
  border-radius: 20px;
  padding: 20px;
}

.partners-item img {
  width: 100%;
  height: 100%;
}

@media (min-width: 479px) {
  .partners-logo {
    grid-template-columns: auto auto auto;
    gap: 50px;
  }
}



@media (min-width: 767px) {
  .partners-item {
    padding: 30px 40px;
  }
}


@media (min-width: 1025px) {
  .partners {
    margin-bottom: 150px;
  }

  .partners h1 {
    font-size: 100px;
    margin-bottom: 100px;
  }
  
  .partners-item {
    padding: 30px;
  }

  .tabs {
    display: flex;
    margin: 0 -20px;
  }

  .tab-body {
    display: none;
    width: 70%;
    padding: 0 20px;
  }

  .tabs-links {
    width: 30%;
    padding: 0 20px;
    overflow: unset;
  }

  .tab-link.active {
    font-weight: 500;
    background-color: transparent;
    color: #000;
  }

  .tab-head {
    display: block;
    border-bottom: 0;
    margin-bottom: 0;
    width: unset;
  }

  .tab-head li {
    border-bottom: 1px solid #323030;
    margin-bottom: 0;
  }

  .tab-head li:first-child {
    margin-right: 0;
  }

  .tab-head a {
    font-size: 30px;
    padding: 15px 0;
  }
}


@media (min-width: 1200px) {
  .partners-item {
    padding: 30px 60px;
  }
}



/* loctaion */
.location {
  margin-bottom: 100px;
}

.location-map {
  display: none;
}

.location-map img {
  width: 100%;
}

  .location-map-mobile {
    display: block;
   }
   
.location-map-mobile img {
    width: 100%;
   }

@media (min-width: 767px) {
  .location-map {
    display: block;
  }
    .location-map-mobile {
    display: none;
   }
}

@media (min-width: 1025px) {
  .location {
    margin-bottom: 150px;
  }
  
}




/* privacy */
.privacy {
  padding-top: 50px;
  padding-bottom: 70px;
}

.privacy h1 {
  font-size: 60px;
  margin-bottom: 20px;
}

.privacy h2 {
  font-size: 50px;
  margin-bottom: 30px;
}

.privacy h3 {
  font-size: 30px;
  margin-bottom: 30px;
}

.privacy p {
  font-size: 25px;
  margin-bottom: 60px;
  font-weight: 300;
}

.privacy ul {
  list-style: none;
  margin-bottom: 60px;
}

.privacy li {
  position: relative;
  padding-left: 30px;
  margin-bottom: 20px;
  font-size: 25px;
}

.privacy li::before {
  position: absolute;
  top: 15px;
  left: 0;
  width: 10px;
  height: 10px;
  border-radius: 100%;
  background-color: #000;
  content: '';
}


@media (min-width: 767px) {
.privacy {
  padding-bottom: 100px;
}

.privacy h1 {
  font-size: 100px;
  margin-bottom: 30px;
}

.privacy h2 {
  font-size: 70px;
  margin-bottom: 30px;
}

.privacy h3 {
  font-size: 50px;
  margin-bottom: 30px;
}
}





/* ### footer ### */
.footer {
	padding-top: 70px;
	padding-bottom: 70px;
	background-color: #000;
	position: relative;
	overflow: hidden;
}

.footer ul {
	margin: 0;
	padding: 0;
	list-style: none;
}

.footer ul>li {
	margin-bottom: 10px;
}

.footer ul>li:last-of-type {
	margin-bottom: 0;
}

.footer ul>li>a {
	display: inline-block;
	color: #fff;
	font-size: 18px;
	text-decoration: none;
}

.footer ul>li>a:hover {
	text-decoration: underline;
}

.footer-title {
	margin-bottom: 30px;
	font-size: 22px;
	font-weight: 700;
	color: #fff;
}

.footer-left {
	margin-bottom: 50px;
}

.footer-mid {
	margin-bottom: 50px;
}

.footer-mid iframe {
	width: 100%;
	height: 350px;
	border-radius: 30px;
}

.footer-location {
	padding-top: 20px;
}

.footer-contact-item {
	display: flex;
	gap: 5px;
	margin-bottom: 8px;
}

.footer-contact-info strong {
	margin-right: 5px;
}

.footer-office {
	margin-bottom: 15px;
	font-size: 20px;
	font-weight: 600;
	color: #fff;
}

.footer-location address {
	color: #fff;
	font-size: 18px;
	font-style: normal;
	line-height: 1.5;
}

.footer-right a {
	margin-right: 5px;
}

@media (min-width:768px) {
	.footer {
		padding-top: 100px;
		padding-bottom: 100px;
	}

	.footer-holder {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}

	.footer-mid {
		margin-bottom: 0;
		width: 50%;
	}

	.footer-right,
	.footer-left {
		margin-bottom: 0;
		width: 23%;
	}
}




/* Pinterest style masonry layout */
.gallery {
  columns: 3;
  column-gap: 90px;
  max-width: 100%;
  margin: 0 auto;
}


#sketch {
  position: fixed;
  z-index: 1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
} 

.hollow {
  opacity: 0;
  pointer-events: none;
}


.gallery {
  margin-top: 20px;
  list-style: none;
}



@media screen and (max-width: 950px) {
  .gallery {
    gap: 25px;
  }
}

@media screen and (max-width: 750px) {
  .gallery {
    gap: 35px;
    columns: 2;
  }
}

@media screen and (max-width: 450px) {
  .gallery {
    columns: 2;
  }
}

.gallery .gallery-item {
  position: relative;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  background-color: transparent;
  border-radius: 8px;
  overflow: hidden !important;
  width: 100%;
  height: 100%;
  will-change: transform !important;
  display: -webkit-inline-flex;
}


/* Style for when WebGL effect is active */
.gallery .gallery-item.effect-active {
  z-index: 0;
}

/* Let original image fade gracefully */
.gallery .gallery-item.effect-active .gallery-item-img {
  opacity: 1;
}


.gallery .gallery-item.featured .gallery-item-img {
  height: auto;
  object-position: center;
  border-radius: 8px;
}

@media screen and (min-width: 751px) {
  .gallery .gallery-item.featured {
    /* Only make featured items larger on non-mobile */
    transform: scale(1.02);
    z-index: 1;
  }
}

@media screen and (max-width: 750px) {
  .gallery .gallery-item.featured {
    grid-column: span 1;
  }
}

.gallery .gallery-item .gallery-item-img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
  max-width: 100%;
}

/* Hide the text elements and categories */
.gallery .gallery-item .gallery-item-text,
.gallery .gallery-item .categories {
  display: none;
}

.gallery .gallery-item .gallery-item-text {
  padding: 1rem 1.25rem;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  background-color: #fff;
}

.gallery .gallery-item .gallery-item-text .text-1 {
  font-size: 0.8rem;
  opacity: 0.6;
}

.gallery .gallery-item .gallery-item-text .text-2 {
  font-size: 1rem;
  font-weight: 600;
  margin-top: 2px;
}

.gallery .gallery-item .categories {
  font-size: 0.75rem;
  opacity: 0;
  margin-top: 0;
  padding: 0 1.25rem 1rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  color: #666;
  word-spacing: 0.5rem;
  background-color: #fff;
}

/* Image container - ensures proper sizing */
.work-image-container {
    width: 100%;
    position: relative;
    overflow: hidden;
}

/* Content container - ensures clear separation */
.work-content-container {
    width: 100%;
    position: relative;
    z-index: 2; /* Ensures content stays above any absolute positioned elements */
}








/* domestic */
    .domestic-holder {
    margin-top: 100px;
}

.domestic-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

    .domestic-content {
    margin-bottom: 40px;
}




@media screen and (min-width: 750px) {
    
    .domestic-holder {
    display: flex;
    margin: 100px -30px 0;
}

.domestic-holder.is-alt {
    flex-direction: row-reverse;
}

    .domestic-content {
    padding: 0 30px;
    width: 50%;
}

.domestic-image {
    padding: 0 30px;
    width: 50%;
}
 
}

/* About Page Responsive Images */
.about-hero {
    position: relative;
    width: 100%;
    margin-bottom: 2rem;
}

.responsive-image, 
.about-image {
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
    max-height: 80vh;
}

/* Optional: Different aspect ratios for mobile/desktop */

@media (min-width: 768px) {
}
.responsive-service-image,
.work-image img {
    width: 100%;
    height: 100%;
    display: block;
    transition: transform 0.3s ease;
}

.work-image img {
   height: unset;
}

.responsive-work-image{
    display: block;
}
.video-container{
 max-width: 1080px;
 margin:0 auto;
}

.footer-credit {
    text-align: right;
    margin-top: 20px;
    padding-right: 40px;
    color: white;
}

@media (max-width: 767px) {
    .footer-credit {
        padding-right: 30px;
        font-size: 12px;
    }
}
.footer-credit a {
    color: white;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.footer-credit img {
    height: 20px;
}
