#page_title {
	background: url(../images/shape_dtp.svg) no-repeat center right;
	background-size: auto 70%;
}

#page_title h2 {
	color: #000;
}

#section1 {
	padding: 0 5%;
	margin-bottom: 150px;
}

#section1 .photo_comment {
	gap: 5%;
	align-items: center;
}

#section1 figure {
	width: 40.7%;
	order: 1;
}

#section1 .comment {
	width: 54.3%;
	order: 2;
}

#section1 .comment h3 {
	font-size: clamp(50px, 4.1666dvw, 80px);
	margin-bottom: 100px;
}

#section1 .comment h4 {
	font-size: 36px;
	margin-bottom: 30px;
	line-height: 1.5em;
}

#section2 {
	margin-bottom: 150px;
}

#section2 article {
	margin-bottom: 50px;
}

#section2 h3 {
	text-align: center;
	font-size: 48px;
	margin-bottom: 80px;
}

#section2 .photo_comment {
	gap: 4.7%;
	align-items: center;
}

#section2 figure {
	width: 36.45%;
	flex: none;
}

#section2 .photo_comment .comment {
	width: 38.0208vw;
	flex: none;
}

#section2 .photo_comment .comment h4 {
	font-size: 36px;
	margin-bottom: 30px;
	line-height: 1.5em;
}

#section2-1 figure,
#section2-3 figure {
	order: 1;
}

#section2-3 figure img {
	width: 100%;
	height: 420px;
	object-fit: contain;
	object-position: top right;
}

#section2-1 .photo_comment .comment,
#section2-3 .photo_comment .comment {
	order: 2;
}

#section2-2 .photo_comment,
#section2-4 .photo_comment {
	justify-content: flex-end;
}

#section_point {
	padding: 0 5%;
	margin-bottom: 150px;
}

#section_point #section_point_inner {
	max-width: 1360px;
	margin: 0 auto;
	display: flex;
}

#section_point h3 {
	width: 320px;
	font-size: 30px;
	flex: none;
}

#section_point h3 .eng {
	font-size: 60px;
	display: block;
	margin-bottom: 15px;
}

#section_point article {
	width: calc(100% - 320px);
	flex: none;
}

#section_point dl {
	padding: 10px 45px 45px 10px;
	background: #eeeeee;
	margin-bottom: 20px;
}

#section_point dt {
	font-size: 30px;
	color: #fff;
	font-family: "futura-pt", sans-serif;
	font-weight: 600;
	font-style: normal;
}

#section_point dd {
	padding: 10px 0 0 35px;
	display: flex;
}

#section_point dd h4 {
	font-size: 36px;
	width: 430px;
	flex: none;
	line-height: 1.5em;
}

#works_list {
	background: #f9f9f9;
	margin-bottom: 150px;
	padding: 100px 5%;
}

#works_list h3 {
	max-width: 1360px;
	margin-bottom: 80px;
	font-size: 30px;
	display: flex;
	gap: 50px;
	align-items: center;
}

#works_list h3 .eng {
	font-size: 60px;
}

#works_list article {
	max-width: 1500px;
	display: flex;
	gap: 3.125dvw;
	margin: 0 auto;
}

#works_list article dl {
	width: calc((100% - 6.25dvw) / 3);
}

#works_list article dt {
	height: 15.625vw;
	background: #eeeeee;
	display: flex;
	width: 100%;
	align-items: center;
	justify-content: center;
	border-radius: 10px;
	overflow: hidden;
}

#works_list article dt a {
	display: block;
	width: 100%;
	height: 100%;
}

#works_list article dt img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: top center;
	margin: 0 auto;
}

#works_list dd {
	padding: 20px 0 0;
}

#works_list .morelink {
	color: #000;
	text-decoration: none;
	font-size: 24px;
}

#works_list .morelink img {
	vertical-align: middle;
	margin-left: 5px;
}

.morelink_text {
	display: block;
	font-size: 18px;
}

#works_list .more {
	padding: 50px 0 0;
}

#works_list .more a {
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	justify-content: center;
	font-size: 16px;
	text-align: center;
	color: #000;
	text-decoration: none;
	width: 420px;
	height: 85px;
	box-sizing: border-box;
	background: url('../images/more1.svg') no-repeat right center;
}

#works_list .more a .eng {
	font-size: 36px;
	display: block;
}

#section_remort {
	padding: 0 0 150px 0;
}

#section_remort h3 {
	background: url('../images/shape_remort.svg') no-repeat center center;
	height: 201px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	font-size: 24px;
	margin-bottom: 40px;
}

#section_remort h3 .eng {
	font-size: 80px;
	margin-bottom: 30px;
}

#section_remort article {
	max-width: 1100px;
	padding: 0 40px;
	box-sizing: border-box;
	margin: 0 auto;
}

#section_remort article h4 {
	font-size: 36px;
	margin-bottom: 40px;
	line-height: 1.5em;
}