@charset "utf-8";


.grid {
	position: relative;
	margin: 0 auto;
	padding: 0;
	max-width: 1200px;
	text-align: center;
}

.grid figure {
	position: relative;
	float: left;
	overflow: hidden;
	margin: 0 auto 3em auto;
	max-width: 1200px;
	max-height: 800px;
	width: 100%;
	text-align: center;
	cursor: pointer;
}

.grid figure img {
	position: relative;
	display: block;
	min-height: 100%;
	max-width: 100%;
	opacity: 1;
}

.grid figure figcaption {
	padding: 1em 0 0 0;
	color: #000;
	text-transform: uppercase;
	font-size: 1.2em;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
}

.grid figure figcaption::before,
.grid figure figcaption::after {
	pointer-events: none;
}

.grid figure figcaption,
.grid figure figcaption > a {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

/***** Service *****/


figure.effect-zoe figcaption {
	top: auto;
	bottom: 0;
	padding: 1em 1em 0 2em;
	height: 100%;
	background: #fff;
	opacity: 0.9;
	color: #000;
	-webkit-transition: -webkit-transform 0.35s;
	transition: transform 0.35s;
	-webkit-transform: translate3d(0,100%,0);
	transform: translate3d(0,100%,0);
	z-index: 350;
}

figure.effect-zoe p.description {
	position: absolute;
	color: #000;
	padding: 1em 2em 0 2em;
	margin: 0 2em 0 0;
	text-transform: none;
	font-size: 96%;
	opacity: 1;
	-webkit-transition: opacity 0s;
	transition: opacity 1;
	-webkit-backface-visibility: hidden; /* Fix for Chrome 37.0.2062.120 (Mac) */
	text-align: left;
	vertical-align: middle;
	width: 80%;
}

figure.effect-zoe h2 {
	float: left;
}

figure.effect-zoe p.icon-links a span::before {
	display: inline-block;

	font-family: 'PT Serif', serif;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

figure.effect-zoe h2 {
	display: inline-block;
}

figure.effect-zoe:hover p.description {
	opacity: 1;
}

figure.effect-zoe:hover figcaption,
figure.effect-zoe:hover h2,
figure.effect-zoe:hover p.icon-links a {
	-webkit-transform: translate3d(0,0,0);
	transform: translate3d(0,0,0);
}

figure.effect-zoe:hover h2 {
	-webkit-transition-delay: 0.05s;
	transition-delay: 0.05s;
}

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

.grid figure {
	width: 100%;
	text-align: center;
	cursor: pointer;
	display: inline-block;
}

figure.effect-zoe p.description {
	position: absolute;
	color: #000;
	padding: 1em 2em 0 2em;
	margin: 0 2em 0 0;
	text-transform: none;
	font-size: 78%;
	opacity: 1;
	-webkit-transition: opacity 0s;
	transition: opacity 1;
	-webkit-backface-visibility: hidden;
	text-align: left;
	vertical-align: middle;
	width: 80%;
}

figure.effect-zoe figcaption {
	top: auto;
	bottom: 0;
	padding: 1em 2em 0 1em;
	height: 100%;
	background: #fff;
	opacity: 0.8;
	color: #000;
	-webkit-transition: -webkit-transform 0.35s;
	transition: transform 0.35s;
	-webkit-transform: translate3d(0,100%,0);
	transform: translate3d(0,100%,0);
}
	
}

@media screen and (max-width: 600px) {
	.content {
		padding: 0 1em;
		text-align: center;
		width: 100%;
	}
	.grid figure {
		display: inline-block;
		float: none;
		margin: 10px auto;
		width: 100%;
		max-height: 240px;
	}
	
	.grid figure figcaption {
	display: none;
}
}