@charset "UTF-8";

/*--------------------------------
フォント
---------------------------------*/
@font-face {
    font-family: 'Noto Sans JP Subset';
	font-weight: 400;
	src: url('../font/NotoSans_medium.woff') format('woff');
}
@font-face {
    font-family: 'Noto Sans JP Subset';
	font-weight: 400;
	src: url('../font/NotoSans_medium.woff2') format('woff2');
}
@font-face {
    font-family: 'Noto Sans JP Subset';
	font-weight:500;
	src: url('../font/NotoSans_semibold.woff') format('woff');
}
@font-face {
    font-family: 'Noto Sans JP Subset';
	font-weight:500;
	src: url('../font/NotoSans_semibold.woff2') format('woff2');
}
@font-face {
    font-family: 'Noto Sans JP Subset';
	font-weight: 700;
	src: url('../font/NotoSans_bold.woff') format('woff');
}
@font-face {
    font-family: 'Noto Sans JP Subset';
	font-weight: 700;
	src: url('../font/NotoSans_bold.woff2') format('woff2');
}
@font-face {
    font-family: 'Noto Sans JP Subset';
	font-weight:300;
	src: url('../font/NotoSans_light.woff') format('woff');
}
@font-face {
    font-family: 'Noto Sans JP Subset';
	font-weight: 300;
	src: url('../font/NotoSans_light.woff2') format('woff2');
}

/*--------------------------------
 スクロールエフェクト scrollEfect + fadeUp/fadeRight/slideIn
---------------------------------*/
.fadeIn{
	opacity: 0;
  }
  .fadeIn.is-active{
	opacity: 0;
	animation-name: fadeIn;
	animation-duration: 0.6s;
	animation-fill-mode: forwards;
  }
  @keyframes fadeIn {
	from {
	  opacity: 0;
	}
	to {
	  opacity: 1;
	}
  }
.fadeUp{
	opacity: 0;
  }
  .fadeUp.is-active{
	opacity: 0;
	animation-name: fadeUp;
	animation-duration: 0.6s;
	animation-fill-mode: forwards;
  }
  @keyframes fadeUp {
	from {
	  opacity: 0;
	  transform: translateY(40px);
	}
	to {
	  opacity: 1;
	  transform: translateY(0);
	}
  }
  .fadeRight{
	opacity: 0;
  }
  .fadeRight.is-active{
	opacity: 0;
	animation-name: fadeRight;
	animation-duration: 1.2s;
	animation-fill-mode: forwards;
  }
  @keyframes fadeRight {
	from {
	  opacity: 0;
	  transform: translatex(-120px);
	}
	to {
	  opacity: 1;
	  transform: translatex(0);
	}
  }
  .fadeLeft{
	opacity: 0;
  }
  .fadeLeft.is-active{
	opacity: 0;
	animation-name: fadeLeft;
	animation-duration: 1.2s;
	animation-fill-mode: forwards;
  }
  @keyframes fadeLeft {
	from {
	  opacity: 0;
	  transform: translatex(120px);
	}
	to {
	  opacity: 1;
	  transform: translatex(0);
	}
  }
  .scrollEfect.is-active.que-01{
	animation-delay: 0.2s;
  }
  .scrollEfect.is-active.que-02{
	animation-delay: 0.4s;
  }
  .scrollEfect.is-active.que-03{
	animation-delay: 0.6s;
  }
  .scrollEfect.is-active.que-04{
	animation-delay: 0.8s;
  }
  .scrollEfect.is-active.que-05{
	animation-delay: 1s;
  }
  .scrollEfect.is-active.que-06{
	animation-delay: 1.2s;
  }
  .scrollEfect.is-active.que-07{
	animation-delay: 1.4s;
  }
  .scrollEfect.is-active.que-08{
	animation-delay: 1.6s;
  }
  .scrollEfect.is-active.que-09{
	animation-delay: 1.8s;
  }
  .scrollEfect.is-active.que-10{
	animation-delay: 2s;
  }


/*--------------------------------
 全体
---------------------------------*/
/*ベースカラー*/
:root{
	--color-blk:#333333;
	--color-gry:#707070;
	--color-gry:#707070;
	--color-nvy:#162EB7;
	--color-drd:#8F0000;
	--color-vio:#6669BE;
	--color-yel:#FEE200;
	--color-org:#DB8F00;
	--color-pale-01:#F7F7F7;
	--color-pale-02:#DDDEF8;


  }
/*layout*/
#wrapper {
	overflow: hidden;
	position: relative;
}

img{
	width: 100%;
	height: auto;
}

.inner{
	width: 95%;
	max-width: 880px;
	margin-left: auto;
	margin-right: auto;
}
.inner-wide{
	width: 95%;
	max-width: 1100px;
	margin-left: auto;
	margin-right: auto;
}

/*スマホ用PC用要素*/
.pc-only {
	display: block;
}
.pc-txt{
	display: inline-block;
}
.sp-only,
.sp-txt{
	display: none;
}


/*1000px以下*/
@media (max-width: 1000px) {

}
/*タブレット&スマホ*/
@media (max-width: 780px) {
	.pc-only,
	.pc-txt {
		display: none;
	}
	.sp-only {
		display: block;
	}
	.sp-txt{
		display: inline-block;
	} 
}

/*スマートフォン*/
@media (max-width : 580px) {


}
/*文字 400 500 700 900*/
body {
	font-family: "Roboto",'Noto Sans JP', sans-serif;
	font-weight: 400;
	color: var(--color-blk);
	background-color:#fff;
	font-size: 16px;
	position: relative;
}
h1,h2,h3,h4,h5{
	letter-spacing: 0.075em;
	line-height: 1.3;
}
.nowrap{
	white-space: nowrap;
}
.t-strong{
	font-weight: 700;
}
.t-small{
	font-size: 0.8em;
}
.tc-drd{
	color: var(--color-drd);
}
.tc-yel{
	color: var(--color-yel);
}

.txt-nomal{
	font-size: min(1.71vw,17px);
	font-feature-settings: "palt";
	text-align: justify;
	letter-spacing: 0.1em;
	line-height: 1.7;
}
.txt-mess{
	font-size: min(2.3vw,19px);
	font-feature-settings: "palt";
	text-align: justify;
	letter-spacing: 0.1em;
	line-height: 1.8;
	text-indent: 1em;
}
.txt-cap{
	font-size: min(1.5vw,15px);
	line-height: 1.5;
}
.bag-character{
	color: #fff;
	text-shadow    : 
	2px  2px 1px var(--color-nvy),
   -2px  2px 1px var(--color-nvy),
	2px -2px 1px var(--color-nvy),
   -2px -2px 1px var(--color-nvy),
	2px  0px 1px var(--color-nvy),
	0px  2px 1px var(--color-nvy),
   -2px  0px 1px var(--color-nvy),
	0px -2px 1px var(--color-nvy); 
}

/*タブレット*/

@media (max-width: 780px) {
	body {
		font-size: 14px;
	}
	.txt-mess{
		font-size: 4.2vw;
	}
	.txt-nomal{
		font-size: 4vw;
	}
	.txt-cap{
		font-size: 3.6vw;
	}

}

/*--------------------------------
aタグ、ボタン
---------------------------------*/
a:hover{
	filter: brightness(1.1); 
	transition:0.3s;
	cursor: pointer;
}

/*--------------------------------
nav ナビゲーション
---------------------------------*/
.mv-nav,
.nav-menu{
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	align-items: center;
}
.nav-menu{
	align-items: flex-start;
}
.mv-nav{
	padding: 10px 30px;
	width: 100%;
	height: 60px;
	background-color: #fffffff7;
	box-shadow: 0 4px 5px #00000009;
	position: fixed;
	z-index: 9999;
}
.nv-logo{
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.nv-logo img{
	width: 160px;
}
.nv-logo p{
	font-size: 13px;
	margin-left: 10px;
}
.nav-menu li{
	text-align: center;
	font-size: 11px;
	font-weight: 500;
	margin-right: 30px;
	letter-spacing: 0.1em;
}
.nav-menu.en li{
	font-size: 14px;
	font-weight: 700;
}
.nav-menu li:last-of-type{
	margin-right: 180px;
}
.nav-menu li span{
	color: var(--color-nvy);
	font-size: 18px;
	font-weight: 700;
}
.nav-menu li a{
	display: block;
}
.nav-menu li a:hover,
.nav-contact-btn:hover{
	opacity: 0.6;	
}

/* #NavBtn */
#NavBtn{
	width: 180px;
	height: 60px;
	position: fixed;
	right: 0;
	top:0;
	z-index: 999;
}
#NavBtn a{
	width: 180px;
	height: 60px;
	display: flex;
	justify-content: center;
	align-items: center;
	background-color: var(--color-org);
}
.nav-contact-btn{
	width: 90%;
}
.open-btn{
	display: none;
}
/*1110px以下*/
@media (max-width: 1110px) {
	.nv-logo p{
		display: none;
	}
	.mv-nav,
	#NavBtn,
	#NavBtn a{
		height: 52px;
	}
}
/*1000px以下*/
@media (max-width: 1000px) {
	.mv-nav{
		padding: 10px 20px;
	}
	.nv-logo img{
		width: 120px;
	}

.nav-menu li{
	font-size: 10px;
	margin-right: 18px;
}
.nav-menu li span{
	font-size: 15px;
}

.nav-menu li:last-of-type{
	margin-right: 140px;
}
#NavBtn,
#NavBtn a{
	width: 140px;
}


}
@media (max-width: 780px) {
	.mv-nav{
		height:46px;
		padding: 0 10px;
	}
	.nv-logo img{
		width: 50%;
		max-width: 420px;
	}
	#NavBtn{
		width: 92px;
		right: 0;
		height: 46px;
		padding: 3px;
	}
	#NavBtn a{
		width: 46px;
		height: 46px;
		position: absolute;
		top: 0;
		left: 0;
	}
	.nav-contact-btn{
		width: 40px;
		height: 40px;
	}

/*--------------------------------
ハンバーガーメニュー
---------------------------------*/

.open-btn{
	display: block;
	width: 46px;
	height: 46px;
	background-color: var(--color-blk);
	position: absolute;
	top: 0;
	right: 0;
}
.open-btn:hover{
	filter: brightness(1.1); 
	transition:0.3s;
	cursor: pointer;
}
.open-btn span{
	display: inline-block;
	transition: all .4s;
	position: absolute;
	left:8px;
	height: 3px;
	border-radius: 2px;
  background: #fff;
	width: 30px;
  }
  .open-btn span:nth-of-type(1) {
  top:14px; 
}
.open-btn span:nth-of-type(2) {
  top:22px;
}
.open-btn span:nth-of-type(3) {
  top:30px;
}
.nav-menu{
	position: fixed;
	left: -100%;
	top: 0;
	z-index: 100;
	width: 100%;
	height: 100dvh;
	transition: all .4s;
	background-color: #eaf2f8ee;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	color: var(--color-sbl);
	z-index: 100;
}
.nav-menu li{
	width: 80%;
	font-size: 14px;
	font-weight: 700;
	padding: 15px;
	border-top: var(--color-sbl) solid 1px;
	margin-right: 0;
}
.nav-menu li:last-of-type{
	margin-right: 0;
}
.nav-menu li{
	font-size: 11px;
}
.nav-menu li span{
	font-size: 18px;
}
.fv-nav-menu li::after{
	display: none;
	}
	/*activeクラスが付与されると線が回転して×に*/
	.open-btn.active span:nth-of-type(1) {
		transform: translateY(8px) rotate(-45deg);
	}
	.open-btn.active span:nth-of-type(2) {
	  opacity: 0;/*真ん中の線は透過*/
	}
	.open-btn.active span:nth-of-type(3){
		transform: translateY(-8px)  rotate(45deg);
	}
	.nav-menu.active{
		left: 0;
	}
	}


/*---------------------------------
top トップページ
----------------------------------*/
#top{
	background-color: var(--color-nvy);
	position: relative;
}
.mv{
	width: 100%;
	position: relative;
	height: 640px;
}
.mv-bk{
	width: 100%;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
}
.mv-in{
	width: 95%;
	max-width: 1100px;
	position: absolute;
	left: 50%;
	top: calc(8% + 60px);
	transform: translateX(-50%);
}
.h1-shoulder{
	width: 50%;
	padding: 0.5em 1em 0.4em 1em;
	background: linear-gradient(90deg,#fff 0%,#fff 30%, #ffffff00);
	color: var(--color-nvy);
	font-size: min(2.3vw,22px);
	font-weight: 700;
	line-height: 1;
	margin-bottom: 1%;
	}
h1{
		width: 54%;
		margin-left: -2%;
	}
.mv-cv{
	width: 45%;
	background-color: #fff;
	margin-top: -5%;
	padding: 15px 20px;
}
.cv-ttl{
	text-align: center;
	font-size: 16px;
	line-height: 1.3;
	font-weight: 500;
	margin-bottom: 15px;
}
.cv-btn-wrap{
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	align-items: center;
}
.cv-btn{
	width: 48%;
}
.cv-btn p{
	width: fit-content;
	margin-left: auto;
	margin-right: auto;
	text-align: center;
	font-size: 14px;
	letter-spacing: 0.1em;
	margin-bottom: 8px;
	position: relative;
}
.cv-btn p::before,
.cv-btn p::after{
	content: "";
	width: 1px;
	height: 106%;
	background-color: var(--color-blk);
	position: absolute;
	top:3%;
}
.cv-btn p::before{
	left: -8%;
	transform:rotate(-30deg);  
}
.cv-btn p::after{
	right: -8%;
	transform:rotate(30deg);  
}
.cv-btn a{
	padding: 1em 0.2em;
	display: flex;
	flex-direction: row;
	justify-content: center;
	font-size: 15px;
	font-weight: 500;
	align-items: center;
	line-height: 1;
}
.cv-btn:first-of-type a{
	background-color: var(--color-yel);
	color: var(--color-nvy);
}
.cv-btn:last-of-type a{
	background-color: var(--color-nvy);
	color: #fff;
}
.icon-file,
.icon-calendar,
.icon-arrow{
	margin-top: -2px;
}
.icon-file,
.icon-calendar{
	width: 15%;
	margin-right: 8px;
	}
.icon-arrow{
	width: 5%;
	margin-left: 5px;
}

/*タブレット&スマホ*/
@media (max-width: 1250px) {
	.mv{
		height: auto;
		padding-top: 50%;
	}
	.mv-in{
		top: 16%;
	}
	.h1-shoulder{
		padding: 0.5em 0.8em 0.4em 0.8em;
		font-size: min(1.9vw,22px);
		margin-bottom: 0;
	}
	h1{
		width: 50%;
		margin-left: 0;
	}
	.mv-cv{
		width: 50%;
		padding: 2% 2.5%;
	}
	.cv-ttl{
		font-size: min(1.7vw,16px);
		margin-bottom: 2.5%;
	}
	.cv-btn p{
		font-size: min(1.5vw,14px);
		margin-bottom: 2%;
	}
	.cv-btn a{
		font-size: min(1.6vw,15px);
	}
}
@media (max-width: 780px) {

	.mv{
		padding-top: 110%;
	}
	.mv-in{
		top: calc(46px + 3%);
	}
	.h1-shoulder{
		width: 100%;
		font-size: 3.6vw;
		margin-bottom: 2%;
	}
	h1{
		width: 75%;
		margin-left: -2%;
	}
	.mv-cv{
		width:100%;
		margin-top: 11%;
	}
	.cv-ttl{
		font-size: 4vw;
	}
	.cv-btn p{
		font-size: 3.2vw;
	}
	.cv-btn a{
		font-size: 3.6vw;
	}
}

/*--------------------------------
secction セクション
---------------------------------*/

/*--------------------------------
sc-ttl セクションタイトル
---------------------------------*/
.sc-ttl{
	position: relative;
	background: url(../img/sc_ttl_left.png),
				url(../img/sc_ttl_right.png);
	background-repeat: no-repeat;
	background-size: contain;
	background-position:left,right;
	text-align: center;
	font-size: 34px;
	color: var(--color-nvy);
	font-weight: 500;
	line-height: 1;
	padding: 0.5em;
}
.sc-ttl::after{
	content: "";
	width: 96%;
	height: 100%;
	background-color: #fff;
	position: absolute;
	left: 2%;
	top:0;
	z-index: -1;
}

.sc-ttl-wrap{
	position: relative;
	overflow: hidden;
	padding-top:220px ;
	padding-bottom: 80px;
}
.sc-ttl-wrap .sc-ttl{
	position: relative;
	z-index: 40;
}
.sc-ttl-wrap .sc-ttl-bk{
	position: absolute;
	width: 100%;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	z-index: 20;
}


.sc-top{
	position: relative;
	padding-top: 80px;
	margin-bottom: 60px;
}
.sc-top h3{
	text-align: center;
	font-size: 42px;
	font-weight: 300;
	margin-bottom: 40px;
}
.sc-top-ill-wrap{
	position: relative;
	z-index: 80;
}
.sc-top-ill-wrap img{
	width: 26%;
	position:absolute;
	right: -30px;
	top: -200px;

}
.sc-top .txt-mess{
	width: 100%;
	max-width: 580px;
	margin-left: auto;
	margin-right: auto;
}
@media (max-width : 1000px) {
	.sc-ttl{
		font-size:min( 4.2vw,28px);
	}
	.sc-ttl-wrap{
		padding-top:20% ;
		padding-bottom: 8%;
	}
	.sc-top{
		padding-top:  10%;
		margin-bottom: 8%;
	}
	.sc-top h3{
		font-size:min(5.2vw,42px);
		margin-bottom: 5%;
	}
	.sc-top img{
		width: 28%;
		right: -8%;
		top: 0;
		transform: translateY(-60%);
	}

}
@media (max-width: 780px) {
	.sc-ttl{
		font-size: 4.8vw;
	}
	.sc-ttl-wrap{
		padding-top:20% ;
		padding-bottom: 5%;
	}
	.sc-top h3{
		font-size:7.2vw;
	}
}

/*--------------------------------
coment
---------------------------------*/
.coment-top{
	position: relative;
	margin-top: 80px;
}
.coment-top::before,
.coment-top::after{
	content:"";
	width: calc((100vw - 100%) / 2);
	height: 100%;
	position: absolute;
	top: 0;
	opacity: 0.7;
}
.coment-top::before{
	left: 0;
	transform: translateX(-100%);
}
.coment-top::after{
	right:0;
	transform: translateX(100%);
}
.coment-top-01::before,
.coment-top-01::after{
	background:url(../img/coment_top_01.jpg) no-repeat ;
	background-size: auto 100%;
}
.coment-top-02::before,
.coment-top-02::after{
	background:url(../img/coment_top_02.jpg) no-repeat ;
	background-size: auto 100%;
}
.coment-top-03::before,
.coment-top-03::after{
	background:url(../img/coment_top_03.jpg) no-repeat ;
	background-size: auto 100%;
}
.coment-top-01::before,
.coment-top-02::before,
.coment-top-03::before{
	background-position: left;
}
.coment-top-01::after,
.coment-top-02::after,
.coment-top-03::after{
	background-position: right;
}
.coment-content{
	background-color: var(--color-pale-01);
	padding-top: 80px;
	padding-bottom: 80px;
}

.coment-box{
width: 95%;
display: flex;
justify-content: space-between;
align-items: flex-start;
}
.coment-box-01{
	flex-direction: row;
	margin-left: auto;
	margin-right: 0;
	margin-bottom: 40px;
}
.coment-box-02{
	flex-direction: row-reverse;
	margin-right: auto;
	margin-left: 0;
}
.coment-fukidashi{
	width: 75%;
	background-color: #fff;
	border-radius: 24px;
	padding: 3em;
	position: relative;
}
.coment-fukidashi::after{
	content:"";
	width: 5%;
	padding-top: 5%;
	background-color: #fff;
	position: absolute;
	top: 30%;
}
.coment-box-01 .coment-fukidashi::after{
	clip-path: polygon(0 0, 0% 100%, 100% 50%);
	right: calc(-5% + 1px);
}
.coment-box-02 .coment-fukidashi::after{
	clip-path: polygon(100% 0, 0 50%, 100% 100%);
	left: calc(-5% + 1px);
}
.ill-coment-02{
	position: absolute;
	width: 25%;
	bottom: -60px;
	right: -70px;
}
.coment-fukidashi h4{
	color: var(--color-vio);
	font-size: 22px;
	font-weight: 500;
	margin-bottom: 20px;
}
.coment-student{
	width: 20%;
}
.coment-student p{
	margin-top: 10px;
}

.coment-colmun{
	width: 95%;
	background-color: #fff;
	border-radius: 24px;
	padding: 3em 5em;
	position: relative;
}
.coment-colmun-01{
	margin-left: auto;
	margin-right: 0;
	margin-bottom: 40px;
}

.coment-column-img-wrap{
	width: 80%;
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	align-items: flex-start;
	flex-wrap: wrap;
	margin-top: 20px;
}
.coment-colmun-02 .coment-column-img-wrap{
	margin-left: auto;
	margin-right: 0;
}
.life-photo-a{
	width: 32%;
}
.life-photo-b{
	width: 28%;
}
.coment-column-student{
	width: 45%;
	position: absolute;
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
}
.coment-colmun-01 .coment-column-student{
	flex-direction: row-reverse;
	right: 0;
	bottom: 0;
}
.coment-colmun-02 .coment-column-student{
	flex-direction: row;
	left: 0;
	bottom: 0;
}
.coment-column-student img{
	width: 45%;
}
.coment-column-student p{
	width: 50%;
	margin-bottom: 10px;
}

@media (max-width : 1000px) {
	.coment-top{
		margin-top: 10%;
	}
	.coment-content{
		padding-top: 8%;
		padding-bottom: 8%;
	}
	.coment-box-01{
		margin-bottom: 8%;
	}
	.coment-fukidashi{
		border-radius: 18px;
		padding: 2em;
	}
	.coment-fukidashi h4{
		font-size:min(2.5vw,22px);
		margin-bottom: 4%;
	}
.ill-coment-02{
		width: 25%;
		bottom: -18%;
		right: -10%;
	}
	.coment-student p{
		margin-top: 5%;
	}
	.coment-colmun{
		border-radius: 18px;
		padding: 2em;
	}
}
@media (max-width: 780px) {
	.coment-box{
		width: 90%;
	}
	.coment-box-01,
	.coment-box-02{
		flex-direction: column;
	}
	.coment-fukidashi{
		width: 100%;
		margin-bottom: 10%;
	}
	.coment-fukidashi::after{
		width: 15%;
		padding-top: 10%;
		top: unset;
		bottom: 0;
		transform: translateY(100%);
	}
	.coment-fukidashi h4{
		font-size:4.2vw;
	}
	.coment-box-01 .coment-fukidashi::after,
	.coment-box-02 .coment-fukidashi::after{
		clip-path: polygon(100% 0, 0 0, 50% 100%);
	}
	.coment-box-01 .coment-fukidashi::after{
		right: unset;
		left: 20%;
	}
	.coment-box-02 .coment-fukidashi::after{
		left: unset;
		right: 20%;
	}
	.coment-student{
		width: 90%;
		margin-left: auto;
		margin-right: auto;
		display: flex;
		align-items: flex-end;
		justify-content: center;
	}
	.coment-box-01 .coment-student{
		flex-direction: row;
	}
	.coment-box-02 .coment-student{
		flex-direction: row-reverse;
	}
.ill-coment-02{
		width: 40%;
		bottom: -20%;
		right: unset;
		left: 5%;
	}
	.coment-student img{
		width: 45%;
	}
	.coment-student p{
		width: 55%;
	}
	.coment-student p{
		font-size: 3vw;
	}
	.coment-box-02 .coment-student p{
		text-align: right;
	}
	.coment-colmun{
		padding: 2em 2em 25% 2em;
	}
	.coment-column-img-wrap{
		width: 100%;
	}
	.life-photo-a{
		width: 50%;
	}
	.life-photo-b{
		width: 45%;
	}
	.coment-column-studen,
	.coment-colmun-01 .coment-column-student,
	.coment-colmun-02 .coment-column-student{
		width: 100%;
		flex-direction: row-reverse;
	}
	.coment-column-student img{
		width: 40%;
	}
	.coment-column-student p{
		width: 55%;
		margin-bottom: 10px;
		text-align: right;
	}
	.coment-colmun-02 .ill-coment-02{
		display: none;
	}
}
/*--------------------------------
circle レスポンシブな円
---------------------------------*/
.circle{
	border-radius: 999px;
	position: relative;
}
.circle::before{
	content: "";
	width: 100%;
	display: block;
	padding-top: 100%;
	height: 0;
}
.circle-in{
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top:0;
	z-index: 80;
}
/*---------------------------------
message メッセージ
----------------------------------*/
#message{
	padding-top: 110px;
	padding-bottom: 160px;
	background-color: #5987EA;
	padding-bottom: 420px;
	background-image: url(../img/message_bk.jpg);
	background-repeat: no-repeat;
	background-size: contain;
	background-position: bottom;
	position: relative;
}
#message::after{
	content: "";
	width: 100%;
	height: 90%;
	background: linear-gradient(to bottom,#5987EA 0%,#5987ea00 100%);
	position: absolute;
	top: 0;
	left: 0;
	z-index: 60;
}
#message .inner{
	position: relative;
	z-index: 80;
}
.message-top{
	width: 100%;
	position: relative;
	margin-bottom: 40px;
}

.message-top img{
	width: 40%;
	position: absolute;
	z-index: 90;
	right: 0;
	top:-260px;
}
.message-top ul,
.message-top .txt-mess{
	width: 100%;
	width: 100%;
	max-width: 580px;
	margin-left: auto;
	margin-right: auto;
}
.message-top ul{
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 40px;
}
.message-top ul li{
	width: 30%;
	position: relative;
	background: url(../img/sc_ttl_left.png),
				url(../img/sc_ttl_right.png);
	background-repeat: no-repeat;
	background-size: contain;
	background-position:left,right;
	text-align: center;
	font-size: 20px;
	color: var(--color-nvy);
	font-weight: 500;
	line-height: 1;
	padding: 0.5em;
}
.message-top ul li::after{
	content: "";
	width: 90%;
	height: 100%;
	background-color: #fff;
	position: absolute;
	left: 5%;
	top:0;
	z-index: -1;
}
.message-top p{
	color: #fff;
}

.message-link{
	text-align: right;
}
.message-link a{
	color: #fff;
	position: relative;
	text-shadow: 0 0 4px #0000007d;
}
.message-link a::before{
	content: "";
	width: 12px;
	height: 100%;
	background-color: #fff;
	clip-path: polygon(0 0, 0% 100%, 100% 50%);
	position: absolute;
	left: -15px;
	top: 0;
}

.message-box-wrap{
	width: 100%;
	height: auto;
	position: relative;
	margin-top: 30px;
	margin-bottom: 20px;
	z-index: 50;
}
.message-box-wrap::after{
	content: "";
	display: block;
	padding-top: 62%;
}
.massage-box{
	position: absolute;
	height: auto;
	background-color: #ffffffbb;
}
.massage-box::after{
	content: "";
	display: block;
}
.massage-box.box-01{
	width: 37%;
	left: 0;
	top: 0;
	z-index: 70;
}
.massage-box.box-01::after{
	padding-top: 55%;	
}
.massage-box.box-02{
	width: 33%;
	left: 40%;
	top: 0;
	z-index: 60;

}
.massage-box.box-02::after{
	padding-top: 62%;	
}
.massage-box.box-03{
	width: 24%;
	left: 76%;
	top: 0;
	z-index: 50;
}
.massage-box.box-03::after{
	padding-top: 177%;	
}
.massage-box.box-04{
	width: 33%;
	left: 0;
	top:42%;
	z-index: 40;
}
.massage-box.box-04::after{
	padding-top: 50%;	
}
.massage-box.box-05{
	width: 35%;
	left: 37%;
	top:42%;
	z-index: 50;
}
.massage-box.box-05::after{
	padding-top: 47%;	
}
.massage-box.box-06{
	width: 41%;
	left: 0;
	top:76%;
	z-index: 60;
}
.massage-box.box-06::after{
	padding-top: 35%;	
}
.massage-box.box-07{
	width: 53%;
	left: 47%;
	top:76%;
	z-index: 40;
}
.massage-box.box-07::after{
	padding-top: 27%;	
}

.massage-box p{
	color: #323232;
	font-weight: 500;
	font-size: min(1.9vw,18px);
	line-height: 1.4;
	position: absolute;
	left: 50%;
	top:50%;
	transform: translate(-50%,-50%);
}
.massage-box p .item-01,
.massage-box p .item-02{
	white-space: nowrap;
}
.massage-box p .item-01{
	font-size: 1.6em;
}
.massage-box p .item-02{
	font-size: 2.2em;
}
.message-img{
	position: absolute;
	box-shadow: 2px 2px 6px #00000022;
	z-index: 100!important;
}
.massage-box.box-01 p{
	left: 48%;
}
.massage-box.box-01 .message-img{
	border-radius: 999px;
	width: 39%;
	right: -8%;
	bottom: -17%;
}

.massage-box.box-02 p{
	left: 46%;
}
.massage-box.box-02 .message-img{
	width: 48%;
	right: -10%;
	bottom: -12%;
	transform: rotate(-7deg);
}
.massage-box.box-03 p{
	top:32%;
}
.massage-box.box-03 .message-img{
	width: 98%;
	left: -5%;
	bottom: -1%;
	transform: rotate(-7deg);
}
.massage-box.box-05 p{
	text-align: right;
	left: 55%;
}
.massage-box.box-05 p .item-03{
	font-size: 1.6em;
	position: absolute;
	bottom: 0;
	right: -1em;
}
.massage-box.box-05 .message-img{
	width: 45%;
	left: -15%;
	bottom: -10%;
	transform: rotate(8deg);
}
.massage-box.box-06 p{
	left: 45%;
}
.massage-box.box-06 .message-img{
	width: 30%;
	transform: rotate(6deg);
	top:-6%;
	right: -10%;
}
@media (max-width: 780px) {
	#message{
		padding-bottom: 40%;
		background-image: url(../img/message_bk_sp.jpg);
		padding-top: 10%;
		padding-bottom: 30%;
	}
	#message::after{
		height: 100%;
}
	.message-top{
		margin-bottom: 10%;
		padding-top: 25%;
	}
	.message-top img{
		width: 60%;
		top:-15%;
	}
	.message-top ul{
		margin-bottom: 5%;
	}
	.message-top ul li{
		width: 32.5%;
		font-size: 4.2vw;
		line-height: 1.1;
	}
	.message-top ul li::after{
		width: 50%;
		left: 25%;
	}
	.message-box-wrap{
		position: relative;
		margin-top: 5%;
		margin-bottom: 2%;
	}
	.message-box-wrap::after{
		padding-top: 152%;
	}
	.massage-box.box-01{
		width: 58%;
	}

	.massage-box.box-02{
		width: 58%;
		left: 0;
		top: 24%;
	}
	.massage-box.box-02::after{
		padding-top: 62%;	
	}
	.massage-box.box-03{
		width: 36%;
		left: 64%;
		top: 0;
	}
	.massage-box.box-03::after{
		padding-top: 177%;	
	}

	.massage-box.box-04{
		width: 50%;
		left: 0;
		top:50%;
	}
	.massage-box.box-04::after{
		padding-top: 55%;	
	}
	.massage-box.box-05{
		width: 44%;
		left: 56%;
		top: 45%;
	}
	.massage-box.box-05::after{
		padding-top: 80%;	
	}
	.massage-box.box-06{
		width: 100%;
		left: 0;
		top:90%;
	}
	.massage-box.box-06::after{
		padding-top: 15%;	
	}
	.massage-box.box-07{
		width: 100%;
		left: 0;
		top:70%;
	}
	.massage-box.box-07::after{
		padding-top: 25%;	
	}
	.massage-box p{
		font-size: 3vw;
	}
	.massage-box.box-02 p{
		left: 40%;
	}
	.massage-box.box-02 .message-img{
		width: 46%;
		right: -5%;
		bottom: -10%;
	}
	.massage-box.box-05 p{
		text-align: right;
		left: 50%;
	}
	.massage-box.box-05 .message-img{
		width: 58%;
		left: -6%;
		bottom: -1%;
	}
	.massage-box.box-06 p{
		left: 50%;
	}
	.massage-box.box-06 .message-img{
		width: 20%;
		transform: rotate(4deg);
		top:-200%;
		right: 0;
	}
	.massage-box.box-07 p{
		left: 42%;
	}

}
/*---------------------------------
roadmap チェコ医学部留学への道のり
----------------------------------*/
.roadmap-dl,
.roadmap-course-dl,
.roadmap-exam-dl{
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	align-items: stretch;
	flex-wrap: wrap
}
.roadmap-dt,
.roadmap-dd{
	margin-bottom: 16px;
}
.roadmap-dt:last-of-type,
.roadmap-dd:last-of-type{
	margin-bottom: 0;
}
.roadmap-dt{
	width: 25%;
	margin-right: 5%;
	display: flex;
	justify-content: center;
	align-items: center;
	background-color: var(--color-pale-02);
	position: relative;
	border-bottom: 4px solid #dfdfdf;
	color: var(--color-vio);
	font-size: min(2vw,19px);
	font-weight: 700;
	letter-spacing: 0.15em;
	line-height: 1;
	text-align: center;
	z-index: -1;
}
.roadmap-dt::after{
	content: "";
	clip-path: polygon(50% 100%, 0 0, 100% 0);
	width: 34px;
	height: 20px;
	background-color: var(--color-vio);
	position: absolute;
	left: 50%;
	bottom:-20px;
	transform: translateX(-50%);
	z-index: 80;
}
.roadmap-dt:last-of-type::after{
	display: none;
}
.roadmap-dd{
	width: 70%;
	padding: 1.5em 0;
}
.roadmap-dd:nth-of-type(2){
	padding: 0;
}
.roadmap-course-dt,
.roadmap-course-dd{
	margin-bottom: 20px;
}

.roadmap-course-dt,
.roadmap-exam-dt{
	width: 30%;
	margin-right: 3%;
	display: flex;
	justify-content: center;
	align-items: center;
	color: var(--color-vio);
	font-size: min(1.7vw,16px);
	font-weight: 700;
	letter-spacing: 0.15em;
	line-height: 1;
	text-align: center;
}
.roadmap-course-dt{
	border: solid 2px var(--color-vio);
}
.roadmap-course-dd,
.roadmap-exam-dd{
	width: 67%;
	display: flex;
	justify-content: flex-start;
	align-items: center;
}
.roadmap-course-dt{
	padding: 1em 0;
}
.roadmap-exam-dt p{
	width: 100%;
	border-radius: 20px;
	padding: 0.25em 0;
	border: solid 2px var(--color-vio);
}
.roadmap-exam-dt:first-of-type{
	position: relative;
	margin-bottom: 20px;
	margin-bottom: 10px;
}
.roadmap-exam-dd:first-of-type{
	margin-bottom: 10px;
}
.roadmap-exam-dt:first-of-type::after{
	content: "";
	clip-path: polygon(50% 100%, 0 0, 100% 0);
	width: 24px;
	height: 15px;
	background-color: var(--color-vio);
	position: absolute;
	left: 50%;
	bottom:-5px;
	transform: translateX(-50%);
	z-index: 80;
}
@media (max-width : 780px) {
	.roadmap-dt,
	.roadmap-dd{
		margin-bottom: 14px;
	}
	.roadmap-dt{
		width: 24%;
		margin-right: 4%;
		font-size: 4vw;
		letter-spacing: 0.05em;
		line-height: 1;
	}
	.roadmap-dt::after{
		width: 24px;
		height: 18px;
		bottom:-18px;
	}
	.roadmap-dd{
		width: 72%;
		padding: 1.5em 0;
	}
	.roadmap-course-dt,
	.roadmap-course-dd{
	margin-bottom: 15px;
}
.roadmap-course-dt,
.roadmap-exam-dt{
	width: 35%;
	margin-right: 4%;
	font-size:3.5vw;
}
.roadmap-course-dd,
.roadmap-exam-dd{
	width: 61%;
}
.roadmap-exam-dt{
	align-items: flex-start;
}
.roadmap-exam-dt:first-of-type::after{
	width: 18px;
	height: 12px;
	bottom:-0;
}
}
/*--------------------------------
about チェコ医学部ってこんなところ
---------------------------------*/
.college-content{
	background-color: var(--color-pale-01);
	padding-top: 40px;
	padding-bottom: 60px;
}
.college-content-ttl{
	background-color: #F4CECE;
}
.college-content-ttl h4{
	font-size: 18px;
	background-color: var(--color-drd);
	color: #fff;
	line-height: 1;
	padding: 0.3em 0.5em 0.2em 0.2em;
	text-align: right;
}
.college-content-ttl-02 h4{
	padding: 0.3em 0.2em 0.2em 0.5em;
	text-align: left;
}
.college-top-wrap{
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	align-items: stretch;
	margin-bottom: 60px;
}
.college-top-wrap-02{
	flex-direction: row-reverse;
}
.college-img,
.college-top{
	width: 48%;
}
.college-top{
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}
.college-top h5{
	font-size: 28px;
	color: var(--color-vio);
	font-weight: 500;
	margin-bottom: 10px;
}
.college-content-link{
	position: relative;
}
.college-content-link::after{
	content: "";
	width: 20px;
	height: 20px;
	background: url(../img/icon_link_arrow.png) no-repeat;
	background-size: contain;
	position: absolute;
	left: 30%;
	top:50%;
	transform: translateY(-50%);
}
.college-content-link a{
	background: #fff;
	border: 1px solid var(--color-gry);
	border-radius: 4px;
	display: block;
	width: 100%;
	color: var(--color-gry);
	text-align: center;
	line-height: 1;
	padding-top: 1em;
	padding-bottom: 1em;
	box-shadow: 0 3px 2px #7070708b;
	font-size: 16px;
}
.college-point-wrap{
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	align-items: stretch;
}
.college-point{
	width: 30%;
	background-color: #fff;
	padding: 2.5em 2em 2em 2em;
	position: relative;
	box-shadow: 0 0 8px #00000033;
}
.college-point h6{
	text-align: center;
	font-size: 17px;
	font-weight: 500;
	color: var(--color-nvy);
	margin-bottom: 10px;
}
.college-point img{
	width: 16%;
	position: absolute;
	left: 50%;
	top: 0;
	transform: translate(-50%,-50%);
}
.about-between-01,
.about-between-02{
	padding-top: 60px;
	padding-bottom: 20px;
}
.about-between-01 img,
.about-between-02 img{
	width: 30%;
}
.about-between-01{
	text-align: right;
}
.about-between-02{
	text-align: left;
}

.course-wrap{
	margin-top: 80px;
	margin-bottom: 80px;
}
.course-content{
	position: relative;
}
.course-content-01{
	margin-bottom: 60px;
}
.course-content{
	border: 2px solid var(--color-vio);
	border-radius: 20px;
	box-shadow: 0 0 8px #00000033;
	padding: 2em 5em;
}
.course-content img{
	position: absolute;
}
.course-content-01 img{
	width: 25%;
	right: 0;
	top: -14%;
}
.course-content-02 img{
	width: 23%;
	left: 0;
	top: -25%;
}
.course-content h4{
	font-size: 22px;
	text-align: center;
	color: var(--color-vio);
	margin-bottom: 20px;
	font-weight: 500;
}
.course-grade-dl,
.course-doctor-dl{
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	align-items: stretch;
	flex-wrap: wrap;
}
.course-grade-dl{
	margin-top: 40px;
	padding-bottom: 20px;
	margin-bottom: 20px;
	border-bottom: 2px var(--color-pale-02) dashed ;
}
.course-grade-dl dt,
.course-grade-dl dd{
	margin-bottom: 10px;
}
.course-grade-dl dt:last-of-type,
.course-grade-dl dd:last-of-type{
	margin-bottom: 0;
}
.course-grade-dl dt{
	width: 15%;
	margin-right: 5%;
	text-align: center;
	padding: 0.5em 0;
	background-color: var(--color-vio);
	color: #fff;
	font-size: 14px;
	font-weight: 500;
	letter-spacing: 0.15em;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}
.course-grade-dl dt:last-of-type{
	background-color: #fff;
	border: 2px solid var(--color-vio);
	color: var(--color-vio);
}
.course-grade-dl dd,
.course-doctor-dl dd{
	display: flex;
	justify-content: flex-start;
	align-items: center;
}
.course-grade-dl dd{
	width: 80%;
}

.course-doctor-dl dt{
	width: 20%;
	margin-right: 5%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}
.course-doctor-dl dt p{
	width: 100%;
	background-color: #fff;
	border: 2px solid var(--color-vio);
	color: var(--color-vio);
	font-size: 14px;
	font-weight: 500;
	text-align: center;
	padding: 0.5em 0;
}
.course-doctor-dl dt p:first-of-type{
	margin-bottom: 10px;
}
.course-doctor-dl dd{
	width: 75%;
}
@media (max-width : 1000px) {
	.college-content{
		padding-top: 5%;
		padding-bottom: 8%;
	}
	.college-content-ttl h4{
		font-size: min(1.9vw,18px);
	}
	.college-top-wrap{
		margin-bottom: 8%;
	}
	.college-top h5{
		font-size: min(2.8vw,28px);
		margin-bottom: 3%;
	}
	.college-content-link::after{
		content: "";
		width: 5%;
		height: 0;
		padding-top: 5%;
	}
	.college-content-link a{
		font-size: min(1.8vw,16px);
	}
	.college-point{
		padding: 2em 1.5em 1.5em 1.5em;
	}
	.college-point h6{
		font-size:min(1.9vw,17px);
		margin-bottom: 3%;
	}
	.about-between-01,
.about-between-02{
	padding-top: 8%;
	padding-bottom: 3%;
}

.course-wrap{
	margin-top: 10%;
	margin-bottom: 10%;
}
.course-content{
	padding: 2em 2em;
}
.course-content h4{
	font-size: min(2.8vw,22px);
	margin-bottom: 3%;
}
}
@media (max-width : 780px) {
	.college-content-ttl h4{
		font-size: 3.7vw;
		padding: 0.3em 0.2em 0.2em 0.5em;
		text-align: left;
	}
	.college-top-wrap{
		flex-direction: column;
	}
	.college-img,
.college-top{
	width: 100%;
}
.college-top h5{
	font-size: 5.8vw;
	margin-top: 3%;
}

.college-content-link{
	margin-top: 5%;
}
.college-content-link a{
	font-size: 3.8vw;
}
.college-point-wrap{
	flex-direction: column;
}
.college-point{
	width: 100%;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 8%;
	padding: 2.5em 1.5em 1.5em 1.5em;
}
.college-point img{
	width: 12%;
	top:0;
}
.college-point h6{
	font-size:4.2vw;
}
.course-content{
	padding: 1.5em;
}
.course-content h4{
	font-size: 4.5vw
}
.course-grade-dl{
	margin-top: 8%;
	padding-bottom: 5%;
	margin-bottom: 5%;
}
.course-grade-dl dt,
.course-grade-dl dd{
	margin-bottom: 3%;
}
.course-grade-dl dt{
	width: 30%;
	margin-right: 5%;
	font-size: 3.6vw;
}
.course-grade-dl dd{
	width: 65%;
}
.course-doctor-dl{
	flex-direction: column;
}
.course-doctor-dl dt,
.course-doctor-dl dd{
	width: 100%;
}
.course-doctor-dl dt{
	flex-direction: row;
	justify-content: space-between;
	margin-right: 0;
	margin-bottom: 3%;
}
.course-doctor-dl dt p{
	width: 48%;
	font-size: 3.6vw;
}
.course-doctor-dl dt p:first-of-type{
	margin-bottom: 0;
}
.course-content-01 img{
	width: 30%;
	right: -3%;
	top: -8%;
}
.course-content-02 img{
	width: 32%;
	left: -5%;
	top: -14%;
}

}

/*--------------------------------
LIFE チェコでの留学生活
---------------------------------*/
.apt-content{
	padding-bottom: 80px;
}
.apt-content h4{
	background-color: var(--color-vio);
	color: #fff;
	font-size: 18px;
	padding: 0.25em;
	text-align: center;
	margin-bottom: 40px;
}
.apt-wrap{
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	align-items: stretch;
	margin-bottom: 40px;
}
.apt-box{
	width: 30%;
}
.apt-icon{
	width: 15%;
	margin-left: auto;
	margin-right: auto;
}
.apt-box h5{
	font-size: 17px;
	font-weight: 500;
	color: var(--color-nvy);
	height: 46px;
	display: flex;
	justify-content: center;
	align-items: center;
	text-align: center;
}
.apt-box p{
	margin-top: 10px;
}
.apt-conetent-bottom{
	border: 2px solid var(--color-vio);
	border-radius: 20px;
	box-shadow: 0 0 8px #00000033;
	padding: 2em 5em;
}
.apt-conetent-bottom h5{
	font-size: 22px;
	text-align: center;
	color: var(--color-vio);
	margin-bottom: 20px;
	font-weight: 500;
}

@media (max-width : 1000px) {
	.apt-content{
		padding-bottom: 8%;
	}
	.apt-content h4{
		font-size: min(1.9vw,18px);
		margin-bottom: 8%;
	}
	.apt-wrap{
		margin-bottom: 8%;
	}
	.apt-box h5{
		font-size:min(1.9vw,17px);
	}
	.apt-conetent-bottom{
		padding: 2em 2em;
	}
	.apt-conetent-bottom h5{
		font-size: min(2.8vw,22px);
		margin-bottom: 3%;
	}
}
@media (max-width : 780px) {
	.apt-content h4{
		font-size: 3.7vw;
	}
	.apt-wrap{
		flex-direction: column;
	}
	.apt-box{
		width: 100%;
		padding-bottom: 8%;
		margin-bottom: 8%;
		border-bottom:1px solid var(--color-vio) ;
	}
	.apt-icon{
		width: 12%;
	}
	.apt-box h5{
		font-size:4vw;
		height: auto;
		margin-top: 1%;
		margin-bottom: 2%;
	}
	.apt-conetent-bottom {
		padding: 1.5em;
	}
	.apt-conetent-bottom h5{
		font-size: 4.5vw
	}
}

/*--------------------------------
information インフォメーション
---------------------------------*/
#info{
	background-color: var(--color-pale-02);
}
.info-content-wrap{
	padding-top: 80px;
	padding-bottom: 80px;
}
.info-content-wrap h2{
	color: var(--color-nvy);
	font-size: 34px;
	text-align: center;
}

.info-content{
	margin-top: 40px;
}
.info-content-wrap .txt-cap,
.info-content .txt-nomal{
	text-align: center;
}
.info-content h3{
	font-weight: 500;
	color: var(--color-nvy);
	font-size: 18px;
	margin-bottom: 1em;
	text-align: center;
}
.info-box{
	background-color: #fff;
	padding: 2em;
	margin-top: 15px;
	box-shadow: 0 0 8px #00000033;
}
.info-list,
.info-table{
	width: 100%;
	max-width: 580px;
	margin-left: auto;
	margin-right: auto;
}



.info-list {
	counter-reset:number;
	list-style-type: none!important;
  }
  
  .info-list li {
	position: relative;
	line-height: 1.5;
	padding-left:4%;
	font-size: 15px;
	margin-bottom: 1em;
  }
  .info-list li:last-of-type{
	margin-bottom: 0;
  }
  .info-list li:before{
	content:"";
	background: var(--color-nvy);
	width: 3%;
	height: auto;
	padding-top: 3%;
	line-height:1;
	position: absolute;
	top: 0.2em;
	left: 0;
  }
  .info-list li::after{
	counter-increment: number;
	content: counter(number);
	color: #fff;
	font-weight:500;
	font-size: 15px;
	position: absolute;
	top: 0.1em;
	left: 0.3em;
  }

  .info-table{
	width: 100%;
  }

  .info-table dl{
	font-size: 15px;
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	margin-bottom: 20px;
  }
  .info-table dl dt{
	width: 38%;
	color: var(--color-nvy);
	font-weight: 500;
	display: flex;
	justify-content: center;
	align-items: center;
	text-align: center;
	border-right:1px solid var(--color-pale-02) ;
  }
  .info-table dd{
	width: 60%;
  }
	
  .info-table dd ul{
	width: 100%;
	display: flex;
	flex-direction: row;
  }
  .info-table dd ul li{
	padding: 0.25em;
  }
  .info-table dd ul li:first-of-type{
	width: 60%;
  }
  .info-table dd ul li:last-of-type{
	width: 40%;
	text-align: right;
  }

@media (max-width : 1000px) {
	.info-content-wrap{
		padding-top: 10%;
		padding-bottom: 10%;
	}
	.info-content-wrap h2{
		font-size:min( 4.2vw,28px);
	}
	.info-content{
		margin-top: 8%;
	}
	.info-content h3{
		font-size: min(1.9vw,18px);
	}
	.info-box{
		margin-top: 5%;
	}
}
@media (max-width : 780px) {
	.info-content-wrap h2{
		font-size: 4.8vw;
	}
	.info-content h3{
		font-size:3.8vw;
		margin-bottom: 2%;
	}
	.info-box{
		margin-top: 3%;
		padding: 1.5em;
	}
	.info-list li {
		padding-left:7%;
		font-size: 3.6vw;
	  }
	  .info-list li:before{
		content:"";
		background: var(--color-nvy);
		width: 6%;
		height: auto;
		padding-top: 6%;
		line-height:1;
		position: absolute;
		top: 0;
		left: 0;
	  }
	  .info-list li::after{
		font-size: 3.6vw;
		top: 0;
		left: 0.4em;
	  }
	  .info-table dl{
		font-size: 3.6vw;
		flex-direction: column;
		margin-bottom: 8%;
	  }
	  .info-table dl dt{
		width: 100%;
		border-right:none;
		border-bottom:1px solid var(--color-pale-02) ;
		padding-bottom: 1%;
		margin-bottom: 1%;
	  }
	  .info-table dd{
		width: 100%;
	  }
}
/*--------------------------------
	footer フッター
---------------------------------*/
footer{
	background-color: var(--color-nvy);
	padding-bottom: 10px;
}
.footer-btn{
	background-color: var(--color-vio);
	padding-top: 60px;
	padding-bottom: 60px;
}

.footer-btn-wrap{
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	align-items: center;
}
.footer-btn-wrap .cv-btn{
	width: 45%;
	height: 110px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}
.footer-btn-wrap .cv-btn{
	font-weight: 500;
	font-size: 20px;
}
.footer-btn-01{
	background-color: var(--color-yel);
	color:var(--color-nvy);
}
.footer-btn-02{
	background-color: #fff;
	color:var(--color-nvy);
}

.footer-address{
	background-color: #fff;
	padding-top: 20px;
	padding-bottom: 20px;
}
.address-wrap{
	display: flex;
	flex-direction: row;
	justify-content: center;
	align-items: flex-start;
}
.address-wrap dl,
.copyright{
	font-size: 14px;
	line-height: 1.2;
}

.footer-logo{
	width: 220px;
	margin-right: 20px;
}
.copyright{
	color: #fff;
	text-align: center;
	margin-top: 20px;
}

/*タブレット&スマホ*/
@media (max-width: 780px) {

	footer{
		padding-bottom: 3%;
	}
	.footer-btn{
		padding-top: 8%;
		padding-bottom: 8%;
	}
	.footer-btn-wrap .cv-btn{
		text-align: center;
		width: 48%;
		height: 80px;
		font-size: 4.2vw;
	}
	.footer-address{
		padding-top: 5%;
		padding-bottom: 5%;
	}
	.address-wrap{
		flex-direction: column;
		align-items: center;
	}
	.address-wrap dl,
	.copyright{
	font-size: 3.2vw;
}
.address-wrap dl{
	text-align: center;
}
.footer-logo{
	width: 50%;
	max-width: 220px;
	margin-right: 0;
	margin-bottom:  4%;
}
.copyright{
	margin-top: 3%;
}
}