@charset "utf-8";
/* home
-------------------------------------------------------------------*/
body.home section{
	position: relative;
	z-index: 0;
}
body .home_tll{
	display:flex;
	flex-direction:column-reverse;
	margin-bottom: 3em;
	gap: 0.875em;
}
body .home_tll h2{
	font-size: 1.125rem;
	font-weight: 500;
}
body .home_tll [lang="en"]{
	color:var(--keycolor);
	font-size: 5rem;
	font-weight: 700;
	line-height:1.0;
}
body.home .mv_wrap{
	overflow: hidden;
	padding-top: 80px;
	background: #f4f4f4;
	filter: blur(10px);
	opacity: 0;
	transition: filter 3s ,opacity 0.5s;
}
body.home .mv_wrap.once{
	filter: none;
	opacity: 1;
}
body.home .mv_wrap .mv_ttl{
	position: absolute;
	z-index: 1;
	margin: auto;
	inset: auto auto 12% 6%;
	font-size: min(4rem , 3.5vw);
	text-align: left;
	font-weight: 600;
	color: #fff;
	font-family: "Zen Kaku Gothic New", sans-serif;
}

body.home .mv_wrap .mv_img{
	background: url(../img/top/img_mv.jpg);
	background-size: cover;
	background-position: center;
	aspect-ratio: 1000/560;
	clip-path: ellipse(60% 100% at 50% 100%);
	overflow: hidden;
}
body.home .mv_wrap .scroll_down {
	position:absolute;
	right: 1rem;
	top: 8em;
	z-index:2;
	font-size: 1em;
	letter-spacing: 0.2em;
}
body.home .mv_wrap .scroll_down a{
	display:flex;
	writing-mode: vertical-rl;
	gap:1em;
	font-weight: 500;
	align-items:center;
	text-decoration:none;
	filter: drop-shadow(0px 0px 2px #ffffff);
}
body.home .mv_wrap .scroll_down a:after{
	content:"";
	display:block;
	width:1px;
	height: 6em;
	background:#000;
	transition: height 0.3s;
	filter: drop-shadow(0px 0px 2px #ffffff);
}
body.home .mv_wrap .scroll_down a:hover:after{
	height: 4em;	
}
@media screen and (max-width: 768px){
	body .home_tll{
		margin-bottom: 1em;
		gap: 0.5em;
	}
	body .home_tll [lang="en"]{
		font-size: 3rem;
	}
	body.home .mv_wrap{
		padding-top: 60px;
	}
	body.home .mv_wrap .mv_ttl{
		inset: auto auto 10% 15px;
		font-size: 2rem;
	}
	
	body.home .mv_wrap .mv_img{
		aspect-ratio: 10/12;
		background-size: cover;
		clip-path: ellipse(90% 100% at 50% 100%);
	}
	
	body.home .mv_wrap .scroll_down{
		top: 5em;
	}
	body.home .mv_wrap .scroll_down a:after{
		height: 3em;
	}
}
body.home .about_wrap{
	padding-block: 6em;
}
body.home .about_wrap .about_inner{
	display: flex;
	flex-direction: row-reverse;
	gap: 1em 6%;
}
body.home .about_wrap .img_area{
	width: 40%;	
}
body.home .about_wrap .img_area .img{
	height: 500px;
}
body.home .about_wrap .img_area .img img{
	height: 100%;
	object-fit: cover;
}
body.home .about_wrap .text_area{
	width: 54%;	
}
body.home .about_wrap .text_area .about_text{
	line-height: 1.8;
	word-break: auto-phrase;
}
@media screen and (max-width: 768px){
	body.home .about_wrap{
		padding-block: 4em;
	}
	body.home .about_wrap .about_inner{
		flex-direction: column;
	}
	body.home .about_wrap .img_area{
		position: absolute;
		z-index: -1;
		margin: auto;
		inset: auto 0 0 auto;
		width: 80%;
		margin-inline: auto;
	}
	body.home .about_wrap .img_area .img{
		height: 300px;
		opacity: 0.2;
	}
	body.home .about_wrap .text_area{
		width: 100%;	
	}
}
body.home .service_wrap{
	margin-bottom: 6em;
	padding-block: 6em 2em;
	background: #3f989d21;
}
body.home .service_inner{
	display: flex;
	align-items: center;
	gap: 2em 6%;
}
body.home .service_wrap .ttl_area{
	width: 300px;
}
body.home .service_wrap .text_area{
	width: calc(94% - 300px);
}
body.home .service_wrap .service_list li{
	margin-bottom: 3em;
	display: flex;
	gap: 1em 2%;
}
body.home .service_wrap .service_list li:nth-child(2){
	margin-left: 4%;
}
body.home .service_wrap .service_list li:nth-child(3){
	margin-left: 8%;
}
body.home .service_wrap .service_list li .serv_num{
	font-size: 2.25rem;
	font-weight: 600;
	background: var(--accent);
	color: #fff;
	border-radius: 50%;
	min-width: 2em;
	height: 2em;
	display: flex;
	justify-content: center;
	align-items: center;
}
body.home .service_wrap .service_list li .serv_detail{
	width: calc(98% - 2em);
}
body.home .service_wrap .service_list li .serv_detail .serv_ttl{
	font-size: 1.5rem;
	font-weight: 600;
	margin-bottom: 1em;
}
body.home .service_wrap .service_list li .serv_detail .serv_ttl:after{
	content:"";
	display:block;
	width: 3rem;
	height:2px;
	background: #282828;
	margin-block: 0.125em 0.175em;
}
body.home .service_wrap .service_list li .serv_detail .serv_text{
	word-break: auto-phrase;
}
@media screen and (max-width: 768px){
	body.home .service_wrap{
		margin-bottom: 4em;
		padding-block: 3em 2em;
	}
	body.home .service_inner{
		flex-direction: column;
		align-items: self-start;
	}
	body.home .service_wrap .ttl_area{
		width: unset;
	}
	body.home .service_wrap .text_area{
		width: 100%;
	}
	body.home .service_wrap .service_list li{
		margin-bottom: 2em;
		display: flex;
		gap: 1em 2%;
	}
	body.home .service_wrap .service_list li:nth-child(2),
	body.home .service_wrap .service_list li:nth-child(3){
		margin-left: 0;
	}
	body.home .service_wrap .service_list li .serv_num{
		font-size: 1.35rem;
	}
	body.home .service_wrap .service_list li .serv_detail{
		width: 100%;
	}
	body.home .service_wrap .service_list li .serv_detail .serv_ttl{
		font-size: 1.35rem;
	}
}
body.home .contact_wrap{
	margin-bottom: 6em;
}
body.home .contact_wrap .contact_bnr{
	padding: 3em 3em 5em;
	display: flex;
	align-items: end;
	gap: 1em 6%;
	margin: 0 auto;
	max-width: 1000px;
	position: relative;
	z-index: 0;
	overflow: hidden;
}
body.home .contact_wrap .contact_bnr::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url(../img/top/img_contact.jpg) no-repeat center / cover;
  filter: brightness(60%) blur(3px);
  z-index: -1;
}
body.home .contact_wrap .contact_bnr .text_area{
	width: calc(94% - 300px);
	color: #fff;
}
body.home .contact_wrap .contact_bnr .text_area .home_tll span{
	font-size: 4rem;
	color: #fff;
}
body.home .contact_wrap .contact_bnr .btn_area{
	width: 300px;
}
@media screen and (max-width: 768px){
	body.home .contact_wrap{
		margin-bottom: 4em;
	}
	body.home .contact_wrap .contact_bnr{
		padding: 2em 2em 3em;
		flex-direction: column;
		gap: 0;
	}
	body.home .contact_wrap .contact_bnr::before{
			filter: brightness(60%) blur(1px);
	}
	body.home .contact_wrap .contact_bnr .text_area{
		width: auto;
	}
	body.home .contact_wrap .contact_bnr .text_area .home_tll span{
		font-size: 3rem;
	}
	body.home .contact_wrap .contact_bnr .btn_area{
		width: auto;
		margin-inline: auto;
	}	
}
