@font-face { font-family: neue-reg; src: url('fonts/NeueMontreal-Light.otf'); } 
@font-face { font-family: neue-med; font-weight: medium; src: url('fonts/NeueMontreal-Regular.otf');}

*{
    margin: 0px;
    padding: 0px;
}

img{
    display: block;
}

body{
	background-color: #000000;
	color: white;
	margin: 0;
}

html {
  scroll-behavior: smooth;
}

/* NAVIGATION */

.nav-link{
	color: #FFFFFF;
	text-decoration: none;
}

nav ul {
	font-family: neue-reg;
	letter-spacing: 1px;
   list-style: none;
   text-align: center;
}

nav ul li {
   display: inline-block;
}

ul {
 	display: flex;
 	flex-direction: row;
 	gap: 40px;
 	justify-content: right;
 	z-index: 3000;
}

.ul-col{
	flex-direction: column;
	gap: 0px;
	justify-content: center;
	padding-left: 18px;
}

li {
	font-family: neue-reg;
	font-size: 16px;
}

.nav-hover {
  transition: font-weight 0.3s ease-in-out;
}

.nav-hover:hover {
	font-weight: 600;
}

/* HAMBURGER MENU */

.off-screen-menu{
	z-index: 10;
	background-color: #000000;
	height: 100vh;
	width: 100%;
	max-width: 900px;
	position: fixed;
	top: 0;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	text-align: center;
	transition: .3s ease;
	right: -900px;
	border: solid;
	border-color: #FFFFFF;
	border-width: 0px 0px 0px 0.5px;
}

.off-screen-menu.active{
	right: 0;
}

.cross {
	width: 30px;
	height: 30px;
	z-index: 20;
	position: absolute;
	top: 40px;
	right: 24px;
	display: none;
	margin-top: 15px;

}

.cross.active{
	display: block;
}

.hamburger {
	width: 30px;
	height: 20px;
	display: none;
	flex-direction: column;
	justify-content: space-between;
}

.line {
	width: 100%;
	height: 2px;
	background-color: #FFFFFF;
}

.hamburger.active{
	display: none;
}

.mobile-nav{
	flex-direction: column;
	list-style: none;
}

.p-mob-nav{
	font-size: 20px;
	color: white;
	text-decoration: none;
}

.cross-line-1 {
	width: 100%;
	height: 2px;
	background-color: #FFFFFF;
	rotate: 45deg;
	position: absolute;
}

.cross-line-2 {
	width: 100%;
	height: 2px;
	background-color: #FFFFFF;
	rotate: -45deg;
	position: absolute;
}

.cta-wrap-mobile{
	display: none;
}

body.active{
	overflow: hidden; /* Prevents scrolling when hamburger menu is opened */
}

/* SECTIONS */

section{
	padding: 86px 84px;
}

.section-border{
	border: solid;
	border-width: 0.5px 0px 0px 0px;
}

.section-border-2{
	border: solid;
	border-width: 0.5px 0px 0.5px 0px;
}

header {
	padding: 24px 84px;
	border: solid;
	border-width: 0px 0px 0.5px 0px;
	border-color: #FFFFFF;
	position: fixed;
	width: 100%;
	top: 0;
	left: 0;
	z-index: 1000;
	background-color: #000000;
	box-sizing: border-box;
}

.no-border{
	border: none;
}

footer {
	padding: 84px 84px;
	background-color: #000000;
	border: solid;
	border-width: 0.5px 0px 0px 0px;
	border-color: #FFFFFF;

}

.section-padding{
	padding: 86px 84px;
}

.hero{
	height: 667px;
}


p {
	font-family: neue-reg;
	letter-spacing: 1px;
}


h1{
	font-family: neue-med;
	font-size: 96px;
	line-height: 100px;
}

.no-margin{
	margin-top: 0px;
}

h2{
 	font-family: neue-med;
	font-size: 64px;
	line-height: 80px;
}

h3{
	font-family: neue-med;
	font-size: 48px;
	line-height: 60px;
}

h4{
	font-family: neue-med;
	font-size: 20px;
	line-height: 22px;
}

.center-text {
	text-align: center;
}

.black-text{
	color: #000000;
}

.work-text{
	padding-top: 220px;
	max-width: 40%;
	margin: 0 auto;
}

.circle-1{
	position: absolute;
	left: -70px;
	top: -35px;
	z-index: -1;
}

.circle-2{
	position: absolute;
	left: -45px;
	top: -35px;
	z-index: -1;
}

.circle-3{
	position: absolute;
	left: -70px;
	top: -50px;
	z-index: -1;
}

.position-relative{
	position: relative;
}

.home-hero-img{
	width: 100%;
	height: 900px;
	background-size: cover;
	background-image: url(images/hero-img.webp);
	background-position: center;
}

.work-hero-img{
	margin-top: 100px;
	height: 800px;
	background-size: cover;
	background-image: url(images/work-hero-img.png);
	background-position: center;
}

.epark-hero-img{
	 margin-top: 100px;
	width: 100%;
	height: 800px;
	background-size: cover;
	background-image: url(images/eparkbg.webp);
	background-position: center;
}

.mucc-hero-img{
	margin-top: 100px;
	width: 100%;
	height: 800px;
	background-size: cover;
	background-image: url(images/muccbg.webp);
	background-position: center;
}

.viva-hero-img{
	margin-top: 100px;
	width: 100%;
	height: 800px;
	background-size: cover;
	background-image: url(images/viva-hero.png);
	background-position: center;
}

.book-hero-img{
	margin-top: 100px;
	width: 100%;
	height: 800px;
	background-size: cover;
	background-image: url(images/bookingcover.webp);
	background-position: center;
}

.form-hero-img{
	margin-top: 100px;
	width: 100%;
	height: 800px;
	background-size: cover;
	background-image: url(images/formcover.webp);
	background-position: center;
}



.cover{
    width: 100%;
    object-fit: cover;
    display: block;
}


.paperclip{
	position: absolute;
	top: -45px;
	left: 180px;
	z-index: 2;
}

.link{
	font-family: neue-reg;
	text-decoration: underline;
	color: white;
}

.overflow-hidden{
	overflow: hidden;
}

.feature-2{
	position: absolute;
	left: -180px;
}

.feature-3{
	position: absolute;
	right: -50px;
}

.margin-top{
	margin-top: 100px;
}

.margin-top-2{
	margin-top: 120px;
}

.section-feature{
	padding-top: 20%;
	padding-bottom: 20%;
}

.arrows{
	position: absolute;
	top: -50px;
	left: -170px;
	z-index: -1;
}

.smiley{
	position: absolute;
	right: -100px;
}

.border-bottom{
	border: solid;
	border-width: 0px 0px 0.5px 0px;
	border-color: #FFFFFF;
	padding-bottom: 30px;
	cursor: pointer;
}

.border-bottom2{
	border: solid;
	border-width: 0px 0px 0.5px 0px;
	border-color: #FFFFFF;
	padding-bottom: 30px;
	cursor: pointer;
}


.padding-nav-main{
	padding-bottom: 40px;
	padding-top: 40px;
	border: solid;
	border-width: 0px 0px 0.5px 0px;
	border-color: #FFFFFF;
	align-items: center;
	position: sticky;
  top: 100px;
  z-index: 900;
  background-color: #000000;
}

.padding-nav{
	padding-bottom: 40px;
	padding-top: 40px;
	border: solid;
	border-width: 0px 0px 0.5px 0px;
	border-color: #FFFFFF;
	align-items: center;
}

/* SCALE HOVER ANIMATION */
@keyframes scale {
  0%, 25% {
    transform: rotate(0deg);
    scale: 101%;
  }
  26%, 50% {
    transform: rotate(-2deg);
    scale: 102%;
  }
  51%, 75% {
    transform: rotate(2deg);
    scale: 103%;
  }
 	76%, 100% {
    transform: rotate(-2deg);
    scale: 104%;
  }
}

.hover-image:hover {
  animation: scale 0.8s infinite steps(2, jump-none);
}

.hover-image-shake:hover {
  animation: scale 0.8s infinite steps(2, jump-none);
}

.arrow {
  width: 50px;
  height: 50px;
  position: relative;
  transform-origin: center;
  align-items: end;
}

.arrow.active {
  width: 50px;
  height: 50px;
  position: relative;
  transform-origin: center;
  transform: scaleY(-1);
  align-items: end;
}

.arrow2 {
  width: 50px;
  height: 50px;
  position: relative;
  transform-origin: center;
}

.arrow2.active {
  width: 50px;
  height: 50px;
  position: relative;
  transform-origin: center;
  transform: scaleY(-1);
}

.line-1, .line-2 {
  width: 20px;  
  height: 1px;
  background: #fff;
  position: absolute;
  top: 50%;
  left: 50%;
  transform-origin: left center;
}

.line-1 {
  transform: translate(-50%, -50%) rotate(-45deg);
}

.line-2 {
  transform: translate(-50%, -50%) rotate(-135deg);
}

.no-bottom-padding{
	padding-bottom: 0px;
}

.no-bottom-padding.active{
	padding-bottom: 86px;
}

.max-width{
	max-width: 500px;
	margin: auto;
}

.max-width-2{
	max-width: 600px;
	margin: auto;
	gap: 80px;
}

.center-image{
	display: block;
	margin: auto;
}

.prototype{
	background: linear-gradient(to bottom, #000000, #131313, #131313, #131313, #131313);
}
@media screen and (max-width: 768px){

	/* NAVIGATION */

	.menu{
		display: none;
	}

	.cta-wrap {
		display: none;
	}

	.cta-wrap-mobile{
		display: block;
	}

	.hamburger{
		display: flex;
	}

	/* TEXT */

	h1 {
		font-size: 40px;
		line-height: 50px;
	}

	h2 {
		font-size: 20px;
		line-height: 22px;
	}

	h3{
	font-family: neue-med;
	font-size: 28px;
	line-height: 35px;
	}


	/* SPACING */

	.sm-padding-2{
		padding: 84px 24px;
	}

	.sm-padding-1{
		padding: 24px 24px;
	}

	.margin-left{
		margin-left: 0px;
	}

	/* IMAGES */

	.work-text{
	padding-top: 120px;
	max-width: 100%;
	margin: 0 auto;
	}

	.border-bottom{
	padding-bottom: 20px;
	}

	.border-bottom2{
	padding-bottom: 20px;
	}

	.line-1, .line-2 {
  width: 15px;  
  height: 1px;
  background: #fff;
  position: absolute;
  top: 90%;
  left: 50%;
  transform-origin: left center;
	}

	.arrow {
	  width: 20px;
	  height: 20px;
	}

	.arrow.active {
	  width: 20px;
	  height: 20px;
	}

	.arrow2 {
	  width: 20px;
	  height: 20px;
	}

	.arrow2.active {
	  width: 20px;
	  height: 20px;
	}

	.feature-2{
		position: absolute;
		left: -80px;
		width: 380px;
	}

	.feature-3{
		position: absolute;
		right: -20px;
		width: 250px;
	}

	.smiley{
		position: absolute;
		width: 100px;
		right: 0;
		top: 0;
	}

	.paperclip{
		position: absolute;
		top: -30px;
		left: 100px;
		z-index: 2;
		width: 70px;
	}

	.home-hero-img{
		margin-top: 110px;
		height: 400px;
	}

	.work-hero-img{
		margin-top: 110px;
		height: 400px;
	}

	.epark-hero-img{
		margin-top: 110px;
		height: 400px;
	}

	.mucc-hero-img{
		margin-top: 110px;
		height: 400px;
	}

	.viva-hero-img{
		margin-top: 110px;
		height: 400px;
	}

	.book-hero-img{
		margin-top: 110px;
		height: 400px;
	}

	.form-hero-img{
		margin-top: 110px;
		height: 400px;
	}

	.cover{
    width: 100%;
    object-fit: cover;
    display: block;
    margin-top: 100px;
	}
	
}

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

	/* NAVIGATION */

	.menu{
		display: none;
	}

	.cta-wrap {
		display: none;
	}

	.cta-wrap-mobile{
		display: block;
	}

	.hamburger{
		display: flex;
	}

	/* TEXT */

	.p-sm{
		font-size: 12px;
	}

	h1 {
		font-size: 40px;
		line-height: 50px;
	}

	h2 {
		font-size: 20px;
		line-height: 22px;
	}

	h3{
	font-family: neue-med;
	font-size: 28px;
	line-height: 35px;
	}


	/* SPACING */

	.sm-padding-2{
		padding: 84px 24px;
	}

	.sm-padding-1{
		padding: 24px 24px;
	}

	.margin-left{
		margin-left: 0px;
	}

	/* IMAGES */

	.home-hero-img{
		height: 400px;
	}

	.work-hero-img{
		height: 200px;
	}

	.work-text{
	padding-top: 33px;
	max-width: 100%;
	margin: 0 auto;
	}

	.border-bottom{
	padding-bottom: 20px;
	}

	.border-bottom2{
	padding-bottom: 20px;
	}

	.line-1, .line-2 {
  width: 15px;  
  height: 1px;
  background: #fff;
  position: absolute;
  top: 90%;
  left: 50%;
  transform-origin: left center;
	}

	.arrow {
	  width: 20px;
	  height: 20px;
	}

	.arrow.active {
	  width: 20px;
	  height: 20px;
	}

	.arrow2 {
	  width: 20px;
	  height: 20px;
	}

	.arrow2.active {
	  width: 20px;
	  height: 20px;
	}

	.feature-2{
		position: absolute;
		left: -60px;
		width: 250px;
	}

	.feature-3{
		position: absolute;
		right: -25px;
		width: 200px;
	}

	.smiley{
		position: absolute;
		width: 100px;
		right: 0;
		top: 0;
	}

	.paperclip{
		position: absolute;
		top: -30px;
		left: 100px;
		z-index: 2;
		width: 70px;
	}

	.home-hero-img{
		margin-top: 110px;
		height: 200px;
	}

	.work-hero-img{
		margin-top: 120px;
		height: 200px;
	}

	.epark-hero-img{
		margin-top: 120px;
		height: 200px;
	}

	.mucc-hero-img{
		margin-top: 120px;
		height: 200px;
	}

	.viva-hero-img{
		margin-top: 120px;
		height: 200px;
	}

	.book-hero-img{
		margin-top: 120px;
		height: 200px;
	}

	.form-hero-img{
		margin-top: 120px;
		height: 200px;
	}

	.cover{
    width: 100%;
    object-fit: cover;
    display: block;
    margin-top: 100px;
	}

	.arrows{
		position: absolute;
		top: -30px;
		left: -78px;
		z-index: -1;
		width:300px;
	}
	
}

