@charset "utf-8";
/*------------------------------------------------------------
	汎用スタイル
------------------------------------------------------------*/
/* 81-LSM */
/* clearfix */	
.clearfix:after {content: "";display: block;clear: both;}
/* flex */	
.flex,.flexA,.flexB,.flexC {display: flex;flex-wrap: wrap;}
.flexA {justify-content: space-around;}
.flexB {justify-content: space-between;}
.flexC {justify-content: center;}
.roboto {
	font-family: "Roboto", sans-serif;
}
/*------------------------------------------------------------
	content
------------------------------------------------------------*/
.content {
	margin: 0 auto;
	max-width: 120rem;
	position: relative;
	z-index: 5;
}
@media all and (max-width: 896px) {
	.content {
		margin: 0 1.5rem;
		max-width: inherit;
	}
}
/*------------------------------------------------------------
	comLink
------------------------------------------------------------*/
.comLink {
	width: 20rem;
}
.comLink a {
	padding: 3rem 8rem 3rem 0;
	display: block;
	color: #172a4f;
	font-size: 2rem;
	font-weight: 700;
	font-family: "Roboto", sans-serif;
	letter-spacing: 0.05em;
	background: url(../img/common/icon01.png) no-repeat right center / 6rem;
}
.comLink a:hover {
	opacity: 0.7;
}
.comLink.white a {
	color: #FFF;
	background-image: url(../img/common/icon03.png);
}
@media all and (max-width: 896px) {
	.comLink {
		width: 16.5rem;
	}
	.comLink a {
		padding: 3rem 6rem 2.8rem 0;
		display: block;
		font-size: 1.6rem;
		background-size: 5rem;
		background-image: url(../img/common/icon01_sp.png);
	}
	.comLink.white a {
		background-image: url(../img/common/icon03_sp.png);
	}
}
/*------------------------------------------------------------
	headLine01
------------------------------------------------------------*/
.headLine01 {
	margin-bottom: 5.4rem;
	font-size: 2.4rem;
	font-weight: 700;
	letter-spacing: 0.05em;
}
.headLine01 .en {
	margin-bottom: -1.3rem;
	display: block;
	color: #172a4f;
	font-size: 10rem;
	font-weight: 700;
	font-family: "Roboto", sans-serif;
	letter-spacing: 0.05em;
}
.headLine01.white,
.headLine01.white .en {
	color: #FFF;
}
@media all and (max-width: 896px) {
	.headLine01 {
		margin-bottom: 1.7rem;
		font-size: 1.8rem;
	}
	.headLine01 .en {
		margin-bottom: -1.1rem;
		font-size: 5.6rem;
	}
}
/*------------------------------------------------------------
	headLine02
------------------------------------------------------------*/
.headLine02 {
	line-height: 1.1;
}
.headLine02 .en {
	margin-bottom: 2rem;
	padding: 0.6rem 2rem 0.4rem;
	width: fit-content;
	display: block;
	color: #FFF;
	background: #172a4f;
	font-size: 10rem;
	font-weight: 700;
	font-family: "Roboto", sans-serif;
	letter-spacing: 0.05em;
}
.headLine02 .jp {
	padding: 1.1rem 2rem 1.3rem;
	display: block;
	width: fit-content;
	color: #172a4f;
	font-size: 2.4rem;
	font-weight: 700;
	background: #FFF;
	letter-spacing: 0.05em;
}
@media all and (max-width: 896px) {
	.headLine02 .en {
		margin-bottom: 1rem;
		padding: 0.6rem 1rem 0.4rem;
		font-size: 3.6rem;
	}
	.headLine02 .jp {
		padding: 0.8rem 1rem;
		font-size: 1.4rem;
	}
}
/*------------------------------------------------------------
	headLine03
------------------------------------------------------------*/
.headLine03 {
	margin-bottom: 5.8rem;
}
.headLine03 .en {
	margin-bottom: -1.6rem;
	display: block;
	color: #172a4f;
	font-family: "Roboto", sans-serif;
	font-size: 8rem;
	font-weight: 700;
	letter-spacing: 0.05em;
}
.headLine03 .jp {
	font-size: 2rem;
	font-weight: 700;
	letter-spacing: 0.05em;
}
@media all and (max-width: 896px) {
	.headLine03 {
		margin-bottom: 3rem;
	}
	.headLine03 .en {
		margin-bottom: -0.8rem;
		font-size: 3.6rem;
	}
	.headLine03 .jp {
		font-size: 1.6rem;
	}
}
/*------------------------------------------------------------
	headLine04
------------------------------------------------------------*/
.headLine04 {
	margin-bottom: 6.1rem;
	padding-left: 3rem;
	position: relative;
	font-size: 3.2rem;
	font-weight: 700;
	letter-spacing: 0.05em;
}
.headLine04::before {
	position: absolute;
	top: 0;
	left: 0;
	width: 0.8rem;
	height: 5rem;
	background: #172a4f;
	content: '';
}
@media all and (max-width: 896px) {
	.headLine04 {
		margin-bottom: 3rem;
		padding-left: 2rem;
		font-size: 2rem;
	}
	.headLine04::before {
		width: 0.4rem;
		height: 2.5rem;
		top: 50%;
		transform: translateY(-50%);
	}
}
/*------------------------------------------------------------
	comTopBox
------------------------------------------------------------*/
.comTopBox {
	margin-bottom: -0.3rem;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
}
.comTopBox .comLink {
	margin-top: 4.3rem;
}
@media all and (max-width: 896px) {
	.comTopBox {
		margin-bottom: 1.3rem;
		display: block;
	}
	.comTopBox .comLink {
		margin: -2rem 0 0 auto;
	}
}
/*------------------------------------------------------------
	comPhotoList
------------------------------------------------------------*/
.comPhotoList {
	margin-bottom: 5.5rem;
}
.comPhotoList > li {
	margin-right: 4rem;
	width: 58rem;
}
.comPhotoList li a {
	display: block;
}
.comPhotoList li a:hover {
	opacity: 0.7;
}
.comPhotoList li a .photoBox {
	position: relative;
}
.comPhotoList li a .photoBox .titleBox {
	padding-top: 2.7rem;
	position: absolute;
	bottom: 0;
	left: 0;
	width: 46rem;
	z-index: 5;
	background: #FFF;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
}
.comPhotoList li a .photoBox .titleBox .tagUl {
	margin-bottom: 0.3rem;
	width: 8rem;
}
.comPhotoList li a .photoBox .titleBox .tagUl li {
	margin-bottom: 0.5rem;
	padding: 0 0.3rem;
	color: #6e7888;
	font-size: 1.4rem;
	letter-spacing: 0.05em;
	border: 1px solid #6e7888;
	text-align: center;
}
.comPhotoList li a .photoBox .titleBox .tagUl li:last-child {
	margin-bottom: 0;
}
.comPhotoList li a .photoBox .titleBox .title {
	padding: 0 1rem 0.4rem 0;
	width: calc(100% - 10rem);
	font-size: 2.4rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1.2;
}
@media all and (max-width: 896px) {
	.comPhotoList {
		margin-bottom: 2.5rem;
	}
	.comPhotoList > li {
		margin-right: 2rem;
		width: 29rem;
	}
	.comPhotoList li a .photoBox .titleBox {
		padding-top: 0.9rem;
		width: 22rem;
	}
	.comPhotoList li a .photoBox .titleBox .tagUl {
		width: 7rem;
	}
	.comPhotoList li a .photoBox .titleBox .tagUl li {
		margin-bottom: 0.5rem;
		padding-bottom: 0.1rem;
		font-size: 1.3rem;
		line-height: 1.2;
	}
	.comPhotoList li a .photoBox .titleBox .title {
		padding-right: 0.5rem;
		width: calc(100% - 8.5rem);
		font-size: 1.8rem;
	}
}
/*------------------------------------------------------------
	common
------------------------------------------------------------*/
@media all and (max-width: 896px) {
}
/*------------------------------------------------------------
	common
------------------------------------------------------------*/
@media all and (max-width: 896px) {
}
/*------------------------------------------------------------
	common
------------------------------------------------------------*/
@media all and (max-width: 896px) {
}
/*------------------------------------------------------------
	common
------------------------------------------------------------*/
@media all and (max-width: 896px) {
}
/*------------------------------------------------------------
	common
------------------------------------------------------------*/
@media all and (max-width: 896px) {
}