.grid *, .grid *:after, .grid *:before { -webkit-box-sizing: border-box; box-sizing: border-box; }



.grid {

	position: relative;

	margin: 0 auto;

	padding:0;

	width:100%;

	list-style: none;

	text-align: center;

}



/* Common style */

.grid figure {

	position: relative;

	float: left;

	overflow: hidden;

	margin:0 1% 20px;

	width: 31.3333333%;

	background: #6c7071;

	text-align: center;

	cursor: pointer;

	max-width:420px;

	height:354px

}



.grid figure img {

	position: relative;

	display: block;

	min-height: 100%;

	max-width: 100%;

	opacity: 0.8;

}



.grid figure figcaption {

	padding: 2em;

	color: #fff;	

	font-size: 1.25em;

	-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%;

}



/* Anchor will cover the whole item by default */

/* For some effects it will show as a button */

.grid figure figcaption > a {

	z-index: 1000;

	text-indent: 200%;

	white-space: nowrap;

	font-size: 0;

	opacity: 0;

}



.grid figure h2 {

	font-weight: 300;

	font-size:22px;

	color:#fff;

	line-height:22px;

}



.grid figure h2 span {

	font-weight: 800;

}



.grid figure h2,

.grid figure p {

	margin: 0;

}



.grid figure p {font-size:14px;font-weight:normal;line-height:19px}









/*---------------*/

/***** Dexter *****/

/*---------------*/



figure.effect-dexter {

	background: -webkit-linear-gradient(top, rgba(37,141,200,1) 0%, rgba(104,60,19,1) 100%);

	background: linear-gradient(to bottom, rgba(37,141,200,1) 0%,rgba(104,60,19,1) 100%); 

}



figure.effect-dexter img {

	-webkit-transition: opacity 0.35s;

	transition: opacity 0.35s;

}



figure.effect-dexter:hover img {

	opacity: 0.4;

}



figure.effect-dexter figcaption::after {

	position: absolute;

	right: 30px;

	bottom: 30px;

	left: 30px;

	height: -webkit-calc(50% - 30px);

	height: calc(50% - 30px);

	border: 2px solid #fff;

	content: '';

	-webkit-transition: -webkit-transform 0.35s;

	transition: transform 0.35s;

	-webkit-transform: translate3d(0,-100%,0);

	transform: translate3d(0,-100%,0);

}



figure.effect-dexter:hover figcaption::after {

	-webkit-transform: translate3d(0,0,0);

	transform: translate3d(0,0,0);

}



figure.effect-dexter figcaption {

	padding: 3em;

	text-align: left;

}



figure.effect-dexter p {

	position: absolute;

	right: 60px;

	bottom: 60px;

	left: 60px;

	opacity: 0;

	-webkit-transition: opacity 0.35s, -webkit-transform 0.35s;

	transition: opacity 0.35s, transform 0.35s;

	-webkit-transform: translate3d(0,-100px,0);

	transform: translate3d(0,-100px,0);

}



figure.effect-dexter:hover p {

	opacity: 1;

	-webkit-transform: translate3d(0,0,0);

	transform: translate3d(0,0,0);

}



/*---------------*/

/***** Bubba *****/

/*---------------*/



figure.effect-bubba {

}



figure.effect-bubba img {

	opacity: 0.7;

	-webkit-transition: opacity 0.35s;

	transition: opacity 0.35s;

}



figure.effect-bubba:hover img {

	opacity: 0.4;

}



figure.effect-bubba figcaption::before,

figure.effect-bubba figcaption::after {

	position: absolute;

	top: 30px;

	right: 30px;

	bottom: 30px;

	left: 30px;

	content: '';

	opacity: 1;

	-webkit-transition: opacity 0.35s, -webkit-transform 0.35s;

	transition: opacity 0.35s, transform 0.35s;

}



figure.effect-bubba figcaption::before {

	border-top: 1px solid #fff;

	border-bottom: 1px solid #fff;

/*	-webkit-transform: scale(0,1);

	transform: scale(0,1);*/

}



figure.effect-bubba figcaption::after {

	border-right: 1px solid #fff;

	border-left: 1px solid #fff;

	/*-webkit-transform: scale(1,0);*/

	/*transform: scale(1,0);*/

}



figure.effect-bubba h2 {

	padding-top: 18%;

	-webkit-transition: -webkit-transform 0.35s;

	transition: transform 0.35s;

	/*-webkit-transform: translate3d(0,-20px,0);

	transform: translate3d(0,-20px,0);*/

}



figure.effect-bubba p {

	padding: 20px 8px;

	opacity: 1;

	-webkit-transition: opacity 0.35s, -webkit-transform 0.35s;

	transition: opacity 0.35s, transform 0.35s;

	/*-webkit-transform: translate3d(0,20px,0);

	transform: translate3d(0,20px,0);*/

}



/*figure.effect-bubba:hover figcaption::before,

figure.effect-bubba:hover figcaption::after {

	opacity: 1;

	-webkit-transform: scale(1);

	transform: scale(1);

}*/



figure.effect-bubba:hover h2,

figure.effect-bubba:hover p {

	opacity: 1;

	-webkit-transform: translate3d(0,0,0);

	transform: translate3d(0,0,0);

}



/*-----------------*/

/***** Apollo *****/

/*-----------------*/



figure.effect-apollo {

	background: #3498db;

}



figure.effect-apollo img {

	opacity: 0.95;

	-webkit-transition: opacity 0.35s, -webkit-transform 0.35s;

	transition: opacity 0.35s, transform 0.35s;

	-webkit-transform: scale3d(1.05,1.05,1);

	transform: scale3d(1.05,1.05,1);

}



figure.effect-apollo figcaption::before {

	position: absolute;

	top: 0;

	left: 0;

	width: 100%;

	height: 100%;

	background: rgba(255,255,255,0.5);

	content: '';

	-webkit-transition: -webkit-transform 0.6s;

	transition: transform 0.6s;

	-webkit-transform: scale3d(1.9,1.4,1) rotate3d(0,0,1,45deg) translate3d(0,-100%,0);

	transform: scale3d(1.9,1.4,1) rotate3d(0,0,1,45deg) translate3d(0,-100%,0);

}



figure.effect-apollo p {



}



figure.effect-apollo h2 {

	text-align: left;

}



figure.effect-apollo:hover img {

	opacity: 0.6;

	-webkit-transform: scale3d(1,1,1);

	transform: scale3d(1,1,1);

}



figure.effect-apollo:hover figcaption::before {

	-webkit-transform: scale3d(1.9,1.4,1) rotate3d(0,0,1,45deg) translate3d(0,100%,0);

	transform: scale3d(1.9,1.4,1) rotate3d(0,0,1,45deg) translate3d(0,100%,0);

}



figure.effect-apollo:hover p {

	opacity: 1;

	-webkit-transition-delay: 0.1s;

	transition-delay: 0.1s;

}







@media screen and (max-width: 50em) {

	.content {

		padding: 0 10px;

		text-align: center;

	}

	.grid figure {

		display:block;

		float: none;

		margin: 10px auto;

		width: 100%;

	}

}