/*
Theme Name: LuxTheme
Author: Milo Caceffo
*/


main {
	min-height: 100vh;
	background-color: #FFF;
}


/* LUX */
.bg-red {
	background-color: #E35E5D;
}
.bg-panna {
	background-color: #dad5ce;
}

.lines {
	position: relative;
}
.lines:after {
	content: '';
	display: block;
	position: absolute;
	bottom: 0;
	height: 1px;
	width: 100%;
	background-color: #000;
}
.lines.ani:after {
	width: 0%;
	transition: width .5s 0s ease-out;
}
.lines.ani.iw:after {
	width: 100%;
}

.txt-white {
  color: #FFF;
}
.txt-red {
  color: #E35E5D;
}

.serif {
	font-family: 'Norman', Arial, sans-serif;
	font-size: .7em;
	line-height: 1.2;
	text-transform: uppercase;
}

/* HERO */
.wrap-hero {
	position: relative;
	min-height: 100vh;
	padding-top: 2rem;
	font-size: 140px;
	line-height: 1;
}
.hero-logo {
  display: block;
  margin: 2rem auto 2rem auto;
  max-width: 100%;
  width: 500px;
  background-color: #fff;
  border-radius: 400px;
  padding: 20px 60px;
  box-shadow: 0 0 0 1px #000;

	opacity: 0;
	animation: fadeLogo 1s 2s ease-in forwards;
}
@keyframes fadeLogo {
	to { opacity: 1; }
}

/* SM - tablet portrait */
@media (max-width: 767px) {

	.wrap-hero {
		font-size: 62px;
    min-height: auto;
		padding-top: 100px;
    padding-bottom: 40px;
	}
	.logo-luxoro {
		display: none !important;
	}

}

.logo-luxoro {
	display: block;
	position: absolute;
  top: 6vh;
  right: 0px;
	height: 160px;
	width: 160px;
	box-shadow: inset 0 0 0 5px #fff;
	border-radius: 50%;
	z-index: 2;
	transition: box-shadow 1s ease-out;

	opacity: 0;
	animation: fadeLogo 1s 1s ease-in forwards;
}

.logo-luxoro:hover {
	box-shadow: inset 0 0 0 1px #fff;
}


/* INTRO */
.wrap-intro {
	min-height: 90vh;
	padding-top: 2rem;
	padding-bottom: 4rem;
	font-size: 90px;
}


/* VIDEO */
.wrap-video {
  position: relative;
  transform: translateY(-80px);
  width: 100%;
  aspect-ratio: 16 / 9;
  margin: 0 auto;
  box-shadow: 0 -10px 20px rgba(0, 0, 0, .1);
}
.wrap-video video {
	height: 100%;
}
.wrap-video:after {
	content: '';
	position: absolute;
	inset: 0;
	z-index: 1;
	opacity: .4;
	pointer-events: none;

	background-position: center;
	background-repeat: no-repeat;
	background-size: 120px;
	background-image: url('assets/icons/play.svg');
	background-color: #000;

	-webkit-transition: opacity .3s ease-in-out;
	transition: opacity .3s ease-in-out;
}
.wrap-video.playing:after {
	opacity: 0;
}


/* DESC */
.wrap-desciption {
	font-size: 90px;
}
.wrap-desciption .serif {
	font-weight: bold;
}
.wrap-desciption .lines {
	display: block !important;
}

.wrap-desciption2 {
	padding-top: 2rem;
	padding-bottom: 2rem;
	font-size: 40px;
}
.wrap-desciption2 p {
	display: block !important;
}


@media (max-width: 767px) {

	.wrap-intro {
    font-size: 30px;
    min-height: auto;
    padding-bottom: 160px;
    padding-top: 80px;
	}

	.wrap-desciption {
	    font-size: 28px;
	}
	.wrap-desciption2 {
    font-size: 16px;
    padding-top: 0;
    padding-bottom: 0;
	}

}


/* CIRCLE */
.circle-number {
	font-size: 120px;
	height: 220px;
	width: 220px;
	text-align: center;
	line-height: 210px;
	border-radius: 50%;
	color: #fff;
	box-shadow: inset 0 0 0 1px #fff;
	transition: all .5s;
}
.circle-number:hover {
	box-shadow: inset 0 0 0 6px #fff;
}
.title-number {
	font-size: 60px;
	color: #fff;
}

@media (max-width: 767px) {

	.circle-number {
		font-size: 60px;
		height: 120px;
		width: 120px;
		line-height: 115px;
	}

	.title-number {
		font-size: 26px;
    line-height: 1.2;
	}

}




/* SWAP */
.txtswap {
	padding-bottom: 1rem;
}
.txtswap img {
	height: 100%;
}
.txtswap .txtswap-txt {
	padding: 2rem 0;
	font-size: 32px;
}
.txtswap .txtswap-txt strong {
	display: inline !important;
}
.txtswap.txtswap-even {
	-webkit-box-orient: horizontal !important;
	-webkit-box-direction: reverse !important;
	-ms-flex-direction: row-reverse !important;
	flex-direction: row-reverse !important;
}

.wrap-works {
	padding: 2px;
}
.wrap-works img {
	width: 100%;
	aspect-ratio: 4 / 3;
	padding: 2px;
	transition: opacity 1s;
}
.wrap-works img:hover {
	opacity: .6;
}

@media (max-width: 767px) {
	.txtswap .txtswap-txt {
		font-size: 24px;
	}
}


/* HORIZONTAL SCROLL */

@media (min-width: 767px) {

	.horiz-scroll-wrap,
	.horiz-scroll-strip {
		display: flex;
		flex-wrap: nowrap;
		will-change: transform;
		position: relative;
	}
	.horiz-scroll-panel {
		width: 100vw;
		height: 100vh;
		box-sizing: content-box;
		background-color: #eee;
	}
	.wrap-panel {
		height: 100vh;
	}
	.col-panel-tit {
		font-size: 80px;
	}
	.col-panel-ico img {
		height: 220px;
		object-fit: contain;
	}
	.col-panel-txt {
		font-size: 40px;
	}

}

@media (max-width: 767px) {
	.horiz-scroll-panel {
		padding-top: 40px;
    padding-bottom: 40px;
	}
	.col-panel-tit {
		font-size: 28px;
    padding-bottom: 30px;
    font-weight: bold;
	}
}




.wrap-footer {
	position: relative;
	font-size: 140px;
	min-height: 100vh;
	padding-top: 2rem;
	padding-bottom: 2rem;
}
.footer-logo {
	width: 460px;
}
.footer-email {
	font-size: 60px;
	font-weight: 500;
	color: #fff;
}

.bg-pattern {
	position: fixed;
	z-index: -10;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;

	background-image: url(assets/img/pattern.png);
	background-size: cover;
	box-shadow: inset 0 0 40px 20px rgba(0, 0, 0, .4);
}


@media (max-width: 767px) {

	.wrap-footer {
		min-height: auto;
		font-size: 58px;
	}
	.footer-logo {
    width: 320px;
    padding-bottom: 40px;
  }
  .footer-email {
  	font-size: 42px;
  }

}


/* SIDE 
.left-bar {
	position: relative;
	position: fixed;
	box-shadow: 1px 0px 0 0 #000;
	left: 0;
	width: 40px;
	height: 100vh;
}
.left-bar-bottom {
	position: absolute;
	bottom: 0;
	transform-origin: 0;
	transform: rotate(-90deg);
}
*/


/* FOOTER */
.footer {
	font-size: 15px;
	color: #000;
	padding-bottom: 40px;
}
.footer a {
	color: #000;
}


/* LG - small desktop */
@media (max-width: 1199px) {
}

/* MD - tablet landscape */
@media (max-width: 991px) {
}

/* SM - tablet portrait */
@media (max-width: 767px) {
}

/* XS - smartphone */
@media (max-width: 575px) {
}
