/*-----
* home-style.css ver1.0.0
* fornt page
-----*/
/***** box1 *****/
.box1.color1{
	background-color: rgb(0 0 0 / 25%);
}
.box1 .overview-box{
	width: 100%;
	height:100%;
	min-height: 100vh;
	display: flex;
	justify-content: center;
	align-items: center;
}
.box1 .overview-box>.t-1{
	font-size: 1.2rem;
	color: #fff;
	font-weight: 500;
	line-height: 2.2em;
	padding: 3rem 0 2rem;
}
@media screen and (max-width:768px){
	.box1 .overview-box{
		align-items: flex-start;
	}
	.box1 .overview-box>.t-1 {
		font-size: 1.1rem;
	}
}
/***** box3 *****/
.box3.bg-set1{
	position: relative;
}
.box3 .bg-image{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: calc(100% + 1px);
	background-color: #fff;
	z-index: -1;
	transition: all 300ms 0s ease;
}
.box3 .bg-image>div{
	width: 100%;
	height: 100%;
	clip-path: content-box;
}
.box3 .bg-image>div>.imgbg2{
	position: relative;
}
.box3 .bg-image>div>.imgbg2::before{
	content:"";
	width: 100%;
	height: 100vh;
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	position: fixed;
	top: 0;
	left: 0;
	opacity: 0.1;
}
.box3 .title-box.mb1{
	margin-bottom: 2rem;
}
.box3 .title-box>.wrap>.t-1{
	font-size: 1rem;
	color: var(--font-color-1);
}
.box3 .title-box>.wrap>.t-2{
	font-size: 1.3rem;
	font-weight: 400;
	color: var(--font-color-1);
}
.box3 .item-box.mb1{
	margin-bottom: 2rem;
}
.box3 .item-box>.wrap{
	width: 100%;
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
}
.box3 .item-box>.wrap>.tab-box{
	width: 15%;
}
.box3 .item-box>.wrap>.tab-box>ul>li{
	margin-bottom: 0.7rem;
}
.box3 .item-box>.wrap>.tab-box>ul>li>.l-1{
	display: inline-block;
	font-size: 0.9rem;
	color: var(--font-color-1);
	line-height: 1em;
	position: relative;
	padding-left:1.5em;
}
.box3 .item-box>.wrap>.tab-box>ul>li>.l-1::before{
	content:"●";
	display: none;
	position: absolute;
	left: 0;
	top: 0;
}
.box3 .item-box>.wrap>.tab-box>ul>li>.l-1.active::before{
	display: block;
}
.box3 .item-box>.wrap>.tab-box>ul>li>.l-1:hover>span{
	display: block;
	cursor: pointer;
	opacity:0.5;
}
.box3 .item-box>.wrap>.list-box{
	width: 85%;
	height: 100%;
	transition: all 300ms 0s ease;
}
.box3 .item-box>.wrap>.list-box>.list-base{
	display: none;
	opacity:0;
}
.box3 .item-box>.wrap>.list-box>.list-base.active{
	display: block;
	opacity:1;
}
.box3 .item-box>.wrap>.list-box>.list-base>ul>li{
	border-top: 1px solid var(--border-color);
	padding: 1rem 0;
}
.box3 .item-box>.wrap>.list-box>.list-base>ul>li:last-child{
	border-bottom: 1px solid var(--border-color);
}
.box3 .item-box>.wrap>.list-box>.list-base>ul>li>div{
	width: 100%;
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
}
.box3 .item-box>.wrap>.list-box>.list-base>ul>li>div p,
.box3 .item-box>.wrap>.list-box>.list-base>ul>li>div a{
	font-size: 0.9rem;
	color: var(--font-color-1);
}
.box3 .item-box>.wrap>.list-box>.list-base>ul>li>div>p{
	display: inline-flex;
	align-items: center;
}
.box3 .item-box>.wrap>.list-box>.list-base>ul>li>div>.t-1{
	width: 24%;
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	align-items: center;
}
.box3 .item-box>.wrap>.list-box>.list-base>ul>li>div>.t-1>.t-1-1{
	width: 50%;
	min-width: 6rem;
}
.box3 .item-box>.wrap>.list-box>.list-base>ul>li>div>.t-1>.t-1-2{
	width: 50%;
	min-width: 4rem;
}
.box3 .item-box>.wrap>.list-box>.list-base>ul>li>div>.t-3{
	width: 76%;
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
}
.box3 .item-box>.wrap>.list-box>.list-base>ul>li>div>.t-3>.t-3-1{
	display: flex;
	min-width: 3rem;
	align-items: center;
}
.box3 .item-box>.wrap>.list-box>.list-base>ul>li>div>.t-3>.t-3-1>span{
	display: inline-block;
	font-size: 0.6em;
	font-weight: 300;
	line-height: 1em;
	background-color: #55504c;
	color: #fff;
	padding: 0.3em 0.6em 0.2em;
}
.box3 .item-box>.wrap>.list-box>.list-base>ul>li>div>.t-3>.t-3-2:hover{
	opacity:0.5;
}
.box3 .link-box{
	text-align: right;
}
.box3 .link-box>.l-1{
	display: inline-flex;
	align-items: center;
	border-bottom: 1px solid var(--border-color);
	padding: 0 0rem 0.2rem;
}
.box3 .link-box>.l-1>.t-1{
	font-size: 1rem;
	color: var(--font-color-1);
	margin-right: 1rem;
	transition: all 300ms 0s ease;
}
.box3 .link-box>.l-1:hover>.t-1{
	opacity:0.5;
}
.box3 .link-box>.l-1>.arrow>div{
	background-color: var(--border-color);
	border-radius: 50%;
	font-size: 1rem;
	width: 1.3em;
	height: 1.3em;
	display: flex;
	justify-content: center;
	align-items: center;
	transition: all 300ms 0s ease;
}
.box3 .link-box>.l-1:hover>.arrow>div{
	transform: scale(1.2);
}
.box3 .link-box>.l-1>.arrow>div>span{
	display: block;
	font-size: 0.8em;
	color: var(--font-color-1);
	line-height: 1em;
	transform: rotateZ(90deg);
}
@media screen and (max-width:768px){
	.box3 .title-box.mb1{
		margin-bottom: 1rem;
	}
	.box3 .item-box>.wrap{
		flex-direction: column;
	}
	.box3 .item-box>.wrap>.tab-box{
		width: 100%;
		margin-bottom: 1rem;
	}
	.box3 .item-box>.wrap>.list-box{
		width: 100%;
	}
	.box3 .item-box>.wrap>.list-box>.list-base>ul>li{
		padding: 1.2rem 0;
	}
	.box3 .item-box>.wrap>.list-box>.list-base>ul>li>div{
		flex-direction: column;
	}
	.box3 .item-box>.wrap>.list-box>.list-base>ul>li>div>.t-1{
		width: 100%;
		justify-content: space-between;
		margin-bottom: 0.7rem;
	}
	.box3 .item-box>.wrap>.list-box>.list-base>ul>li>div>.t-1>.t-1-2{
		text-align: right;
	}
	.box3 .item-box>.wrap>.list-box>.list-base>ul>li>div>.t-1>.t-1-2>span{
		background-color: var(--border-color);
		font-size: 0.8em;
		padding: 0.1em 0.5em;
	}
	.box3 .item-box>.wrap>.list-box>.list-base>ul>li>div>.t-3{
		width: 100%;
	}
	.box3 .item-box>.wrap>.list-box>.list-base>ul>li>div>.t-3>.t-3-1>span{
		adding: 0.3em 0.6em 0.3em;
	}
}
/***** box4 *****/
.box4.pt1{
	padding-top: 4rem;
}
.box4>.inner{
	max-width: none;
	padding: 0;
}
.box4 .title-box{
	width: 100%;
	max-width: 1200px;
	margin: auto;
	padding: 0 2%;
}
.box4 .title-box.mb1{
	margin-bottom:2rem;
}
.box4 .title-box>.wrap{
	width: 100%;
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	align-items: center;
}
.box4 .title-box>.wrap>.t-1{
	font-size: 1rem;
	margin-right: 4rem;
}
.box4 .title-box>.wrap>.t-2{
	font-size: 1.3rem;
	font-weight: 400;
	line-height: 1.7em;
}
.box4 .title-box>.wrap>.t-2.type2{
	line-height: 1.5em;
}
.box4 .title-box>.wrap>.t-2>span{
	font-size: 0.7em;
}
.box4 .item-box{
	width: 100%;
}
.box4 .item-box.color-b{
	background-color: #000;
}
.box4 .item-box>.wrap{
	width: 100%;
	height: 100%;
	position: relative;
}
.box4 .item-box>.wrap>.image{
	width: 100%;
	height: 50vh;
	min-height: 600px;
	display: flex;
}
.box4 .item-box>.wrap>.image{
	justify-content: flex-start;
}
.box4 .item-box.reversal>.wrap>.image{
	justify-content: flex-end;
}
.box4 .item-box>.wrap>.image>picture{
	
}
.box4 .item-box>.wrap>.image>img{
	width: 70%;
	height: 100%;
	max-width: none;
	object-fit: cover;
	opacity: 0.6;
}
.box4 .item-box>.wrap>.image>img{
	object-position: 50% 50%;
}
.box4 .item-box>.wrap>.image>picture>img{
	width: 70%;
	height: 100%;
	max-width: none;
	object-fit: cover;
	opacity: 0.6;
	object-position: 50% 50%;
}
.box4 .item-box.reversal>.wrap>.image>img{
	object-position: 50% 50%;
}
.box4 .item-box>.wrap>.text-box{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	display: flex;
	justify-content: flex-end;
	background: linear-gradient(to right, transparent 60%, #000 60%);
}
.box4 .item-box.reversal>.wrap>.text-box{
	justify-content: flex-start;
	background: linear-gradient(to left, transparent 60%, #000 60%);
}
.box4 .item-box>.wrap>.text-box>div{
	width: 100%;
	max-width: 1200px;
	height: 100%;
	margin: auto;
	display: flex;
	justify-content: flex-end;
}
.box4 .item-box.reversal>.wrap>.text-box>div{
	justify-content: flex-start;
}
.box4 .item-box>.wrap>.text-box>div>.in-wrap{
	width: 48%;
	min-width: 450px;
	height: 100%;
	display: flex;
	background-color: #000;
	flex-direction: column;
	justify-content: center;
	padding: 0 10px 0 3rem;
}
.box4 .item-box.reversal>.wrap>.text-box>div>.in-wrap{
	padding: 0 2rem 0 10px;
}
.box4 .item-box>.wrap>.text-box>div>.in-wrap>.t-1,
.box4 .item-box>.wrap>.text-box>div>.in-wrap>.t-2{
	font-size: 1.2rem;
	line-height: 1.5em;
	color: #fff;
	font-weight: 500;
}
.box4 .item-box>.wrap>.text-box>div>.in-wrap>.t-1{
	border-bottom: 1px solid #fff;
	padding-bottom: 1rem;
	margin-bottom: 1.8rem;
}
.box4 .item-box>.wrap>.text-box>div>.in-wrap>.t-1>.image{
	
}
.box4 .item-box>.wrap>.text-box>div>.in-wrap>.t-1>.image>img{
	height: 2.8rem;
	filter: invert(1);
}
.box4 .item-box>.wrap>.text-box>div>.in-wrap>.t-1>.t-1-1{
	font-size: 1.5rem;
	font-weight: 500;
}
.box4 .item-box>.wrap>.text-box>div>.in-wrap>.t-2.mb2{
	 margin-bottom: 1.5rem;
}
.box4 .item-box>.wrap>.text-box>div>.in-wrap>.t-3{
	font-size: 0.9rem;
	color: #fff;
	font-weight: 300;
	line-height: 2em;
}
.box4 .item-box>.wrap>.text-box>div>.in-wrap>.t-3.mb3{
	margin-bottom: 2rem;
}
.box4 .item-box>.wrap>.text-box>div>.in-wrap>.t-4>a{
	display: inline-flex;
	width: 60%;
	border: 1px solid #fff;
	flex-direction: row;
	flex-wrap: nowrap;
	align-items: center;
	padding: 0.7rem 2rem;
	justify-content: center;
	position: relative;
	transition: all 300ms 0s ease;
}
.box4 .item-box>.wrap>.text-box>div>.in-wrap>.t-4>a:hover{
	background-color: rgba(255,255,255,40%);
}
.box4 .item-box>.wrap>.text-box>div>.in-wrap>.t-4>a>.t-4-1{
	font-size: 0.9rem;
	font-weight: 300;
	color: #fff;
	line-height: 1em;
}
.box4 .item-box>.wrap>.text-box>div>.in-wrap>.t-4>a>.arrow{
	position: absolute;
	top: 0;
	bottom: 0;
	right: 1rem;
	display: flex;
	align-items: center;
}
.box4 .item-box>.wrap>.text-box>div>.in-wrap>.t-4>a>.arrow>div{
	background-color: var(--border-color);
	border-radius: 50%;
	font-size: 0.9rem;
	width: 1.3em;
	height: 1.3em;
	display: flex;
	justify-content: center;
	align-items: center;
}
.box4 .item-box>.wrap>.text-box>div>.in-wrap>.t-4>a>.arrow>div>span{
	display: block;
	font-size: 0.6em;
	color: var(--font-color-1);
	line-height: 1em;
	transform: rotateZ(90deg);
}
.box4 .item2-box{
	width: 100%;
}
.box4 .item2-box>.wrap{
	width: 100%;
	height: 100%;
	position: relative;
}
.box4 .item2-box>.wrap>.image{
	width: 100%;
	height: 50vh;
	min-height: 450px;
	display: flex;
	justify-content: flex-start;
}
.box4 .item2-box>.wrap>.image>img{
	width: 70%;
	height: 100%;
	max-width: none;
	object-fit: cover;
	object-position: 70% 50%;
}
.box4 .item2-box>.wrap>.text-box{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	display: flex;
	justify-content: flex-end;
	background: linear-gradient(to right, transparent 60%, #fff 60%);
}
.box4 .item2-box>.wrap>.text-box>div{
	width: 100%;
	max-width: 1200px;
	height: 100%;
	margin: auto;
	display: flex;
	justify-content: flex-end;
}
.box4 .item2-box>.wrap>.text-box>div>.in-wrap{
	width: 40%;
	min-width: 400px;
	height: 100%;
	display: flex;
	background-color: #fff;
	flex-direction: column;
	justify-content: center;
	padding: 0 4rem 0 3rem;
}
.box4 .item2-box>.wrap>.text-box>div>.in-wrap>.t-1{
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	border-bottom: 1px solid var(--border-color);
	padding-bottom: 1rem;
	margin-bottom: 1rem;
}
.box4 .item2-box>.wrap>.text-box>div>.in-wrap>.t-1>.t-1-1{
	font-size: 1rem;
	color: var(--font-color-1);
}
.box4 .item2-box>.wrap>.text-box>div>.in-wrap>.t-1>.t-1-2{
	padding-right: 1rem;
}
.box4 .item2-box>.wrap>.text-box>div>.in-wrap>.t-1>.t-1-2>a{
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	align-items: center;
	padding: 0.3rem 1rem;
	transition: all 300ms 0s ease;
}
.box4 .item2-box>.wrap>.text-box>div>.in-wrap>.t-1>.t-1-2>a:hover{
	background-color: rgb(207 207 207 / 40%);
}
.box4 .item2-box>.wrap>.text-box>div>.in-wrap>.t-1>.t-1-2>a>.t-1-2-1{
	font-size: 1rem;
	color: var(--font-color-1);
	line-height: 1em;
	padding-right: 1rem;
}
.box4 .item2-box>.wrap>.text-box>div>.in-wrap>.t-1>.t-1-2>a>.arrow>div{
	background-color: var(--border-color);
	border-radius: 50%;
	font-size: 0.9rem;
	width: 1.3em;
	height: 1.3em;
	display: flex;
	justify-content: center;
	align-items: center;
}
.box4 .item2-box>.wrap>.text-box>div>.in-wrap>.t-1>.t-1-2>a>.arrow>div>span{
	display: block;
	font-size: 0.6em;
	color: var(--font-color-1);
	line-height: 1em;
	transform: rotateZ(90deg);
}
.box4 .item2-box>.wrap>.text-box>div>.in-wrap>.t-2,
.box4 .item2-box>.wrap>.text-box>div>.in-wrap>.t-3{
	font-size: 0.9rem;
	color: var(--font-color-1);
	font-weight: 300;
	line-height: 2em;
}
@media screen and (max-width:768px){
	.box4 .title-box.mb1{
		margin-bottom: 1rem;
	}
	.box4 .title-box>.wrap>.t-1{
		margin-right: 2rem;
	}
	.box4 .item-box>.wrap>.text-box>div>.in-wrap>.t-1>.image>img{
		height: 2rem;
	}
	.box4 .item-box>.wrap>.image,
	.box4 .item2-box>.wrap>.image{
		height: 30vh;
		min-height: 250px;
	}
	.box4 .item-box>.wrap>.image>img,
	.box4 .item2-box>.wrap>.image>img{
		width: 100%;
	}
	.box4 .item-box>.wrap>.image>picture>img{
		width: 100%;
	}
	.box4 .item-box>.wrap>.text-box,
	.box4 .item2-box>.wrap>.text-box{
		position: relative;
	}
	.box4 .item-box>.wrap>.text-box>div>.in-wrap,
	.box4 .item2-box>.wrap>.text-box>div>.in-wrap{
		width: 100%;
		min-width: fit-content;
		padding: 3rem 5%;
	}
	.box4 .item-box.reversal>.wrap>.text-box>div>.in-wrap{
		padding: 3rem 5% 3rem;
	}
	.box4 .item-box>.wrap>.text-box>div>.in-wrap>.t-1>.t-1-1{
		font-size: 1.3rem;
	}
	.box4 .item-box>.wrap>.text-box>div>.in-wrap>.t-2{
		font-size: 1.1rem;
	}
	.box4 .item2-box>.wrap>.text-box>div>.in-wrap>.t-1>.t-1-2>a{
		background-color: rgb(207 207 207 / 40%);
		padding: 0.5rem 1rem;
	}
}