@charset "utf-8";

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;200;300;400;500;600;700;800;900&display=swap');


/*
	BASE
-------------------------------------------------- */
html {
	font-family: Noto Sans JP,"游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
}

body {
	width: 100%;
	margin: 0;
	font-size: 62.5%;
}

/*
	COMMON
-------------------------------------------------- */
a {
	text-decoration: none;
	cursor: pointer;
}
a:hover {
	opacity: 0.7;
}
a:focus, *:focus {
	outline:none;
}

section {
	width: 100%;
}

img {
	max-width: 100%;
	vertical-align: middle;
}

sup {
	vertical-align:text-top;
	font-size:small;
}

.small {
	font-size: 1.1em !important;
}

.tac {
	text-align: center !important;
}

.mb0 {
	margin-bottom: 0 !important;
}

.mt0 {
	margin-top: 0 !important;
}

.mbS {
	margin-bottom: 13px !important;
}

/*
	FV
-------------------------------------------------- */
.wrap_fv {
	width:100%;
  background-image: url(../img/mvbg_pc.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  padding: 50px 0 50px 0;
  text-align:center;
	position: relative;
}

.wrap_fv-img {
	max-width: 800px;
  margin-bottom: 17px;
}

.mv_btn_pc{
	max-width:353px;
  display: inline-block;
	margin: auto 10px;
}

.mv_btn_sp{
  display: none;
}

.mv_badge{
  position: absolute;
  z-index: 5;
  width: 160px;
  right: 1%;
  top: 3%;
  height: auto;
}

@media (max-width:820px) {
  .wrap_fv {
		max-width:520px;
  	width:100%;
    padding: 20px 0;
		z-index: 200;
		background-color: #000;
		background-position: top;
		color: #fff;
  }



  .wrap_fv-img {
		width:60%;
  	max-width:60%;
    margin-bottom: 10px;
  }

  .mv_btn_pc{
    display: none;
  }

  .mv_btn_sp{
    display: inline-block;
    width: 100%;
    margin: 0 auto ;
		background-color: #000102;
  }

	.mv_btn_sp+.mv_btn_sp {
		padding-top: 15px;
	}

	.mv_btn_sp img{
    width: 80%;
  }

	.mv_btn2_sp{
    display: inline-block;
    width: 100%;
    margin: 0 auto 10px;
		background-color: #000102;
		padding-bottom: 30px;
  }

	.mv_btn2_sp img{
    width: 80%;
  }
	.mv_badge{
    position: absolute;
    width: 73px;
    top: 1%;
    right: auto;
		left: 0;
  }
}



/*
	base
-------------------------------------------------- */

.content{
	width: 1036px;
	margin: auto;
}

.content h2{
	font-size: 3.6em;
	line-height: 1.53;
	font-weight: 900;
	color: #1D2285;
	margin: auto;
	text-align: center;
}

.content p{
	font-size: 1.6em;
	line-height: 2;
	color: #000;
	margin: auto;
}


@media (max-width:820px) {
	.content{
		width: 100%;
		margin: auto;
	}

	.content h2{
		font-size: 2.4em;
		line-height: 1.458;
		font-weight: 900;
		color: #1D2285;
		margin: auto;
		text-align: center;
	}

	.content p{
		font-size: 1.4em;
		line-height: 1.785;
		color: #000;
		margin: auto;
	}

}

/*
	sec01
-------------------------------------------------- */

.sec01{
	margin: 77px auto 0px;
}

.sec01 .wrap_all{
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-top: 10px;
}

.sec01 .wrap_all div:nth-of-type(1){
	width: 492px;
	margin-left: 70px;
}

.sec01 .wrap_all div:nth-of-type(2){
	width: 402px;
	margin-right: 40px;
}

.sec01 .wrap_all div:nth-of-type(1) p{
	margin-top: 20px;
	font-size: 1.55em;
}

.sec01 .wrap_all div:nth-of-type(1) img{
	width: 326px;
	margin-bottom: 10px;
}


@media (max-width:820px) {
	.sec01{
		margin: 25px auto 0px;
	}

	.sec01 .wrap_all{
		display: block;
		margin-top: 15px;
	}

	.sec01 .wrap_all div:nth-of-type(1){
		width: 86%;
		margin: auto;
	}

	.sec01 .wrap_all div:nth-of-type(2){
		width: 100%;
		margin: 10px 0 0;
	}

	.sec01 .wrap_all div:nth-of-type(1) p{
		margin-top: 20px;
	}

	.sec01 .wrap_all div:nth-of-type(1) img{
		width: 100%;
		margin-top: 5px;
		margin-bottom: 0px;
	}

}


/*
	sec02
-------------------------------------------------- */

.sec02{
	margin: 101px auto;
	background: #F4F4F4;
	position: relative;
	padding: 40px 0;
}

.sec02::before{
	content: url(../img/bg_top.svg);
	position: absolute;
  top: -101px;
}

.sec02::after{
	content: url(../img/bg_bottom.svg);
	position: absolute;
  bottom: -101px;
}

.sec02 .wrap_all{
}


.slider {
  /*overflow-y: auto;*/
  width: 836px;
  margin: 30px auto 0;
}
.slider table {
  margin: 0 auto;
  padding: 0;
	border-collapse:collapse;
}

.slider table p{
	font-size: 1.6em;
}

.slider th{
	font-size: 1.6em;
	background: #1D2285;
	color: #fff;
	font-weight: bold;
	width: 134px;
	text-align: center;
	border-bottom: #6C6FB0 solid 1px;
}

.slider tr:nth-of-type(1) td{
	text-align: center;
	font-weight: 800;
	font-size: 1.6em;
}

.slider tr:nth-of-type(4) td{
	border: none;
}

.slider tr:nth-of-type(1) td:nth-of-type(1){
	color: #242888;
}

.slider td:nth-of-type(1){
	background: #E8F6FA;
	border-bottom: #C3D8D9 solid 1px;
	padding: 20px;
	width: 350px;
	box-sizing: border-box;
	font-weight: 500;
}

.slider td:nth-of-type(2){
	background: #fff;
	border-bottom: #D5D5D6 solid 1px;
	padding: 20px;
	width: 350px;
	box-sizing: border-box;
	font-weight: 300;
}


@media (max-width:820px) {
	.sec02{
		margin: 50px auto;
		background: #F4F4F4;
		position: relative;
		padding: 40px 0 20px;
		width: 100%;
	}

	.sec02::before{
		content: "";
		position: absolute;
	  top: -50px;
		display: inline-block;
	  width: 100%;
	  height: 50px;
	  background-image: url(../img/bg_top.svg);
	  background-size:cover;
		background-position: top;
	}

	.sec02::after{
		content: "";
    position: absolute;
    bottom: -50px;
    display: inline-block;
    width: 100%;
    height: 50px;
    background-image: url(../img/bg_bottom.svg);
    background-size:cover;
	}

	.slider {
	  overflow-y: auto;
	  width: 95%;
	  margin: 30px 0 0 5%;
	}



	  .slider table {
	  }
	  .slider th, .slider td {
	  }

		.slider th{
			width: 20px;
			padding: 10px;
			font-size: 1.4em;
			line-height: 1.3;
		}

		.slider td{
			white-space:nowrap;
		}

		.slider td p{
			font-size: 1.5em;
			width: 230px;
			white-space:normal;
		}

		.slider th{
	    z-index: 100;
	  }



	  .slider tr th:first-child {
	    position: sticky;
	    position: -webkit-sticky;
	    top: 0;
	    left: 0;
	  }


	  .slider tr:first-child th:before,
	  .slider tr th:first-child:before {
	    content: "";
	    position: absolute;
	    top: -1px;
	    left: -1px;
	  }

}




/*
	sec03
-------------------------------------------------- */

.sec03{
	margin: auto;
	padding: 60px 0;
	text-align: center;
}

.content p.sec03_lead{
	font-size: 1.6em;
	line-height: 2;
	text-align: center;
	margin: 30px auto;
}

.sec03 .wrap_all{
	display: flex;
	justify-content: space-between;
	align-items: top;
	margin: 40px auto 0;
	width: 1036px;
}

.sec03 .wrap_all div.shadow{
	width: 328px;
	text-align: center;
	padding: 20px 15px 30px;
}
.sec03 .wrap_all div.shadow{
	box-shadow: 0 0px 30px 0 rgba(0, 0, 0, .08);
}


.sec03 .wrap_all div h3{
	font-size: 1.7em;
	color: #1D2285;
	margin-bottom: 13px;
	letter-spacing: -0.01em;
}

.sec03 .wrap_all div p{
	font-size: 1.4em;
	text-align: left;
	margin-top: 10px;
}

.wrap_all .shadow .sec03_no{
	width: 24px;
	margin: 8px auto 23px;
}

.sec03-ttl {
	margin-bottom: 10px;
}



@media (max-width:820px) {

	.sec03{
		margin: auto;
		padding: 50px 0;
		text-align: center;
	}

	.content p.sec03_lead{
		font-size: 1.4em;
		line-height: 1.8;
		text-align: left;
		margin: 25px 7%;
	}

	.sec03 .wrap_all{
		display: block;
		margin: 40px auto 0;
		width: 100%;
	}

	.sec03 .wrap_all div{
		width: 100%;
		text-align: center;
		padding: 15px 15px 30px;
		margin: 0 auto 0;
	}

	.sec03 .wrap_all div.shadow{
		box-shadow: 0 0px 30px 0 rgba(0, 0, 0, .08);
	}


	.sec03 .wrap_all div h3{
		font-size: 1.7em;
		color: #1D2285;
		margin-bottom: 13px;
		letter-spacing: -0.01em;
	}

	.sec03 .wrap_all div p{
		font-size: 1.4em;
		text-align: left;
		margin-top: 10px;
	}

	.wrap_all .shadow .sec03_no{
		width: 24px;
		margin: 10px auto 10px;
		padding: 0;
	}
	.sec03-ttl {
		min-height: auto;
		padding: 0 !important;
	}
}




/*
	sec04
-------------------------------------------------- */

.sec04{
	margin: 101px auto;
	background: #F4F4F4;
	position: relative;
	padding: 40px 0;
}

.sec04::before{
	content: url(../img/bg_top.svg);
	position: absolute;
  top: -101px;
}

.sec04::after{
	content: url(../img/bg_bottom.svg);
	position: absolute;
  bottom: -101px;
}

.sec04 .wrap_all{
	margin: 40px auto 0;
	width: 950px;
	border-radius: 10px;
	background: #fff;
	padding: 40px 155px;
}

.sec04 .wrap_all h3{
	font-size: 2.5em;
	color: #1D2285;
	margin: 0 auto 27px;
	text-align: center;
	display: grid;
	grid-template-columns: 1fr 1fr;
}
.sec04 .wrap_all h3 span{
	display: grid;
	margin: 5px;
	padding: 5px;
	border: solid 1px #1D2285;
}
.content p.sec04_lead{
	font-size: 1.6em;
	line-height: 2;
	text-align: center;
	margin: 25px auto;
}


.sec04 .wrap_all h4{
	font-size: 2.0em;
	color: #1D2285;
	margin: 40px auto 12px;
	position: relative;
	width: 100%;
	text-align: center;
}

.sec04 .wrap_all h4::before{
	content: "";
	width: 194px;
	border-top: #1D2285 dotted 1px;
	position: absolute;
	left: 0;
	top: 50%;
}

.sec04 .wrap_all h4::after{
	content: "";
	width: 194px;
	border-top: #1D2285 dotted 1px;
	position: absolute;
	right: 0;
	top: 50%;
}

.wrap_all2{
	display: flex;
	justify-content: space-between;
	width: 510px;
	margin: 30px auto 0;
}

.wrap_all2 div{
	width: 235px;
}

.sec04 .wrap_all2 h5{
	font-size: 1.7em;
	color: #1D2285;
	margin: 0 auto 10px;
	text-align: center;
	letter-spacing: -0.01em;
}

.sec04 .wrap_all2 p{
	font-size: 1.4em;
	margin: 10px auto 0px;
}

.sec04 .wrap_all .expert {
	background: #E8F6FA;
	margin-top: 40px;
	padding: 40px;
}

.sec04 .wrap_all .expert h3 {
	text-align: center;
	display: block;
}

.sec04 .wrap_all .expert p {
	text-align: center;
	margin-top: 30px;
}

.sec04 .wrap_all .expert .expert_ttl {
	margin-top: 0 !important;
	position: relative;
	margin-bottom: 5px;
}

.sec04 .wrap_all .expert .expert_ttl::before {
	content: "";
	width: 90px;
	border-top: #1D2285 dotted 1px;
	position: absolute;
	left: 0;
	top: 50%;
}

.sec04 .wrap_all .expert .expert_ttl::after {
	content: "";
	width: 90px;
	border-top: #1D2285 dotted 1px;
	position: absolute;
	right: 0;
	top: 50%;
}

.sec04 .wrap_all .expert .wrap_all2 {
	justify-content: center;
	width: 100%;
	margin-top: 30px
}

.sec04 .wrap_all .expert .wrap_all2 .item {
	background: #fff;
	padding: 25px 20px;
	width: 100%;
}

.sec04 .wrap_all .expert .wrap_all2 .item:first-child {
	margin-right: 20px;
}

.sec04 .wrap_all .expert .wrap_all2 .item .wrap_all2_ttl {
	width: 100%;
	display: flex;
	flex-direction: column;
	align-items: center;
	span {
		display: inline-block;
		font-size: 16px;
		background: #1D2285;
		color: #fff;
		padding: 2px 20px;
	}

	h4 {
		position: relative;
		margin: 5px auto 10px;
		padding-bottom: 5px;
	}

	h4::before{
		content: "";
		width: 100%;
		border-top: #1D2285 dotted 1px;
		position: absolute;
		left: 50%;
		top: 100%;
		transform: translateX(-50%);
	}
	h4::after{
		display: none;
	}
}

.sec04 .wrap_all .expert .wrap_all2 .item .list-disc li {
	position: relative;
	padding-left: 13px;
	font-size: 16px;
	line-height: 2;
	list-style: none;
}

.sec04 .wrap_all .expert .wrap_all2 .item .list-disc li::before {
	content: "";
	background: #1D2285;
	border-radius: 50%;
	display: block;
	position: absolute;
	left: 0;
	top: 50%;
	width: 5px;
	height: 5px;
	transform: translateY(-50%);
}


@media (max-width:820px) {
	.sec04{
		margin: 0px auto;
		background: #F4F4F4;
		position: relative;
		padding: 40px 0 ;
	}

	.sec04::before{
		content: "";
		position: absolute;
	  top: -50px;
		display: inline-block;
	  width: 100%;
	  height: 50px;
	  background-image: url(../img/bg_top.svg);
	  background-size:cover;
		background-position: top;
	}

	.sec04::after{
		content: "";
    position: absolute;
    bottom: -50px;
    display: inline-block;
    width: 100%;
    height: 50px;
    background-image: url(../img/bg_bottom.svg);
    background-size:cover;
	}

	.sec04 .wrap_all{
		width: 90%;
		text-align: center;
		padding: 30px 15px 5px;
		margin: 20px auto 0px;
		box-shadow: 0 0px 30px 0 rgba(0, 0, 0, .08);
		border-radius: 0;
	}


	.sec04 .wrap_all h3{
		font-size: 1.3em;
		margin: 0 auto 20px;
	}

	.content p.sec04_lead{
		font-size: 1.4em;
		line-height: 1.66;
		text-align: left;
		margin: 15px auto;
	}


	.sec04 .wrap_all h4{
		font-size: 1.8em;
		color: #1D2285;
		margin: 30px auto 12px;
		position: relative;
		width: 100%;
		text-align: center;
	}

	.sec04 .wrap_all h4::before{
		content: "";
		width: 45px;
		border-top: #1D2285 dotted 1px;
		position: absolute;
		left: 0;
		top: 50%;
	}

	.sec04 .wrap_all h4::after{
		content: "";
		width: 45px;
		border-top: #1D2285 dotted 1px;
		position: absolute;
		right: 0;
		top: 50%;
	}

	.wrap_all2{
		display: block;
		width: 80%;
		margin: 30px auto 0;
	}

	.wrap_all2 div{
		width: 100%;
		margin-bottom: 30px;
	}

	.sec04 .wrap_all2 h5{
		font-size: 1.7em;
		color: #1D2285;
		margin: 0 auto 10px;
		text-align: center;
		letter-spacing: -0.01em;
	}

	.sec04 .wrap_all2 p{
		font-size: 1.4em;
		margin: 10px auto 0px;
		text-align: left;
	}

	.sec04 .wrap_all .expert {
		margin-top: 20px;
		padding: 30px 20px;
	}

	.sec04 .wrap_all .expert h3 {
		font-size: 20px;
	}

	.sec04 .wrap_all .expert p {
		text-align: left;
		margin-top: 15px;
	}

	.sec04 .wrap_all .expert .expert_ttl {
		text-align: center;
	}

	.sec04 .wrap_all .expert .expert_ttl::before {
		width: 30px;
	}

	.sec04 .wrap_all .expert .expert_ttl::after {
		width: 30px;
	}


	.sec04 .wrap_all .expert .wrap_all2 {
		margin-top: 20px
	}

	.sec04 .wrap_all .expert .wrap_all2 .item:first-child {
		margin: 0 0 15px 0;
	}

	.sec04 .wrap_all .expert .wrap_all2 .item:last-child {
		margin-bottom: 0;
	}

	.sec04 .wrap_all .expert .wrap_all2 .item {
		padding: 20px;
	}

	.sec04 .wrap_all .expert .wrap_all2 .item .wrap_all2_ttl span {
		font-size: 12px;
	}

	.sec04 .wrap_all .expert .wrap_all2 .item .wrap_all2_ttl h4 {
		margin: 5px auto 0;
		font-size: 17px;
		padding-bottom: 7px;
	}

	.sec04 .wrap_all .expert .wrap_all2 .item .list-disc li {
		text-align: left;
		font-size: 14px;
		line-height: 2;
	}
	.sec04 .wrap_all .expert .wrap_all2 .item .wrap_all2_ttl {
		margin-bottom: 10px;
	}
}



/*
	sec05
-------------------------------------------------- */

.sec05{
	margin: auto;
	padding: 100px 0 40px;
	text-align: center;
}

.sec05 h2 span{
	font-size: 0.4em;
	font-weight: normal;
	display: block;
	margin-bottom: 5px;
}

.content p.sec05_lead{
	font-size: 1.6em;
	line-height: 2;
	text-align: center;
	margin: 30px auto 47px;
}

.sec05_img01{
	width: 287px;
}

.sec05 .wrap_all{
	display: flex;
	justify-content: space-between;
	align-items: top;
	margin: 50px auto 0;
	width: 945px;
}



.sec05 .wrap_all div h3{
	font-size: 2.0em;
	color: #1D2285;
	margin-bottom: 13px;
	letter-spacing: -0.01em;
}

.sec05 .wrap_all div h3 span{
	background-color: #FFFF00;
	display: inline-block;
	padding: 0 5px;
}

.sec05 .wrap_all div img{
	width: 235px;
}

.sec05 .wrap_all div p{
	font-size: 1.4em;
	text-align: left;
	margin-top: 10px;
	width: 235px;
}

.sec05-rate {
	position: relative;
	display: flex;
	flex-direction: column;
	padding-top: 50px;
}

.sec05-rate::before {
	position: absolute;
	content: "";
	background: #EDF7FD;
	width: 300px;
	height: 300px;
	border-radius: 50%;
	left: 50%;
	top: 0;
	transform: translateX(-50%);
	z-index: -1;
}

.sec05-num-txt {
	font-size: 5em;
	color: #1D2285;
	font-weight: 600;
	letter-spacing: .1em;
}

.sec05-num-wrap {
	font-size: 10em !important;
	font-weight: 900;
	color: #D91112 !important;
	margin-top: -5% !important;
}

.sec05-num-wrap .par {
	font-size: 3rem;
	margin-left: -8%;
	position: relative;
}

.sec05-num-wrap .par sup {
	position: absolute;
	right: 0;
	top: -15%;
	font-size: 15px;
}

.sec05-note {
	color: #1D2285 !important;
	font-weight: bold;
	margin-top: 5% !important;
}


@media (max-width:820px) {

	.sec05{
		margin: auto;
		padding: 50px 0;
		text-align: center;
	}

	.sec05 h2 span{
		font-size: 0.6em;
		font-weight: bold;
		display: block;
		margin-bottom: 5px;
	}

	.content p.sec05_lead{
		font-size: 1.4em;
		line-height: 1.8;
		text-align: left;
		margin: 25px 7%;
	}

	.sec05_img01{
		width: 65%;
	}


	.sec05 .wrap_all{
		display: block;
		margin: 40px auto 0;
		width: 100%;
	}

	.sec05 .wrap_all div{
		width: 100%;
		text-align: center;
		padding: 15px 15px 0;
		margin: 0 auto 30px;
	}

	.sec05 .wrap_all div h3{
		font-size: 2.0em;
		color: #1D2285;
		margin-bottom: 13px;
		letter-spacing: -0.01em;
	}

	.sec05 .wrap_all div p{
		font-size: 1.4em;
		text-align: left;
		margin-top: 10px;
		width: 65%;
	}


	.sec05 .wrap_all div img{
		width: 65%;
	}

	.sec05-rate {
		padding-top: 30px;
	}
	
	.sec05-rate::before {
		width: 220px;
		height: 220px;
	}
	
	.sec05-num-txt {
		font-size: 4em;
	}
	
	.sec05-num-wrap {
		font-size: 7em !important;
		margin-top: -5% !important;
		padding-left: 1%;
	}
	
	.sec05-num-wrap .par {
		font-size: 2rem;
		margin-left: -10%;
	}
	
	.sec05-num-wrap .par sup {
		top: -25%;
		font-size: 13px;
	}
	
	.sec05-note {
		margin-top: 10% !important;
		width: 90%;
		text-align: left;
	}

}




/*
	sec06
-------------------------------------------------- */

.sec06{
	margin: 101px auto;
	background: #F4F4F4;
	position: relative;
	padding: 40px 0 30px;
}

.sec06 h2 span{
	font-size: 0.4em;
	font-weight: bold;
	display: block;
	margin-bottom: 5px;
}

.content p.sec06_lead{
	font-size: 1.6em;
	line-height: 2;
	text-align: center;
	margin: 30px auto 47px;
}


.sec06::before{
	content: url(../img/bg_top.svg);
	position: absolute;
  top: -101px;
}

.sec06::after{
	content: url(../img/bg_bottom.svg);
	position: absolute;
  bottom: -101px;
}

.sec06 .wrap_all{
	display: flex;
	justify-content: space-between;
	align-items: top;
	margin: 50px auto 0;
	width: 918px;
}

.sec06 .wrap_all div{
	width: 285px;
	text-align: center;
}

.sec06 .wrap_all div h3{
	font-size: 2.0em;
	color: #1D2285;
	margin-bottom: 10px;
}

.sec06 .wrap_all div p{
	font-size: 1.4em;
	line-height: 1.76;
	margin-top: 10px;
	text-align: left;
}


@media (max-width:820px) {
	.sec06{
		margin: 0px auto;
		background: #F4F4F4;
		position: relative;
		padding: 40px 0 20px;
		width: 100%;
	}

	.sec06::before{
		content: "";
		position: absolute;
	  top: -50px;
		display: inline-block;
	  width: 100%;
	  height: 50px;
	  background-image: url(../img/bg_top.svg);
	  background-size:cover;
		background-position: top;
	}

	.sec06::after{
		content: "";
    position: absolute;
    bottom: -50px;
    display: inline-block;
    width: 100%;
    height: 50px;
    background-image: url(../img/bg_bottom.svg);
    background-size:cover;
	}

	.sec06 h2 span{
		font-size: 0.6em;
		font-weight: bold;
		display: block;
		margin-bottom: 5px;
	}

	.content p.sec06_lead{
		font-size: 1.4em;
		line-height: 1.8;
		text-align: left;
		margin: 25px 7%;
	}

	.sec06 .wrap_all{
		display: block;
		margin: 0px auto 0;
		width: 75%;
	}

	.sec06 .wrap_all div{
		width: 100%;
		text-align: center;
	}

	.sec06 .wrap_all div h3{
		font-size: 2.0em;
		color: #1D2285;
		margin: 35px auto 12px;
		position: relative;
		width: 96%;
	}


}






/*
	characters
-------------------------------------------------- */


.p-characters {
    position: relative;
}

.p-characters-cont {
    position: absolute;
    top: -28px;
    left: 0;
    font-size: 160px;
    line-height: 140px;
    font-family: 'Poppins', sans-serif;
    font-weight: 700;
    color: #FFFFFF;
}

.p-characters-cont--features {
    top: 182px;
    left: -35px;
    color: #F7F8FA;
    z-index: -1;
    font-size: 237px;
    line-height: 332px;
    letter-spacing: 0;
}

.p-characters-cont--parents {
    color: #F7F8FA;
}

@media screen and (max-width:820px) {
    .p-characters-cont {
        top: -13px;
        left: -44px;
        font-size: 100px;
        -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
        writing-mode: vertical-rl;
        -webkit-text-orientation: sideways;
        text-orientation: sideways;
    }

    .p-characters-cont--alt {
        left: -36px;
    }

    .p-characters-cont--features {
        top: 197px;
        left: -42px;
        font-size: 100px;
        line-height: 140px;
    }
}

.top-vantan {
    position: relative;
    margin: 0 auto;
    padding: 96px 32px 120px;
    max-width: 924px;
    box-sizing: border-box;
}

@media screen and (max-width:820px) {
    .top-vantan {
        padding: 48px 16px;
    }
}

.top-vantan__logo {
    width: 200px;
    margin: 0 auto;
}

@media screen and (max-width:820px) {
    .top-vantan__logo {
        width: 140px;
    }
}

.top-vantan__title {
    margin-top: 30px;
    font-size: 40px;
    line-height: 1;
    font-weight: 700;
    text-align: center;
}

@media screen and (max-width:820px) {
    .top-vantan__title {
        margin-top: 8px;
        font-size: 28px;
        line-height: 42px;
    }
}

.top-vantan__lead {
    margin-top: 38px;
    text-align: center;
}

@media screen and (max-width:820px) {
    .top-vantan__lead {
        margin-top: 32px;
        padding: 5px;
        text-align: left;
    }
}

.top-vantan__items {
    margin-top: 40px;
}

@media screen and (max-width:820px) {
    .top-vantan__items {
        margin-top: 33px;
    }

}

.top-vantan__item {
    width: 32.09%;
    padding: 30px;
    border-radius: 4px;
    background-color: #F7F8FA;
    box-sizing: border-box;
    text-align: center;
    display: flex;
    flex-flow: column;
    justify-content: center;
}

@media screen and (max-width:820px) {
    .top-vantan__item {
        width: 100%;
        padding: 24px;
    }
}

.top-vantan__item:not(:first-child) {
    margin-left: 1.86%;
}

@media screen and (max-width:820px) {
    .top-vantan__item:not(:first-child) {
        margin-top: 8px;
        margin-left: 0;
    }
}

@media screen and (min-width : 768px) {
    .top-vantan__item:nth-child(4) {
        margin-left: 0px;
    }

    .top-vantan__item:nth-child(n + 4) {
        margin-top: 16px;
    }
}

.top-vantan-sub {
    font-size: 16px;
    line-height: 24px;
}

@media screen and (max-width:820px) {
    .top-vantan-sub {
        font-size: 14px;
        line-height: 20px;
    }
}

.top-vantan-em {
    margin-top: 10px;
    font-size: 32px;
    line-height: 40px;
    font-weight: 900;
    color: #1D2285;
    text-align: center;
}

@media screen and (max-width:820px) {
    .top-vantan-em {
        font-size: 32px;
        line-height: 47px;
    }
}

.top-vantan-em > span {
    display: inline-block;
    font-size: 24px;
    line-height: 1;
    font-weight: 900;
}

.top-vantan-note {
    margin-top: 8px;
    font-size: 12px;
    line-height: 17px;
}

@media screen and (max-width:820px) {
    .top-vantan-note {
        margin-top: 0;
    }
}

.top-vantan__kadokawa {
    margin: 80px auto 0;
    width: 233px;
}

@media screen and (max-width:820px) {
    .top-vantan__kadokawa {
        margin: 57px auto 0;
    }
}

.top-vantan__catch {
    margin-top: 37px;
    text-align: center;
    font-size: 24px;
    line-height: 36px;
    font-weight: 700;
}

@media screen and (max-width:820px) {
    .top-vantan__catch {
        padding: 0 16px;
        margin-top: 32px;
        font-size: 20px;
        line-height: 30px;
    }
}

.top-vantan__lead {
    margin-top: 24px;
    text-align: center;
}

@media screen and (max-width:820px) {
    .top-vantan__lead {
        text-align: left;
    }
}

.top-vantan-btn {
    margin-top: 24px;
}

@media screen and (max-width:820px) {
    .top-vantan-btn {
        margin-top: 40px;
    }
}
.l-bg-gray {
    background-color: #F7F8FA;
}
.c-text {
    font-size: 16px;
    line-height: 2;
    letter-spacing: 0;
}

.c-text--intro {
    margin-top: 36px;
    text-align: center;
}

@media screen and (max-width:820px) {
    .c-text {
        font-size: 14px;
    }

    .c-text--intro {
        margin-top: 20px;
        text-align: left;
    }
}

@media screen and (min-width : 768px) {
    .c-flex {
        display: flex;
    }

    .c-flex--jc-sb {
        justify-content: space-between;
    }

    .c-flex--jc-center {
        justify-content: center;
    }

    .c-flex--ai-fs {
        align-items: flex-start;
    }

    .c-flex--ai-ct {
        align-items: center;
    }

    .c-flex--wrap {
        flex-wrap: wrap;
    }
}


.top-vantan-em > span {
    font-size: 32px;
}

@media screen and (max-width:820px) {
    .u-pcOnly {
        display: none!important;
    }
}

@media screen and (min-width : 768px) {
    .u-spOnly {
        display: none!important;
    }
}




/*
	sec07
-------------------------------------------------- */

.sec07{
	margin: 30px auto 100px;
	background: #F4F4F4;
	position: relative;
	padding: 40px 0;
}

.sec07::before{
	content: url(../img/bg_top.svg);
	position: absolute;
  top: -101px;
}

.sec07::after{
	content: url(../img/bg_bottom.svg);
	position: absolute;
  bottom: -101px;
}

.sec07 .wrap_all{
	display: flex;
	justify-content:center;
	align-items: top;
	margin: 40px auto 0;
	width: 1036px;
}

.sec07 .wrap_all div.shadow{
	width: 325px;
	text-align: center;
	padding: 30px 15px 30px;
	margin: 0 15px;
}

.sec07 .wrap_all div.shadow{
	box-shadow: 0 0px 30px 0 rgba(0, 0, 0, .08);
}


.sec07 .wrap_all div h3{
	font-size: 1.8em;
	color: #1D2285;
	margin-bottom: 13px;
	letter-spacing: -0.01em;
}

.sec07 .wrap_all div p{
	font-size: 1.4em;
	text-align: left;
	margin-top: 10px;
}

.wrap_all .shadow .sec07_no{
	font-size: 2.2em;
	font-weight: 900;
	color: #002076;
	position: relative;
	margin-bottom: 10px;
	padding-bottom: 10px;
}

.wrap_all .shadow .sec07_no span{
	font-size: 0.6em;
	font-weight: 500;
	display: block;
}

.wrap_all .shadow .sec07_no::after {
    content: "";
    width: 20px;
    border-bottom: #002076 solid 2px;
    position: absolute;
    bottom: 0;
    left: 50%;
		transform: translateX(-50%);
}




@media (max-width:820px) {
	.sec07{
		margin: 20px auto 60px;
		background: #F4F4F4;
		position: relative;
		padding: 30px 0 20px;
		width: 100%;
	}

	.content .sec07 h2 {
	    font-size: 2.7em;
	}


	.sec07::before{
		content: "";
		position: absolute;
	  top: -50px;
		display: inline-block;
	  width: 100%;
	  height: 50px;
	  background-image: url(../img/bg_top.svg);
	  background-size:cover;
		background-position: top;
	}

	.sec07::after{
		content: "";
    position: absolute;
    bottom: -50px;
    display: inline-block;
    width: 100%;
    height: 50px;
    background-image: url(../img/bg_bottom.svg);
    background-size:cover;
	}

	.sec07 .wrap_all{
		display: block;
		margin: 20px auto 0;
		width: 100%;
	}

	.sec07 .wrap_all div{
		width: 100%;
		text-align: center;
		padding: 5px 15px 30px;
		margin: 0 auto 30px;
	}

	.sec07 .wrap_all div.shadow{
		margin: 0 auto 40px;
	}

	.sec07 .wrap_all div.shadow{
		box-shadow: 0 0px 30px 0 rgba(0, 0, 0, .08);
	}

	.sec07 .wrap_all div:nth-of-type(2).shadow{
		margin: 0 auto 0px;
	}



	.sec07 .wrap_all div h3{
		font-size: 1.7em;
		color: #1D2285;
		margin-bottom: 13px;
		letter-spacing: -0.01em;
	}

	.sec07 .wrap_all div p{
		font-size: 1.4em;
		text-align: left;
		margin-top: 10px;
	}

}





/*
	sec08
-------------------------------------------------- */

.sec08{
	margin: 0px auto 0px;
	padding: 60px 0 30px;
}

.sec08 h2 span{
	font-size: 0.45em;
	font-weight: bold;
	display: block;
	margin-top: 30px;
}

.sec08 h3{
	font-size: 2.2em;
	font-weight: bold;
	display: block;
	margin-bottom: 22px;
	color: #1D2285;
	line-height: 1.7;
}

.sec08 .wrap_all{
	display: flex;
	justify-content: space-between;
	margin: 60px auto 0;
	width: 985px;
}

.sec08 .wrap_all p{
	font-size: 1.4em;
	line-height: 1.7;
}

.sec08 .wrap_all p.sec08_name01{
	margin: 20px 10px 0;
}

.sec08 .wrap_all p.sec08_name02{
	font-size: 2.0em;
	font-weight: bold;
	margin: 0px 10px 25px;
}

.sec08_prof{
	border: #E0E0E0 solid 1px;
	padding: 23px 20px;
}

.sec08 .wrap_all .sec08_prof p{
	font-size: 1.3em;
}

.sec08 .wrap_all p.sec08_prof_ttl{
	font-size: 1.8em;
	font-weight: bold;
	margin: 0px 0px 10px;
}

.sec08 .wrap_all div:nth-of-type(1){
	width: 325px;
}

.sec08 .wrap_all div:nth-of-type(2){
	width: 608px;
}






@media (max-width:820px) {
	.sec08{
		margin: 0px auto 0px;
		padding: 30px 0 30px;
	}

	.sec08 h2{
		font-size: 2.7em;
		font-weight: bold;
		display: block;
		margin-top: 0px;
	}

	.sec08 h2 span{
		font-size: 0.7em;
		font-weight: bold;
		display: block;
		margin-top: 20px;
	}

	.sec08 h3{
		font-size: 1.8em;
		font-weight: bold;
		display: block;
		margin-top: 50px;
		margin-bottom: 17px;
		color: #1D2285;
		line-height: 1.7;
		text-align: center;
		position: relative;
	}

	.sec08 h3::after {
	    content: "";
	    width: 20px;
	    border-bottom: #002076 solid 2px;
	    margin: 20px auto 30px;
	    position: absolute;
	    top: -50px;
	    left: 50%;
	}

	.sec08 .wrap_all{
		display: block;
		margin: 20px auto 0;
		width: 86%;
	}

	.sec08 .wrap_all p{
		font-size: 1.4em;
		line-height: 1.7;
	}

	.sec08 .wrap_all p.sec08_name01{
		margin: 20px 10px 0;
	}

	.sec08 .wrap_all p.sec08_name02{
		font-size: 2.0em;
		font-weight: bold;
		margin: 0px 10px 25px;
	}

	.sec08_prof{
		border: #E0E0E0 solid 1px;
		padding: 23px 20px;
	}

	.sec08 .wrap_all .sec08_prof p{
		font-size: 1.3em;
	}

	.sec08 .wrap_all p.sec08_prof_ttl{
		font-size: 1.8em;
		font-weight: bold;
		margin: 0px 0px 10px;
	}

	.sec08 .wrap_all div:nth-of-type(1){
		width: 100%;
	}

	.sec08 .wrap_all div:nth-of-type(2){
		width: 100%;
	}

	.sec08_prof{
		margin-top: 30px;
	}

}



/*
	アクセス
-------------------------------------------------- */


.sec09{
	margin: 100px auto 100px;
	background: #F4F4F4;
	position: relative;
	padding: 40px 0;
}

.sec09::before{
	content: url(../img/bg_top.svg);
	position: absolute;
  top: -101px;
}

.sec09::after{
	content: url(../img/bg_bottom.svg);
	position: absolute;
  bottom: -101px;
}



@media screen and (max-width:820px) {

.sec09{
	margin: 60px auto 60px;
	background: #F4F4F4;
	position: relative;
	padding: 30px 0 20px;
	width: 100%;
}


.sec09::before{
	content: "";
	position: absolute;
	top: -50px;
	display: inline-block;
	width: 100%;
	height: 50px;
	background-image: url(../img/bg_top.svg);
	background-size:cover;
	background-position: top;
}

.sec09::after{
	content: "";
	position: absolute;
	bottom: -50px;
	display: inline-block;
	width: 100%;
	height: 50px;
	background-image: url(../img/bg_bottom.svg);
	background-size:cover;
}

}




.content .l-section p {
    font-size: 1.4em;
    line-height: 1.6;
    color: #000;
    margin: auto;
}


.l-section {
    margin: 0 auto;
    padding: 96px 32px 120px;
    max-width: 1104px;
    box-sizing: border-box;
    overflow: hidden;
}

.l-section img {
    display: block;
}

.l-section--corp {
    padding: 42px 32px 120px;
}

.l-section--base {
    padding: 96px 32px 120px;
}

.l-section--intro {
    padding: 96px 32px 112px;
}

.l-section--introAlt {
    padding: 96px 32px 0;
}

.l-section--anchor {
    padding: 48px 32px 120px;
}

.l-section--pb0 {
    padding: 96px 32px 0;
}

.l-section--article {
    padding: 80px 32px 120px;
}

.l-section--adjust {
    margin-top: -60px;
    padding: 108px 32px 120px;
}

@media screen and (max-width:820px) {
    .l-section {
        padding: 64px 16px;
    }

    .l-section--feature, .l-section--startup, .l-section--course, .l-section--admission {
        padding: 48px 16px 64px;
    }

    .l-section--base {
        padding: 48px 16px 64px;
    }

    .l-section--corp {
        padding: 75px 16px 64px;
    }

    .l-section--intro {
        padding: 48px 16px 104px;
    }

    .l-section--introAlt {
        padding: 48px 16px 0;
    }

    .l-section--anchor {
        padding: 8px 16px 64px;
    }

    .l-section--pb0 {
        padding: 64px 16px 0;
    }

    .l-section--article {
        padding: 48px 16px 64px;
    }

    .article-event {
        padding: 32px 16px 64px;
    }

    .l-section--adjust {
        margin-top: 0;
    }
}

.l-section--narrow {
    padding: 0px 32px 0px;
    max-width: 924px;
}

@media screen and (max-width:820px) {
    .l-section--narrow {
        padding: 0 ;
        max-width: 90%;
    }
}



.c-head-ja {
    margin-top: 5px;
    font-size: 40px;
    line-height: 60px;
    letter-spacing: 0;
    font-weight: 700;
    text-align: center;
}

.c-head-ja--small {
    margin-top: 4px;
    font-size: 32px;
    line-height: 46px;
}

@media screen and (max-width:820px) {
    .c-head-ja {
        margin-top: 4px;
        font-size: 28px;
        line-height: 42px;
    }

    .c-head-ja--small {
        margin-top: 6px;
        font-size: 20px;
        line-height: 28px;
    }
}

.c-head-ja--white {
    color: #FFFFFF;
}

.top-access {
    margin-top: 48px;
}

.top-access__img{
	max-width: 410px;
}

@media screen and (max-width:820px) {
    .top-access {
        margin-top: 20px;
    }
}

.top-access__item {
    width: calc((100% / 2) - (80px / 2));
}

@media screen and (min-width : 768px) {
    .top-access__item:nth-child(n + 3) {
        margin-top: 40px;
    }
}

@media screen and (max-width:820px) {
    .top-access__item {
        width: 100%;
    }

    .top-access__item:not(:first-child) {
        margin-top: 57px;
    }
}

.top-access__text {
    padding: 20px 8px 0;
}

@media screen and (max-width:820px) {
    .top-access__text {
        padding: 13px 16px 0;
    }
}

.top-access__title {
    font-size: 24px;
    line-height: 35px;
    font-weight: 700;
}

@media screen and (max-width:820px) {
    .top-access__title {
        font-size: 20px;
        line-height: 28px;
    }
}

.top-access__lead {
    margin-top: 17px;
    font-size: 14px;
    line-height: 20px;
    font-family: 'NotoSansCJKjp-Regular', 'NotoSansCJKjp-Medium', 'NotoSansCJKjp-Bold', 'NotoSansCJKjp-DemiLight', 'Noto Sans', 'Noto Sans CJK JP', 'Noto Sans', 'Helvetica', 'Arial', 'メイリオ', 'Meiryo', 'ヒラギノ角ゴ ProN', 'MS ゴシック', sans-serif;
}

@media screen and (max-width:820px) {
    .top-access__lead {
        margin-top: 16px;
    }
}

.top-access__link {
    margin-top: 4px;
    display: inline-block;
    font-size: 14px;
    line-height: 20px;
    color: #00B4A6;
    text-decoration: underline;
}

.top-access__link + .top-access__lead {
    margin-top: 12px;
}







/*
	CTA
-------------------------------------------------- */

.cta{
	margin: 101px auto 30px;
	background: #1D2285;
	position: relative;
	padding: 10px 0 ;
	text-align: center;
}

.cta::before{
	content: url(../img/bg2_top.svg);
	position: absolute;
  top: -101px;
	left: 0;
}

.cta::after{
	content: url(../img/bg2_bottom.svg);
	position: absolute;
  bottom: -101px;
	left: 0;
}

.cta h2{
	color: #fff;
	font-size: 3.4em;
	font-weight: 600;
	margin-bottom: 10px;
}

.cta img{
	width: 480px;
}



@media (max-width:820px) {
	.cta{
		margin: 40px auto 60px;
		background: #1D2285;
		position: relative;
		padding: 20px 0 ;
		z-index: 200;
	}

	.cta::before{
		content: "";
		position: absolute;
	  top: -49px;
		display: inline-block;
	  width: 100%;
	  height: 50px;
	  background-image: url(../img/bg2_top.svg);
	  background-size:cover;
		background-position: top;
	}

	.cta::after{
		content: "";
    position: absolute;
    bottom: -49px;
    display: inline-block;
    width: 100%;
    height: 50px;
    background-image: url(../img/bg2_bottom.svg);
    background-size:cover;
	}

	.cta h2{
		color: #fff;
		font-size: 2.3em;
		font-weight: 600;
		margin-bottom: 10px;
	}

	.cta img{
		width: 90%;
	}

}

.cta2{
	display: none;
}

.mb50{
	margin-bottom: 100px;
}

.pc{
	display: block;
}

.sp{
	display: none;
}

@media (max-width:820px) {
	.sp{
		display: block;
	}

	.pc{
		display: none;
	}



	.cta2{
		position: sticky;
		bottom: 10px;
		left: 0;
		text-align: center;
		z-index: 300;
	}

	.cta2 img{
		width: 95%;
	}


	.float-button__wrap {
	    display: none;/*最初は隠す*/
	}


		.cta_wrap{
			width: 96%;
			margin: auto;
			display: flex;
			justify-content: space-between;
		}



}







/*//////  20240923  //////*/

@media screen and (max-width: 768px){
  .main-head__catch-read {
    text-align: center;
    line-height: 1;
  }

  .main-head__catch-read-small {
    font-size: 16px;
    line-height: 1.3;
    padding-bottom: 0px;
    display: inline-block;
		font-weight: 500;
  }

  .main-head__catch-read-small-yellow {
    color:#FFFF00;
  }

	.main-head__catch-note2 {
      font-size: 7px;
      padding-top: 10px;
      line-height: 1.4;
      font-weight:100;
      padding-bottom: 10px;
      border-bottom: 1px dotted #659ED0;
      letter-spacing: 0.02em;
			display: block;
			margin: auto;
			width: 65%;
  }

	.main-head__catch-note3 {
      font-size: 8px;
      padding-top: 10px;
      line-height: 1.4;
      font-weight:100;
      letter-spacing: 0.02em;
			display: block;
			margin: auto;
			width: 65%;
  }


  .main-head__catch-read-rate1 {
    font-size: 22px;
  }

  .main-head__catch-read-rate2 {
    font-size: 34px;
    letter-spacing: -0.05em;
		line-height: 1.1;
  }

  .main-head__catch-read-rate3 {
    font-size: 20px;
  }

.main-head__catch-copy{
	margin: 13px auto 0;
}

.mv_btn_sp img {
        width: 87%;
    }

	.main-head__catch-copy01 {
    font-size: 32px;
		font-weight: bold;
		line-height: 1;
  }

	.main-head__catch-copy02 {
		font-size: 20px;
		font-weight:lighter;
		line-height: 1;
		padding: 7px 0 8px 0;
	}

  .main-head__school {
    text-align: center;
    padding-top: 12px;
    font-weight: bold;
    line-height: 1.3;
  }

  .main-head__school-lead {
    font-size: 13px;
    color: #FFFF00;
    display: inline-block;
    padding: 12px 0 5px;
		border-top: 1px dotted #659ED0;
		font-weight:500;
  }

	.main-head__school-lead sup{
		font-size: 8px;
	}

  .main-head__school-name {
    font-size: 20px;
  }

  .attention02{
		width: 87%;
    margin: 13px auto 20px;
    color: #fff;
    background: #FF3333;
    border-radius: 5px;
    padding: 7px 5px 5px;
    font-size: 11.6px;
    font-feature-settings: "palt";
    text-align: center;
    line-height: 1.2;
  }

  .attention02_en{
    font-size: 8px;
  }



  .main-information02-inner {
  	max-width: 1200px;
  	margin: 0 auto;
  	background: #fff;
  	font-weight: bold;
  	border-radius: 10px;
  	padding: 40px 15px 40px;
  	text-align: center;
    color: #323276;
  }


  .main-information02__ttl02 {
				font-size: 2.4em;
        line-height: 1.458;
        font-weight: 900;
        color: #1D2285;
        margin: auto;
        text-align: center;
  }


  .main-information02__ttl02-small{
    font-size: 0.6em;
    display: inline-block;
    padding-bottom: 2px;
		font-weight: normal;
  }

	.info-desc02 {
  	font-size: 15px;
  	line-height: 1.7;
		margin-top: 20px;
  	margin-bottom: 30px;
		line-height: 1.785;
    color: #000;
		text-align: left;
		font-weight: normal;
  }

  .employment{
    background: #F7F7F7;
    border-radius: 10px;
    padding: 25px 25px 35px;
  }

  .employment02{
    background: #F7F7F7;
    border-radius: 10px;
    padding: 25px 25px 35px;
    height: 85vh;
    overflow: scroll;
  }

  .employment_ttl{
    font-size: 20px;
  	line-height: 1.7;
  	margin-bottom: 20px;
  }

  .employment_ttl02{
    font-size: 20px;
  	line-height: 1.7;
  	margin-bottom: 7px;
  }


	.employment_logo {
		list-style-type: none;
	}


  .employment_logo img{
  	margin-bottom: 17px;
    max-width: 100%;
  }

  .employment_btn{
  	display: inline-block;
    text-align: center;
    padding: 13px 70px;
    border: 1px solid #292929;
    background: #fff;
    font-size: 16px;
		color: #1D2285 !important;
    margin-top: 10px;
  }

  .employment_ttl_small{
    font-size: 12px;
    margin-top:10px;
    font-weight: lighter;
    margin-bottom: 20px;
  }

  .employment_txt{
    font-size: 11px;
        text-align: left;
        font-weight: lighter;
        line-height: 1.6;
  }

.main-course__content-modal .modal-close02{
	position: relative;
  width: 23px;
          height: 23px;
          margin: 0px 12px -34px auto;
}

.main-course__content-modal02 {
    padding: 18px 12px 10px;
}

}





@media screen and (min-width: 769px) {

	.wrap_fv{
		color: #fff;
	}

.wrap_fv-img{
	width:380px;
}

  .main-head__catch-read {
    text-align: center;
    line-height: 1.2;
  }

  .main-head__catch-read-small {
    font-size: 28px;
    line-height: 1.3;
    padding-bottom: 7px;
    display: inline-block;
  }

  .main-head__catch {
    max-width: 500px;
position: absolute;
bottom: 15%;
left: 6%;
margin: 0;
padding: 30px 5px 25px;
  }

  .main-head__catch-read-small-yellow {
    color:#FFFF00;
  }

  .main-head__catch-read-rate1 {
    font-size: 50px;
  }

  .main-head__catch-read-rate2 {
    font-size: 70px;
    letter-spacing: normal;
    font-weight: bold;
		line-height: 1;
  }

  .main-head__catch-read-rate3 {
    font-size: 40px;
  }

  .main-head__catch-note2 {
		font-size: 11px;
			padding-top: 10px;
			line-height: 1.4;
			padding-bottom: 10px;
			border-bottom: 1px dotted #659ED0;
			letter-spacing: 0.02em;
			font-weight: 100;
			display: block;
			width: 60%;
			margin: auto;
  }

	.main-head__catch-note3 {
		font-size: 11px;
			padding-top: 10px;
			line-height: 1.4;
			font-weight: 100;
			letter-spacing: 0.02em;
			display: block;
			margin: auto;
			width: 85%;
	}


	.main-head__catch-copy{
		margin: 24px auto 0;
        display: flex;
        justify-content: center;
        align-items: center;
	}

	.mv_btn_sp img {
	        width: 87%;
	    }

			.mv_btn_pc {
			    max-width: 375px;
			    display: inline-block;
			    margin: auto 15px;
			}

	.main-head__catch-copy01 {
		font-size: 56px;
        font-weight: bold;
        line-height: 1;
  }

	.main-head__catch-copy02 {
		font-size: 35px;
        font-weight: lighter;
        line-height: 1;
        padding: 5px 12px 6px;
	}





  .main-head__school {
		text-align: center;
        padding-top: 24px;
        font-weight: bold;
        line-height: 1.3;
  }

  .main-head__school-lead {
		font-size: 15px;
        color: #FFFF00;
        display: inline-block;
        padding: 20px 0 5px;
        border-top: 1px dotted #659ED0;
        font-weight: 500;
        width: 60%;
  }

	.main-head__school-lead sup{
		font-size: 8px;
	}

  .main-head__school-name {
    font-size: 34px;
  }

  .attention02 {
          width: 100%;
          max-width: 500px;
          margin: 25px auto 30px;
          color: #fff;
          background: #FF3333;
          border-radius: 10px;
          padding: 12px 10px 10px;
          font-size: 14px;
          font-feature-settings: "palt";
          text-align: center;
          line-height: 1.3;
      }

  .attention02_en{
    font-size: 12px;
  }



  .main-information02-inner {
  	max-width: 1200px;
  	margin: 0 auto;
  	background: #fff;
  	font-weight: bold;
  	border-radius: 10px;
  	padding: 60px 15px 40px;
  	text-align: center;
    color: #323276;
  }


  .main-information02__ttl02 {
    font-size: 36px;
    color: #323276;
    position: relative;
    padding-bottom: 20px;
    margin-bottom: 0px;
  }



  .main-information02__ttl02-small{
    font-size: 24px;
    display: inline-block;
    padding-bottom: 8px;
		font-weight: 500;
  }

  .info-desc02 {
  	font-size: 15.5px;
  	line-height: 1.7;
		margin-top: 20px;
  	margin-bottom: 30px;
		line-height: 1.785;
    color: #000;
		font-weight: normal;
  }

  .employment{
    background: #F7F7F7;
    border-radius: 10px;
    padding: 25px 40px 35px;
    margin-bottom: 50px;
  }

  .employment02{
    background: #F7F7F7;
    border-radius: 10px;
    padding: 25px 25px 35px;
    height: auto;
    overflow:hidden;
  }

  .employment_ttl{
    font-size: 20px;
  	line-height: 1.7;
  	margin-bottom: 20px;
  }

  .employment_ttl02{
    font-size: 20px;
  	line-height: 1.7;
  	margin-bottom: 7px;
  }

  .employment_logo{
		display: grid;
		grid-template-columns: repeat(4,1fr);
		gap: 20px;
		list-style-type: none;
  }

  .employment_btn{
  	display: inline-block;
    text-align: center;
    padding: 13px 70px;
    border: 1px solid #292929;
    background: #fff;
    font-size: 16px;
		color: #1D2285 !important;
    margin-top: 20px;
  }

  .employment_ttl_small{
    font-size: 12px;
    margin-top:10px;
    font-weight: lighter;
    margin-bottom: 20px;
  }

  .employment_txt{
    font-size: 14px;
        text-align: left;
        font-weight: lighter;
        line-height: 1.8;
  }

.main-course__content-modal .modal-close02{
  width: 23px;
	position: relative;
          height: 23px;
          margin: 0px 12px -34px auto;
}

.main-course__content-modal02 {
    padding: 18px 12px 10px;
}

.main-panhu__txt {
  font-size: 30px;
  margin-bottom: 15px;
  font-weight: bold;
}

.main-panhu__txt-yellow {
  color: #FFDB14;
}

}









#modal-bg {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #000;
  z-index: 10;
  display: none
}

#modal-bg.is-show {
  display: block
}


.main-course__content-modal {
  width: calc(100% - 40px);
  position: fixed;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  border-radius: 10px;
  padding: 18px 22px 10px;
  z-index: 11;
  display: none
}

.main-course__content-modal .grade_2 {
  min-height: 115px;
}

@media screen and (min-width: 769px) {
  .main-course__content-modal {
    max-width: 800px
  }
  .main-course__content-modal .grade_2 {
    min-height: auto;
  }
}

.main-course__content-modal.is-show {
  display: block
}

.main-course__content-modal .modal-ttl {
  position: relative;
  color: #fff;
  text-align: center;
  font-size: 2.3rem;
  font-weight: 600;
  line-height: 1.73
}

@media screen and (min-width: 769px) {
  .main-course__content-modal .modal-ttl {
    font-size: 3.6rem
  }
}

@media screen and (max-width: 800px){
  .main-course__content-modal .modal-ttl {
    font-size: 1.6em;
  }
}

.main-course__content-modal .modal-ttl>span {
  display: inline-block;
  position: relative;
  z-index: 1;
  padding: 0 12px
}

@media screen and (min-width: 769px) {
  .main-course__content-modal .modal-ttl>span {
    padding: 0 50px
  }
}

.main-course__content-modal .modal-ttl>span::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -webkit-transform: skew(-15deg);
  transform: skew(-15deg);
  z-index: -1
}

.main-course__content-modal .modal-ttl>span[data-bgColor="green"]::after {
  background: #00C099
}

.main-course__content-modal .modal-ttl>span[data-bgColor="pink"]::after {
  background: #E36EEE
}

.main-course__content-modal .modal-ttl>span[data-bgColor="purple"]::after {
  background: #BE86FF
}

.main-course__content-modal .modal-txt {
  color: #fff;
  font-size: 2rem;
  font-weight: 600;
  line-height: 1.4;
  letter-spacing: 0.02em;
  margin-top: 18px
}

@media screen and (max-width: 800px){
  .main-course__content-modal .modal-txt {
    font-size: 1.6em;
  }
}

.main-course__content-modal .modal-subttl {
  text-align: center
}

.main-course__content-modal .modal-subttl span {
  background: #00c099;
  background: linear-gradient(80deg, #00c099 0%, #2ca8cb 32%, #8146c3 73%, #ff79fc 100%);
  color: #fff;
  font-size: 2.7rem;
  font-weight: 600;
  text-align: center;
  line-height: 1.22;
  margin-top: 28px;
  font-size: 1.8rem;
  padding: 4px 11px;
  display: inline-block
}

.main-course__content-modal .modal-subtxt {
  color: #fff;
  font-size: 1.5rem;
  line-height: 1.46;
  margin-top: 14px;
  text-align: center;
}

.main-course__content-modal .modal-note {
  position: relative;
  color: #fff;
  font-size: 1.9rem;
  font-weight: 600;
  text-align: center;
  line-height: 1.68;
  margin-top: 26px;
  padding: 20px 0 19px;
  background: url("../img/bg_modal_note.png") center/cover no-repeat
}

@media screen and (max-width: 800px){
  .main-course__content-modal .modal-note {
    font-size: 1.4rem;
  }
  .main-course__content-modal .modal-subtxt {
    text-align: left;
  }
}

.main-course__content-modal .modal-note::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5)
}

.main-course__content-modal .modal-note>span {
  position: relative
}

.main-course__content-modal .modal-close {
  width: 26px;
  height: 26px;
  margin: 20px auto 0
}

.main-course__content-modal .modal-close02{
	position: relative;
  width: 23px;
          height: 23px;
          margin: 0px 12px -34px auto;
}

.main-course__content-modal02 {
    padding: 18px 12px 10px;
}







.is-pc {
  display: inline-block !important
}

@media screen and (max-width: 768px) {
  .is-pc {
    display: none !important
  }
}

.is-sp {
  display: none !important
}

@media screen and (max-width: 768px) {
  .is-sp {
    display: inline-block !important
  }
}
