@import url('normalize-min.css');

@-webkit-keyframes lookme {
	0%,40%,60%,80%,100% { transform: scale(1.0); }
	20% { transform: scale(1.3); }
}
@-moz-keyframes lookme {
	0%,40%,60%,80%,100% { transform: scale(1.0); }
	20% { transform: scale(1.3); }
}
@-o-keyframes lookme {
	0%,40%,60%,80%,100% { transform: scale(1.0); }
	20% { transform: scale(1.3); }
}
@keyframes lookme {
	0%,40%,60%,80%,100% { transform: scale(1.0); }
	20% { transform: scale(1.3); }
}

*{color: #fff;}

html {
	height: 100%;
} 
body {
	overflow: auto;
	background-color: #2f2a29;
	font-size: 16px;
}

h1, h2, h3, h4, h5, h6 {
	font-family: "Bebas Neue", sans-serif;
	font-weight: normal;
	text-transform: uppercase;
}

#site {
	min-height: 100vh;
}

#site.home {
	/*background: url('../img/bg-placeholder-1.jpg') no-repeat center top;*/
	-webkit-background-size: cover;
	background-size: cover;
	position: relative;
}

.bg.overlay {
	z-index: 1;
	height: 100%;
	width: 100%;
	top: 0;
	left: 0;
	position: absolute;
	background-image: url('../img/stripes.png');
	background-color: rgba(0,0,0,0.5);
	opacity: .3;
}

.clear {
	clear: both;
}

.text-italic {
	font-style: italic !important;
}
.text-right {
	text-align: right !important;
}
.text-left {
	text-align: left !important;
}
.center-text {
	text-align: center !important;
}
em.sb {
	font-style: normal !important;
	font-weight: 600 !important;
}
.fill-width {
	width: 100%;
	height: auto;
	display: inline-block;
}
.img-holder {
	padding: 0 1rem;
}
.img-holder-mask {
	height: 20rem;
	width: 100%;
	overflow: hidden;
}
.holder{
	padding: .75rem 1rem;
}

#site > header, #site > main, #site > footer {
	position: relative;
	z-index: 10;
}

#site.cover-page > header {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 20;
}

#mobile-header, #mobile-menu {
	display: none;
}

.home #logo img {
	margin: 3rem 0;
}

.cover-page #logo {
	margin-top: 3rem;
}

#logo img {
	width: 100%;
	margin-left:0.6rem;
}

.pure-button {
	padding: 1rem;
	text-align: center;
	background: transparent;
	border: 3px solid rgba(255,255,255,0.7);
	border-radius: 0;
	color: #fff;
	font-family: 'Thasadith', sans-serif;
	-webkit-transition: all 200ms cubic-bezier(0.250, 0.250, 0.750, 0.750); 
	-moz-transition: all 200ms cubic-bezier(0.250, 0.250, 0.750, 0.750); 
	 -o-transition: all 200ms cubic-bezier(0.250, 0.250, 0.750, 0.750); 
		transition: all 200ms cubic-bezier(0.250, 0.250, 0.750, 0.750); /* linear */

	-webkit-transition-timing-function: cubic-bezier(0.250, 0.250, 0.750, 0.750); 
	-moz-transition-timing-function: cubic-bezier(0.250, 0.250, 0.750, 0.750); 
	 -o-transition-timing-function: cubic-bezier(0.250, 0.250, 0.750, 0.750); 
		transition-timing-function: cubic-bezier(0.250, 0.250, 0.750, 0.750); /* linear */
}

.pure-button:hover, .pure-button:focus {
	background: #fff;
	border-color: #fff;
}
.pure-button:hover, .pure-button:focus,
.pure-button:hover *, .pure-button:focus * {
	color: #2f2a29;
}

.pure-button.button-large {
	font-size: 1.250rem;
}
.pure-button.button-small {
	padding: 0.75rem 1rem;
}

#start-buttons-holder .pure-button {
	margin-bottom: 1.25rem;
	width: 100%;
	padding: 1rem 0;
}

#site > #home-footer {
	background: rgba(41,38,37,0.3);
	margin-top: 2rem;
	padding: 2rem 0;
	position: absolute;
	bottom: 0;
}

.contact-link {
	display: inline-block;
	margin: 0 0.6125rem;
	text-decoration: none;
	font-family: "Thasadith", sans-serif;
}

.contact-link i.fas,.contact-link i.fab, .contact-link i.far  {
	font-size: 1.250em;
	margin-top: -2px;
	margin-right: 0.3em;
	display: block;
	float: left;
}

.menu ul {
	margin: 2rem 0 0 0;
	padding: 0;
	list-style: none;
	line-height: 2.441rem;
}

.menu ul li a {
	text-decoration: none;
	font-family: "Bebas Neue", sans-serif;
	text-transform: uppercase;
	font-size: 1.563rem;
	-webkit-transition: all 200ms cubic-bezier(0.250, 0.250, 0.750, 0.750); 
	-moz-transition: all 200ms cubic-bezier(0.250, 0.250, 0.750, 0.750); 
	 -o-transition: all 200ms cubic-bezier(0.250, 0.250, 0.750, 0.750); 
		transition: all 200ms cubic-bezier(0.250, 0.250, 0.750, 0.750); /* linear */

	-webkit-transition-timing-function: cubic-bezier(0.250, 0.250, 0.750, 0.750); 
	-moz-transition-timing-function: cubic-bezier(0.250, 0.250, 0.750, 0.750); 
	 -o-transition-timing-function: cubic-bezier(0.250, 0.250, 0.750, 0.750); 
		transition-timing-function: cubic-bezier(0.250, 0.250, 0.750, 0.750); /* linear */
}

.menu ul li a:hover, .menu ul li a:focus {
	background: #fff;
	color: #2f2a29;
	outline-color:#fff;
}

#video-cover {
	overflow: hidden;
	position: fixed;
	width: 100%;
	top: 0;left: 0;
}

#video-cover .gif {
	width: 100%;
}

#video-cover video, #video-cover .cover {
	height: 100%;
}

#video-cover .cover {
	position: relative;
	opacity: 0.7;
	background-repeat: no-repeat;
	width: 100%;
	display: inline-block;
	-webkit-background-size: cover;
	background-size: cover;
}

#video-cover .cover-text{
	position: fixed;
	top: 35%;
	left: 0;
	font-weight: 300;
	font-size: 1.5rem;
	line-height: 2.51rem;
	z-index: 50;
	text-shadow: 0px 2px 2px rgba(0,0,0,0.9);
}

#video-cover .cover-text span {
	font-family: "Thasadith", sans-serif;
}


#video-sound-toggle-button, #page-down {
	position: fixed;
	font-size: 1.75rem;
	text-decoration: none;
}

#page-down {
	bottom: 3rem;
	right: 50%;
	margin-left: -50%;
	z-index: 20;
	-webkit-animation: lookme 5s infinite;
	-o-animation: lookme 5s infinite;
	animation: lookme 5s infinite;
}

#video-sound-toggle-button {
	position: fixed;
	top: 3rem;
	right: 2rem;
	z-index: 20;
	text-align: right;
}

#video-sound-toggle-button.animated {
	-webkit-animation: lookme 5s infinite;
	-o-animation: lookme 5s infinite;
	animation: lookme 5s infinite;
}
#video-sound-toggle-button .fas {
	display: inline-block;
	vertical-align: sub;
}
#video-sound-toggle-button .description {
	display: inline-block;
	vertical-align: middle;
}
#video-sound-toggle-button .description .muted, #video-sound-toggle-button .description .unmuted {
	width: 0px;
	overflow: hidden;
	display: inline-block;
	font-size: 0.75rem;
	font-family: "Thasadith", sans-serif;
	white-space: nowrap;
	-webkit-transition: all 200ms cubic-bezier(0.250, 0.250, 0.750, 0.750); 
	   -moz-transition: all 200ms cubic-bezier(0.250, 0.250, 0.750, 0.750); 
		 -o-transition: all 200ms cubic-bezier(0.250, 0.250, 0.750, 0.750); 
			transition: all 200ms cubic-bezier(0.250, 0.250, 0.750, 0.750); /* linear */

	-webkit-transition-timing-function: cubic-bezier(0.250, 0.250, 0.750, 0.750); 
	   -moz-transition-timing-function: cubic-bezier(0.250, 0.250, 0.750, 0.750); 
		 -o-transition-timing-function: cubic-bezier(0.250, 0.250, 0.750, 0.750); 
			transition-timing-function: cubic-bezier(0.250, 0.250, 0.750, 0.750); /* linear */
}

#video-sound-toggle-button.muted:hover .description .muted {
	width: 3.2rem;
}
#video-sound-toggle-button.unmuted:hover .description .unmuted {
	width: 5rem;
	padding-right: 0.4rem;
}

main #content {
	background: #2f2a29;
	position: relative;
	z-index: 10;
}

main h1 {
	font-size: 3rem;
	padding: 1.5rem 0;
	font-family: "Bebas Neue", sans-serif;
	text-transform: uppercase;
	text-align: center;
}

article.highlight {
	margin-bottom: 3.815rem;
}

article.highlight .description p {
	padding: 0;
	margin: 0 0 1rem 0;
	font-family: "Montserrat", sans-serif;
	font-style: italic;
	letter-spacing: 1px;
	font-size: 1rem;
	font-weight: 300;
	line-height: 1.5rem;
}

article.highlight .description h4 {
	text-align: right;
	font-size: 1.25rem;
	margin: 1em 0;
	opacity: .5;
}

hr{
	clear: both;
	margin: 2rem 5em;
	border: 0;
	border-top: 1px solid rgba(255,255,255,0.5);
}

hr.invisible {
	margin: 1rem 0 0 0;
	border: 1px solid rgba(0,0,0,0.0);
}

.spacer {
	margin: 1rem 0;
	display: inline-block;
}

article.highlight .description .pure-button+.pure-button {
	margin-left: 1rem;
}

.brief {
	margin-bottom: 3.815rem;
}

.brief h2 {
	text-align: center;
	font-size: 1.953rem;
	margin: 3.815rem 0 3.815rem;
}

.brief p, .brief blockquote {
	font-weight: 300;
	font-family: "Montserrat", sans-serif;
}

.brief p {
	font-size: 1.1rem;
	line-height: 1.7rem;
	margin: 0 0 1.3rem 0;
}

.brief blockquote {
	font-size: 1.563rem;
	position: relative;
	font-family: "Thasadith", sans-serif;
}

.brief blockquote .quote-mark {
	display: inline-block;
	position: absolute;
	font-size: 3rem;
	margin-left: -2rem;
	margin-top: -1rem;
	opacity: .3;
}

.brief p.smaller {
	padding: 0 .25rem;
	font-weight: 400;
	font-size: 0.8rem;
    line-height: 1.250rem;
	opacity: .7;
}

.brief h3 {
	margin-top: 0;
	margin-bottom: 1.5rem;
	font-size: 1.9rem;
}

#site.cover-page > footer {
	margin-top: -2px;
	background-color: #2f2a29;
}

.modal {
	background:rgba(47,42,41,0.9);
	position: fixed;
	width: 100%;
	height: 100%;
	z-index: 200;
	top: 0;
	left: 0;
	display: none;
}

.modal.visible {
	display: block;
}

.modal > .bar {
	padding: 1rem 1.5rem;
	display: inline-block;
	width: 100%;
	box-sizing: border-box;
}

.modal > .bar > .close {
	text-decoration: none;
	font-size: 2rem;
	display: inline-block;
	float: right;
}

.modal > .content {
	position: relative;
	height: 100%;
	box-sizing: border-box;
}

.modal > .content > .video {
	width: 94%;
	margin-top: 2%;
	margin-left: 3%;
	height: 80%;
}

.ss {
	display: none;
}

.pure-control-group {
	margin-bottom: 1rem;
}

@media screen and (max-width: 48em) {
	.ss {
		display: inline-block;
	}
	
	.img-holder-mask img {
		margin-top: -10rem;
	}

	.his {
		display: none;
	}

	#video-cover .cover-text {
	    top: 6%;
	}

	#mobile-header {
		display: block;
		background: #fff;
		height: 4.5rem;
		position: relative;
	}

	#mobile-header #mobile-logo .holder {
		text-align: center;
	}

	#mobile-header #mobile-logo img {
		height: 2.5rem;
	}

	main {
		margin-top: 2rem;
	}
	
	#video-sound-toggle-button {
		top: 6rem;
	}

	#video-cover {
	    top: 4rem;
	}
	
	#mobile-header a, #mobile-menu .close-menu {
		display: inline-block;
		padding: 1.2rem;
	}

	#mobile-header a * , #mobile-menu .close-menu *{
		color: #000;
		font-size: 2rem !important;
	}

	#mobile-menu {
		display: block;
		position: fixed;
		top: 0;
		left: 0;
		width: 50%;
		height: 100%;
		background: #fff;
		z-index: 500;
		transform: translate(-100%,0);
			-webkit-transition: all 200ms cubic-bezier(0.250, 0.250, 0.750, 0.750); 
	   -moz-transition: all 200ms cubic-bezier(0.250, 0.250, 0.750, 0.750); 
		 -o-transition: all 200ms cubic-bezier(0.250, 0.250, 0.750, 0.750); 
			transition: all 200ms cubic-bezier(0.250, 0.250, 0.750, 0.750); /* linear */

	-webkit-transition-timing-function: cubic-bezier(0.250, 0.250, 0.750, 0.750); 
	   -moz-transition-timing-function: cubic-bezier(0.250, 0.250, 0.750, 0.750); 
		 -o-transition-timing-function: cubic-bezier(0.250, 0.250, 0.750, 0.750); 
			transition-timing-function: cubic-bezier(0.250, 0.250, 0.750, 0.750); /* linear */
	}

	#mobile-menu.opened {
		transform: translate(0,0);
	}
	
	#mobile-menu ul {
		margin: 1rem 3rem;
		line-height: 3.5rem;
	}

	#mobile-menu ul li a {
		color: #000;
		font-size: 2.5rem;
	}

	.brief p.smaller {
	    font-size: 1.1rem;
	    line-height: 1.9rem;
	    opacity: .9;
	}

	.pure-button.button-large {
		font-size: 1.25rem;
		padding: 0.75rem;
		border-width: 3px;
	}

	#start-buttons-holder .pure-button {
		padding: .75rem 0;
	}
	

	#site > #home-footer {
		padding: 2rem 0;
		position: relative;
	}

	.contact-link i.fas,
	.contact-link i.fab,
	.contact-link i.far {
		font-size: 2rem;
	}

	.brief h3 {
		font-size: 1.50rem
	}
}

@media screen and (max-width: 30em) { 
	.img-holder-mask img {
		margin-top: 0;
	}

	#mobile-menu {
		width: 100%;
	}
}

.pure-form-aligned .pure-control-group label {
	font-family: "Montserrat", sans-serif;
}

.pure-form input[type=password],
.pure-form input[type=email],
.pure-form input[type=url],
.pure-form input[type=date],
.pure-form input[type=month],
.pure-form input[type=time],
.pure-form input[type=datetime],
.pure-form input[type=datetime-local],
.pure-form input[type=week],
.pure-form input[type=tel],
.pure-form input[type=color],
.pure-form input[type=number],
.pure-form input[type=search],
.pure-form input[type=text],
.pure-form select,
.pure-form textarea,
.pure-form option {
	font-family: "Montserrat", sans-serif;
	color: #333;
}

@media screen and (min-width: 48.1em) {
	/*.pure-u-md-1-4, .pure-u-md-6-24 {
		width: 100%;
	}*/
	#site.home > header #logo {
		height: 100%;
	}
	#site.home > header #logo > div {
		height: 100%;
		position: relative;
	}

	#site.home > header #logo > div > img  {
		position: absolute;
		top: 40%;
		width: 100%;
	}

	#start-buttons-holder {
		border-left: 2px solid rgba(255,255,255,0.3);
		position: absolute;
		top: 25%;
		padding: 5% 0;
	}

	#start-buttons-holder .pure-button.button-large {
		font-size: 1.25rem;
		padding: 0.8rem 0;
	}


	#start-buttons-holder .pure-button {
		margin-bottom: 1.250em;
	}

	.pure-button.button-large {
		border-width: 4px;
	}

	#logo img {
		width: 100%;
		margin-left:0.3rem;
	}

	.menu ul {
		margin: 1.25rem 0 0 0;
		line-height: 1.953rem;
	}

	.menu ul li a {
		font-size: 1.25rem;
	}
}

@media screen and (min-width: 88em) {
	#site.home > header #logo > div > img  {
		top: 40%;
	}

	#start-buttons-holder {
		top: 30%;
	}

	article.highlight .description p {
		font-size: 1.3rem;
		line-height: 1.8rem;
	}

	article.highlight .description p {
		font-size: 1.3rem;
		line-height: 2.3rem;
	}

	.brief h2 {
		font-size: 2.4rem;
	}

	.brief p {
		font-size: 1.5rem;
		line-height: 2.2rem;
		margin-bottom: 1.9rem;
	}

	.brief p.smaller {
		padding: 0 .5rem;
		font-size: 0.9rem;
		line-height: 1.5rem;
	}

	.service-description h3 {
		font-size: 2.2rem;
	}

	article.highlight .description h4 {
		font-size: 1.7rem;
	}
}


@media screen and (min-width: 98em) {
	#site.home > header #logo > div > img  {
		top: 38%;
	}

	#start-buttons-holder {
		top: 25%;
	}
	.brief p.smaller {
		padding: 0 .5rem;
		font-size: 1rem;
		line-height: 1.9rem;
	}
}

@media screen and (min-width: 108em) {

	#site.home > header #logo > div > img  {
		top: 43%;
	}

	#start-buttons-holder {
		top: 35%;
	}
	#site.cover-page #logo {
		margin-top: 5rem;
	}
	#video-sound-toggle-button {
		top: 5rem;
		right: 5rem;
	}
	.pure-button.button-small {
		padding: 1.250rem 1.5rem;
		font-size: 1.9rem;
	}
	.pure-button.button-large {
		font-size: 2rem;
		padding: 1.250rem;
	}
	.menu ul {
		margin: 2.5rem 0 0 0;
		line-height: 2.441rem;
	}
	.menu ul li a {
		font-size: 1.65rem;
	}

	main h1 {
		font-size: 3.8rem;
		padding: 2rem 0;
	}

	.brief h2 {
		font-size: 3.052rem;
	}

	.brief p {
		font-size: 1.7rem;
		line-height: 2.8rem;
		margin-bottom: 2.4rem;
	}

	.brief p.smaller {
		padding: 0 .5rem;
		font-size: 1.1rem;
		line-height: 1.9rem;
	}

	.service-description h3 {
		font-size: 2.4rem;
	}

	article.highlight .description .holder{
		padding: 1.25rem 2.5rem 0;
	}
	article.highlight .description p {
		font-size: 1.5rem;
		line-height: 2.4rem;
	}

	article.highlight .description h4 {
		font-size: 1.9em;
	}
}

@media screen and (min-width: 120em) {

}