html { font-size: 62.5%; }
p{
	font-size: 1.6rem;
	margin: 0 0 1rem;
}

#overlay{
	position: fixed;
	top:0;
	right:0;
	bottom:0;
	left:0;
	z-index: 100;
	background:#fff;
}

#loader{
	width: 100%;
	height: 100%;
	position: relative;
    overflow: hidden;
    background: -moz-radial-gradient(center, ellipse cover, #ffffff 50%, #FBF9EA 100%);
    background: -webkit-gradient(radial, center center, 0px, center center, 100%, color-stop(50%,#ffffff), color-stop(100%,#FBF9EA));
    background: -webkit-radial-gradient(center, ellipse cover, #ffffff 50%,#FBF9EA 100%);
    background: -o-radial-gradient(center, ellipse cover, #ffffff 50%,#FBF9EA 100%);
    background: -ms-radial-gradient(center, ellipse cover, #ffffff 50%,#FBF9EA 100%);
    background: radial-gradient(center, ellipse cover, #ffffff 50%,#FBF9EA 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#FBF9EA',GradientType=1 );
}
.layer{
    display: block;
    height: 100%;
    width: 100%;
    padding: 0;
    margin: 0;
}
#loader .background{
    background:url(images/compass.svg) center center/contain no-repeat;
	position: absolute;
	width: 110%;
	height: 110%;
	left: -5%;
	top: -5%;
}
#loader .runner{
	position: absolute;
	max-width:1000px;
	width:100%;
	height:100%;
	bottom:0;
	left:0;
	background:url(images/runner.png) bottom left/contain no-repeat;
	transition:left 0.2s;
	opacity:0.2;
}
#loader .runner img{
	width:100%;
}
#logo {
	width: 50%;
	height:13%;
	min-width:300px;
	min-height:90px;
	position: absolute;
	left: 50%;
	top: 30%;
	transform: translateX(-50%);
}
#tagline{
	position: absolute;
	top: 55%;
	margin: 0;
	width: 100%;
	padding: 0 30px;
	text-align: center;
	font-size: 2rem;
}
#more{
	font-size: 30px;
	border-radius: 100%;
	border: 1px solid #d32727;
	background:#d32727;
	padding:15px;
	width: 75px;
	height: 75px;
	display: inline-block;
	text-align: center;
	position: absolute;
	bottom: 20px;
	left: 50%;
	transform: translateX(-50%);
	color:#fff;
	text-decoration: none;
	transition:color 0.5s, background 0.5s;
}
#more:hover, #more:focus{
	background:transparent;
	color:#d32727;
}
#thanks #more{
	bottom:60px;
}
#moretext{
	position: absolute;
	bottom:20px;
	left:0;
	display: block;
	width:100%;
	margin:0;
	font:700 25px 'freight-macro-pro', sans-serif;
	color:#d32727;
	text-align: center;
}
h1, h2, h3, h4{
	font-family: 'freight-macro-pro', sans-serif;
	font-weight: 800;
}
#tagline h2{
	font-weight: 700;
	font-size: 3.5rem;
	font-family:'futura-pt-condensed', 'Arial Narrow', Arial, sans-serif;
	letter-spacing:.07em;
	color:#d32727;
	/*text-transform: uppercase;*/
}
h3{
	color: #E5001C;
	text-transform: uppercase;
	font-size: 2.4rem
}
h4{
	color: #E5001C;
	text-transform: uppercase;
	font-size: 2.0rem
}
#approach{
	background: #333 url(images/binding_dark.png) repeat center top;
	padding:60px 20px; 
}
#approach p{
	font-size: 2rem;
	color: #fff;
}
#approach .content{
	max-width: 700px;
	margin: auto;
	text-align: justify;
}
#approach h1{
	font-size: 7.6rem;
	/*background: url(images/approach.png) no-repeat left top;*/
	background-size: contain;
	margin:0 0 1rem 0;
	padding:0;
	color:#fff;
	text-align: center;
}
#approach h3{
	text-align: center;
}
#process{
	padding: 80px 20px;
}
#process .intro{
	font-size: 2rem;
}
#process .content{
	max-width: 900px;
	margin: auto;
}
#process h1{
	font-size: 7.6rem;
	/*background: url(images/process.png) no-repeat left top;*/
	background-size: contain;
	margin:0 0 1rem 0;
	padding:0;
}
.item{
	clear: both;
	margin: 4rem 0;
}
.item .img{
	width: 12rem;
	height: 12rem;
	float: left;
	position: relative;
}
.item .txt{
	margin-left: 15rem;
}
#services{
	text-align: center;
}
#services .content{
	padding: 20px;
}
#services h1{
	font-size: 7.6rem;
	/*background: url(images/services.png) no-repeat center top;*/
	background-size: contain;
	margin:0 0 1rem 0;
	padding:0;
}
#services .intro{
	font-size: 2rem;
	max-width: 900px;
	margin:0 auto 2rem;
}
.engagement{
	background: #333 url(images/binding_dark.png) repeat center top;
	padding:60px 20px; 
}
.engagement p{
	color: #fff;
}
#services .col-sm-4 img{
	max-width: 15rem;
}
#services .col-sm-5 img{
	max-width: 20rem;
}
#services .engagement .col-md-2 img{
	max-width: 10rem;
}
.tactics{
	background: #E5001C;
	padding: 20px 0;
}
#services .tactics .col-md-2 img{
	max-width: 10rem;
}
.tactics p{
	color: #fff;
}
.tactics h4{
	color: #000;
}
.tactics::before{
	width: 20px; 
	height: 20px; 
	content: '';
	display: block;
	margin: auto;
	-ms-transform: translate(0, -30px) rotate(45deg); /* IE 9 */
    -webkit-transform: translate(0, -30px) rotate(45deg); /* Safari */
    transform: translate(0, -30px) rotate(45deg);
	background-image: url(images/binding_dark.png);
}
.bobox{
	border-bottom: 2px solid #DDDDDD;
	border-right:2px solid #DDDDDD;
	border-left: 2px solid #DDDDDD;
	width:100%;
	height: 20px;
}
.bovert{
	border-left:2px solid #DDDDDD;
	height: 20px;
	display: inline-block;
	width:2px;
}
.boarrow::after{
	border-top: 20px solid #DDDDDD;
	border-right: 20px solid transparent;
	border-left: 20px solid transparent;
	border-bottom: 20px solid transparent;
	width:20px;
	height: 20px;
	display: block;
	margin: auto;
	content: ' ';
	white-space: pre;
}
.boarrow::before{
	content: ' ';
	width:12px;
	height: 20px;
	display: inline-block;
	background: #DDDDDD;
	white-space: pre;
}
#success{
	background: #333 url(images/binding_dark.png) repeat center top;
	color:#fff;
	text-align: center;
}
#success h1{
	font-size: 7.6rem;
	/*background: url(images/success.png) no-repeat center top;*/
	background-size: contain;
	margin:0 0 1rem 0;
	padding:0;
}
#success .content{
	padding: 80px 20px;
}
#success .stat h3{
	margin: 0;
	font-size: 7.7rem;
}
#success .stat span{
	color: #E5001C;
	text-transform: uppercase;
	font-family: 'Assistant', sans-serif;
	font-weight: 800;
	font-size: 1.9rem;
}
#success .case{
	position: relative;
	width: 33.3333333333%;
	float: left;
	background: #000;
}
#success .case img{
	width: 100%;
}
#success .case h2{
	position: absolute;
	margin: 0;
	top: 50%;
	width:100%;
	transform: translateY(-50%);
	text-transform: uppercase;
	z-index: 10;
	color: #fff;
	font-size: 3rem;
}
#success .case a{
	position: absolute;
	background-color: rgba(229,0,28,0);
	top: 0;
	bottom: 0;
	width: 100%;
	display: block;
	z-index: 9;
	transition: background 0.5s, outline 0.5s;
}
#success .case a:hover{
	background-color: rgba(229,0,28,0.7);
	outline: 1px solid #fff;
	outline-offset: -20px;
}
#contact{
	border-top: 5px solid #E5001C;
	padding:80px 20px;
}
#contact .content{
	max-width: 700px;
	margin: auto;
}
#contact h3{
	font-weight: 300;
}
#contact a{
	color:#E5001C;
}
#contact label span{
	vertical-align: middle;
}
#contact label i{
	color:#E5001C;
	font-size:.7em;
	vertical-align: middle;
}
#contact input, #contact button, #contact textarea{
	border-radius: 0;
}
#contact button{
	background: #E5001C;
	text-transform: uppercase;
	border: 0;
	border-bottom: 2px solid #A40011;
	padding:1rem 3rem;
}
@media (max-width: 768px){
	html{
		font-size: 50%;
	}
}
@media (max-width: 568px){
	#success .case{
		width: 100%;
		float: none;
	}
}

/*case study section*/

#nav{
	background: #333 url(images/binding_dark.png) repeat center top;
	padding: 20px;
}
#nav h1{
	font-size: 7.6rem;
	/*background: url(images/casestudy.png) no-repeat left top;*/
	background-size: contain;
	margin:0 0 1rem 0;
	padding:0;
}
#logo-footer{
	max-width:200px;
	display: block;
	margin:auto;
	padding: 20px;
}
.right{
	width: 25%;
	float: right;
	margin: 1rem 0 1rem 2rem;
}
.right img{
	display: inline-block;
	width: 100%;
	margin: 1rem 0;
}
.right img.half{
	width: 48%;
}
@media (max-width: 768px){
	.right img.half{
		width: 100%;
	}
	div .three-col{
		-webkit-column-count: 2; /* Chrome, Safari, Opera */
	    -moz-column-count: 2; /* Firefox */
	    column-count: 2;
	    list-style-type: none;
	}
}

.three-col{
	-webkit-column-count: 3; /* Chrome, Safari, Opera */
    -moz-column-count: 3; /* Firefox */
    column-count: 3;
    list-style-type: none;
    padding: 0;
}
.three-col li{
	margin-left:1.6rem;
}
.three-col li::before{
	content:'\25B6';
	float: left;
	margin-left: -1.6rem;
}