
.grid figure {
	margin: 0;
	position: relative;
}

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

.grid figcaption {
	position: absolute;
	top: 0;
	left: 0;
	padding: 10%;
	background: #dce6e4;
	color: #574f4d;
}

.grid figcaption {
	height: 100%;
	width: 100%;
	opacity: 0;
	text-align: center;
	-webkit-backface-visibility: hidden;
	-moz-backface-visibility: hidden;
	backface-visibility: hidden;
	-webkit-transition: -webkit-transform 0.3s, opacity 0.3s;
	-moz-transition: -moz-transform 0.3s, opacity 0.3s;
	transition: transform 0.3s, opacity 0.3s;
}

.grid figcaption.box {opacity: 1; float: left; display: inline-block; padding: 2.5rem; position: relative;}
section.grid figcaption.box p {margin:0; padding:0; text-align: center; max-width: 100%;}
section.grid figcaption.box a {font-size: .875rem;}
section.grid figcaption.box h3 {text-align: center; font-size: 1.25rem; max-width: 100%;}

.no-touch .grid figure:hover figcaption,
.grid figure.cs-hover figcaption,
.grid figure:hover figcaption {
	opacity: 1;
}

.no-touch .grid figure:hover,
.grid figure.cs-hover {opacity: 1;}

.no-touch .cs-hover figure:hover figcaption,
.cs-hover figure.cs-hover figcaption,
.no-touch .cs-hover figure:hover figcaption {
	opacity: 1;
}
