@charset "utf-8";
/* CSS Document */
.boxwrap3{
	--gap: clamp(40px, 6vw, 90px);
	max-width: 1280px;
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--gap);
	position: relative;
	padding-bottom: 70px;
}

.boxwrap3::after{
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	height: 2px;
	background-image: radial-gradient(circle, #6BCEF2 1.5px, transparent 1.5px);
	background-size: 8px 2px;
	background-repeat: repeat-x;
}

.boxwrap3 > .imgbox{
	width: calc((100% - var(--gap)) * .56);
	position: relative;
	min-height: 520px;
	padding-right: 30px;
	padding-bottom: 30px;
}

.boxwrap3 .img1{
	width: 72%;
	border-radius: 18px;
	overflow: hidden;
}

.boxwrap3 .img2{
	width: 40%;
	margin-left: auto;
	margin-top: -140px;
	border-radius: 18px;
	overflow: hidden;
	position: relative;
	z-index: 2;
}

.boxwrap3 .imgbox img{
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.boxwrap3 .img1 img{
	aspect-ratio: 4 / 4.6;
}

.boxwrap3 .img2 img{
	aspect-ratio: 1 / 1;
}

.boxwrap3 .txtbox{
	width: calc((100% - var(--gap)) * .44);
}

.boxwrap3 .about_en{
	color: #C3E3F4;
	line-height: 1;
	letter-spacing: .03em;
	font-weight: 700;
}

.boxwrap3 .about_en::first-letter{
	color: #6BCEF2;
}

.boxwrap3 h2{
	color: #2f291b;
	line-height: 1.8;
	letter-spacing: .12em;
	margin-bottom: 30px;
}

.boxwrap3 .txtbox p:not(.about_en){
	color: #2f291b;
	letter-spacing: .08em;
}

@media screen and (max-width: 900px){
	.boxwrap3{
         gap:0px;
		flex-direction: column;
		align-items: flex-start;
	}

	.boxwrap3 > .imgbox,
	.boxwrap3 .txtbox{
		width: 100%;
	}

	.boxwrap3 > .imgbox{
		min-height: 480px;
	}
}

@media screen and (max-width: 576px){
	.boxwrap3{
		padding-bottom: 50px;
       
	}

	.boxwrap3 > .imgbox{
		min-height: 360px;
		padding-right: 20px;
		padding-bottom: 25px;
	}

	.boxwrap3 .img1{
		width: 78%;
	}

	.boxwrap3 .img2{
		width: 45%;
		margin-left: auto;
		margin-top: -110px;
		transform: translate(18px, 18px);
	}

	.boxwrap3 .about_en{
		margin-bottom: 28px;
	}

	.boxwrap3 h2{
		margin-bottom: 24px;
	}
}
.cate2{
}

.feature_box{
	--gap: clamp(40px, 6vw, 90px);
	max-width: 1280px;
    margin-right: auto;
     margin-left: auto;
}

.feature_box .feature_head{
	position: relative;
}

.feature_box .feature_head .num{
	color: #37A1DB;
	line-height: 1;
	font-weight: 700;
	margin-bottom: 8px;
	position: relative;
	z-index: 2;
}

.feature_box .feature_head .bg_en{
	position: absolute;
	left: 50%;
	top: 70%;
	transform: translate(-50%, -50%);
	color: rgba(107, 206, 242, .16);
	line-height: 1;
	z-index: 1;
	pointer-events: none;
}

.feature_box .feature_head h3{
	color: #2f291b;
	line-height: 1;
	letter-spacing: .18em;
	position: relative;
	z-index: 2;
}

.feature_box .feature_wrap{
	align-items: center;
	justify-content: space-between;
	gap: var(--gap);
}

.feature_box .feature_wrap > .imgbox{
	width: calc((100% - var(--gap)) * .42);
	border-radius: 24px;
	overflow: hidden;
}

.feature_box .feature_wrap > .imgbox img{
	width: 100%;
	aspect-ratio: 1 / 1;
	object-fit: cover;
	display: block;
}

.feature_box .feature_wrap .txtbox{
	width: calc((100% - var(--gap)) * .58);
}

.feature_box .feature_wrap h4{
	color: #37A1DB;
	line-height: 1.7;
	letter-spacing: .12em;
	padding-bottom: 8px;
	border-bottom: 2px dotted #6BCEF2;
}

.feature_box .feature_wrap .txtbox > p{
	color: #2f291b;
	letter-spacing: .08em;
}

@media screen and (max-width: 900px){
	.feature_box .feature_wrap{
		flex-direction: column;
		align-items: flex-start;
	}

	.feature_box .feature_wrap > .imgbox,
	.feature_box .feature_wrap .txtbox{
		width: 100%;
        max-width: 600px;
            margin-right: auto;
     margin-left: auto;
	}
}

@media screen and (max-width: 576px){
	.feature_box .feature_wrap > .imgbox{
		border-radius: 18px;
	}

.feature_box .feature_head .num {
  font-size: 30px;
}
}
/* ---------- IEのみ ---------- */
@media all and (-ms-high-contrast: none) {
}
/* ---------- 1280px ~ ---------- */
@media screen and (max-width: 1280px){
}
/* ---------- 1080px ~ ---------- */
@media screen and (max-width: 1080px){
}
/* ---------- 768px ~ ---------- */
@media screen and (max-width: 768px){
}
/* ---------- 576px ~ ---------- */
@media screen and (max-width: 576px){
}
/* ---------- 350px ~ ---------- */
@media screen and (max-width: 350px){
}

