/* common
---------------------------------------------------------- */
#top_page section {
	overflow: hidden;
}
.tit_coming_soon {
	font-size: 25px;
	text-align: center;
	font-weight: normal;
}

/* mv_top
---------------------------------------------------------- */
#mv_top {
	height: 100vh;
}
#mv_top video {
    position: absolute;
    margin: auto;
	width: 100%;
    height: 100vh;
    object-fit: cover;
}
#mv_top .container {
	position: relative;
	height: inherit;
}
#mv_top .btn_wrap_sp {
	display: none;
}
#mv_top .btn_mv {
	position: absolute;
	right: 30px;
	bottom: 40px;
	max-width: 355px;
	width: 100%;
}
#mv_top .btn_mv a {
	position: relative;
	display: block;
	padding: 15px 55px 15px 35px;
	color: #fff;
	font-size: 12px;
	box-sizing: border-box;
	overflow: hidden;
	background-color: rgba(0, 0, 0, .5);
	border-radius: 10px;
	-webkit-border-radius: 10px;
	-moz-border-radius: 10px;
	-ms-border-radius: 10px;
	-o-border-radius: 10px;
}
#mv_top .btn_mv a:hover {
	background-color: #EFC100;
}
#mv_top .btn_mv a > * {
	position: relative;
	z-index: 1;
}
#mv_top .btn_mv a .arrow {
	position: absolute;
	top: 0;
	right: 45px;
	bottom: 0;
	height: 35px;
	width: 35px;
	margin: auto;
	overflow: hidden;
	background: url(../img/common/ico_arrow03.png) no-repeat center / 12px;
}
#mv_top .btn_mv a .arrow::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;
	background: url(../img/common/ico_arrow-hov02.png) no-repeat left -100px center / 12px;
	background-color: #fff;
	border-radius: 50%;
	-webkit-border-radius: 50%;
	-moz-border-radius: 50%;
	-ms-border-radius: 50%;
	-o-border-radius: 50%;
	transform: scale(0);
	-webkit-transform: scale(0);
	-moz-transform: scale(0);
	-ms-transform: scale(0);
	-o-transform: scale(0);
	transition: all .4s cubic-bezier(0.165, 0.84, 0.44, 1);
	-webkit-transition: all .4s cubic-bezier(0.165, 0.84, 0.44, 1);
	-moz-transition: all .4s cubic-bezier(0.165, 0.84, 0.44, 1);
	-ms-transition: all .4s cubic-bezier(0.165, 0.84, 0.44, 1);
	-o-transition: all .4s cubic-bezier(0.165, 0.84, 0.44, 1);
}
#mv_top .btn_mv a:hover .arrow::before {
	background-position: center;
	transform: scale(1);
	-webkit-transform: scale(1);
	-moz-transform: scale(1);
	-ms-transform: scale(1);
	-o-transform: scale(1);
}
#mv_top .btn_mv .btn_tit {
	display: block;
	font-size: 17px;
}

/* business
---------------------------------------------------------- */
#business {
	padding: 115px 0 170px;
}
#business p {
	font-size: 16px;
	text-align: justify;
}
#business .business_links {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 17px 1.7%;
	margin-top: 50px;
}
#business .business_links .links_wrap {
	position: relative;
	max-width: 322px;
	width: 32.2%;
}
#business .business_links .links_wrap::before {
	content: '';
	position: absolute;
	top: 15px;
	right: 15px;
	width: 9px;
	height: 9px;
	background: url(../img/common/ico_arrow04.png) no-repeat center / contain;
	z-index: 999;
}
#business .business_links .links_wrap a {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	gap: 15px;
	min-height: 322px;
	color: #fff;
	z-index: 99;
	overflow: hidden;
}
#business .business_links .links_wrap a .img_wrap {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center;
	transition: all .4s cubic-bezier(0.075, 0.82, 0.165, 1);
	-webkit-transition: all .4s cubic-bezier(0.075, 0.82, 0.165, 1);
	-moz-transition: all .4s cubic-bezier(0.075, 0.82, 0.165, 1);
	-ms-transition: all .4s cubic-bezier(0.075, 0.82, 0.165, 1);
	-o-transition: all .4s cubic-bezier(0.075, 0.82, 0.165, 1);
}
#business .business_links #housing a .img_wrap {
	background-image: url(../img/index/ph_business01.jpg);
}
#business .business_links #restaurant a .img_wrap {
	background-image: url(../img/index/ph_business02.jpg);
}
#business .business_links #travel_stay a .img_wrap {
	background-image: url(../img/index/ph_business03.jpg);
}
#business .business_links #life_support a .img_wrap {
	background-image: url(../img/index/ph_business04.jpg);
}
#business .business_links #business_service a .img_wrap {
	background-image: url(../img/index/ph_business05.jpg);
}
#business .business_links #international a .img_wrap {
	background-image: url(../img/index/ph_business06.jpg);
}
#business .business_links .links_wrap a::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background-color: #000;
	opacity: .45;
	z-index: 9;
	transition: all .4s cubic-bezier(0.075, 0.82, 0.165, 1);
	-webkit-transition: all .4s cubic-bezier(0.075, 0.82, 0.165, 1);
	-moz-transition: all .4s cubic-bezier(0.075, 0.82, 0.165, 1);
	-ms-transition: all .4s cubic-bezier(0.075, 0.82, 0.165, 1);
	-o-transition: all .4s cubic-bezier(0.075, 0.82, 0.165, 1);
}
#business .business_links .links_wrap a span {
	position: relative;
	text-align: center;
	z-index: 10;
}
#business .business_links .links_wrap a .tit_jp {
	font-size: 25px;
	line-height: 1;
}
#business .business_links .links_wrap a .tit_en {
	font-size: 11px;
	text-transform: capitalize;
	line-height: 1.5;
	letter-spacing: 0.5px;
}
#business .business_links .links_wrap a:hover::before {
	opacity: 0;
}
#business .business_links .links_wrap a:hover .img_wrap {
	transform: scale(1.1);
	-webkit-transform: scale(1.1);
	-moz-transform: scale(1.1);
	-ms-transform: scale(1.1);
	-o-transform: scale(1.1);
}

/* recruit
---------------------------------------------------------- */
#recruit {
	padding: 40px 0;
	background-color: #F0F0EC;
}
#recruit .tit_recruit {
	color: #EFC100;
	font-size: 65px;
}
#recruit p {
	text-align: justify;
}
#recruit .slider_recruit {
	margin-left: 10%;
}
#recruit .slider_recruit .slick-list {
	border-radius: 10px;
	-webkit-border-radius: 10px;
	-moz-border-radius: 10px;
	-ms-border-radius: 10px;
	-o-border-radius: 10px;
}
#recruit .slider_recruit li img {
	border-radius: 10px;
	-webkit-border-radius: 10px;
	-moz-border-radius: 10px;
	-ms-border-radius: 10px;
	-o-border-radius: 10px;
}
#recruit .gallery_recruit {
	display: flex;
	gap: 16px;
	width: 100%;
	overflow: hidden;
}
#recruit .gallery_recruit .gallery_wrap {
	display: flex;
	flex-shrink: 0;
	gap: 16px;
	/*animation: gallery-slide 20s linear infinite;
	backface-visibility: hidden;
	will-change: transform;
	transform: translateZ(0);*/
}
#recruit .gallery_recruit .gallery_wrap img {
	width: 400px;
	max-width: 100%;
	border-radius: 10px;
}
@keyframes gallery-slide {
	0% { transform: translateX(0); }
	100% { transform: translateX(-100.8%); }
}

/* media
---------------------------------------------------------- */
#media {
	padding: 40px 0;
	background-color: #FDF9E5;
}
#media .media_wrap {
	display: flex;
	align-items: center;
	margin: auto;
	max-width: 800px;
	width: 100%;
	color: #333;
	background-color: #fff;
	box-shadow: 7px 7px 14px rgba(51, 51, 42, .15);
}
#media .media_wrap .tit_media {
	padding: 33px 20px;
	width: 295px;
	color: #fff;
	font-size: 23px;
	font-weight: 400;
	text-align: center;
	background-color: #333;
	box-sizing: border-box;
}
#media .media_wrap .tit_media span {
	display: inline-block;
	padding-left: 35px;
	background: url(../img/common/ico_media.png) no-repeat left center / 26px;
}
#media .media_wrap .media_content {
	padding: 0 55px 0 30px;
	width: 53%;
	background: url(../img/common/ico_arrow-hov.png) no-repeat right 35px center / 24px;
}
#media .media_wrap:hover {
	box-shadow: none;
}

/* mic_group
---------------------------------------------------------- */
#mic_group {
	margin-bottom: 40px;
}
#mic_group .tit_sub .tit_en {
	text-transform: none;
}
#mic_group .mic_case .mic_pack {
	margin-bottom: 115px;
}
#mic_group .mic_case .mic_pack:last-child {
	margin-bottom: 0;
}
#mic_group .mic_case .mic_pack .mic_img {
	margin: 0 auto 90px;
	max-width: 897px;
	width: 100%;
}
#mic_group .mic_case .mic_pack .mic_links {
	display: flex;
	flex-wrap: wrap;
	gap: 50px 8.9%;
	max-width: 808px;
	margin: 0 auto;
}
#mic_group .mic_case .mic_pack .mic_links .link_wrap {
	max-width: 368px;
	width: 45.545%;
}
#mic_group .mic_case .mic_pack .mic_links .link_wrap a {
	display: block;
	color: #333;
	font-family: 'Noto Sans JP', sans-serif;
	word-break: break-all;
}
#mic_group .mic_case .mic_pack .mic_links .link_wrap a .date {
	display: block;
	letter-spacing: 1px;
}
#mic_group .mic_case .mic_pack .mic_links .link_wrap a .img_wrap {
	position: relative;
}
#mic_group .mic_case .mic_pack .mic_links .link_wrap a .img_wrap::before {
	content: '';
	position: absolute;
	right: 20px;
	bottom: 20px;
	height: 36px;
	width: 36px;
	background: url(../img/common/ico_arrow05.png) no-repeat center / contain;
}
#mic_group .mic_case .mic_pack .mic_logo {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 25px;
	margin-bottom: 50px;
}
#mic_group .mic_case .mic_pack .mic_logo img {
	max-width: 132px;
	width: 100%;
}
#mic_group .mic_case .mic_pack .mic_logo .mic_text h3 {
	font-size: 16px;
	line-height: 1;
}
#mic_group .mic_case .mic_pack .mic_logo .mic_text span {
	display: inline-block;
	padding: 0 10px;
	font-size: 11px;
	text-align: center;
	border: 1px solid #EFC100;
	border-radius: 5px;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	-ms-border-radius: 5px;
	-o-border-radius: 5px;
}
#mic_group .mic_case .mic_pack .list_group {
	margin: auto;
	max-width: 800px;
}
#mic_group .mic_case .mic_pack .list_group ul {
	display: flex;
	flex-wrap: wrap;
	gap: 37px 4.5%;
	margin-bottom: 40px;
}
#mic_group .mic_case .mic_pack .list_group ul li {
	max-width: 242px;
	width: 30.3%;
	box-shadow: 5px 5px 10px rgba(0, 0, 0, .2);
}
#mic_group .btn_wrap{
	display: flex;
	flex-wrap: nowrap;
	gap: 20px;
	justify-content: center;
	margin-bottom: 50px;
}
#mic_group .btn_wrap .btn{
	margin: 0;
}
.banner_wrap .bnr_button{
	width: 200px;
	display: block;
	opacity: 1;
	margin: 0 auto 50px;
	transition: all ease .3s;
}
.banner_wrap .bnr_button:hover{
	opacity: .7;
}
.mic_pack .txt_link{
	text-align: center;
	display: block;
	margin: 0 auto 20px;
	font-size: 18px;
	color: #111;
	font-weight: bold;
}
@media screen and ( max-width : 768px ) {
	/* common
	---------------------------------------------------------- */
	.tit_coming_soon {
		font-size: 160%;
	}

	/* mv_top
	---------------------------------------------------------- */
	#mv_top .btn_mv a {
		padding: 10px 35px 10px 20px;
	}
	#mv_top .btn_mv a .arrow {
		right: 15px;
	}
	#mv_top .btn_mv .btn_tit {
		font-size: 135%;
	}

	/* business
	---------------------------------------------------------- */
	#business {
		padding: 85px 0 140px;
	}
	#business p {
		font-size: 100%;
	}
	#business .business_links {
		gap: 13px 1.7%;
	}
	#business .business_links .links_wrap {
		max-width: none;
		width: 49%;
	}
	#business .business_links .links_wrap a {
		gap: 5px;
		min-height: 280px;
	}
	#business .business_links .links_wrap a .tit_jp {
		font-size: 160%;
	}
	#business .business_links .links_wrap a .tit_en {
		font-size: 75%;
	}

	/* recruit
	---------------------------------------------------------- */
	#recruit .tit_recruit {
		font-size: 360%;
		line-height: 1.4;
	}
	#recruit .gallery_recruit .gallery_wrap img {
		max-width: 300px;
	}
	@keyframes gallery-slide {
		0% { transform: translateX(0); }
		100% { transform: translateX(-100.9%); }
	}

	/* media
	---------------------------------------------------------- */
	#media {
		padding: 30px 0;
	}
	#media .media_wrap .tit_media {
		padding: 20px 10px;
		width: 200px;
		font-size: 120%;
	}
	#media .media_wrap .tit_media span {
		padding-left: 30px;
		background-size: 20px;
	}
	#media .media_wrap .media_content {
		padding: 0 30px 0 15px;
		width: 60%;
		background-position: right 20px center;
	}

	/* mic_group
	---------------------------------------------------------- */
	#mic_group {
		margin-bottom: 30px;
	}
	#mic_group .mic_case .mic_pack {
		margin-bottom: 80px;
	}
	#mic_group .mic_case .mic_pack .mic_img {
		margin-bottom: 70px;
	}
	#mic_group .mic_case .mic_pack .mic_logo {
		flex-direction: column;
		gap: 15px;
	}
	#mic_group .mic_case .mic_pack .mic_logo .mic_text {
		text-align: center;
	}
	#mic_group .mic_case .mic_pack .mic_logo .mic_text h3 {
		margin-bottom: 10px;
	}
}

@media screen and ( max-width : 640px ) {
	/* common
	---------------------------------------------------------- */
	.tit_coming_soon {
		font-size: 150%;
	}

	/* mv_top
	---------------------------------------------------------- */
	#mv_top {
		position: relative;
		height: 80dvh;
	}
	#mv_top video {
		height: 65dvh;
	}
	#mv_top .container {
		display: none;
	}
	#mv_top .btn_wrap_sp {
		position: absolute;
		left: 0;
		right: 0;
		bottom: 0;
		display: flex;
		justify-content: center;
		padding: 20px;
		margin-top: -9px;
		background-color: #EFC100;
	}
	#mv_top .btn_wrap_sp .btn_mv {
		position: relative;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
	}

	/* business
	---------------------------------------------------------- */
	#business {
		padding: 65px 0 100px;
	}
	#business .business_links {
		gap: 12px;
		margin-top: 30px;
	}
	#business .business_links .links_wrap {
		width: 100%;
	}
	#business .business_links .links_wrap a .tit_jp {
		font-size: 140%;
	}

	/* recruit
	---------------------------------------------------------- */
	#recruit .gallery_recruit {
		margin-bottom: 20px;
	}
	#recruit .tit_recruit {
		margin-bottom: 10px;
		font-size: 245%;
	}

	/* media
	---------------------------------------------------------- */
	#media .media_wrap {
		display: block;
	}
	#media .media_wrap .tit_media {
		padding: 20px;
		width: 100%;
		font-size: 110%;
		text-align: left;
		background: url(../img/common/ico_arrow03.png) no-repeat right 20px center / 12px;
		background-color: #333;
	}
	#media .media_wrap .tit_media span {
		padding-left: 25px;
		background-size: 15px;
	}
	#media .media_wrap .media_content {
		padding: 15px 20px;
		width: 100%;
		background-image: none;
		box-sizing: border-box;
	}
	#media .media_wrap .media_content p br {
		display: none;
	}

	/* mic_group
	---------------------------------------------------------- */
	#mic_group {
		margin-bottom: 0;
	}
	#mic_group .mic_case .mic_pack {
		margin-bottom: 60px;
	}
	#mic_group .mic_case .mic_pack .mic_img {
		margin-bottom: 50px;
	}
	#mic_group .mic_case .mic_pack .mic_links {
		gap: 30px;
	}
	#mic_group .mic_case .mic_pack .mic_links .link_wrap {
		max-width: none;
		width: 100%;
	}
	#mic_group .mic_case .mic_pack .mic_links .link_wrap a .img_wrap::before {
		right: 15px;
		bottom: 15px;
		height: 28px;
		width: 28px;
	}
	#mic_group .mic_case .mic_pack .list_group ul {
		gap: 25px 4%;
	}
	#mic_group .mic_case .mic_pack .list_group ul li {
		max-width: none;
		width: 48%;
	}
}
@media screen and ( max-width : 480px ) {
	#mic_group .btn_wrap{
		flex-wrap: wrap;
	}
}