@charset "utf-8";
/* Simple fluid media
   Note: Fluid media requires that you remove the media's height and width attributes from the HTML
   http://www.alistapart.com/articles/fluid-images/ 
*/
img, object, embed, video {
	max-width: 100%;
}
/* IE 6 does not support max-width so default to width 100% */
.ie6 img {
	width:100%;
}

/*
	Dreamweaver Fluid Grid Properties
	----------------------------------
	dw-num-cols-mobile:		6;
	dw-num-cols-tablet:		10;
	dw-num-cols-desktop:	14;
	dw-gutter-percentage:	25;
	
	Inspiration from "Responsive Web Design" by Ethan Marcotte 
	http://www.alistapart.com/articles/responsive-web-design
	
	and Golden Grid System by Joni Korpi
	http://goldengridsystem.com/
*/

/* Mobile Layout: 480px and below. */




.expertise-container section{
	width: 100%;
	display: block;
}

section.otherservices{
	margin-top: 5vh;
}

.otherservices .os-inner{
	display: grid; 
  grid-template-columns: 1fr; 
  grid-template-rows: 1fr; 
  gap: 2em 2em; 
  grid-template-areas: 
    "."; 
	width: calc(100% - 2em);
	height: auto;
	float: left;
	clear: both;
	text-align: left;
  text-justify: inter-word;
}








.casepage-hero{
	width: 100%;
	height: 60vh;
	display: block;
	float: left;
	clear: none;
	overflow: hidden;
	margin: 0;
}


.cases-preview{
	width: 100%;
	height: auto;
	display: block;
	margin: -15vh auto auto;
}

.cases-preview .case{
	border-radius: 2em;
	overflow: hidden;
	height: 100vh;
	margin: 1.5em 0;
		border: 1px solid #ffffff28;
}

.cases-preview .case .case-details{
	width: calc(90% - 2em);
	height: calc(35vh - 2em);
	border-radius: 2em;
	bottom: calc(5vh - 2em);
	right: calc(5vh - 2em);

}
    

.shb-right.case-page-details{
	background-color: #e21010;
	background-image: none;
	margin-top: 5vh;
	width: 100%;
	min-height: 100vh;
	max-height: 150vh;
	display: block;
	clear: none;
	float: right;
}

.case-page-details .case-details-inner{
	width: calc(100% - 6em);
	height: calc(auto - 6em);
	position: absolute;
	z-index: 10;
	float: left;
	clear: none;
	top: 3em;
	left: 3em;
	color: #fff;
	z-index: 100;
	transition: all .2s ease-in-out;
}


.case-page-details .tags{
	width: 65%;
	height: auto;
	display: block;
	float: left;
	clear: both;
	margin: auto -1em 0;
}




.case-img-onpage{
	width: 100%;
	height: 40vh;
	border-radius: 3em;
	display: block;
	float: left;
	clear: both;
	margin: 1em 0;
	background-size: cover;
	background-position: center;
	position: relative;
}

.case-img-onpage a{
	width: 100%;
	height: 100%;
	display: block;
}


.case-img-onpage i{
	font-size: 1.6em;
	color: #fff;
	position: absolute;
	bottom: 1em;
	right: 1em;
	border-radius: 2em;
	padding: .8em;
	background-color: #ffffff00;
	z-index: 10;
	transition: all .2s ease-in-out;
	transform: scale(70%);
	transform-origin: center;
}

.case-img-onpage:hover i{
	font-size: 1.6em;
	color: #e21010;
	position: absolute;
	bottom: .8em;
	right: .8em;
	border-radius: 4em;
	padding: 1em;
	background-color: #ffffff;
	z-index: 10;
	transform-origin: center;
	-webkit-transform: scale(100%);

}









/* Tablet Layout: 481px to 768px. Inherits styles from: Mobile Layout. */

@media only screen and (min-width: 481px) {
	
	
	
	
	
	
    
    
    
    
    
    
    
    
    
	

	
	
	
}



/* Desktop Layout: 769px to a max of 1232px.  Inherits styles from: Mobile Layout and Tablet Layout. */

@media only screen and (min-width: 769px) {

    
.expertise-container section{
	width: 100%;
	display: block;
}

section.otherservices{
	margin-top: 10vh;
}

.otherservices .os-inner{
	display: grid; 
  grid-template-columns: 1fr 1fr 1fr; 
  grid-template-rows: 1fr; 
  gap: 2em 2em; 
  grid-template-areas: 
    ". . ."; 
	width: 100%;
	height: auto;
	float: left;
	clear: both;
	margin: auto auto 30vh;
}
    
    
    



.casepage-hero{
	width: 100%;
	height: 60vh;
	display: block;
	float: left;
	clear: none;
	overflow: hidden;
	margin: 0;
}


.cases-preview{
	width: 100%;
	height: auto;
	display: block;
	margin: -25vh auto auto;
}

.cases-preview .case{
	border-radius: 3em;
	overflow: hidden;
	height: 80vh;
	margin: 1.5em 0;
}

.cases-preview .case .case-details{
	width: calc(35% - 6em);
	height: calc(50vh - 2em);
	border-radius: 2em;
	bottom: calc(15vh - 2em);
	right: calc(15vh - 2em);
}

    
.shb-right.case-page-details{
	background-color: #e21010;
	background-image: none;
	margin-top: 5vh;
	width: 100%;
	min-height: 70vh;
	max-height: 90vh;
}

.case-page-details .case-details-inner{
	width: calc(100% - 6em);
	height: calc(auto - 6em);
	position: absolute;
	z-index: 10;
	float: left;
	clear: none;
	top: 3em;
	left: 3em;
	color: #fff;
	z-index: 100;
	transition: all .2s ease-in-out;
}


.case-page-details .tags{
	width: 110%;
	height: auto;
	display: block;
	float: left;
	clear: both;
	margin: auto -1em 0;
}


.case-img-onpage{
	width: 100%;
	height: 40vh;
	border-radius: 3em;
	display: block;
	float: left;
	clear: both;
	margin: 1em 0;
	background-size: cover;
	background-position: center;
	position: relative;
}

.case-img-onpage a{
	width: 100%;
	height: 100%;
	display: block;
}


.case-img-onpage i{
	font-size: 1.6em;
	color: #fff;
	position: absolute;
	bottom: 1em;
	right: 1em;
	border-radius: 2em;
	padding: .8em;
	background-color: #ffffff00;
	z-index: 10;
	transition: all .2s ease-in-out;
	transform: scale(70%);
	transform-origin: center;
}

.case-img-onpage:hover i{
	font-size: 1.6em;
	color: #e21010;
	position: absolute;
	bottom: .8em;
	right: .8em;
	border-radius: 4em;
	padding: 1em;
	background-color: #ffffff;
	z-index: 10;
	transform-origin: center;
	-webkit-transform: scale(100%);

}


    
    
    
    
    
    
  
    
    
}
    /* Desktop Layout: 769px to a max of 1080px.  Inherits styles from: Mobile Layout and Tablet Layout. */

@media only screen and (min-width: 1080px) {
	
    
	

.expertise-container section{
	width: 100%;
	display: block;
}

section.otherservices{
	margin-top: 10vh;
}

.otherservices .os-inner{
	display: grid; 
  grid-template-columns: 1fr 1fr; 
  grid-template-rows: 1fr; 
  gap: 2em 2em; 
  grid-template-areas: 
    ". ."; 
	width: 100%;
	height: auto;
	float: left;
	clear: both;
	margin: auto auto auto;
}









.casepage-hero{
	width: 100%;
	height: 80vh;
	display: block;
	float: left;
	clear: none;
	overflow: hidden;
	margin: 0;
}


.cases-preview{
	width: 100%;
	height: auto;
	display: block;
	margin: -15vh auto auto;
}

.cases-preview .case{
	border-radius: 3em;
	overflow: hidden;
	height: 80vh;
	margin: 1.5em 0;
}

.cases-preview .case .case-details{
	width: calc(30% - 6em);
	height: calc(50vh - 2em);
	border-radius: 2em;
	bottom: calc(15vh - 2em);
	right: calc(15vh - 2em);
}

    

.shb-right.case-page-details{
	background-color: #e21010;
	background-image: none;
	margin-top: -25vh;
	width: 40%;
	min-height: 70vh;
	max-height: 150vh;
}

.case-page-details .case-details-inner{
	width: calc(100% - 6em);
	height: calc(auto - 6em);
	position: absolute;
	z-index: 10;
	float: left;
	clear: none;
	top: 3em;
	left: 3em;
	color: #fff;
	z-index: 100;
	transition: all .2s ease-in-out;
}


.case-page-details .tags{
	width: 110%;
	height: auto;
	display: block;
	float: left;
	clear: both;
	margin: auto -1em 0;
}


.case-img-onpage{
	width: 100%;
	height: 40vh;
	border-radius: 3em;
	display: block;
	float: left;
	clear: both;
	margin: 1em 0;
	background-size: cover;
	background-position: center;
	position: relative;
}

.case-img-onpage a{
	width: 100%;
	height: 100%;
	display: block;
}


.case-img-onpage i{
	font-size: 1.6em;
	color: #fff;
	position: absolute;
	bottom: 1em;
	right: 1em;
	border-radius: 2em;
	padding: .8em;
	background-color: #ffffff00;
	z-index: 10;
	transition: all .2s ease-in-out;
	transform: scale(70%);
	transform-origin: center;
}

.case-img-onpage:hover i{
	font-size: 1.6em;
	color: #e21010;
	position: absolute;
	bottom: .8em;
	right: .8em;
	border-radius: 4em;
	padding: 1em;
	background-color: #ffffff;
	z-index: 10;
	transform-origin: center;
	-webkit-transform: scale(100%);

}







    
    
}
    
    
    /* Desktop Layout:1080px to a max of 1440px.  Inherits styles from: Mobile Layout and Tablet Layout. */

@media only screen and (min-width: 1440px) {

    
	
	
	
	
	
	
	
    
    
    
}
    
        /* Desktop Layout: 1440px to a max of 1920px.  Inherits styles from: Mobile Layout and Tablet Layout. */

@media only screen and (min-width: 1920px) {
	
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
  
    
    
    
}
            /* Desktop Layout: 1920px to a max of 2400px.  Inherits styles from: Mobile Layout and Tablet Layout. */

@media only screen and (min-width: 2400px) {
	

    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
		
}