@charset "utf-8";
/* CSS Document */





/*****************************************************************************
 catTopMainVA
 *****************************************************************************/
#catTopMainVA .pageTitle {
	width: 100%;
	position: absolute;
	left: 0;
	top: 50%;
	margin-top: -21px;
	text-align: center;
	vertical-align: middle;
	line-height: 1;
	transition: opacity 0.3s ease;
}
#catTopMainVA .pageTitle .text {
	display: inline;
	font-size: 42px;
	color: #ffffff;
	text-align: center;
}
#catTopMainVA .pageTitle.off {
	opacity: 0;
}

@media screen and (max-width: 600px) {
#catTopMainVA .pageTitle .text {
	font-size: 26px;
}
}
#catTopMainVA .mask {
	position: absolute;
	top: 0;
	left: 0;
	height: 100%;
	width: 100%;
	background: #46d2e6;
	opacity: 0.6;
	transition: opacity 2s ease;
}
/*****************************************************************************
 indexList
 *****************************************************************************/
#indexList {
	width: 1015px;
	overflow: hidden;
	margin: 0 auto 0;
	line-height: 1;
}
#indexList ul {
	display: flex;
	flex-wrap: wrap;
	margin: -1px auto 0;
}
#indexList li {
	width: calc(100%/5);
	border-right: 1px solid #4fd3e6;
	border-top: 1px solid #4fd3e6;
	position: relative;
}
#indexList li:nth-child(5n) {
	border-right-color: #ffffff;
}
#indexList li.img span, #indexList li.link a {
	display: block;
	width: 100%;
	padding: 100% 0 0 0;
	position: relative;
	overflow: hidden;
}
#indexList li.img img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: auto;
}
#indexList li.link span {
	position: absolute;
	display: block;
	top: 50%;
	left: 0;
	width: 100%;
	margin-top: -0.6em;
	font-size: 16px;
	text-align: center;
	color:#4fd3e6;
}
#indexList li.wrap.link span {
	margin-top: -1.2em;
}

@media screen and (max-width: 1014px) {
#indexList {
	width: 86%;
}
#indexList li, #indexList li:nth-child(5n) {
	width: calc(100%/3);
	border-right: 1px solid #4fd3e6;
	border-top: 1px solid #4fd3e6;
}
#indexList li:nth-child(3n) {
	border-right-color: #ffffff;
}
}

@media screen and (max-width: 450px) {
#indexList li, #indexList li:nth-child(3n) {
	width: calc(100%/2) !important;
	border-right: 1px solid #4fd3e6;
	border-top: 1px solid #4fd3e6;
}
#indexList li.img {
	z-index: 1;
}
#indexList li.link {
	z-index: 2;
	margin-left: -50%;
	border: none;
}
#indexList li.link span {
	top: inherit;
	margin-top: 0;
	bottom: 0;
	width: calc(100% - 1px);
	background: rgba(70,210,230,0.7);
	color: #ffffff;
	font-size: 14px;
	padding: 0.75em 0;
}
#indexList li.wrap.link span {
	padding: 0.25em 0;
}
#indexList li {
	border-color: #ffffff !important;
}
}
/*****************************************************************************
 indexListOC
 *****************************************************************************/
#indexListOC > ul {
	max-width: 1280px;
	margin: 0 auto;
	display: flex;
	line-height: 1;
}
#indexListOC > ul > li {
	width: 25%;
	max-width:320px;
}
#indexListOC > ul > li a,
#indexListOC > ul > li .aBox {
	display: block;
	position: relative;
}
#indexListOC > ul > li img {
	width: 100%;
}
#indexListOC .next {
	padding: 13px;
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	padding: 10px;
}
#indexListOC .next span {
	display: block;
	padding: 8px 15px;
	background: #4fd3e6;
	color: #ffffff;
	text-align: center;
	font-size: 12px;
}
#indexListOC .next .fa {
	margin-right: 5px;
}
#indexListOC .date {
	margin: 10px 0 0;
	font-size: 22px;
	color: #646464;
}
#indexListOC .date i {
	font-size: 16px;
	margin-left: -0.3em;
}

@media screen and (max-width: 1300px) {
#indexListOC > ul {
	width: 86%
}
}
@media screen and (max-width: 600px) {
#indexListOC > ul {
	flex-wrap: wrap;
}
#indexListOC > ul > li {
	width: 50%;
}
}
@media screen and (max-width: 450px) {
#indexListOC > ul > li {
	width: 100%;
	margin:20px auto 0;
}
#indexListOC > ul > li:first-child {
	margin:0 auto 0;
}
}
/*****************************************************************************
 indexListOC2
 *****************************************************************************/
#indexListOC2 > ul {
	max-width: 1280px;
	margin: 30px auto 0;
	display: flex;
	flex-wrap: wrap;
}
#indexListOC2 > ul > li {
	width: calc((100% - 61px)/3);
	text-align: center;
	margin-top: -1px;
	margin-left: 30px;
	border-top: 1px solid #4fd3e6;
	border-bottom: 1px solid #4fd3e6;
}
#indexListOC2 > ul > li:nth-child(3n+1) {
	margin-left: 0;
}
#indexListOC2 > ul > li a,
#indexListOC2 > ul > li .aBox {
	display: block;
	padding:  8px 5px 15px;
	text-decoration: none;
	line-height: 1.3;
}
#indexListOC2 .status {
	line-height: 18px;
	margin:0 0 8px;
}
#indexListOC2 .status span {
	display: inline-block;
	background: #4fd3e6;
	color:#ffffff;
	padding:0 10px;
	font-size:12px;
}
#indexListOC2 .title {
	font-size: 20px;
	color:#4fd3e6;
}
#indexListOC2 .title br {
	display:none;
}
#indexListOC2 .title span {
}
#indexListOC2 .date {
	margin: 7px 0 0;
	color: #646464;
}
#indexListOC2 .date li {
	font-size: 16px;
	display: inline;
	margin-left: -0.5em;
}
#indexListOC2 .date li:before {
	content: ", ";
}
#indexListOC2 .date li:nth-child(1) {
	margin-left: 0;
}
#indexListOC2 .date li:nth-child(1):before {
	content: "";
}
#indexListOC2 .date li i {
	font-size:12px;
	/*margin-left:-0.4em;*/
}
@media screen and (max-width: 1300px) {
#indexListOC2 > ul {
	width: 86%
}
}
@media screen and (max-width: 800px) {
#indexListOC2 > ul > li,
#indexListOC2 > ul > li:nth-child(3n+1) {
	width: calc((100% - 30px)/2);
	margin-left: 30px;
}
#indexListOC2 > ul > li:nth-child(2n+1) {
	margin-left:0;
}
}
@media screen and (max-width: 600px) {
#indexListOC2 > ul > li,
#indexListOC2 > ul > li:nth-child(3n+1),
#indexListOC2 > ul > li:nth-child(2n+1){
	width: 100%;
	margin-left: 0;
}
}
@media screen and (max-width: 450px) {
#indexListOC > ul > li {
	max-width: 320px;
}
}


/******************************************************************************
 入学案内 ADMISSION GUIDE
 *****************************************************************************/
.admissionGuide {
	padding:60px 0 84px 0;
	background-color: #E8F8F8;
}

.admissionGuide-content {
	max-width: 1224px;
	margin: 26px auto 18px auto;
	padding: 0 16px;
}

.menu-list {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
  gap: 24px;
	padding-bottom: 16px;
}
@media screen and (max-width: 1023px) {
	.menu-list {
		grid-template-columns: repeat(2, 1fr);
		gap: 16px;
	}
}
@media screen and (max-width: 575px) {
	.menu-list {
		grid-template-columns: 1fr;
	}
}

.menu-list__link {
	font-size: 18px;
  background-color: #fff;
  border-radius: 10px;
	color: #646464;
	display: grid;
  place-items: center left;
	grid-template-columns: 48px auto;
	gap: 29px;
	padding: 20px 42px 20px 24px;
	position: relative;
	text-decoration: none;
}

.menu-list__link:hover {
	background-color: #46d2e6;
	color: #ffffff;
}

.menu-icon {
	display: inline-block;
	width: 48px;
	height: 48px;
	background: url(../images/menu-icon01.svg);
}
.menu-icon--01 {
	background: url(../images/menu-icon01.svg);
}
.menu-icon--02 {
	background: url(../images/menu-icon02.svg);
}
.menu-icon--03 {
	background: url(../images/menu-icon03.svg);
}
.menu-icon--04 {
	background: url(../images/menu-icon04.svg);
}
.menu-icon--05 {
	background: url(../images/menu-icon05.svg);
}
.menu-icon--06 {
	background: url(../images/menu-icon06.svg);
}

.menu-icon::after {
	content: '';
	position: absolute;
	top: calc(50% - 4px);
	right: 30px;
	display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-top: 4px solid transparent;
  border-bottom: 4px solid transparent;
  border-left: 8.8px solid #46D2E6;
  border-right: 0;
}

.menu-list__link:hover .menu-icon::after {
	border-left: 8.8px solid #ffffff;
}

.admissionGuide-btn-wrapper {
	margin: 16px 0;
	/* text-align: center; */
}

.admissionGuide-btn {
	background-color: #46D2E6;
	border-radius: 10px;
	color: #ffffff;
	font-size: 18px;
	font-weight: 700;
	line-height: 1.6;
	text-decoration: none;
	padding: 17px 48px 22px 48px;
	transition: opacity 0.3s;
	display: grid;
	justify-items: center;
}
@media screen and (max-width: 575px) {
	.admissionGuide-btn {
		padding: 17px 24px 22px 24px;
	}
}

.admissionGuide-btn:hover {
	opacity: 0.7;
}

.admissionGuide-btn__item {
	display: grid;
	justify-content: start;
	align-items: center;
	grid-template-columns: 43px auto;
	gap: 29px;
	position: relative;
	padding-right: 35px;
}
@media screen and (max-width: 575px) {
	.admissionGuide-btn__item {
		gap: 18px;
	}
}


.admissionGuide-btn__item--pdf::after {
	content: '';
	/* display: inline-block; */
	width: 19px;
	height: 19px;
	background: url(../images/menu-icon-w-pdf.svg);
	background-repeat: no-repeat;
	position: absolute;
	right: 0;
}

.admissionGuide-btn__icon {
	display: inline-block;
	width: 48px;
	height: 48px;
	background: url(../images/menu-icon-w-01.svg);
	background-repeat: no-repeat;
}

.admissionGuide-btn__icon-pdf {
	display: inline-block;
	width: 19px;
	height: 1px;
	background: url(../images/menu-icon-w-pdf);
	background-repeat: no-repeat;
}