@charset "utf-8";
/*------------------------------------------------------------
	index
------------------------------------------------------------*/
#main .mainVisual {
	margin: 0 auto;
	width: 128.1rem;
	aspect-ratio: 16 / 9;
	mask-image: url("../img/index/mask01.png");
	-webkit-mask-image: url("../img/index/mask01.png");
	mask-position: center bottom;
	-webkit-mask-position: center bottom;
	mask-repeat: no-repeat;
	-webkit-mask-repeat: no-repeat;
	mask-size: 100% auto;
	-webkit-mask-size: 100% auto;
	position: relative;
}
#main .mainVisual img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
#main .mainVisual video {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
#main .mainTextImg {
	margin: -20.5rem auto -1.8rem;
	padding-right: 9.2rem;
	width: 57.3rem;
	position: relative;
	z-index: 10;
	box-sizing: content-box;
}
#main .secBox .hTitle {
	margin-bottom: 2.4rem;
	color: #0068b6;
	font-size: 3.1rem;
	font-weight: 400;
	text-align: center;
	letter-spacing: 0.05em;
}
#main .secBox .link {
	margin: 0 auto 2.4rem;
	width: 20.9rem;
}
#main .secBox .link a {
	padding-bottom: 0.2rem;
	min-height: 4.5rem;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	box-shadow : 0 0 0.8rem rgba(0, 0, 0, 0.75);
	color: #0068b6;
	font-size: 2rem;
	text-align: center;
	border-radius: 3rem;
	letter-spacing: 0.05em;
}
#main .secBox .link a:hover {
	opacity: 0.7;
}
#main .secBox .topText {
	padding: 12.3rem 0 13.6rem;
	position: relative;
	color: #0068b6;
	font-size: 3rem;
	font-family: "Noto Serif JP", serif;
	line-height: 1.75;
	text-align: center;
}
#main .secBox .topText::before {
	position: absolute;
	top: 0;
	left: 50%;
	width: 1px;
	height: 9.9rem;
	background: #0068b6;
	content: '';
}
#main .secBox .photoList {
	margin: 0 auto 13.5rem;
	max-width: 109.4rem;
}
#main .secBox .photoList .slick-slide > div {
	margin-right: 1.4rem;
	width: 35.5rem;
}
#main .secBox .photoList li a {
	padding: 1.3rem 0 3.5rem;
	display: block;
	height: 100%;
}
#main .secBox .photoList li a:hover {
	opacity: 0.7;
}
#main .secBox .photoList li .number {
	margin-bottom: 1.3rem;
	padding-bottom: 2.3rem;
	position: relative;
	color: #333;
	font-size: 2.6rem;
	text-align: center;
	font-family: "Inter", sans-serif;
}
#main .secBox .photoList li .number::before {
	margin-left: -1px;
	position: absolute;
	bottom: 0;
	left: 50%;
	width: 1px;
	height: 2.1rem;
	background: #333;
	content: '';
}
#main .secBox .photoList li.style01 a {
	background: #3fa9f5;
}
#main .secBox .photoList li.style02 a {
	background: #7ac943;
}
#main .secBox .photoList li.style03 a {
	background: #ff931e;
}
#main .secBox .photoList li.style04 a {
	background: #ff1d25;
}
#main .secBox .photoList li.style05 a {
	background: #ff7bac;
}
#main .secBox .photoList li .title {
	margin-bottom: 2.9rem;
	color: #FFF;
	font-family: "Noto Serif JP", serif;
	font-size: 3rem;
	line-height: 1.27;
	text-align: center;
	letter-spacing: 0.04em;
}
#main .secBox .photoList li.style04 .title {
	letter-spacing: -0.05em;
}
#main .secBox .photoList li .photo {
	margin: 0 auto;
	width: 25.7rem;
}
#main .secBox .photoList .slick-dots {
	text-align: center;
	margin-top: 3.9rem;
}
#main .secBox .photoList .slick-dots li {
	margin: 0 0.5rem;
	display: inline-block;
	width: 1.5rem;
	height: 1.5rem;
	background-color: #ccc;
	cursor: pointer;
}
#main .secBox .photoList .slick-dots li button {
	display: none;
}
#main .secBox .photoList .slick-dots li.slick-active {
	background-color: #0068b6;
}
#main .secBox .bannerBox {
	margin: 0 auto;
	width: 85.3rem;
	position: relative;
	z-index: 10;
}
#main .secBox .bannerBox a {
	display: block;
}
#main .secBox .bannerBox a:hover {
	opacity: 0.7;
}
#main .secBox .bannerBox .banner01,
#main .secBox .bannerBox .banner03 {
	margin: 0 auto;
	width: 85.2rem;
}
#main .secBox .bannerBox .banner01 {
	margin-bottom: 3.2rem;
}
#main .secBox .bannerBox .banner02 {
	margin-bottom: 2.9rem;
}
#main .comInterviewBox {
	padding: 16.7rem 0 0;
	position: relative;
}
#main .comInterviewBox::before {
	position: absolute;
	top: -46.4rem;
	left: 0;
	width: 100%;
	bottom: -8.5rem;
	background : rgba(0, 104, 182, 0.2);
	content: '';
}
#main .comInterviewBox .content {
	padding: 2rem 0 0;
	max-width: 85.2rem;
	position: relative;
	z-index: 10;
	background: #FFF;
}
#main .comInterviewBox .photoList {
	margin: 0 -2.1rem 8.2rem;
}
#main .comInterviewBox .arrow {
	left: -2.1rem;
	width: auto;
	right: -2.1rem;
}
@media all and (max-width: 896px) {
	#main .mainVisual {
		margin: 0 0 -38.3vw;
		width: auto;
		aspect-ratio: 750 / 766;
		mask-image: none;
		-webkit-mask-image: none;
	}
	#main .mainTextImg {
		margin: 0;
		padding-right: 0;
		width: auto;
		position: absolute;
		top: 3.8rem;
		left: 3.3rem;
		right: 3.2rem;
	}
	#main .mainTextImg img {
		width: 100%;
	}
	#main .secBox .hTitle {
		margin-bottom: 1.6rem;
		font-size: 1.6rem;
		font-weight: 500;
	}
	#main .secBox .link {
		margin: 0 auto 1.9rem;
		width: 17.2rem;
		position: relative;
		z-index: 5;
	}
	#main .secBox .link a {
		padding-bottom: 0.3rem;
		min-height: 3.7rem;
		font-weight: 500;
		font-size: 1.6rem;
		background: #FFF;
	}
	#main .secBox .topText {
		padding: 6rem 0 2.2rem;
		font-size: 1.6rem;
		line-height: 1.59;
	}
	#main .secBox .topText::before {
		height: 3.9rem;
	}
	#main .secBox .photoList {
		margin: 0 -2rem 4.3rem;
		max-width: inherit;
		position: relative;
		z-index: 5;
	}
	#main .secBox .photoList .slick-slide > div {
		margin: 0 0.6rem;
		width: 19.2rem;
	}
	#main .secBox .photoList li a {
		padding: 0.8rem 0 1.8rem;
	}
	#main .secBox .photoList li .number {
		margin-bottom: 0.7rem;
		padding-bottom: 1.3rem;
		font-size: 1.4rem;
	}
	#main .secBox .photoList li .number::before {
		margin-left: -1px;
		height: 1.2rem;
	}
	#main .secBox .photoList li .title {
		margin-bottom: 1.6rem;
		font-size: 1.6rem;
	}
	#main .secBox .photoList li .photo {
		margin: 0 auto;
		width: 14rem;
	}
	#main .secBox .photoList .slick-dots {
		margin-top: 2.2rem;
	}
	#main .secBox .bannerBox {
		margin: 0 0 2.3rem;
		width: auto;
	}
	#main .secBox .bannerBox img {
		width: 100%;
	}
	#main .secBox .bannerBox .banner01,
	#main .secBox .bannerBox .banner03 {
		margin: 0;
		width: auto;
	}
	#main .secBox .bannerBox .banner01 {
		margin-bottom: 1.1rem;
	}
	#main .secBox .bannerBox .banner02 {
		margin-bottom: 0;
	}
	#main .secBox .bannerBox .banner03 {
		margin-bottom: 1.2rem;
	}
	#main .secBox .bannerBox .comVideoBox {
		margin-bottom: 1.2rem;
	}
#main .comInterviewBox {
	padding: 3.4rem 0 0;
	position: relative;
}
	#main .comInterviewBox::before {
		top: 0;
		bottom: -5.1rem;
	}
	#main .comInterviewBox .content {
		padding: 0;
		max-width: inherit;
		background: transparent;
	}
	#main .comInterviewBox .photoList {
		margin: 0 -2.2rem 3.8rem;
	}
}