#works .step:nth-of-type(even) {
	background-color: #F5F5F5;
}

#works .step:last-of-type {
	margin-bottom: 60px;
}

#works .step .text {
	padding: 0 0 20px 0;
}

#works .step .photo {
	padding-bottom: 10px;
}

#works .step .photo img {
	margin-bottom: 5px;
	border: solid 1px #CCCCCC;
}

#works #wmenu ul {
	padding: 30px 0;
	border-top: solid 1px #848484;
}

#works #wmenu ul li {
	margin-bottom: 20px;
}

#works #wmenu ul li a {
	display: flex;
	position: relative;
	width: 100%;
	height: 100%;
	font-size: max(min(5.3vw, 2.6rem), 2rem);
	background-color: #F7F7F7;
	box-shadow: 2px 2px 4px 2px rgba(102, 102, 102, 0.4);
}

#works #wmenu ul li a:hover {
	text-decoration: none;
}

#works #wmenu ul li a > span:not(.thumb) {
	padding: 10px;
	width: 66%;
}


#works #wmenu ul li .sourcesans {
	display: block;
	font-size: max(min(4.8vw, 2.2rem), 1.8rem);
	line-height: 1;
}

#works #wmenu ul li a .thumb {
	position: absolute;
	right: 0;
	width: 34%;
	height: 100%;
	overflow: hidden;
}

#works #wmenu ul li a .thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}


@media all and (max-width: 767px) {
	#works #service {
		padding: 30px 0;
	}

	#works .step {
		padding: 30px 0;
	}

	#works #wmenu {
		margin-top: 30px;
	}

	#works #wmenu ul li a {
		min-height: calc(34vw - 20px);
	}
}

@media all and (min-width: 768px) {
	#works #service {
		padding: 60px 0;
		text-align: center;
	}

	#works .step {
		padding: 60px 0;
	}

	#works .step .flex {
		justify-content: space-between;
	}

	#works .step .flex:not(.two) .text {
		width: 600px;
	}

	#works .step .flex .photos {
		width: 460px;
	}

	#works #wmenu {
		margin-top: 80px;
	}

	#works #wmenu ul {
		padding: 80px 0;
	}

	#works #wmenu ul li a {
		height: 110px;
	}
}