@charset "utf-8";
/*------------------------------------------------------------
	index
------------------------------------------------------------*/
#gHeader {
	position: absolute;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	background-color: transparent;
	z-index: 999;
}
#gHeader.scroll {
	background-color: #fff;
}
@media all and (min-width: 897px) {
	#gHeader .hBox .menuBox .link a {
		padding: 1.1rem 6rem 1.1rem 1.8rem;
		border-color: #FFF;
	}
}
#main {
	padding-top: initial;
}
#main .mainVisual {
	margin-bottom: -30rem;
	padding-top: 2.7rem;
	aspect-ratio: 1440 / 900;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	position: relative;
	background: url(../img/index/main_bg.png) no-repeat center bottom / cover;
	box-sizing: border-box;
}
#main .mainVisual .inner {
	margin: 0 auto;
	padding-top: 5rem;
	width: 117.2rem;
	box-sizing: border-box;
}
#main .mainVisual .textImg {
	margin: 0 auto 16.4rem;
	width: 69.6rem;
}
#main .mainVisual .topicsBox {
	margin: 0 0 0 auto;
	width: 87.7rem;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	background-color: #FFF;
}
#main .mainVisual .topicsBox .ttl {
	width: 9.7rem;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	color: #FFF;
	font-size: 1.8rem;
	font-weight: 700;
	text-align: center;
	background-color: #19265B;
}
#main .mainVisual .topicsBox .txtBox {
	width: calc(100% - 9.7rem);
	box-sizing: border-box;
}
#main .mainVisual .topicsBox .txtBox a {
	padding: 1rem 10rem 1rem 2rem;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	background: url(../img/common/icon02.png) no-repeat right 4rem center / 3.6rem;
}
#main .mainVisual .topicsBox a:hover {
	opacity: 0.7;
}
#main .mainVisual .topicsBox .txtBox .date {
	margin-top: 0.2rem;
	width: 8rem;
}
#main .mainVisual .topicsBox .txtBox .txt {
	width: calc(100% - 9rem);
	font-size: 1.2rem;
	line-height: 2;
	text-decoration: underline;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
#main .mission {
	padding: 44.3rem 0 7.7rem;
	background: url(../img/index/mission_bg01.jpg) no-repeat center top -77.4rem / 100%;
}
#main .mission .topBox {
	padding: 0 1.4rem;
}
#main .mission .enImg {
	margin-bottom: -6.6rem;
	width: 59.1rem;
}
#main .mission .textBox {
	margin: 0 2.2rem 4.9rem auto;
	width: 60rem;
}
#main .mission .textBox .text {
	margin-bottom: 4rem;
	color: #19265B;
	font-size: 3rem;
	font-weight: 700;
	line-height: 2.2;
}
#main .mission .textBox .text:last-child {
	margin-bottom: 0;
}
#main .future {
	padding: 14.6rem 0 7.6rem;
	background-color: #C3C7D6;
}
#main .future .titleBox {
	margin-bottom: -5.1rem;
	padding: 0 2.9rem;
	display: flex;
	position: relative;
	z-index: 5;
}
#main .future .titleBox span {
	display: block;
}
#main .future .titleBox .enImg {
	width: 50.5rem;
}
#main .future .titleBox .jp {
	margin: 6.3rem 0 0 -8.4rem;
	color: #19265B;
	font-size: 3rem;
	font-weight: 700;
}
#main .future .pic {
	position: absolute;
	top: -18.9rem;
	right: -11.1rem;
	width: 50rem;
}
#main .future .photoList {
	display: flex;
	flex-wrap: wrap;
	gap: 6rem;
}
#main .future .photoList li {
	width: calc((100% - 12rem) / 3);
}
#main .future .photoList li img {
	width: 100%;
}
#main .future .photoList li:nth-child(2n) {
	margin-top: 10rem;
}
#main .future .photoList li:nth-child(3n) {
	margin-top: 20rem;
}
#main .future .photoList li .txtBox {
	margin-top: 2rem;
	padding: 0 3rem;
}
#main .future .photoList li .txt {
	color: #19265B;
	font-size: 1.8rem;
	font-weight: 500;
	line-height: 1.8;
}
#main .future .photoList li .ttl {
	color: #19265B;
	font-size: 2.4rem;
	font-weight: 700;
  word-break: keep-all;
  overflow-wrap: anywhere;
}
#main .contents {
	margin-bottom: -8.4rem;
	padding: 13rem 0 0;
}
#main .contents .titleBox {
	margin-bottom: 2rem;
	padding: 0 1.7rem;
}
#main .contents .titleBox span {
	display: block;
}
#main .contents .titleBox .enImg {
	margin-bottom: -2.1rem;
	width: 78.2rem;
}
#main .contents .titleBox .jp {
	padding: 0 1.1rem;
	color: #19265B;
	font-size: 2.8rem;
	font-weight: 700;
}
#main .contents .imgBox .text {
	margin: 4.6rem 0 0 1rem;
	width: calc(100% - 60rem);
	color: #19265B;
	font-size: 3rem;
	font-weight: 700;
	line-height: 1.66;
}
#main .contents .imgBox .photo {
	margin-right: -1.5rem;
	width: 58.5rem;
}
#main .learning {
	margin-bottom: 10rem;
}
#main .learning .content {
	max-width: 108rem;
}
#main .learning .inner .subInner {
	margin-bottom: 8rem;
	padding: 11.5rem 0 0;
	position: relative;
}
#main .learning .inner .subInner:last-child {
	margin-bottom: 0;
}
#main .learning .inner .subInner .photo {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
}
#main .learning .inner .subInner .textBox {
	margin-bottom: 4.5rem;
	padding: 3.9rem 4rem;
	width: 48rem;
	background-color: #FFF;
	box-sizing: border-box;
}
#main .learning .inner .subInner.reverse .textBox {
	margin-left: auto;
}
#main .learning .inner .subInner .textBox h3 {
	margin-bottom: 1.9rem;
	color: #19265B;
	font-size: 3.4rem;
	font-weight: 700;
}
#main .learning .inner .subInner .textBox .text {
	margin: 0 -0.8rem 2.7rem 0;
	line-height: 1.93;
}
#main .learning .inner .subInner .textBox .text:last-child {
	margin-bottom: 0;
}
#main .learning .inner .subInner .photoList {
	display: flex;
	flex-wrap: wrap;
	gap: 4rem;
}
#main .learning .inner .subInner .photoList li {
	width: calc((100% - 8rem) / 3);
	background-color: #FFF;
	box-shadow: 0 0.4rem 0.4rem 0 rgba(0, 0, 0, 0.25);
}
#main .learning .inner .subInner .photoList li a {
	padding: 2.7rem 0 0;
	display: block;
}
#main .learning .inner .subInner .photoList li a:hover {
	opacity: 0.7;
}
#main .learning .inner .subInner .photoList li .ttl {
	margin-bottom: 2.7rem;
	font-size: 2.4rem;
	font-weight: 500;
	text-align: center;
}
#main .learning .inner .subInner .photoList li .link {
	padding: 0.8rem 1.5rem 0.9rem;
	text-align: right;
	background-color: #19265B;
}
#main .learning .inner .subInner .photoList li .link .sub {
	padding-right: 3.1rem;
	display: inline-block;
	color: #FFF;
	font-size: 1.6rem;
	font-weight: 500;
	background: url(../img/common/icon09.png) no-repeat right center / 2.6rem;
}
#main .learning .inner .subInner.style01 {
	padding: 2rem 0;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	aspect-ratio: 1440 / 524;
}
#main .learning .inner .subInner.style01 .content {
	width: 100%;
}
#main .learning .inner .subInner.style01 .textBox {
	margin-bottom: 0;
}
#main .learning .inner .subInner.style01.mb01 {
	margin-bottom: 4rem;
}
#main .learning .inner .subInner.style01.spec01 {
	aspect-ratio: 1440 / 551;
}
#main .learning .inner .subInner.style01.spec02 {
	aspect-ratio: 1440 / 578;
}
#main .about {
	padding: 8.6rem 0;
	background-color: #19265B;
}
#main .about .content {
	max-width: 108rem;
}
#main .about h2 {
	margin-top: 2.1rem;
	color: #FFF;
	font-size: 2.8rem;
	font-weight: 400;
}
#main .about h2 .enImg {
	margin-bottom: 0.7rem;
	display: block;
	width: 33.7rem;
}
#main .about .textBox {
	padding: 4rem;
	width: 50.6rem;
	background-color: #FFF;
	box-sizing: border-box;
}
#main .about .textBox .textUl li {
	padding: 2rem 0 1.8rem;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	border-bottom: 1px solid #DBDBDB;
}
#main .about .textBox .textUl li .ttl {
	width: 10rem;
	font-weight: 700;
}
#main .about .textBox .textUl li .txt {
	padding-top: 0.1rem;
	width: calc(100% - 12.4rem);
	line-height: 1.71;
}
@media all and (max-width: 896px) {
	#gHeader {
		padding-right: 6.6rem;
	}
	#gHeader .hBox .link01 {
		width: 12.7rem;
	}
	#gHeader .hBox .link01 a {
		border: 1px solid #FFF;
	}
	#main .mainVisual {
		margin-bottom: -40vw;
		padding-top: 0;
		min-height: 40rem;
		height: 100vh;
		align-items: flex-end;
		aspect-ratio: inherit;
		background-image: url(../img/index/main_bg_sp.png);
	}
	#main .mainVisual .inner {
		margin: 0 2.2rem;
		width: inherit;
	}
	#main .mainVisual .textImg {
		margin: 0 auto 1.2rem;
		width: auto;
	}
	#main .mainVisual .topicsBox {
		margin: 0 0 4.2rem auto;
		width: auto;
		display: block;
	}
	#main .mainVisual .topicsBox .ttl {
		padding: 0.5rem 1rem 0.4rem;
		width: auto;
		display: block;
		font-size: 1.4rem;
	}
	#main .mainVisual .topicsBox .txtBox {
		width: auto;
	}
	#main .mainVisual .topicsBox .txtBox a {
		padding: 1.2rem 7rem 1rem 2rem;
		display: block;
		background: url(../img/common/icon02_sp.png) no-repeat right 2rem bottom 3rem / 3.1rem;
	}
	#main .mainVisual .topicsBox .txtBox .date {
		margin: 0 0 0.6rem;
		width: auto;
	}
	#main .mainVisual .topicsBox .txtBox .txt {
		width: auto;
		-webkit-line-clamp: 3;
	}
	#main .mission {
		padding: calc(40vw + 6.8rem) 0 4.9rem;
		background-image: url(../img/index/mission_bg01_sp.jpg);
		background-position: center top;
	}
	#main .mission .topBox {
		padding: 0 0.2rem;
	}
	#main .mission .enImg {
		margin-bottom: 2.7rem;
		width: 25.9rem;
	}
	#main .mission .textBox {
		margin: 0 -0.1rem 3rem;
		width: auto;
	}
	#main .mission .textBox .text {
		margin-bottom: 4.1rem;
		font-size: 1.6rem;
		line-height: 1.8;
	}
	#main .mission .textImg img {
		width: 100%;
	}
	#main .future {
		padding: 8.1rem 0 4.6rem;
	}
	#main .future .titleBox {
		margin-bottom: 9rem;
		padding: 0 0.6rem;
		display: block;
	}
	#main .future .titleBox .enImg {
		width: 22.1rem;
	}
	#main .future .titleBox .jp {
		margin: -0.1rem 0 0 0;
		font-size: 1.8rem;
	}
	#main .future .pic {
		position: absolute;
		top: -7.9rem;
		right: -4.5rem;
		width: 28rem;
	}
	#main .future .photoList {
		padding: 0 2.2rem;
		display: block;
	}
	#main .future .photoList li {
		margin-bottom: 3.6rem;
		width: auto;
	}
	#main .future .photoList li:last-child {
		margin-bottom: 0;
	}
	#main .future .photoList li:nth-child(2n) {
		margin-top: 0;
	}
	#main .future .photoList li:nth-child(3n) {
		margin-top: 0;
	}
	#main .future .photoList li .txtBox {
		margin-top: 1.2rem;
		padding: 0;
	}
	#main .future .photoList li .txt {
		font-size: 1.1rem;
	}
	#main .future .photoList li .ttl {
		font-size: 1.7rem;
	}
	#main .contents {
		margin-bottom: 0;
		padding: 7.1rem 0 4.9rem;
	}
	#main .contents .titleBox {
		margin-bottom: 4.2rem;
		padding: 0 0.3rem;
	}
	#main .contents .titleBox .enImg {
		margin-bottom: 0.8rem;
		width: 32.3rem;
	}
	#main .contents .titleBox .jp {
		padding: 0 0.4rem;
		font-size: 1.8rem;
	}
	#main .contents .imgBox {
		display: block;
	}
	#main .contents .imgBox .text {
		margin: 0 0 3rem;
		width: auto;
		font-size: 1.6rem;
		line-height: 1.8;
	}
	#main .contents .imgBox .photo {
		margin: 0 1.6rem;
		width: auto;
	}
	#main .contents .imgBox .photo img {
		width: 100%;
	}
	#main .learning {
		margin-bottom: 0;
	}
	#main .learning .content {
		max-width: inherit;
	}
	#main .learning .inner .subInner {
		margin-bottom: 3rem;
		padding: 0;
	}
	#main .learning .inner .subInner .photo {
		position: static;
	}
	#main .learning .inner .subInner .photo img {
		width: 100%;
	}
	#main .learning .inner .subInner .textBox {
		margin: 0 0 3.3rem !important;
		padding: 2.1rem 0.2rem;
		width: auto;
	}
	#main .learning .inner .subInner .textBox h3 {
		margin-bottom: 1.6rem;
		font-size: 2.4rem;
	}
	#main .learning .inner .subInner .textBox .text {
		margin: 0 0 2.2rem;
		font-size: 1.2rem;
		line-height: 1.8;
	}
	#main .learning .inner .subInner .photoList {
		margin: 0 -2.2rem;
		display: block;
		border-top: 1px solid #19265B;
	}
	#main .learning .inner .subInner .photoList li {
		width: auto;
		box-shadow: none;
	}
	#main .learning .inner .subInner .photoList li a {
		padding: 0;
	}
	#main .learning .inner .subInner .photoList li .subBox {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		align-items: center;
	}
	#main .learning .inner .subInner .photoList li .ttl {
		margin-bottom: 0;
		font-size: 1.7rem;
		width: calc(100% - 17.4rem);
	}
	#main .learning .inner .subInner .photoList li .pho {
		width: 17.4rem;
	}
	#main .learning .inner .subInner .photoList li .link {
		padding: 0.3rem 4rem 0.5rem;
	}
	#main .learning .inner .subInner .photoList li .link .sub {
		padding-right: 2.3rem;
		font-size: 1.1rem;
		background: url(../img/common/icon09.png) no-repeat right center / 1.9rem;
	}
	#main .learning .inner .subInner.style01 {
		padding: 2rem 0;
		display: block;
		aspect-ratio: inherit;
	}
	#main .learning .inner .subInner.style01 .content {
		width: auto;
	}
	#main .learning .inner .subInner.style01.mb01 {
		margin-bottom: -2rem;
	}
	#main .learning .inner .subInner.style01.spec01 {
		aspect-ratio: inherit;
	}
	#main .learning .inner .subInner.style01.spec02 {
		aspect-ratio: inherit;
	}
	#main .about {
		padding: 6.8rem 0 5rem;
	}
	#main .about .content {
		max-width: inherit;
	}
	#main .about .inner {
		display: block;
	}
	#main .about h2 {
		margin: 0 0 4.2rem;
		font-size: 1.8rem;
		font-weight: 500;
	}
	#main .about h2 .enImg {
		margin-bottom: 2.6rem;
		width: 29.6rem;
	}
	#main .about .textBox {
		padding: 2.8rem 2rem 2.7rem 2.8rem;
		width: auto;
	}
	#main .about .textBox .textUl li {
		padding: 1.4rem 0 1.3rem;
	}
	#main .about .textBox .textUl li .ttl {
		width: 7rem;
		font-size: 1rem;
	}
	#main .about .textBox .textUl li .txt {
		padding-top: 0;
		width: calc(100% - 7rem);
		font-size: 1rem;
	}
}