@charset "UTF-8";

main {
	position: relative;
}

/*------イメージ-----*/

.mv {
	position: relative;
	padding-top: 150px;
	overflow: hidden;
}
.video_wrap {
	background: #dff2fa;
	width: 100%;
	height: 100vh;
	position: fixed;
	z-index: -1;
	top: 0;
	left: 0;
}
.video {
	width: 100%;
	height: 100vh;
	background: url(../img/common/bg.png) no-repeat center/cover;
	overflow: hidden;
	opacity: 0.75;
	position: relative;
}
.video video {
  min-width: 100%;
  min-height: 100%;
  width: auto;
  height: auto;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
}

.scroll_down {
	position: fixed;
	right: 50px;
	bottom: 15%;
	width: 140px;
	height: 140px;
	border-radius: 50%;
	background-image: linear-gradient(90deg, #5D3483 0%, #7AAFFF 100%);
	transition: all 0.6s ease;
	z-index: 99;
	display: flex;
	justify-content: center;
	align-items: center;
}
.scroll_down .txt {
	width: 124px;
	animation: 16s linear infinite rotation;
}
.scroll_down .arrow {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%,-50%);
}
.scroll_down.showIn {
	opacity: 0;
	visibility: hidden;
}
@keyframes rotation {
	0% { transform: rotateZ(0);}
	100% { transform: rotateZ(360deg); }
}

.sec_intro .lead {
	font-size: 64px;
	line-height: 1.7;
	position: relative;
	left: 10%;
	margin-bottom: 150px;
}

@media screen and (max-width: 1365px){
	
	.sec_intro .lead {
		font-size: 4.68vw;
		margin-bottom: 10vw;
	}

}


@media screen and (max-width: 999px){
	
	.mv {
		padding-top: 90px;
	}
	
	
	
}

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

	.sec_intro .lead {
		font-size: 6vw;
		left: 5%;
	}
	
	.scroll_down {
		right: 20px;
		bottom: auto;
		top: 55vw;
		width: 70px;
		height: 70px;
	}
	.scroll_down .txt {
		width: 60px;
		animation: 16s linear infinite rotation;
	}
	.scroll_down .arrow {
		width: 11px;
	}
	
}


.swiper-container2 {
	position: absolute;
	width: 100%;
	top: 400px;
	overflow: hidden;
	z-index: 999;
}
.swiper-container2 .swiper-wrapper, .swiper-container2 .swiper-slide {
	width: 100%;
}
.swiper-container2 .swiper-wrapper {
	transition-timing-function: linear;
}
.swiper-container2 .swiper-slide {
	font-size: 9vw;
	background-image: linear-gradient(90deg, #C9F5FF 0%, #DDB1FD 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	white-space: nowrap;
	width: 95% !important;
}
.swiper-container2 .swiper-slide img {
	width: 100% !important;
	opacity: 0.4;
}
@media screen and (max-width: 1365px){
	
	.swiper-container2 {
		top: 35vw;
	}

}

@media screen and (max-width: 999px){
	
	.swiper-container2 {
		top: 30vw;
	}
	
}

@media screen and (max-width: 767px){
	
	.swiper-container2 {
		top: 40vw;
	}
	.swiper-container2 .swiper-slide {
		font-size: 12vw;
	}
	
}

.swiperr {
    width: 100%;
	margin-bottom: 120px;
}
.swiperr .swiper-slide {
	width: 100%;
    opacity: 0.6;
    overflow: hidden;
    transition: .7s;
	padding: 0 2vw;
}
.swiperr .swiper-slide img {
    width: 100% !important;
	height: auto !important;
}

.swiperr .swiper-slide-active {
    opacity: 1;
    z-index: 1;
    transform: scale(1.3) !important;
}


@media screen and (max-width: 1365px){
	
	.swiperr {
		margin-bottom: 8.78vw;
	}
	
}

@media screen and (max-width: 767px){
	
	.swiperr .swiper-slide {
		padding: 0 0vw;
	}
	
}


/*------ビジョン-----*/

.sec_vision {
	padding: 0 50px;
}
.sec_vision .inner {
	max-width: 1200px;
	margin: 0 auto;
	padding: 100px 0;
}
.sec_vision .lead {
	font-size: 48px;
	line-height: 1.7;
	margin-bottom: 45px;
	letter-spacing: 0.1em;
}
.sec_vision .honbun {
	line-height: 2;
	font-size: 18px;
	margin-bottom: 40px;
	max-width: 500px;
	margin-right: auto;
}

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

	.sec_vision {
		padding: 0 50px;
	}
	.sec_vision .inner {
		padding: 50px 0;
	}
	.sec_vision .lead {
		font-size: 30px;
		margin-bottom: 30px;
	}
	.sec_vision .honbun {
		font-size: 16px;
		margin-bottom: 30px;
		max-width: 500px;
	}
	
}


@media screen and (max-width: 767px){
	
	.sec_vision {
		padding: 0 30px;
	}
	.sec_vision .inner {
		max-width: 400px;
		padding: 50px 0;
		margin: 0 auto;
	}
	.sec_vision .lead {
		font-size: 22px;
		margin-bottom: 25px;
	}
	.sec_vision .honbun {
		font-size: 14px;
		margin-bottom: 25px;
	}
	
}



/*------中間イメージ-----*/

.img_home_mid {
	height: 600px;
	width: 100%;
	background: url("../img/home/P=ver002_img_home_mid.jpg") no-repeat 50% 50%;
	background-size: cover;
}

@media screen and (max-width: 999px){
	
	.img_home_mid {
		height: 40vw;
	}
	
}

@media screen and (max-width: 639px){
	
	.img_home_mid {
		height: 60vw;
	}
	
}

/*------各事業-----*/

.home_biz_wrap {
	background-color: #fff;
	padding-top: 1px;
	padding-bottom: 120px;
}
.sec_home_biz {
	margin: 150px 0 120px;
	padding: 80px 50px;
	position: relative;
	z-index: 1;
}
.sec_home_biz .inner {
	max-width: 1200px;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
	align-items: center;
	position: relative;
}
.sec_home_biz .inner .img {
	width: 48%;
}
.sec_home_biz .inner .img img {
	width: 100%;
}
.sec_home_biz .inner .txt {
	width: 45%;
	color: #fff;
}
.sec_home_school .inner .txt {
	order: 1;
}

.sec_home_biz::after {
	content: '';
	display: block;
	width: calc( 100% - ( ( 100% - 1120px ) / 2 ) );
	height: 100%;
	position: absolute;
	top: 0;
	z-index: -1;
}
.sec_home_school::after {
	background: url("../img/home/bg_school.jpg") no-repeat 50% 50%;
	background-size: cover;
	right: 0;
}
.sec_home_corp::after {
	background: url("../img/home/bg_corp.jpg") no-repeat 50% 50%;
	background-size: cover;
	left: 0;
}
.sec_home_school_after, .sec_home_corp_after {
	display: inline-block;
	position: absolute;
	top: -145px;
	font-size: 80px;
	font-family: "Junge", cursive !important;
	font-weight: 400;
	font-style: normal;
	opacity: 0.8 !important;
	white-space: nowrap;
	z-index: -2;
}
.sec_home_school_after {
	right: 0;
	background-image: linear-gradient(90deg, #5D3483 0%, #817FF4 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	text-shadow: 0px 4px 4px rgb(255 255 255 / 33%), 0 0 rgb(0 0 0 / 6%);
}
.sec_home_corp_after {
	left: 0;
	background-image: linear-gradient(90deg, #072D8E 0%, #006BCE 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	text-shadow: 0px 4px 4px rgb(255 255 255 / 33%), 0 0 rgb(0 0 0 / 6%);
}

.sec_home_biz h2 {
	font-size: 24px;
	margin-bottom: 30px;
	display: inline-block;
}
.sec_home_biz h2::after {
	content: '';
	display: block;
	width: 100%;
	height: 1px;
	background: #fff;
	margin-top: 5px;
}
.sec_home_biz .lead {
	font-size: 32px;
	line-height: 1.7;
	margin-bottom: 30px;
}
.sec_home_biz .honbun {
	font-size: 15px;
	line-height: 1.7;
	margin-bottom: 30px;
}
.sec_home_biz .btn_more {
	border: 1px solid #fff;
	background: none !important;
	box-shadow: none;
}
.sec_home_biz .btn_more::before {
	background-image: none !important;
	background-color: rgba(255,255,255,1);
}
.sec_home_biz .btn_more:hover {
	color: #5D3483;
}
.sec_home_corp .btn_more:hover {
	color: #072d8e !important;
}
.sec_home_biz .btn_more:hover::after {
	background: url("../img/common/arrow_pp.png") no-repeat 50% 50%;
	background-size: cover;
}
.sec_home_corp .btn_more:hover::after {
	background: url("../img/common/arrow_bl.png") no-repeat 50% 50%;
	background-size: cover;
}
@media screen and (max-width: 999px){

	.home_biz_wrap {
		padding-bottom: 60px;
	}
	.sec_home_biz {
		margin: 120px 0 100px;
		padding: 60px 40px;
	}
	.sec_home_school {
		padding-left: 0;
	}
	.sec_home_corp {
		padding-right: 0;
	}
	.sec_home_biz .inner .img {
		width: 45%;
	}
	.sec_home_biz .inner .txt {
		width: 50%;
	}
	.sec_home_biz::after {
		width: 100%;
	}
	.sec_home_school_after, .sec_home_corp_after {
		top: -110px;
		font-size: 60px;
	}
	.sec_home_biz h2 {
		font-size: 20px;
		margin-bottom: 25px;
	}
	.sec_home_biz .lead {
		font-size: 24px;
		margin-bottom: 30px;
	}
	.sec_home_biz .honbun {
		font-size: 14px;
		margin-bottom: 25px;
	}

}


@media screen and (max-width: 767px){
	
	.home_biz_wrap {
		padding-bottom: 40px;
	}
	.sec_home_biz {
		margin: 80px 0 40px;
		padding: 50px 20px;
	}
	.sec_home_biz .inner {
		max-width: 400px;
		display: block;
	}
	.sec_home_biz .inner .img {
		width: 100%;
	}
	.sec_home_biz .inner .txt {
		width: 100%;
		margin-bottom: 30px;
	}
	.sec_home_school_after,.sec_home_corp_after {
		width: calc( 100% + 40px );
	}
	.sec_home_school_after {
		top: -84px;
		left: 0px;
		font-size: 40px;
	}
	.sec_home_corp_after {
		right: auto;
		left: 0px;
		top: -84px;
		font-size: 40px;
	}
	.sec_home_biz h2 {
		font-size: 18px;
		margin-bottom: 20px;
	}
	.sec_home_biz .lead {
		font-size: 24px;
		margin-bottom: 20px;
	}
	.sec_home_biz .honbun {
		font-size: 14px;
		margin-bottom: 25px;
	}
	
	
}

/*------リクルート-----*/

.sec_home_recruit {
	padding: 150px 0px 0;
	position: relative;
	background-color: #f6f8fa;
	z-index: 1;
}
.sec_home_recruit::after {
	content: '';
	display: block;
	width: 100%;
	height: 90%;
	background: url("../img/home/bg_recruit.jpg") no-repeat 50% 50%;
	background-size: cover;
	position: absolute;
	left: 0;
	top: 0;
	z-index: -1;
}
.sec_home_recruit .inner {
	max-width: 1300px;
	margin: 0 auto 50px;
	display: flex;
	padding: 0 50px;
	justify-content: space-between;
}
.sec_home_recruit .home_ttl {
	margin-bottom: 40px;
}
.sec_home_recruit .home_ttl .en {
	background: none;
	color: #fff;
	opacity: 0.4;
	-webkit-text-fill-color: currentcolor;
}
.sec_home_recruit .home_ttl .jp {
	background: none;
	color: #fff;
	-webkit-text-fill-color: currentcolor;
}
.sec_home_recruit .home_ttl .jp::after {
	background: #fff;
}
.sec_home_recruit .lead {
	font-size: 40px;
	line-height: 1.7;
	color: #fff;
}
.sec_home_recruit .btn_more {
	border: 1px solid #fff;
	background: none !important;
	box-shadow: none;
}
.sec_home_recruit .btn_more::before {
	background-image: none !important;
	background-color: rgba(255,255,255,1) !important;
}
.sec_home_recruit .btn_more:hover {
	color: #5D3483;
}
.sec_home_recruit .btn_more:hover::after {
	background: url("../img/common/arrow_pp.png") no-repeat 50% 50%;
	background-size: cover;
}

.swiper-container3 {
	overflow: hidden;
	margin: 0 0px;
}
.swiper-container3 .swiper-wrapper, .swiper-container3 .swiper-slide {
	width: 100%;
	height: 100%;
}
.swiper-container3 .swiper-wrapper {
	transition-timing-function: linear;
}
.swiper-container3 .swiper-slide {
	width: fit-content;
	height: 480px;
}
.swiper-container3 .swiper-slide img {
	height: 100%;
}


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

	.sec_home_recruit {
		padding: 100px 0px 0;
	}
	.sec_home_recruit .inner {
		margin: 0 auto 40px;
	}
	.sec_home_recruit .home_ttl {
		margin-bottom: 30px;
	}
	.sec_home_recruit .lead {
		font-size: 30px;
	}

	.swiper-container3 .swiper-slide {
		height: 360px;
	}
	
}


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

	.sec_home_recruit {
		padding: 80px 0px 0;
	}
	.sec_home_recruit::after {
		height: 90%;
	}
	.sec_home_recruit .inner {
		max-width: 440px;
		margin: 0 auto 40px;
		padding: 0 20px;
		display: block;
	}
	.sec_home_recruit .home_ttl {
		margin-bottom: 30px;
	}
	.sec_home_recruit .lead {
		font-size: 30px;
		margin-bottom: 30px;
	}
	
	.swiper-container3 {
		margin: 0 -20px;
	}
	.swiper-container3 .swiper-slide {
		height: 70vw;
		max-height: 360px;
	}

}


/*------店舗情報-----*/

.sec_home_shop {
	padding: 150px 50px 100px;
	background-color: #f6f8fa;
}
.sec_home_shop .inner {
	max-width: 1200px;
	margin: 0 auto;
}
.sec_home_shop .home_ttl .en {
	opacity: 0.8;
}
.shoplist_wrap {
	display: flex;
	justify-content: space-between;
	width: 100%;
}
.shoplist_wrap > div {
	width: 48%;
	transition: all 0.3s ease;
	box-shadow: 10px 10px 20px rgba(0,0,0,0);
}
.shoplist_wrap > div:hover {
	box-shadow: 10px 10px 20px rgba(0,0,0,0.1);
}
.shoplist_wrap > div a {
	background-color: #fff;
	display: flex;
	justify-content: space-between;
	padding: 40px;
	color: #13384D;
	text-decoration: none;

}
.shoplist_wrap > div a:hover {

}
.shoplist_wrap .img {
	width: 160px;
	order: -1;
}
.shoplist_wrap .img img {
	width: 100%;
}
.shoplist_wrap .txt {
	width: calc( 100% - 200px );
}
.shoplist_wrap h3 {
	font-size: 24px;
	color: #5D3483;
	margin-bottom: 1.3em;
}
.shoplist_wrap .address {
	margin-bottom: 1.3em;
	font-size: 16px;
	line-height: 1.5;
}
.shoplist_wrap ul {
	margin-left: 2em;
}
.shoplist_wrap li {
	margin-bottom: 1em;
	font-size: 15px;
	line-height: 1.8;
	text-indent: -1em;
}
.shoplist_wrap li:last-child {
	margin-bottom: 0;
}

.shoplist_wrap .tel::before {
	content: '';
	display: inline-block;
	width: 20px;
	height: 20px;
	background: url("../img/common/icon_tel.png") no-repeat 50% 50%;
	background-size: cover;
	vertical-align: -4px;
	position: relative;
	left: -1em;
}
.shoplist_wrap .time::before {
	content: '';
	display: inline-block;
	width: 20px;
	height: 20px;
	background: url("../img/common/icon_clock.png") no-repeat 50% 50%;
	background-size: cover;
	vertical-align: -4px;
	position: relative;
	left: -1em;
}


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

	.sec_home_shop {
		padding: 130px 50px 80px;
	}
	.shoplist_wrap > div a {
		padding: 25px;
	}
	.shoplist_wrap .img {
		width: 80px;
	}
	.shoplist_wrap .txt {
		width: calc( 100% - 110px );
	}
	.shoplist_wrap h3 {
		font-size: 20px;
	}
	.shoplist_wrap .address {
		font-size: 14px;
	}
	.shoplist_wrap li {
		font-size: 14px;
	}
	.shoplist_wrap .tel::before {
		width: 18px;
		height: 18px;
		vertical-align: -4px;
	}
	.shoplist_wrap .time::before {
		width: 18px;
		height: 18px;
		vertical-align: -4px;
	}
	
}


@media screen and (max-width: 767px){
	
	.sec_home_shop {
		padding: 80px 20px 40px;
	}
	.sec_home_shop .inner {
		max-width: 400px;
	}
	.shoplist_wrap {
		display: block;
	}
	.shoplist_wrap > div {
		width: 100%;
	}
	.shoplist_wrap > div a {
		background-color: #fff;
		display: block;
		padding: 30px;
	}
	.shoplist_wrap > div:first-of-type {
		margin-bottom: 20px;
	}
	.shoplist_wrap .img {
		width: 100%;
		margin-bottom: 25px;
	}
	.shoplist_wrap .txt {
		width: 100%;
	}
	.shoplist_wrap h3 {
		font-size: 20px;
	}
	.shoplist_wrap .address {
		margin-bottom: 1.3em;
		font-size: 14px;
	}
	.shoplist_wrap li {
		font-size: 14px;
	}

}

/*------ニュース-----*/

.sec_home_news {
	padding: 100px 50px 100px;
	background-color: #fff;
}
.sec_home_news .inner {
	max-width: 1200px;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
}
.sec_home_news .ttl {
	width: 300px;
	padding-top: 100px;
}
.sec_home_news .home_ttl .en {
	opacity: 0.8;
}
.sec_home_news .list {
	width: calc( 100% - 350px );
}
.ul_newslist li {
	position: relative;
}
.ul_newslist li::before {
	position: absolute;
	bottom: 0;
	left: 0;
	content: '';
	display: inline-block;
	width: 100%;
	height: 1px;
	background: #dedede;
	transition: all 0.3s ease;
}
.ul_newslist li a {
	display: block;
	padding: 25px 70px 25px 0;
	color: #13384D;
	text-decoration: none;
	position: relative;
}
.ul_newslist li a::before {
	position: absolute;
	bottom: 0;
	left: 0;
	content: '';
	display: inline-block;
	width: 100%;
	height: 1px;
	background: linear-gradient(90deg, #5D3483 0%, #817FF4 100%);
	transition: all 0.3s ease;
	opacity: 0;
}
.ul_newslist li a::after {
	content: '';
	display: inline-block;
	position: absolute;
	right: 0;
	top: 50%;
	width: 26px;
	height: 8px;
	background: url("../img/common/arrow_pp.png") no-repeat 50% 50%;
	background-size: cover;
}
.ul_newslist .meta {
	margin-bottom: 20px;
	display: flex;
	align-items: center;
}
.ul_newslist .date {
	font-size: 14px;
	margin-right: 20px;
	color: #5D3483;
}
.ul_newslist span {
	border: 1px solid #5D3483;
	display: flex;
	justify-content: center;
	align-items: center;
	height: 24px;
	padding: 0 8px;
	font-size: 13px;
	min-width: 100px;
	color: #5D3483;
}
.ul_newslist .link {
	line-height: 1.7;
}
.ul_newslist a:hover::before {
	opacity: 1;
}


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

	.sec_home_news {
		padding: 50px 50px 70px;
	}
	.sec_home_news .ttl {
		width: 260px;
		padding-top: 70px;
	}
	.sec_home_news .list {
		width: calc( 100% - 330px );
	}
	
}


@media screen and (max-width: 767px){
	
	.sec_home_news {
		padding: 80px 20px 40px;
	}
	.sec_home_news .inner {
		max-width: 400px;
		display: block;
	}
	.sec_home_news .ttl {
		width: auto;
		padding-top: 0px;
	}
	.sec_home_news .list {
		width: auto;
	}
	.ul_newslist {
		margin-bottom: 30px;
	}
	.ul_newslist li a {
		padding: 20px 0;
	}
	.ul_newslist li a::after {
		display: none;
	}
	.ul_newslist .meta {
		margin-bottom: 15px;
	}
	.ul_newslist .date {
		margin-right: 15px;
	}
	.ul_newslist span {
		height: 22px;
		font-size: 12px;
	}
}