@charset "utf-8";
/* CSS Document */
/*---------------------------------------------------------------------
	フロントページfront-page.php　専用
---------------------------------------------------------------------*/

/*---------------------------------------------------------------------
	見出し部分
---------------------------------------------------------------------*/
h2,
h3,
h4{
	font-optical-sizing: auto;
	font-weight: 700;
	font-style: normal;
	line-height: 1.5;
}
h2 span{
	font-family: "Montserrat", sans-serif;
	font-optical-sizing: auto;
	font-weight: 700;
	font-style: normal;
}
/* 見出し２ */
.el_headLv2{
	margin-bottom: 2.5vw;
	font-size: clamp(38px,3.25vw,60px);
}
.el_headLv2 span{
	display: flex;
	align-items: center;
	font-size: clamp(14px,1vw,18px);
}
.el_headLv2 span svg{
	margin-right: 10px;
	width: 6px;
	fill:#1A1311;
}
.el_headLv2.hp_fcWhite span svg{
	fill:#fff;
}

/*--------------------------------------------------------
	メインビジュアル
--------------------------------------------------------*/
/*メインビジュアルコンテナ*/
.bl_mv {
	position: relative;
	width: 100%;
	height: 100dvh;
}
#bl_mv__slider {
	position: relative;
	width: 100%;
	height: 85dvh !important;
	padding-top: 100px;
}
/*slick変更*/
.slick-slider{
	height: calc(85dvh - 100px);
	width: 100%;
}
.slick-list{
	height: 100%;
}
.slick-slide img{
	height: calc(85dvh - 100px);
}
#bl_mv__slider ul li {
	display: block;
	height: 100% !important;
	width: auto !important;
	margin: 0 1.15vw;
}
/*キャッチコピー*/
.bl_mv__catchL,
.bl_mv__catchR{
	position: absolute;
	bottom:3%;
	font-size: max(42px,6.75vw);
	line-height: 1;
	font-weight: 900;
}
.bl_mv__catchL{
	left: 20px;
}
.bl_mv__catchR{
	right: max(40px,2vw);
	text-align: right;
}
.bl_mv__catchR span{
	font-size: max(50px,6.25vw);
}
@media (min-width: 950px) {
	.bl_mv__slider{
		padding-top: 100px;
	}
	.bl_mv__catchL{
		left: max(40px,2vw);
	}
	.bl_mv__catchL,
	.bl_mv__catchR{
		font-size: max(40px,4vw);
	}
}

/*--------------------------------------------------------
	スクロールダウン
--------------------------------------------------------*/
.el_scrolldown{
	position: absolute;
	right: 20px;
	bottom:3%;
	display: inline-block;
	padding: 8px;
	font-size: 10px;
	border: 1px solid #1A1311;
	line-height: 1;
	border-radius: 50px;
}
.el_scrolldown svg{
	margin-left: 8px;
	width: 6px;
	fill:#1A1311;
}
.el_scrolldown:hover{
	opacity: 1;
	background: #383889;
	color: #fff;
	border: 1px solid #383889;
}
.el_scrolldown:hover svg{
	fill:#fff;
}
@media (min-width: 950px) {
	.el_scrolldown{
		right: inherit;
		left: 50%;
		font-size: 14px;
		transform: translateX(-50%);
	}
	.el_scrolldown svg{
		margin-left: 20px;
	}
}


/*--------------------------------------------------------
	コンテナ
--------------------------------------------------------*/
.bl_cont,
.bl_cont__box{
	width: 100%;
}
.bl_cont__box.SS,
.bl_cont__box.S,
.bl_cont__box.M,
.bl_cont__box.L{
	width: 100%;
	margin: 0 auto;
	padding: max(80px,10vw) max(20px,4vw);
}
/* 3カラムカード */
.bl_card{
	display: block;
	margin: 0 auto;
}
.bl_cardCont{
	width: 100%;
	border-radius: 20px;
	padding: 1rem max(20px,3vw);
}
.bl_card .bl_cardCont p{
	line-height: 1.6;
	margin-top: .5rem;
}
.bl_cardCont__ttl{
	font-size: clamp(24px,1.15vw,36px);
	font-weight: 500;
	margin-bottom: .5rem;
}
@media (min-width: 768px) {
	/* 3カラムカード */
	.bl_card{
		display: flex;
		justify-content: space-between;
		align-items: stretch;
		flex-wrap: wrap;
	}
	.bl_cardCont__ttl{
		margin-bottom: .5rem;
	}
}
@media (min-width: 950px) {
	.bl_cont__box{
		width: 49vw;
	}
	.bl_cont__box.SS{
		width: 950px;
		margin: 0 auto;
		padding: 5vw;
	}
	.bl_cont__box.S{
		max-width: 1250px;
		width: 90vw;
		margin: 0 auto;
		padding: 8vw 0 0;
	}
	.bl_cont__box.M{
		max-width: 1750px;
		width: 100%;
		margin: 0 auto;
		padding: 8vw clamp(20px,4.25vw,80px) 0;
	}
	.bl_cont__box.L{
		width: 100%;
		max-width: inherit;
		margin: 0 auto;
		padding: 8vw 20px 0;
	}
	.bl_cardCont{
		width: 31%;
		padding: 2.5vw 2vw;
	}
}



/*--------------------------------------------------------
	TOPページ
	　・お知らせ
--------------------------------------------------------*/
#info .bl_cont__box.M{
	padding-bottom: max(80px,10vw);
}
#info .bl_flexCol{
	justify-content: space-between;
}
#info .el_headLv2{
	min-width: 15vw;
	margin-bottom: 0;
}
.bl_info{
	width:auto;
	margin: .875rem auto 0;
}
.bl_info li a{
	display: block;
	align-items: center;
	margin: .25rem 0;
}
.bl_info li span{
	display: inline-block;
	margin-right: 1rem;
	font-family: "Montserrat", sans-serif;
	font-optical-sizing: auto;
	font-weight: 700;
	font-style: normal;
	color: #383889;
}
@media (min-width: 950px) {
	.bl_info{
		margin: 0 auto 0 1.5rem;
	}
	.bl_info li a{
		display: flex;
	}
}

/*--------------------------------------------------------
	TOPページ
	　・マルチビジョンって？
--------------------------------------------------------*/
#about{
	position: relative;
	width: 100%;
	margin: 0 auto;
	text-align: center;
}
#about .bl_cont__box.L{
	padding-top: 10vw;
}
.el_about-tl{
	position: absolute;
	top: 0;
	left: 20px;
	width: max(270px,24vw);
	border-radius: 1.5vw;
	z-index: -1;
}
.el_about-tr{
	position: absolute;
	top: 20%;
	right: 3%;
	width: max(240px,24vw);
	border-radius: 1.5vw;
	z-index: -1;
}
.el_about-bl{
	position: absolute;
	bottom: 15%;
	left: 5%;
	width: max(200px,20vw);
	border-radius: 1.5vw;
	z-index: -1;
}
.el_about-br{
	position: absolute;
	bottom: 0;
	right: 0;
	width: max(280px,28vw);
	border-radius: 1.5vw;
	z-index: -1;
}
#about .el_headLv2 {
	position:relative;
	width: fit-content;
	margin:  0 auto 2.5vw;
}
#about .el_headLv2::before {
	content: "";
	position: absolute;
	top:-70%;
	left:-60%;
	background:url("../img/img_aboutTtl.png")top/ contain no-repeat;
	width: 150%;
	height: 150%;
	z-index: -1;
}
#about .el_headLv2 span{
	justify-content: center;
}
#about .bl_card{
	max-width: 1250px;
	padding: 0 1rem;
}
#about .bl_cardCont{
	background: rgba(247,245,239,.8);
}
#about .bl_cardCont img{
	width: 65%;
}

@media (max-width: 949px) {
	#about .bl_card{
		max-width: 100%;
		padding: 2rem;
	}
	#about .bl_cardCont{
		width: 100%;
		display: flex;
		justify-content: space-between;
		align-items: center;
		margin-bottom: 1.5rem;
	}
	#about .bl_cardCont img{
		width: 35%;
		height: 100%;
		margin: 0;
	}
	#about .bl_cardCont>div {
		width: 60%;
		text-align: left;
	}
	#about{
		background: rgba(255,255,255,.7);
	}
}
@media (max-width: 650px) {
	#about .bl_card{
		padding: 0;
	}
}


/*--------------------------------------------------------
	TOPページ
	　クラスについて
--------------------------------------------------------*/
#class.bl_cont{
	background: #F7F5EF;
	border-radius: clamp(20px,2.65vw,50px);
}
#class .bl_cont__box.M{
	padding-bottom: 10vw;
}
#class .bl_flexCol .L,
#class .bl_flexCol .R{
	width: 100%;
}
@media (min-width: 950px) {
	#class .bl_flexCol .L{
		width: 40%;
		margin-right: 5rem;
	}
	#class .bl_flexCol .R{
		width: 60%;
	}
}
/*--------------------------------------------------------
	TOPページ
	　・1日の流れ
--------------------------------------------------------*/
#schedule {
	display: block;
	margin: 20px auto;
	width: 100%;
	background: url("../img/img_top__schedule.jpg")center / cover no-repeat;
	height: 100%;
	border-radius: clamp(20px,2.65vw,50px);
	padding: 6vw 0;
}
#schedule .bl_cont__box.SS{
	background: rgba(255,255,255,.8);
	border-radius: clamp(20px,2.65vw,50px);
}
#schedule .el_headLv2 span{
	justify-content: center;
}
.bl_flow{
	display: block;
	padding-bottom: 1.25rem;
	position: relative;
	width: 100%;
	margin-bottom: 1.25rem;
}
.bl_flow:before {
	content: "";
	width: 1px;
	height: 75px;
	background: #1A1311;
	display: block;
	position: absolute;
	left: 0.375rem;
	top: 1.5rem;
}
.bl_flow.un_noLine:before {
	height: 0;
}
.bl_flow:after {
	content: "";
	height: 1px;
	width: calc(100% - 1.875rem);
	display: block;
	margin: 0 0 0 auto;
	border-bottom: 1px dashed #888;
	position: absolute;
	bottom: 0;
	right: 0;
}
.bl_flow dt:before {
	content: "";
	width: 13px;
	height: 13px;
	border-radius: 50%;
	display: block;
	background: #1A1311;
	top: 12px;
	left: 0;
	position: absolute;
}
.bl_flow dt {
	font-size: 1.25rem;
	font-weight: 700;
	width: 170px;
	padding-left: 2rem;
	position: relative;
	line-height: 1.7;
}
.bl_flow dd {
	width: calc(100% - 170px);
}
.bl_flow dd .el_headLv3{
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 1.7;
	text-align: left;
}
@media (max-width: 1280px) {
	.bl_cont__box.SS{
		width: 88%;
	}
}
@media (max-width: 768px) {
	.bl_flow dd{
		width: 100%;
		padding-left: 2rem;
	}
	.bl_flow:before{
		height: 90px;
	}
	.bl_flow dd .el_headLv3{
		font-size: 14px;
		line-height: 1.3;
	}
}
@media (max-width: 650px) {
	.bl_cont__box.SS{
		width: 100%;
	}
	#schedule{
		padding: 0;
	}
}
@media (min-width: 768px) {
	#schedule {
		margin: 20px auto 0;
		width: calc(100% - 40px);
	}
	.bl_flow{
		display: flex;
	}
}


/*--------------------------------------------------------
	TOPページ
	　・利用者様の声、よくある質問コンテナ
--------------------------------------------------------*/
.bl_comm-faq{
	width: 100%;
	display: block;
}
@media (min-width: 1280px) {
	.bl_comm-faq{
		display: flex;
		align-items: stretch;
		max-height: 750px;
	}
}


/*--------------------------------------------------------
	TOPページ
	　・利用者様の声
--------------------------------------------------------*/
#comments{
	position: relative;
	display:inline-block;
	background: #ED6B03;
	border-radius: clamp(20px,2.65vw,50px);
	width: calc(100% - 40px);
	margin: 20px;
	padding: max(30px,2vw);
}
#comments>.bl_flexCol{
	justify-content: space-between;
	align-items: flex-start;
	height: 100%;
}
.bl_commentsTxt{
	width: 100%;
	margin-bottom: 2rem;
}
.bl_commentsTxt .el_headLv2{
	margin-bottom: 0;
}
.bl_commentsList{
	width: 100%;
	height: 65dvh;
	box-sizing: border-box;
	padding: max(20px,1.75vw);
	background: #fff;
	border-radius: 30px;
	/* 縦方向のスクロールバーを表示 */
	overflow-y: auto;
	/* IE などのスクロールバーの色設定 */
	scrollbar-face-color: #999;
	scrollbar-track-color: #eee;
	/* スマホ用の慣性スクロール */
	-webkit-overflow-scrolling: touch;
}
.bl_commentsList::-webkit-scrollbar {
	width: 15px;
}
.bl_commentsList::-webkit-scrollbar-thumb {
	background: #999;
	border-radius: 10px;
	height: 40px;
}
.bl_commentsList::-webkit-scrollbar-track {
	background: #dcdcdc;
	border-radius: 10px;
}

/* 各人の声コンテナ*/
.bl_commentsList__box {
	display: flex;
	-moz-column-gap: 2rem;
	column-gap: 2rem;
	margin-bottom: 3rem;
}
.bl_commentsList__box:last-child {
	margin-bottom: 0;
}
.bl_commentsList__box:nth-child(even) {
	flex-direction: row-reverse;
}
.bl_commentsList__box .el_icon {
	flex-shrink: 0;
	width: 6rem;
	height: 6rem;
	border-radius: 50%;
}
.bl_commentsList__box .el_txt p {
	margin-top: .5rem;
	position: relative;
	line-height: 1.4;
	background: #E5E4DE;
	padding: 1rem 1.5rem;
	border-radius: 10px;
}
.bl_commentsList__box .el_txt p::before {
	content: "";
	width: 2rem;
	height: 3rem;
	display: block;
	position: absolute;
	top: .5rem;
	background-image: url("../img/img_top__commentsTxt.png");
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
}
.bl_commentsList__box:nth-child(odd) .el_txt p::before {
	left: -1.25rem;
}
.bl_commentsList__box:nth-child(even) .el_txt p::before {
	right: -1.29rem;
	scale: -1 1;
}
#comments .bl_commentsTxt img{
	display: none;
}

@media (min-width: 950px) {
	.bl_commentsList{
		height: 80dvh;
		max-height: 608px;
	}
	.bl_commentsTxt{
		width: 40%;
		margin-bottom: 0;
		margin-right: 2rem;
	}
	#comments .bl_commentsTxt img{
		position: absolute;
		bottom: 1.5vw;
		width: 25%;
		display: block;
	}
}
@media (min-width: 1280px) {
	#comments{
		width: 65%;
		flex-grow: 1;
		height: 100%;
	}
	.bl_commentsContainer{
		display: flex;
		flex-direction: column;
		width: 60%;
	}
}
@media (max-width: 650px) {
	.bl_commentsList__box .el_icon {
		width: 2.5rem;
		height: 2.5rem;
	}
	.bl_commentsList__box {
		-moz-column-gap: .75rem;
		column-gap: .75rem;
		margin-bottom: 2rem;
	}
}

/*--------------------------------------------------------
	TOPページ
	　・よくある質問
--------------------------------------------------------*/
#faq{
	margin: 20px;
	display:inline-block;
	width: calc(100% - 40px);
	background: #66B6E4;
	border-radius: clamp(20px,2.65vw,50px);
	padding: max(30px,2vw);
}
.bl_faq li p{
	display: flex;
	align-items: center;
	background: #fff;
	border-radius: 20px;
	padding: 1rem 2rem;
	margin-bottom: .5rem;
	line-height: 1.3;
}
.bl_faq li span{
	display: inline-block;
	margin-right: 1rem;
	font-size: clamp(24px,2vw,40px);
	font-weight: 700;
	color: #66B6E4;
}
@media (min-width: 1280px) {
	#faq{
		width: 35%;
		margin: 20px 20px 20px 0;
	}
}


/*--------------------------------------------------------
	TOPページ
	　・採用情報
--------------------------------------------------------*/
#recruit{
	position: relative;
	width: 100%;
	height: 45vw;
	min-height: 77dvh;
	max-height: 1080px;
	background: #383889;
}
#recruit::before {
	content: "";
	position: absolute;
	top:10%;
	right:0;
	background:url("../img/img_top__recruit.png")top/ contain no-repeat;
	width: 85vw;
	height: 100%;
	z-index: 0;
}
#recruit .bl_cont__box{
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: 3;
	width: 100%;
	padding: 20vw 4.5vw 6vw;
}
#recruit .bl_cont__box p{
	font-size: 28px;
	line-height: 1.6;
	font-weight: 700;
}