@charset "utf-8";
/* -----------------------------------------------------------
    about
-------------------------------------------------------------- */

.no-wrap{
    white-space: nowrap;
}

#wrapper {
    overflow: clip;
}


/* -----------------------------
	pagetitle-area
-------------------------------- */
.pagetitle-area{
	margin: 67px 0 0;
	position: relative;
}
.pagetitle-area .txt-area{
	text-align: center;
}
.pagetitle-area .txt-area .section-ttl{
	position: relative;
	display: inline-block;
}
.pagetitle-area .txt-area .fukidashi{
	margin: 30px auto 0;
	font-size: 2.3rem;
	line-height: 1.2;
}
.pagetitle-area .txt-area .catch-l{
	padding: 30px 0 0;
}
.pagetitle-area .txt-area .basic-txt{
	padding: 30px 0 0;
}
.pagetitle-area .splide{
	margin: 70px 0 0;
}
.pagetitle-area .splide__slide:nth-child(odd){
	margin: 196px 0 0;
}
.pagetitle-area .geometry-img.geometry01{
	top: 100px;
	left: 60px;
}
.pagetitle-area .geometry-img.geometry02{
	top: 100px;
    left: 310px;
}
.pagetitle-area .geometry-img.geometry03{
	top: 400px;
    left: 450px;
}
.pagetitle-area .geometry-img.geometry04{
	top: 500px;
    left: 590px;
}
.pagetitle-area .geometry-img.geometry05{
	top: 50px;
	right: 0px;
}
.pagetitle-area .geometry-img.geometry06{
	top: 1250px;
	right: 400px;
}

@media screen and (max-width: 768px){
	.pagetitle-area{
		padding: 50px 0 0;
		margin: 0;
	}
	.pagetitle-title{
		font-size: 1.7rem;
		margin: 10px 0 0;
	}
	.pagetitle-title .l{
		font-size: 2.8rem;
		margin: 0 0 12px;
	}
	.pagetitle-area .txt-area .fukidashi{
		font-size: 1.6rem;
	}
	.pagetitle-area .txt-area .basic-txt{
		text-align: left;
		padding: 20px 0 0;
	}
	.pagetitle-area .splide{
		margin: 35px 0 0;
	}
	.pagetitle-area .splide__slide{
		width: 154px;
		height: 220px;
	}
	.pagetitle-area .splide__slide:nth-child(odd){
		width: 175px;
		height: 175px;
		margin: 105px 0 0;
	}
	.pagetitle-area .geometry-img.geometry01{
		left: 0;
		width: 70px;
		top: 80px;
	}
	.pagetitle-area .geometry-img.geometry02{
		top: 140px;
		left: 60px;
		width: 100px;
	}
	.pagetitle-area .geometry-img.geometry03{
		top: 630px;
		left: 100px;
	}
	.pagetitle-area .geometry-img.geometry04{
		bottom: auto;
        left: 70px;
        top: 370px;
        width: 70px;
        left: auto;
	}
	.pagetitle-area .geometry-img.geometry05{
		top: 540px;
		right: -50px;
		width: 190px;
	}
	.pagetitle-area .geometry-img.geometry06{
		display: none;
	}
}

/* -----------------------------
	feature-area
-------------------------------- */
.feature-area{
	margin: 200px 0 0;
	position: relative;
}
.feature-area .txt-area {
display: grid;


grid-column-gap: 0px;
grid-row-gap: 0px;
	margin: 0 0 30px;
}

.feature-area .txt-area .section-ttl { 
	grid-area: 1 / 1 / 2 / 6; 
	margin: 0 0 50px;
}
.feature-area .txt-area .catch-m {
	grid-area: 2 / 1 / 3 / 3; 
	margin: 0 150px 0 0;

}
.feature-area .txt-area .basic-txt { 
	grid-area: 2 / 3 / 3 / 6;
}

.feature-block{
	padding: 100px 50px 100px 100px;
	border-top: solid 1px var(--line-black);
	position: relative;
}
.feature-block .num{
	position: absolute;
	left: -5px;
	top: 20px;
	writing-mode: vertical-rl;
	color: var(--orange);
	font-size: 2.6rem;
	font-weight: 500;
	font-family: var(--en);
}
.feature-block::before{
	content: '';
	position: absolute;
	width: 1px;
	height: 100%;
	top: 0;
	left: 50px;
	background: var(--line-black);
}

.feature-block .wrap{
	display: flex;
}
.feature-block .wrap img{
	margin: 0 100px 0 0;
	border-radius: 5px;
}

.feature-block .wrap02{
	display: flex;
	flex-direction: row-reverse;
	margin: 50px 0 0;
}

.feature-block .wrap02 .fukidashi{
	margin: 30px 0 0;
}

.feature-block .catch-m,
.feature-block .basic-txt{
	margin: 30px 0 0;
}
.feature-block .merit-list{
	margin: 30px 0 0;
}
.feature-block .merit-list dt{
	width: 10%;
}
.feature-block .merit-list li{
	font-weight: bold;
	line-height: 2;
	display: flex;
}
.feature-block .merit-list li .merit-num{
	margin: 0 5px 0 0;
}
.feature02-list{
	display: flex;
	gap: 30px;
	margin: 30px 0 0;
}
.feature02-list li{
	width: calc((100% / 3) - 20px);
	background: var(--light-orange);
	padding: 20px 20px 20px 85px;
	position: relative;
}
.feature02-list li img{
	width: 45px;
	position: absolute;
	top: 50%;
    left: 30px;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}
.feature02-list li .txt{
	line-height: 1.5;
}
.feature03-box{
	background: #F2F2F2;
	margin: 30px 0 0;
	padding: 30px 50px;
	display: flex;
	align-items: center;
}
.feature03-box .title{
	font-size: 2rem;
	font-weight: bold;
	position: relative;
	margin: 0 60px 0 0;
	white-space: nowrap;
}
.feature03-box .title::before{
	content: '';
	position: absolute;
	width: 25px;
	height: 1px;
	left: 0;
	background: #333;
    left: -50px;
	top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}
.feature03-box ul{
	display: flex;
	gap:20px 20px;
	flex-wrap: wrap;
}
.feature03-box ul li{
	/*width: calc((100% / 2) - 20px);*/
}

.feature-area .geometry01{
	right: -100px;
	top: 800px;
	width: 600px;
}
.feature-area .geometry07{
	left: 100px;
	top: 400px;
	width: 300px;
}

.feature-area .geometry03{
	left: 100px;
	top: 2500px;
}

.feature-area .geometry12{
	right: 100px;
	top: 2500px;
}

.feature-area .geometry04{
	left: -100px;
	top: 2500px;
}
@media screen and (max-width: 1600px){
	.feature-block .wrap img{
		margin: 0 50px 0 0;
	}
	.feature-block .wrap02 img{
		width: 40%;
		object-fit: contain;
		margin: 0 0 0 30px;
	}
}

@media screen and (max-width: 768px){
	.feature-area{
		margin: 50px 0 0;
	}
	.feature-area .txt-area {
		display: block;
		margin: 0 0 30px;
	}

	.feature-area .txt-area .section-ttl { 
		margin: 0 0 20px;
	}
	.feature-area .txt-area .catch-m {
		margin: 0;

	}
	.feature-area .txt-area .basic-txt { 
		margin: 20px 0 0;
	}

	.feature-block{
		padding: 20px 20px 20px 52px;
	}
	.feature-block .num{
		font-size: 2rem;
	}
	.feature-block::before{
		left: 32px;
	}

	.feature-block .wrap{
		display: block;
	}
	.feature-block .wrap img{
		margin: 0;
		height: 250px;
		width: 100%;
		object-fit: cover;
	}
	.feature-block .wrap .txt-box{
		margin: 10px 0 0;
	}

	.feature-block .wrap02{
		display: block;
		margin: 20px 0 0;
	}
	.feature-block .wrap02 img{
		width: 100%;
		margin: 0;
	}

	.feature-block .wrap02 .fukidashi{
		font-size: 1.6rem;
		margin: 20px 0 0;
	}
	.feature-block .catch-s{
		font-size: 1.8rem;
		margin: 20px 0 0;
	}
	.feature-block .catch-m{
		font-size: 2.3rem;
		margin: 20px 0 0;
	}

	.feature-block .basic-txt{
		margin: 20px 0 0;
	}

	.feature02-list{
		display: block;
		margin: 20px 0 0;
	}
	.feature02-list li{
		width: 100%;
		padding: 10px 10px 10px 80px;
		margin: 10px 0 0;
	}
	.feature02-list li img{
		width: 40px;
		left: 20px;
	}

	.feature03-box{
		display: block;
		padding: 10px 10px;
	}
	.feature03-box .title{
		margin: 0;
		font-size: 1.6rem;
	}
	.feature03-box .title::before{
		display: none;
	}
	.feature03-box ul{
		display: block;
	}
	.feature03-box ul li{
		line-height: 2;
	}
	
	.feature-area .geometry01{
		right: -100px;
		top: 470px;
		width: 300px;
	}
	.feature-area .geometry07{
		left: -50px;
		top: 100px;
		width: 120px;
	}

	.feature-area .geometry03{
		left: 0px;
		top: 2500px;
	}

	.feature-area .geometry12{
		right: 0px;
		top: 3500px;
	}

	.feature-area .geometry04{
		left: -50px;
        top: auto;
        bottom: -120px;
        width: 200px;
	}

}


/* -----------------------------
	media-area
-------------------------------- */
.media-area{
	margin: 100px 0 0;
}
.media-area .basic-txt{
	margin: 30px 0 0;
}
@media screen and (max-width: 768px){
	.media-area{
		margin: 40px 0 0;
	}
	.media-area .basic-txt{
		margin: 20px 0 0;
	}
}


/* -----------------------------
	office-area
-------------------------------- */
.office-area{
	margin: 100px 0 0;
}
.office-area table{
	margin: 30px 0 0;
	width: 100%;
}
.office-area table tr{
	border-bottom: solid 1px var(--line-black);
	display: flex;
}

.office-area table th,
.office-area table td {
  padding: 24px 0;
  border: none;
	line-height: 1.8;
}

.office-area table th {
  width: 30%;
}
.office-area table a{
	border: solid 1px var(--line-black);
	margin: 0 0 0 20px;
	border-radius: 50px;
	padding: 0 20px;
	transition: .3s all;
	font-size: 1.5rem;
	font-family: var(--en);
}
.office-area table a:hover{
	background: #333;
	color: #fff;
}
.office-area table a i{
	margin: 0 5px 0 0;
}


@media screen and (max-width: 768px){
	.office-area{
		margin: 40px 0 0;
	}
	.office-area table{
		margin: 10px 0 0;
	}
	.office-area table th, .office-area table td{
		padding: 10px 0 ;
	}
	.office-area table th{
		width: 42%;
	}
	.office-area table a{
		margin: 0;
	}
}

/* -----------------------------
	.top-link-area
-------------------------------- */
.top-link-area{
	margin: 100px 0 0;
}
@media screen and (max-width: 768px){

}
