.contenedor-img {
	width: 300px;
	height: 300px;
	float: left;
	overflow: hidden;
	position: relative;
	text-align: center;
	cursor: default;
	background: #fff;
	border: 1px solid black;
}

.contenedor-img .mascara,
.contenedor-img .contenido{
    width: 300px;
	height: 300px;
	position: absolute;
	overflow: hidden;
    top: 0;
    left: 0;
}

.contenedor-img img{
	display: block;
	position: relative;
	width: 300px;
	height: 300px;
}

.contenedor-img h2{
	text-transform: uppercase;
	color: #fff;
	text-align: center;
	position: relative;
	font-size: 17px;
	padding: 10px;
	background: rgba(0,0,0,0.5);
	margin: 20px 0 0 0;
}

.contenedor-img p{
	font-size: 16px;
	position: relative;
	color: #fff;
	padding: 10px 20px 10px;
	text-align: center;
}

.contenedor-img a.link{
	display: inline-block;
	text-decoration: none;
	padding: 7px 14px;
	background: #222;
	color: #fff;
	text-transform: uppercase;
	box-shadow: 0 0 1px #000;
}

.contenedor-img a.link:hover{
	box-shadow: 0 0 5px #000;
}

/*Efecto*/
.efecto img{
	transition: all 0.2s linear;
}

.efecto .mascara{
	opacity: 0;
	background-color: rgba(46,157,120,0.7);
	transition: all 0.3s ease-in-out;
}

.efecto h2{
	transform: translateX(-200px);
	opacity: 0;
	transition: all 0.7s ease-in-out;
}

.efecto img p{
	transform: translateX(200px);
	opacity: 0;
	transition: all 0.4s linear;
}

.efecto a.link{
	opacity: 0;
	transition: all 0.4s ease-in-out;
	transform: translateY(100px);
}

.efecto:hover img{
   transform: scale(1.1);
}

.efecto:hover .mascara{
	opacity: 1;
}

.efecto:hover h2,
.efecto:hover p,
.efecto:hover a.link{
	opacity: 1;
	transform: translateX(0px);
}

.efecto:hover p{
	transition-delay: 0.1s;
}

.efecto:hover a.link{
	transition-delay: 0.1s;
	transform: translateY(0px);
}