@charset "UTF-8";

/*=======================================================
front : concept
=======================================================*/
.concept-sec{ 
	width: 800px;
	margin: 0 auto 8em;
}
@media screen and (max-width: 896px){
	.concept-sec{
	width: 90%;
	}
}

.concept-cp{
	font-size: 2.5rem;
	line-height: 2;
	margin: 0 0 1em;
}
@media screen and (max-width: 896px){
	.concept-cp{
	font-size: 2rem;
	line-height: 2;
	margin: 0 0 1em;
	}
}

.front-lead{ 
	font-size: 1.6rem;
	line-height: 2.5;
}

.lead-line{
	margin-bottom: 1.5em;
}


.marker{
	background:  -webkit-linear-gradient(left, rgb(204,187,117) 50%, transparent 50%);
	background:  -moz-linear-gradient(left, rgb(204,187,117) 50%, transparent 50%);
	background:  linear-gradient(left, rgb(204,187,117) 50%, transparent 50%);
	background-repeat: no-repeat;
	background-size: 200% .8em;
	background-position: 100% .52em;
	transition:  2s;
	-o-transition:  2s;
	-webkit-transition:  2s;
}
.marker.is-active{
	background-position: 0% .5em;
}


/*=======================================================
service
=======================================================*/
.col2-sub-left{
	width: 55%;
}
.col2-sub-right{
	width: 45%;
	padding-left: 1.5em;
}
.col2-sub-image{
	display: none;
}

@media screen and (max-width: 767px){
.col2-sub-left{ 
	width: 100%;
}
.col2-sub-left 	.sec-sub-ttl{
		text-align: center;
	}	
.col2-sub-image{
	display: block;
	margin-bottom: 2em;
}	
	
.col2-sub-right{ 
	display: none;
	}
}

.front-service img{
	width: 100%;
}
@media screen and (max-width: 767px){
	.front-service img{
	width: 70%;
	margin: 0 auto;
	display: block;
	}
}

.sec-sub-cp{
	font-size: 1.6rem;
	line-height: 1.8;
	margin-top: 2em;
}
@media screen and (max-width: 767px){
	.sec-sub-cp{
		text-align: center;
		margin-bottom: 1.5em;
	}
}

.text-up{
	margin-top: 3em;
}

.text-line{
	margin-bottom: 1.3em;
}


/*front view more
----------------------------------*/
.view-btn{ 
	font-size: 1.8rem;
	font-weight: 600;
	color: #111;
	position: relative;
	transition: all 0.12s ease-in 0s;
}

.view-btn::after{ 
	content: '';
	display: inline-block;
	width: 45px;
	height: 45px;
	border-radius: 50%;
	border: 1px solid #111;
	position: absolute;
	top: 50%;
	right: -60px;
	transform: translateY(-50%);
}
.view-btn::before{
	content: '';
	display: inline-block;
	width: 6px;
	height: 6px;
	border-top: 2px solid #111;
	border-right: 2px solid #111;
	transform: rotate(45deg);
	position: absolute;
	top: 6px;
	right: -38px;
	
}

.view-btn:hover{ 
	color: #bc8f14;
}
.view-btn:hover::after{
	border: none;
	background: #bc8f14;
}
.view-btn:hover::before{
	border-top: 2px solid #fff;
	border-right: 2px solid #fff;
	z-index: 1;
}
@media screen and (max-width: 767px){
.view-btn::after{ 
	width: 33px;
	height: 32px;
	right: -40px;
}
.view-btn::before{
	width: 6px;
	height: 6px;
	top: 6px;
	right: -25px;
}

.view-btn:hover{ 
	color: #111
}
.view-btn:hover::after{
	border: 1px solid #111;
	background: none;
}
.view-btn:hover::before{
	border-top: 2px solid #111;
	border-right: 2px solid #111;
	z-index: 1;
	}
}

/*=======================================================
front : ABOUT
=======================================================*/
.bg-about{ 
	color: #fff;
	width: 100vw;
	margin: 0;
	padding: 5em 0 1em 0;
	background: #bc8f14; 
}
.name-eng{
	font-size: 2rem;
	color: #fff;
	margin-bottom: 1em;
}
.name-jp{
	font-size: 3.3rem;
	color: #fff;
}

.profile{
	color: fff;
}


/*front about view more
----------------------------------*/
.about-btn{ 
	font-size: 1.8rem;
	font-weight: 600;
	color: #111;
	position: relative;
	text-align: center;
	display: block;
	width: 130px;
	margin: 1em auto;
	transition: all 0.12s ease-in 0s;
}


.about-btn::before{
	content: '';
	display: inline-block;
	width: 6px;
	height: 6px;
	border-top: 2px solid #111;
	border-right: 2px solid #111;
	transform: rotate(45deg);
	position: absolute;
	top: 40%;
	right: 0;
}

.about-btn:hover{ 
	color: #fff;
}
.about-btn:hover::before{
	border-top: 2px solid #fff;
	border-right: 2px solid #fff;
	z-index: 1;
}
@media screen and (max-width: 767px){
.about-btn:hover{ 
	color: #111
}
.about-btn:hover::before{
	border-top: 2px solid #111;
	border-right: 2px solid #111;
	z-index: 1;
	}
}

/*=======================================================
front : works
=======================================================*/

.cols-works{ 
	margin-bottom: 1em;
}

.img-views-quare { 
	width: 32%;
}
@media screen and (max-width: 767px){
	.img-views-quare{
	width: 47%;
	}
}
.img-quare{
	width: 32%;
	box-shadow: 0 2px 4px rgba(0,0,0,0.3);
}
.img-quare:nth-child(2){
	width: 32%;
	box-shadow: 0 2px 4px rgba(0,0,0,0.3);
	margin: 0 1.5em;
}
@media screen and (max-width: 999px){
.img-quare{
	width: 31.9%;
	}
.img-quare:nth-child(2){
	width: 31.9%;
	margin: 0 1.5em 0 1.5em;
	}	
}
@media screen and (max-width: 896px){
.img-quare{
	width: 48.5%;
	}
.img-quare:nth-child(2){
	width: 48.5%;
	margin: 0 0 0 1.5em;
	}
.sp-none{
	display: none;
	}	
}

.img-quare img{
	width: 100%;
	height: 100%;
	margin: 0;
	padding: 0;
	object-fit: cover;
}


/*=======================================================
front : about us
=======================================================*/

 .aboutus-box{ 
	display: table-cell;
	vertical-align:middle;
	width: 50%;
	box-sizing: border-box;
	padding: 0 1.5em;
}
@media screen and (max-width: 767px){
 .aboutus-box{
	 display: block;
	 width: 100%;
	}
}
/*=======================================================
front : works
=======================================================*/
.point-lead{
	margin: 2em 0;
}
