@charset "utf-8";
/* CSS Document */
/*----------------------------------------------------
  #web-lead
--------------------------------------------------- */

.wrap_title {
	padding: 20px 0 60px;
	margin: -60px auto 0;
    background: #fff;
	width: 750px;
  }

.wrap_title p {

  margin: 0 0 20px;
  font-size: 44px;
  font-weight: bold;
  line-height: 1;
  text-align: center;
font-family: 'Open Sans', sans-serif;	
  }

.wrap_title h1, .wrap_title p.txt_title {
  margin: 0;
  font-size: 15px;
  font-weight: bold;
  line-height: 1;
  text-align: center;
  font-family: 'Noto Sans JP', sans-serif;
  color:#9a9a9a;
  }
@media screen and (max-width: 769px) and (min-width: 600px) {
	
.wrap_title {

  padding: 20px 0 40px;
	margin: 0px auto 0;
    background: #fff;
	width: auto;
	
  }

.wrap_title p {

  font-size: 40px;
  }
	
	
}

@media screen and (max-width: 600px) {
.wrap_title {
  padding: 20px 0 40px;
	margin: 0px auto 0;
    background: #fff;
	width: auto;
  }

.wrap_title p {

  font-size: 32px;
  margin: 0 0 4px;
  }

.wrap_title h1 {

  font-size: 14px;
  }

}





.w-cts-index {
    display: block;
    position: relative;
    max-width: 130px;
    color: #af9b50;
    font-family: 'Open Sans', sans-serif;
    font-size: 12px;
    font-size: 1.2rem;
    font-weight: 400;
    font-weight: 500;
    letter-spacing: .12em;
    line-height: 1;
}
.w-cts-index::after {
    display: block;
    position: absolute;
    top: calc(50% + 1px);
    right: 0;
    height: 1px;
    background-color: #af9b50;
    content: '';
}
.w-cts-index + .w-cts-ttl {
    margin-top: 10px;
}
.w-cts-index + .w-cts-ttl-u {
    margin-top: 10px;
}

.w-cts-ttl {
    font-size: 20px;
    font-size: 2rem;
    font-weight: 600;
    letter-spacing: .16em;
    line-height: 1.75;
	font-family: 'Noto Sans JP', sans-serif;
}
.w-cts-ttl-u {
    font-size: 20px;
    font-size: 2rem;
    font-weight: 600;
    letter-spacing: .16em;
    line-height: 1.75;
	font-family: 'Noto Sans JP', sans-serif;
	padding-bottom: 10px;
	border-bottom: 1px solid #e3e4e5;
}

@media screen and (min-width: 769px) {
.w-cts-index {
    max-width: 180px;
    font-size: 11px;
    font-size: 1rem;
    line-height: 1;
}
.w-cts-index--point::after {
    width: 80px;
}
.w-cts-index + .w-cts-ttl {
    margin-top: 20px;
}
.w-cts-index + .w-cts-ttl-u {
    margin-top: 20px;
}
	
}	

/*----------------------------------------------------
  .common_h3
--------------------------------------------------- */


@media (min-width: 769px) {
.common_h3 h3 {
    font-size: 30px;
    line-height: 46px;
    margin: 15px 0 35px;
    font-family: "Avenir-Black","Arial","游ゴシック体",YuGothic,"游ゴシック","Yu Gothic",sans-serif;
    font-weight: 700;
	
}	
	
	
.category_title {
  position: relative;
  font-size: 1rem;
  font-family: neue-haas-grotesk-text, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "游ゴシック", YuGothic, "メイリオ", Meiryo, "Helvetica Neue", Helvetica, Arial, sans-serif !important;
  font-weight: 700;
  line-height: 100%;
  padding-left: 17px;
  /*margin-bottom: 20px;*/
  color :#af9b50;}

.category_title::before {
  position: absolute;
  display: block;
  left: 0;
  top: 40%;
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background-color: #af9b50; }
}

@media (max-width: 768px) {
.common_h3 h3 {
    font-size: 30px;
    line-height: 46px;
    margin: 15px 0 30px;
    font-family: "Avenir-Black","Arial","游ゴシック体",YuGothic,"游ゴシック","Yu Gothic",sans-serif;
    font-weight: 700;
}	
	
	
.category_title {
  position: relative;
  font-size: 1rem;
  font-family: neue-haas-grotesk-text, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "游ゴシック", YuGothic, "メイリオ", Meiryo, "Helvetica Neue", Helvetica, Arial, sans-serif !important;
  font-weight: 500;
  line-height: 100%;
  padding-left: 17px;
  /*margin-bottom: 25px;*/
  color :#af9b50;	}

.category_title::before {
  position: absolute;
  display: block;
  left: 0;
  top: 36%;
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background-color: #af9b50; }
}

/*----------------------------------------------------
  .num-title
--------------------------------------------------- */
.num-title-area {
    margin-bottom: 60px;
}	

.num-title {
    text-align: center;
}

.num-title {
    font-family: Roboto,sans-serif;
    font-size: 1.2vw;
    font-weight: 700;
    line-height: 1;
    color: #af9b50;
    letter-spacing: 1.2px;
}
.num-title span {
    position: relative;
    margin-left: 2px;
}
.num-title span:before {
    display: inline-block;
    width: .85938vw;
    height: 1px;
    margin-right: 4px;
    margin-bottom: -1px;
    content: "";
    background: #af9b50;
}
.num-title__jp {
	text-align: center;
    font-size: 36px;
    font-weight: 600;
    line-height: 1;
    margin-top: 18px;
    letter-spacing: 2.3px;
}
@media screen and (max-width: 767px){
.num-title-area {
    margin-bottom: 40px;
}	
.num-title {
    font-size: 14px;
    letter-spacing: 1px;
}
.num-title span {
    margin-left: 1px;
}
.num-title span:before {
    width: 8px;
    height: 1px;
    margin-right: 5px;
    margin-bottom: 0;
}
.num-title__jp {
    font-size: 24px;
    font-weight: 600;
    line-height: 1;
    margin-top: 8px;
}	
}	

/*----------------------------------------------------
  btn
--------------------------------------------------- */
.cmn-btn01 {
    margin-top: 20px;
}
    
.cmn-btn01 {
    width: 300px;
}

.cmn-btn01 a, .cmn-btn01 a span {
    position: relative;
    display: block;
}
.cmn-btn01 a {
    background: #333;
}


.cmn-btn01 a{
    text-decoration: none;
    color: #fff!important;
}
.cmn-btn01 a span {
    z-index: 1;
    text-align: right;
    font-size: 14px;
    padding: 14px 25px;
    letter-spacing: 1px;
}
.cmn-btn01 a span::before {
    width: 60px;
    top: 50%;
    right: 130px;
}
.cmn-btn01 a span::before {
    content: "";
    display: block;
    border-bottom: 1px solid #fff;
    position: absolute;
}
.cmn-btn01 a::after {
    top: 0;
    height: 100%;
    background: #af9b50;
}
.cmn-btn01 a::after {
    content: "";
    position: absolute;
    left: 0;
    width: 0;
    -webkit-transition: all .3s ease;
    transition: all .3s ease;
}
.cmn-btn01 a:hover::after {
    width: 100%
}

@media screen and (max-width:768px) {
.cmn-btn01 {
    margin: 20px auto 0;
}
	
.cmn-btn01 {
    width: 250px;
}
	}
/*----------------------------------------------------
  btn02
--------------------------------------------------- */
.cmn-btn {
    box-shadow: 3px 3px 5px #e3e5ea, -3px -3px 5px #fff;
    font-family: jaf-bernina-sans, Hiragino Kaku Gothic Pro, Meiryo, sans-serif;
    font-size: 1.2rem;
    line-height: 1.3;
    color: #f8f8f8;
    font-weight: 600;
    letter-spacing: 0.01em;
    text-align: center;
    width: 190px;
    height: 55px
}
.cmn-btn,
.cmn-btn__inner {
    position: relative;
    display: inline-flex;
    border-radius: 42px
}
.cmn-btn__inner {
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    background-color: #f8f8f8;
    color: #333;
    transition: color 0.2s 0.2s;
    overflow: hidden;
    z-index: 1;
    -webkit-mask-image: -webkit-radial-gradient(#fff,#000)
}
.cmn-btn__circle {
    top: 25px;
    left: 24px
}
.cmn-btn__circle,
.cmn-btn__circle > span {
    position: absolute;
    width: 5px;
    height: 5px;
    display: inline-block
}
.cmn-btn__circle > span {
    top: 50%;
    left: 50%;
    transform: translate3d(-50%, -50%, 0);
    background-color: #333;
    border-radius: 50%;
    transition: width 0.35s cubic-bezier(0.87,.24,0.36,1), height 0.35s cubic-bezier(0.87,.24,0.36,1);
    z-index: 1
}
.cmn-btn__link,
.cmn-btn__txt {
    position: relative;
    z-index: 2;
	font-size: 12px;
}
.cmn-btn__link {
    display: inline-block;
    width: 10px;
    height: 10px;
    margin-left: 5px;
    margin-right: -10px;
    background: url('../images/icon-ar.svg') no-repeat 50%/contain;
    transition: background 0.2s 0.2s
}

@media (-ms-high-contrast:none), (hover:hover) {
    .c-artCard__inner:hover .c-artCard__thm img {
        transform: scale(1.05)
    }
    .cmn-btn:hover .cmn-btn__inner {
        color: #fff
    }
    .cmn-btn:hover .cmn-btn__circle > span {
        width: 400px;
        height: 400px
    }
    .cmn-btn:hover .cmn-btn__link {
        background: url('../images/icon-ar_white.svg') no-repeat 50%/contain
    }
}

/*----------------------------------------------------
  #hover-effect
--------------------------------------------------- */

a.hover-effect {
    overflow: hidden
}
a.hover-effect__zoom {
    display: block
}
a.hover-effect__zoom img {
    -webkit-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1);
    vertical-align: middle;
    -webkit-transition: 0.8s ease all;
    -o-transition: 0.8s ease all;
    transition: 0.8s ease all;
	max-width: 100%;
    height: auto;
}
a.hover-effect__zoom:hover img {
    -webkit-transform: scale(1.2);
    -ms-transform: scale(1.2);
    transform: scale(1.2)
}


/*----------------------------------------------------
  #w-t-img
--------------------------------------------------- */


.w-t-img{
position:relative;
overflow:hidden}
@media screen and (min-width:768px){
.w-t-img{
height:200px}
}
@media screen and (min-width:992px){
.w-t-img{
height:250px}
}

.w-t-img__img{
width:100vw;
height:auto}
@media screen and (min-width:768px){
.w-t-img__img{
position:absolute;
top:50%;
left:50%;
-webkit-transform:translate(-50%,-50%);
-ms-transform:translate(-50%,-50%);
transform:translate(-50%,-50%)}
}
@media screen and (min-width:992px){
.w-t-img__img{
width:100vw}
}
@media screen and (min-width:992px) and (max-width:1366px){
.w-t-img__img{
width:auto;
height:365px}
}
@media screen and (min-width:768px){
.w-t-img .w-t-img__img, .w-t-img .w-t-img__img{
position:absolute;
top:0;
left:50%;
-webkit-transform:translate(-50%,0);
-ms-transform:translate(-50%,0);
transform:translate(-50%,0)}
}


/*----------------------------------------------------
  #web-lead
--------------------------------------------------- */
#web-lead{
  width: 100%;
  margin: 0 auto;
  overflow: hidden;
  position: relative;
  z-index: 1;
  padding: 90px 0 100px;
  background: #FFF;
}
#web-lead .inner{
  width: 900px;
  margin: 0 auto;
  position: relative;
}
#web-lead .title{
  font-size: 38px;
  line-height: 58px;
  font-weight: bold;
    color: #000;
	text-align: center;
}
#web-lead .title em{
    color: #148f2d;
	font-style:normal;
}

#web-lead .intr{
  margin-top: 24px;
  font-size: 22px;
  line-height: 42px;
  font-weight: bold;
}

#web-lead .image{
  margin-top:60px;
  margin-bottom: 35px;
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  #web-lead .inner{
    width: 760px;
    margin: 0 auto;
    position: relative;
  }
  #web-lead .image img{
    width: 100%;
    height: auto;
  }
	
}
@media only screen and (max-width: 767px) {
  #web-lead{
    padding: 60px 0 45px;
  }
  #web-lead .inner{
    width: 100%;
  }
  #web-lead .title,
  #web-lead .title.b{
    width: 89.0vw;
    margin: 0 auto;
    font-size: 21px;
	text-align: center;
	line-height: 38px;  
  
  }
	
  #web-lead p{
    width: 89.0vw;
    margin: 0 auto;
    margin-top: 25px;
    font-size: 15px;
    line-height: 24px;
  }
  #web-lead .image{
    width: 89.0vw;
    margin: 0 auto;
    margin-top:24px;
    margin-bottom: 24px;
  }
	
}
@media only screen and (max-width: 465px) {

  #web-lead .title,
  #web-lead .title.b{
    width: 89.0vw;
    margin: 0 auto;
    font-size: 17px;
	line-height: 28px;  
  }
}
/*----------------------------------------------------
  web-std
--------------------------------------------------- */
.web-std{
  width: 100%;
  margin: 0 auto;
  overflow: hidden;
  position: relative;
  z-index: 1;
  padding: 0px 0 70px;
 }

.gray-c {
  background-color: #fafafa;
}


.web-std .h_title {
    padding: 70px 0 65px;
    background: #148f2d;
}
.web-std .h_title .h_inner {
    width: 1080px;
    margin: 0 auto;
    font-size: 34px;
    color: #FFF;
    font-weight: bold;
    text-align: center;
}
.web-std .h_title span {
    font-size: 42px;
}
.web-std .inner{
  width: 900px;
  margin: 0 auto;
  position: relative;
}
.web-std .inner_1100{
  width: 1100px;
  margin: 0 auto;
  position: relative;
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  .web-std .inner{
    width: 760px;
    margin: 0 auto;
    position: relative;
  }
  .web-std .inner_1100{
    width: 760px;
    margin: 0 auto;
    position: relative;
  }
	
.web-std .h_title .h_inner {
    width: 720px;
}	
}
@media only screen and (max-width: 767px) {
  .web-std{
    padding: 0px 0 5px;
  }
  .web-std .inner{
    width: 92%;
  }
  .web-std .inner_1100{
    width: 92%;
  }
	
.web-std .h_title {
    padding: 20px 0 10px;
}	
.web-std .h_title .h_inner {
    width: auto;
    padding: 0 20px;
    font-size: 28px;
	line-height: 1.8;
}
.web-std .h_title span {
    font-size: 38px;
}
	
}

/*----------------------------------------------------
  #sec-lead
--------------------------------------------------- */
.sec-lead__wrap {
    text-align: center;
}
.sec-lead .lead-acc {
    color: #005c97;
}
.sec-lead .lead-acc {
    position: relative;
    display: inline-block;
    padding-bottom: 2.5px;
    margin-bottom: 40px;
    font-size: 20px;
    font-weight: 600;
    line-height: 2;
    letter-spacing: .15em;
}

.sec-lead .lead-acc::after {
    background-color: #005c97;
}
.sec-lead .lead-acc::after {
    position: absolute;
    right: 0;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 2px;
    content: "";
}


.sec-lead .lead-ttl {
    margin-bottom: 60px;
    font-size: 36px;
    line-height: 1.6;
    letter-spacing: .23em;
}


@media(max-width:768px) {
	
.sec-lead .lead-acc {
    margin-bottom: 30px;
    font-size: 15px;
}
.sec-lead .lead-ttl {
    margin-bottom: 20px;
    font-size: 25px;
    letter-spacing: .23em;
}
.sec-lead__wrap p{
	width: auto!important;
    margin: 0 auto!important;
    margin-bottom: 20px!important;
    margin-top: 0px!important;
	
	}	
	
	
	}
/*----------------------------------------------------
  web-brd
--------------------------------------------------- */
.web-brd{
  width: 100%;
  margin: 0 auto;
  overflow: hidden;
  position: relative;
  z-index: 1;
  padding: 0px 0 10px;
 background: #f5f7f8;
}	
 
.web-brd .breadcrumbs{
	font-size:12px!important;
	font-weight: normal!important;
	color:#414141!important;
}
.web-brd .breadcrumbs a{
	color:#414141!important;
}

@media only screen and (max-width: 767px) {
.web-brd{
  display: none;
 }
}	
.w-1000{
margin: 0 auto 10px;
    max-width: 1050px;
}

@media all and (min-width: 768px) and (max-width: 1049px) {
	.w-1000 {
		margin: 0 20px 20px;
	}
}

@media screen and (max-width: 767px) {
	.w-1000 {
		margin: 0 0px 0px;
	}
}

/*----------------------------------------------------
  #web-tit
--------------------------------------------------- */
.web-tit-area {
    text-align: center;
	margin-bottom: 60px;	
}

.web-tit-area__en {
  margin: 0 0 20px;
  font-size: 44px;
  font-weight: bold;
  line-height: 1;
  text-align: center;
   font-family: 'Open Sans', sans-serif;	
}
.web-tit-area__jp {
  margin: 0;
  font-size: 15px;
  font-weight: bold;
  line-height: 1;
  text-align: center;
  font-family: 'Noto Sans JP', sans-serif;
  color:#9a9a9a;
}


@media all and (max-width: 767px){
.web-tit-area {
	margin-bottom: 40px;	
}
	
.web-tit-area__jp {
  font-size: 14px;
}
.web-tit-area__en {
  font-size: 32px;
  margin: 0 0 4px;
}
	
	}

/*----------------------------------------------------
  #web-tit-h3-4
--------------------------------------------------- */

.web-tit-h3-4 {
    font-size: 30px;
    font-weight: 700;
    line-height: 1;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    color: #1f1f1f;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}
.web-tit-h3-4.border-left:before {
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    content: "";
    display: inline-block;
    vertical-align: middle;
    background-image: linear-gradient(135deg, #0c21c3 0%, #0874dc 100%);
    margin-top: -1px;
    margin-right: 23px;
    height: 80px;
    width: 3px;
}


.web-tit-h3-4.border-left {
    padding-left: 10px;
}

@media (max-width: 767px) {
	
.web-tit-h3-4.border-left {
    padding-left: 10px;
}
.web-tit-h3-4 {
    font-size: 18px;
    line-height: 1;
}
.web-tit-h3-4 {
    line-height: inherit !important;
    position: relative;
}	
	
.web-tit-h3-4.border-left:before {
    position: absolute;
    left: 0;
    top: 0;
    margin-top: -1px;
    margin-right: 0;
    min-height: inherit;
    min-width: 2px;
    height: 100%;
    width: 2px;
}	
	
}
.dot_title{
	position: relative;
    line-height: 100%;
    padding-left: 17px;
}
.dot_title h4 {
    font-size: 20px;
    margin-bottom: 20px;
    font-family: "Avenir-Black","Arial","游ゴシック体",YuGothic,"游ゴシック","Yu Gothic",sans-serif;
    font-weight: 700;
	line-height: 1.6;
}	
	


.dot_title::before {
    position: absolute;
    display: block;
    left: 0;
    top: 40%;
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background-color: #006AB8;
}

@media (max-width: 768px) {
.dot_title{
	position: relative;
    line-height: 100%;
    padding-left: 0px;
}
	
.dot_title h4 {
    font-size: 18px;
    margin-bottom: 20px;
    font-family: "Avenir-Black","Arial","游ゴシック体",YuGothic,"游ゴシック","Yu Gothic",sans-serif;
    font-weight: 700;
	line-height: 1.6;
}	
	


.dot_title::before {
    display: none;
}
	
	
}

/*----------------------------------------------------
  #web-col
--------------------------------------------------- */
#web-col{
  width: 100%;
  margin: 0 auto;
  overflow: hidden;
  position: relative;
  z-index: 1;
  padding: 0px 0 100px;
  background: #FFF;
}
#web-col .inner{
  width: 1100px;
  margin: 0 auto;
  position: relative;
	padding-left: 10px;
    padding-right: 10px;
	
}
#web-col .inner-900{
  width: 900px;
  margin: 0 auto;
  position: relative;
	padding-left: 10px;
    padding-right: 10px;
	
}
.w-1420{
margin: 0 auto 150px;
    max-width: 1420px;
}

@media all and (min-width: 768px) and (max-width: 1424px) {
	.w-1420 {
		margin: 0 20px 150px;
	}
}

@media screen and (max-width: 767px) {
	.w-1420 {
		margin: 0 30px 74px;
	}
}


.w-900{
  width: 900px;
  margin: 0 auto;
  position: relative;
	padding-left: 10px;
    padding-right: 10px;
	
}

.w-700{
  width: 700px;
  margin: 0 auto;
  position: relative;
	padding-left: 10px;
    padding-right: 10px;
	
}


#web-col .title{
  font-size: 38px;
  line-height: 58px;
  font-weight: bold;
    color: #000;
	text-align: center;
}
#web-col .title em{
    color: #148f2d;
	font-style:normal;
}

#web-col .intr{
  margin-top: 24px;
  font-size: 22px;
  line-height: 42px;
  font-weight: bold;
}

#web-col .image{
  margin-top:60px;
  margin-bottom: 35px;
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {
  #web-col .inner{
    width: 760px;
    margin: 0 auto;
    position: relative;
  }
  #web-col .inner-900{
    width: 760px;
    margin: 0 auto;
    position: relative;
  }
 .w-900{
    width: 760px;
    margin: 0 auto;
    position: relative;
  }	
	
  #web-col .image img{
    width: 100%;
    height: auto;
  }
	
}
@media only screen and (max-width: 767px) {
	
  #web-col{
    padding: 0px 0 45px;
  }
  #web-col .inner{
    width: 100%;
	padding-left: 10px;
    padding-right: 10px;
  
  }
  #web-col .inner-900{
    width: 100%;
	padding-left: 10px;
    padding-right: 10px;
  
  }
  .w-900{
    width: 100%;
	padding-left: 10px;
    padding-right: 10px;
  
  }
  .w-700{
    width: 100%;
	padding-left: 10px;
    padding-right: 10px;
  
  }
	
  #web-col .title,
  #web-col .title.b{
    width: 89.0vw;
    margin: 0 auto;
    font-size: 21px;
	text-align: center;
	line-height: 38px;  
  
  }
	
  #web-col p{
    /*width: 89.0vw;*/
    margin: 0 auto;
    margin-top: 25px;
    font-size: 15px;
    line-height: 24px;
  }
  #web-col .image{
    width: 89.0vw;
    margin: 0 auto;
    margin-top:24px;
    margin-bottom: 24px;
  }
	
}
@media only screen and (max-width: 465px) {
  #web-col .inner{
    width: 100%;
	padding-left: 10px;
    padding-right: 10px;
  
  }
  #web-col .inner-900{
    width: 100%;
	padding-left: 10px;
    padding-right: 10px;
  
  }
  .w-900{
    width: 100%;
	padding-left: 10px;
    padding-right: 10px;
  
  }
  .w-700{
    width: 100%;
	padding-left: 10px;
    padding-right: 10px;
  
  }

  #web-col .title,
  #web-col .title.b{
    width: 89.0vw;
    margin: 0 auto;
    font-size: 17px;
	line-height: 28px;  
  }
}

/*----------------------------------------------------
  #col
--------------------------------------------------- */
*, :after, :before {
    box-sizing: border-box;
}
.NavGrid:not(.NavGrid_overflow) {
    overflow: hidden
}
.NavGrid_col_2 > * {
    margin: -0.25rem;
    display: flex;
    flex-wrap: wrap
}
.NavGrid_col_2 > * > * {
    padding: 0.25rem;
    flex: 0 0 auto;
    width: 100%
}
.NavGrid_col_2>*>*>:first-child:last-child {
    height: 100%
}
@media(min-width:48em) {
    .NavGrid_col_2 > * {
        margin: -1.25rem
    }
    .NavGrid_col_2 > * > * {
        padding: 1.25rem;
        width: 50%
    }
}
.NavGrid_col_3 > * {
    margin: -0.25rem;
    display: flex;
    flex-wrap: wrap
}
.NavGrid_col_3 > * > * {
    padding: 0.25rem;
    flex: 0 0 auto;
    width: 100%
}
.NavGrid_col_3>*>*>:first-child:last-child {
    height: 100%
}
@media(min-width:48em) {
    .NavGrid_col_3 > * {
        margin: -1.25rem
    }
    .NavGrid_col_3 > * > * {
        padding: 1.25rem;
        width: 50%
    }
}
@media(min-width:80em) {
    .NavGrid_col_3 > * > * {
        width: 33.3333333333%
    }
}
.FlexCard {
    position: relative;
    display: flex;
    align-items: center
}
@media(min-width:48em) {
    .FlexCard {
        flex-flow: column;
        align-items: flex-start
    }
}
.FlexCard-mediaBlock {
    position: relative;
    align-self: flex-start;
    flex-shrink: 0;
    border-radius: 0.5rem;
    width: 9rem;
    margin-right: 1rem;
    pointer-events: none;
    overflow: hidden
}
@media(min-width:48em) {
    .FlexCard-mediaBlock {
        width: 100%;
        margin-right: 0;
        margin-bottom: 1rem
    }
}
.FlexCard-mediaBlock:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border: 0.2rem solid #096fc8;
    transition: transform 0.4s cubic-bezier(0.4,.1,0.3,1);
    transform: scale(1.2);
    z-index: 1
}
@media(min-width:48em) {
    .FlexCard-mediaBlock:before {
        transform: scale(1.1)
    }
}
.FlexCard-mediaBlock:after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border: 0.3rem solid #096fc8;
    transform: scale(1.2);
    transition: transform 0.4s cubic-bezier(0.4,.1,0.3,1);
    border-radius: 0.6rem
}
@media(min-width:48em) {
    .FlexCard-mediaBlock:after {
        transform: scale(1.1)
    }
}
@media(hover:hover) {
    .FlexCard:hover .FlexCard-mediaBlock:after,
    .FlexCard:hover .FlexCard-mediaBlock:before {
        transform: scale(1)
    }
}
.FlexCard-mediaImage {
    background-position: 50%;
    background-size: cover;
    transition: transform 0.5s cubic-bezier(0.4,.1,0.3,1);
    border-radius: 0.5rem;
    transform: translateZ(0) scale(1)
}
.FlexCard-mediaImage:before {
    content: "";
    display: block;
    padding-top: 66.6666666667%
}
@media(hover:hover) {
    .FlexCard:hover .FlexCard-mediaImage {
        transform: translateZ(0) scale(1.08)
    }
}
.FlexCard-title {
    font-weight: 600;
    font-size: 1.11111rem;
    line-height: 1.35em
}
@media(min-width:48em) {
    .FlexCard-title {
        font-weight: 500;
        font-size: 1.42857rem;
        line-height: 1.225em
    }
}
.FlexCard-link {
    color: inherit;
    text-decoration: none
}
.FlexCard-link:before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0
}
.FlexCard-subtitle {
	font-family: My Galano Grotesque, sans-serif;
    font-weight: 500;
    font-size: 0.61429rem;
    line-height: 1.75em;
	color:#999;
}
@media(min-width:48em) {
    .FlexCard-subtitle {
		font-family: My Galano Grotesque, sans-serif;
        font-size: 0.80909rem;
        line-height: 1.65em;
        margin-top: 0.25rem
    }
}

/*----------------------------------------------------
  #col-2
--------------------------------------------------- */
@media(hover:hover) {
    .ServicesIndexNavItem:hover .IconArrow_direction_right,
    a:hover .IconArrow_direction_right {
        transform: translate3d(0.4em, 0, 0) scale(1.2)
    }
.ServicesIndexNav {
    overflow: hidden
}
.ServicesIndexNav > * {
    margin: -1.25rem;
    display: flex;
    flex-wrap: wrap
}
.ServicesIndexNav > * > * {
    padding: 1.25rem;
    flex: 0 0 auto;
    width: 100%
}
.ServicesIndexNav>*>*>:first-child:last-child {
    height: 100%
}
}	
@media(min-width:48em) {
    .ServicesIndexNav > * > * {
        width: 50%
    }
}
.ServicesIndexNavItem {
    position: relative;
    font-family: A\+EqpB-游ゴシック体 Pr6N M, sans-serif;
    font-weight: 400;
    font-size: 0.71429rem;
    line-height: 1.75em
}
@media(min-width:48em) {
    .ServicesIndexNavItem {
        font-size: 0.90909rem;
        line-height: 1.65em
    }
}
.ServicesIndexNavItem-image {
    position: relative;
    overflow: hidden;
    border-radius: 0.5rem;
    margin-bottom: 1rem;
    pointer-events: none
}
@media(min-width:48em) {
    .ServicesIndexNavItem-image {
        margin-bottom: 1.5rem
    }
}
.ServicesIndexNavItem-image:before {
    border: 0.2rem solid #096fc8;
    z-index: 1
}
.ServicesIndexNavItem-image:after,
.ServicesIndexNavItem-image:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    transition: transform 0.4s cubic-bezier(0.4,.1,0.3,1);
    transform: scale(1.1)
}
.ServicesIndexNavItem-image:after {
    border: 0.3rem solid #096fc8;
    border-radius: 0.6rem
}
.ServicesIndexNavItem-imageTarget {
    background-position: 50%;
    background-size: cover;
    background-repeat: no-repeat;
    border-radius: 0.5rem;
    transform: translateZ(0) scale(1);
    transition: transform 0.5s cubic-bezier(0.4,.1,0.3,1)
}
.ServicesIndexNavItem-imageTarget:before {
    content: "";
    display: block;
    padding-top: 66.6666666667%
}
@media(hover:hover) {
    .ServicesIndexNavItem:hover .ServicesIndexNavItem-image:after,
    .ServicesIndexNavItem:hover .ServicesIndexNavItem-image:before {
        transform: scale(1)
    }
}
@media(hover:hover) {
    .ServicesIndexNavItem:hover .ServicesIndexNavItem-imageTarget {
        transform: translateZ(0) scale(1.08)
    }
}
.ServicesIndexNavItem-title {
    color: #096fc8;
    font-weight: 600;
    font-size: 1.4rem;
    line-height: 1.2em;
    letter-spacing: -0.025em
}
@media(min-width:48em) {
    .ServicesIndexNavItem-title {
        font-size: 1.5rem;
        line-height: 1.1em;
        margin-bottom: 0.5rem
    }
}
.ServicesIndexNavItem-link:before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0
}
.ServicesIndexNavItem-subtitle {
    margin-bottom: 0.5rem;
    font-family: A\+EqpB-游ゴシック体 Pr6N B, sans-serif;
    font-weight: 400;
    font-size: 0.71429rem;
    line-height: 1.4em
}
@media(min-width:48em) {
    .ServicesIndexNavItem-subtitle {
        font-size: 0.90909rem;
        line-height: 1.375em;
        margin-bottom: 1rem
    }
}
.ServicesIndexNavItem-content p+p {
    margin-top: 0.5rem
}


/*----------------------------------------------------
  #com-ov
--------------------------------------------------- */


.com_ov
{border-top:solid 1px #edefea;
width:100%;
color:#363833;
margin-bottom: 60px;}
.com_ov a
{color:#1cb57b;
transition:.16s ease-in-out;
-webkit-transition:.16s ease-in-out;
-moz-transition:.16s ease-in-out;
-ms-transition:.16s ease-in-out;
-o-transition:.16s ease-in-out}
.com_ov th,
.com_ov td
{border-bottom:solid 1px #edefea;
padding:24px 30px 21px 0;
line-height:200%;
position:relative;
overflow:visible;
box-sizing:border-box;
-webkit-box-sizing:border-box;
-moz-box-sizing:border-box;
-ms-box-sizing:border-box;
-o-box-sizing:border-box}
.com_ov th
{width:160px;
white-space:nowrap}
.com_ov td
{border-left:solid 1px #edefea}
.com_ov td::before,
.com_ov td::after
{content:"";
background-color:#fff;
width:5px;
height:20px;
display:block;
position:absolute;
left:-3px}
.com_ov td::before
{top:0}
.com_ov td::after
{bottom:0}
.com_ov *+th,
.com_ov *+td
{padding-left:30px}
.com_ov .svg-tel,
.com_ov .svg-mail
{margin-right:10px;
width:12px;
max-height:10px;
vertical-align:middle;
display:inline-block;
position:relative;
top:-1px}
.com_ov .tel span,
.com_ov .mail span
{display:none}
.ie7 .com_ov a,
.ie8 .com_ov a,
.iphone .com_ov a,
.ipad .com_ov a,
.ipod .com_ov a,
.android .com_ov a
{color:#1cb57b;
transition:none 0 ease 0;
-webkit-transition:none 0 ease 0;
-moz-transition:none 0 ease 0;
-ms-transition:none 0 ease 0;
-o-transition:none 0 ease 0}
.ie8 .com_ov .svg-tel,
.ie8 .com_ov .svg-mail,
.android .com_ov .svg-tel,
.android .com_ov .svg-mail
{display:none}
.ie8 .com_ov .tel:before,
.ie8 .com_ov .mail:before,
.android .com_ov .tel:before,
.android .com_ov .mail:before
{margin:0 7px 0 0;
width:10px;
height:10px;
font-size:0;
line-height:10px;
vertical-align:middle;
display:inline-block;
position:relative;
top:-1px}


table.basic{
border-top:solid 1px #edefea;
width:100%;
color:#363833
}
table.basic a{
color:#096fc8;
transition:.16s ease-in-out;
-webkit-transition:.16s ease-in-out;
-moz-transition:.16s ease-in-out;
-ms-transition:.16s ease-in-out;
-o-transition:.16s ease-in-out
}
table.basic th,table.basic td{
border-bottom:solid 1px #edefea;
padding:14px 08px 11px 0;
line-height:200%;
position:relative;
overflow:visible;
box-sizing:border-box;
-webkit-box-sizing:border-box;
-moz-box-sizing:border-box;
-ms-box-sizing:border-box;
-o-box-sizing:border-box
}
table.basic th{
min-width:70px;
width:70px;
white-space:normal;
word-break:break-all;
word-wrap:break-word;
hyphens:auto;
-webkit-hyphens:auto;
-moz-hyphens:auto;
-ms-hyphens:auto;
-o-hyphens:auto
}
table.basic td{
border-left:solid 1px #edefea
}
table.basic td::before,table.basic td::after{
content:"";
width:5px;
height:15px;
display:block;
position:absolute;
left:-3px
}
table.basic td::before{
top:0
}
table.basic td::after{
bottom:0
}
table.basic *+th,table.basic *+td{
padding-left:14px
}
table.basic .svg-tel,table.basic .svg-mail{
margin-right:7px;
width:10px;
height:10px;
vertical-align:middle;
display:inline-block
}
table.basic .tel span,table.basic .mail span{
display:none
}
.ie7 table.basic a,.ie8 table.basic a,.iphone table.basic a,.ipad table.basic a,.ipod table.basic a,.android table.basic a{
color:#1cb57b;
transition:none 0 ease 0;
-webkit-transition:none 0 ease 0;
-moz-transition:none 0 ease 0;
-ms-transition:none 0 ease 0;
-o-transition:none 0 ease 0
}
.android table.basic .svg-tel,.android table.basic .svg-mail{
display:none
}
.android table.basic .tel::before,.android table.basic .mail::before{
margin:0 7px 0 0;
width:10px;
height:10px;
font-size:0;
line-height:10px;
vertical-align:middle;
display:inline-block;
position:relative;
top:-1px
}
.android table.basic .tel::before{
content:url(/common/svg/icon_tel_gray.svg)
}
.android table.basic .mail::before{
content:url(/common/svg/icon_mail_gray.svg)
}
@media screen and (min-width: 768px), print{
table.basic
{border-top:solid 1px #edefea;
width:100%;
color:#363833}
table.basic a
{color:#1cb57b;
transition:.16s ease-in-out;
-webkit-transition:.16s ease-in-out;
-moz-transition:.16s ease-in-out;
-ms-transition:.16s ease-in-out;
-o-transition:.16s ease-in-out}
table.basic th,
table.basic td
{border-bottom:solid 1px #edefea;
padding:24px 30px 21px 0;
line-height:200%;
position:relative;
overflow:visible;
box-sizing:border-box;
-webkit-box-sizing:border-box;
-moz-box-sizing:border-box;
-ms-box-sizing:border-box;
-o-box-sizing:border-box}
table.basic th
{width:160px;
white-space:nowrap}
table.basic td
{border-left:solid 1px #edefea}
table.basic td::before,
table.basic td::after
{content:"";
background-color:#fff;
width:5px;
height:20px;
display:block;
position:absolute;
left:-3px}
table.basic td::before
{top:0}
table.basic td::after
{bottom:0}
table.basic *+th,
table.basic *+td
{padding-left:30px}
table.basic .svg-tel,
table.basic .svg-mail
{margin-right:10px;
width:12px;
max-height:10px;
vertical-align:middle;
display:inline-block;
position:relative;
top:-1px}
table.basic .tel span,
table.basic .mail span
{display:none}
.ie7 table.basic a,
.ie8 table.basic a,
.iphone table.basic a,
.ipad table.basic a,
.ipod table.basic a,
.android table.basic a
{color:#1cb57b;
transition:none 0 ease 0;
-webkit-transition:none 0 ease 0;
-moz-transition:none 0 ease 0;
-ms-transition:none 0 ease 0;
-o-transition:none 0 ease 0}
.ie8 table.basic .svg-tel,
.ie8 table.basic .svg-mail,
.android table.basic .svg-tel,
.android table.basic .svg-mail
{display:none}
.ie8 table.basic .tel:before,
.ie8 table.basic .mail:before,
.android table.basic .tel:before,
.android table.basic .mail:before
{margin:0 7px 0 0;
width:10px;
height:10px;
font-size:0;
line-height:10px;
vertical-align:middle;
display:inline-block;
position:relative;
top:-1px}
.ie8 table.basic .tel:before,
.android table.basic .tel:before
{content:url(/common/svg/icon_tel_gray.svg)}
.ie8 table.basic .mail:before,
.android table.basic .mail:before
{content:url(/common/svg/icon_mail_gray.svg)}
.ie8 table.basic .tel:before
{content:url(/common/image/icon_tel_gray.gif)}
.ie8 table.basic .mail:before
{content:url(/common/image/icon_mail_gray.gif)}
}


@media screen and (max-width: 768px){
.ggmap {
position: relative;
padding-bottom: 50%;
padding-top: 30px;
height: 0;
overflow: hidden;
}
 
.ggmap iframe,
.ggmap object,
.ggmap embed {
position: absolute;
top: 0;
left: 0;
width: 100%!important;
height: 100%!important;
}

.com_ov{
border-top:solid 1px #edefea;
width:100%;
margin:0 auto;	
color:#363833
}
.com_ov table {
    width: 100%!important;
}
.com_ov table {
    border-collapse: collapse!important;
    border-spacing: 0!important;
}	
.com_ov a{
color:#1cb57b;
transition:.16s ease-in-out;
-webkit-transition:.16s ease-in-out;
-moz-transition:.16s ease-in-out;
-ms-transition:.16s ease-in-out;
-o-transition:.16s ease-in-out
}
.com_ov th,.com_ov td{
border-bottom:solid 1px #edefea;
padding:14px 08px 11px 0;
line-height:200%;
position:relative;
overflow:visible;
box-sizing:border-box;
-webkit-box-sizing:border-box;
-moz-box-sizing:border-box;
-ms-box-sizing:border-box;
-o-box-sizing:border-box
}
.com_ov th{
min-width:70px;
width:70px;
padding:14px 08px 11px 5px;	
white-space:normal;
word-break:break-all;
word-wrap:break-word;
hyphens:auto;
-webkit-hyphens:auto;
-moz-hyphens:auto;
-ms-hyphens:auto;
-o-hyphens:auto;
font-size:90%	
}
.com_ov td{
border-left:solid 1px #edefea;
font-size:90%
}
.com_ov td::before,.com_ov td::after{
content:"";
background-color:#fff;
width:5px;
height:15px;
display:block;
position:absolute;
left:-3px
}
.com_ov td::before{
top:0
}
.com_ov td::after{
bottom:0
}
.com_ov th,.com_ov td{
padding-left:14px
}
.com_ov .svg-tel,.com_ov .svg-mail{
margin-right:7px;
width:10px;
height:10px;
vertical-align:middle;
display:inline-block
}
.com_ov .tel span,.com_ov .mail span{
display:none
}
}	
/* .box-history                      */
/*-----------------------------------*/
.box-history {
	margin: 128px 0 0;
}
.box-history:first-child {
	margin: 62px 0 0;
}
.box-history__section {
	font-size: 39px;
	font-family: "YakuHanMP", "ヒラギノ明朝 Pro W3","Hiragino Mincho Pro";
	line-height: 1.25;
}
[lang="en"] .box-history__section {
	font-family: "Georgia", "YakuHanMP", "ヒラギノ明朝 Pro W3","Hiragino Mincho Pro";
}
.box-history__content-wrp {
	position: relative;
}
.box-history__content-wrp:before {
	content: "";
	position: absolute;
	width: 1px;
	height: 103%;
	background: #a2a2a2;
	top: -9px;
	left: 66px;
}
.box-history__year {
	/*display: table-cell;*/
	display: block;
	width: 66px;
	box-sizing: border-box;
	padding: 18px 20px 18px 0;
	font-size: 16px;
	color: #a2a2a2;
}
.box-history__txt {
	display: table-cell;
	position: relative;
	padding: 18px 0 18px 20px;
	font-size: 15px;
	width: 100%;
	border-bottom: 1px solid #a2a2a2;
}
.box-history__txt:before {
	content: "・";
	position: absolute;
	font-size: 35px;
	color: #006AB8;
	left: -8px;
	top: 12px;
}
.box-history__content li {
	display: table;
}
.box-history__content li:last-child .box-history__txt {
	border-bottom: 0;
}
.box-history__image {
	margin-top: 35px;
}
@media only screen and (min-width: 1px) and (max-width: 767px) {
	.box-history {
		margin-top: 60px;
	}
	.box-history__section {
		font-size: 20px;
	}
	.box-history__content-wrp {
		margin-top: 10px
	}
	.box-history__content-wrp:before {
		height: 101%;
		top: -3px;
		left: 57px;
	}
	.box-history__year {
		width: 57px;
		font-size: 14px;
		padding: 9px 15px 9px 0;
	}
	.box-history__txt {
		font-size: 13px;
		padding: 9px 0 9px 15px;
	}
	.box-history__txt:before {
		top: 30px;
		left: -8px;
	}
	.box-history__image {
		margin-top: 18px;
	}
	.box-history__content li p{
		width:100%!important;
	}
}
/*-----------------------------------*/

.fadeshow > .active {
	left: 0;
	display: block;
}
.fadeshow > .fadeshow-item:not(.active) {
	display: none;
	position: relative;
	transition: 0.6s ease-in-out left;
}
.img-fadeshow {
	width: 100%;
}
.img-fadeshow:first-child {
	opacity: 0;
}


/*---------------------------------------------*/
.box {
	border: 1px solid #ddd;
	margin-bottom: 20px;
}
.box__title{
	padding: 9px 10px;
	background: #424242;
	color: #fff;
	font-size: 16px;
}
.box__inner {
	padding: 10px;
	box-sizing: border-box;
}
@media only screen and (min-width: 1px) and (max-width: 767px) {

}
.box-heading{
	text-align: center;
	position: relative;
}
.box-heading + *:first-child {
	margin-top: 0;
}
.box-heading .hdg-lv1{
	font-size: 55px;
	letter-spacing: 0.06em;
	font-weight: normal;
	line-height: 1.28;
	padding: 140px 0 120px;
}
.box-heading .hdg-lv1-s{
	font-size: 45px;
}
@media only screen and (min-width: 1px) and (max-width: 767px) {
	.box-heading__sub{
		font-size: 10px;
		margin-bottom: 10px;
	}
	.box-heading .hdg-lv1{
		font-size: 28px;
		padding: 60px 0;
	}
	.box-heading:before{
		width: 25px;
		height: 1px;
	}
}
/*---------------------------*/

/*-------------------------*/
.box-col {
	margin-top: 40px;
}
.box-col .box-col__text h4:first-child {
	margin-top: 0;
}
.box-col .box-col__txt-title {
	font-weight: bold;
	display: block;
	margin: 20px 0;
}
.box-col .box-col__image > span {
	display: inline-block;
}
.box-col .box-col__image-link {
	display: block;
	margin-top: 20px;
	text-align: left;
	line-height: 1.15;
}
.box-col--02 .box-col__text {
	width: 66%;
}
.box-col--02 .box-col__image {
	width: 34%;
}

@media only screen and (min-width: 1px) and (max-width: 767px){
	.box-col{
		margin: 30px 0 0;
	}
	.box-col__vision {
		margin-left: -15px;
		margin-right: -15px;
	}
	.box-col__image + .box-col__text {
		margin-top: 5px;
	}
	.box-col__text + .box-col__image {
		margin-top: 20px;
	}
	.box-col__image + .box-col__image {
		margin-top: 20px;
	}
	.box-col__image{
		text-align: center;
	}
	.box-col__text p {
		font-size: 13px;
		line-height: 20px;
	}
	.box-col .box-col__txt-title {
		margin: 10px 0;
		text-align: left;
	}
	.box-col .box-col__image-link {
		margin-top: 10px;
	}
	.box-col--02 .box-col__image,
	.box-col--02 .box-col__text {
		width: 100%;
	}
}

/*----------------------------------------------------
  #received-pages
--------------------------------------------------- */
.r-container {
    margin: 0 auto;
    width: 81.2%;
    max-width: 1170px;
}
@media screen and (max-width: 767px) {
    .r-container {
        width: auto;
    }
}


.mainvisual_web {
    margin: 56px auto 0;
}
.mainvisual__item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-left: -11.75%;
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end;
}
.mainvisual__item .main {
    width: 58.6%;
}
.mainvisual__item .sub {
    width: 41.4%;
}
.c-hdg-lg {
    position: relative;
    margin-top: 127px;
    padding-bottom: 30px;
    width: 66.66%;
    line-height: 1.5;
    font-size: 1.6rem;
    font-weight: bold;
}
.c-hdg-lg:after {
    position: absolute;
    display: block;
    content: "";
    width: 60px;
    height: 2px;
    background: #006AB8;
    bottom: 0;
    left: 0;
}
.c-hdg-lg-first {
    position: relative;
    padding-bottom: 30px;
    width: 66.66%;
    line-height: 1.5;
    font-size: 1.6rem;
    font-weight: bold;
}
.c-hdg-lg-first:after {
    position: absolute;
    display: block;
    content: "";
    width: 60px;
    height: 2px;
    background: #006AB8;
    bottom: 0;
    left: 0;
}

.c-wysiwyg {
    margin: 52px 0 0 15%;
    font-size: 1.6rem;
    line-height: 2.2;
}

@media screen and (max-width: 767px) {
    .mainvisual {
        margin-top: 39px;
    }
	
    .mainvisual__item {
        margin-left: 0;
    }
    .mainvisual__item .main {
        width: 100%;
    }
    .mainvisual__item .sub {
        display: none;
    }
    .c-hdg-lg {
        padding: 0 7% 17px;
        width: 100%;
        margin-top: 77px;
        font-size: 1rem;
    }
    .c-hdg-lg:after {
        width: 40px;
        left: 7%;
    }
    .c-hdg-lg-first {
        padding: 0 7% 17px;
        width: 100%;
         font-size: 1rem;
    }
    .c-hdg-lg-first:after {
        width: 40px;
        left: 7%;
    }
	
    .c-wysiwyg {
        margin: 24px 7% 0;
        font-size: 1.4rem;
    }
	
	
}
/* morelink
----------------------------------------------- */
.issue__morelink a {
    width: 220px;
}

.morelink {
	
}
.morelink a {
	display: block;
	position: relative;
	height: 60px;
	z-index: 1;
	float: right;
}
.morelink a:before,
.morelink a:after {
	display: block;
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: 4px;
	background-color: #000;
	z-index: 1;
}
.morelink a:after {
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	height: auto;
	transform: scaleX(0);
	transform-origin: right;
}
.morelink__label {
	display: flex;
	align-items: center;
	position: absolute;
	top: 0;
	left: 20px;
	right: 0;
	bottom: 0;
	font-size: 16px;
	font-weight: 700;
	text-indent: 0.08em;
	letter-spacing: 0.08em;
	z-index: 2;
}
.morelink__icon {
	position: absolute;
	top: 50%;
	margin: -6px 0 0;
	right: 10px;
	width: 8px;
	height: 13px;
	color: #000;
	z-index: 2;
}
.morelink__icon svg {
	position: absolute;
	top: 0;
	left: 0;
	max-width: 100%;
	max-height: 100%;
	z-index: 1;
	fill: currentColor;
}
@media(min-width: 769px) {

	/* morelink
	----------------------------------------------- */

	.morelink a:after,
	.morelink__label,
	.morelink__icon {
		transition-property: color, transform;
		transition-duration: 0.35s;
		transition-timing-function: cubic-bezier(0.83, 0, 0.17, 1);
	}

	/* hover */

	.morelink a:hover:after {
		transform: scaleX(1);
		transform-origin: left;
	}
	.morelink a:hover .morelink__label {
		color: #fff;
	}
	.morelink a:hover .morelink__icon {
		color: #fff;
		transform: translateX(3px);
	}
}


@media (max-width: 768px) {
.issue__morelink a {
    width: 200px;
}

	
	
}
/*----------------------------------------------------
  p-system
--------------------------------------------------- */


@media only screen and (min-width: 768px){
  .p-system .sub_title_l {
    margin-bottom: 30px; }
  .p-system .box-p {
    display: flex;
    justify-content: flex-start;
    flex-flow: nowrap;
    background: #fff;
    width: 100%;
    box-sizing: border-box;
    padding: 30px 50px;
    margin-bottom: 20px; }
    .p-system .box-p .title {
      width: 26%;
      padding-top: 15px; }
      .p-system .box-p .title div {
        font-size: 0.7rem;
        font-weight: 600;
        color: #777;
        padding-top: 20px;
        letter-spacing: 1px; }
        .p-system .box-p .title div span {
          display: block;
          color: #111419;
          font-family: neue-haas-grotesk-text, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "游ゴシック", YuGothic, "メイリオ", Meiryo, "Helvetica Neue", Helvetica, Arial, sans-serif !important;
          font-size: 1.2rem;
          letter-spacing: 0;
          padding-top: 7px;
          padding-bottom: 10px; }
    .p-system .box-p .text {
      position: relative;
      width: 74%;
      padding-top: 10px;
      padding-bottom: 25px; }
      .p-system .box-p .text .top_text {
        font-size: 1.5rem;
        font-weight: 700;
        line-height: 150%;
        letter-spacing: 1.7px;
        margin-bottom: 15px; }
      .p-system .box-p .text .slidedown {
        position: relative;
        width: 100%;
        height: auto;
        overflow: hidden;
        -webkit-transition: .35s ease-in-out;
        -moz-transition: .35s ease-in-out;
        transition: .35s ease-in-out; }
        .p-system .box-p .text .slidedown p {
          position: relative;
          z-index: 1;
          padding-right: 50px; }
      .p-system .box-p .text .slidedown.active {
        overflow: visible;
        height: auto; }
        .p-system .box-p .text .slidedown.active:after {
          display: none; }
      .p-system .box-p .text .p-system_btn {
        display: none; }
}
	
	
@media only screen and (max-width: 767px) {
  .p-system .box-p {
    position: relative;
    z-index: 2;
    background: #fff;
    width: 100%;
    box-sizing: border-box;
    padding: 30px 30px 70px;
    margin-bottom: 20px; }
    .p-system .box-p .title {
      display: flex;
      justify-content: space-between;
      flex-wrap: nowrap; }
      .p-system .box-p .title img {
        width: 28%;
        height: 28%; }
      .p-system .box-p .title div {
        width: 67%;
        font-size: 0.6rem;
        font-weight: 700;
        color: #777;
        letter-spacing: 1px; }
        .p-system .box-p .title div span {
          display: block;
          color: #111419;
          font-family: neue-haas-grotesk-text, "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "游ゴシック", YuGothic, "メイリオ", Meiryo, "Helvetica Neue", Helvetica, Arial, sans-serif !important;
          font-size: 0.9rem;
          letter-spacing: 0;
          padding-top: 7px;
          padding-bottom: 10px; }
    .p-system .box-p .text {
      position: relative;
      z-index: 2;
      border-bottom: 1px solid #e0e0e0;
      padding-top: 20px;
      padding-bottom: 10px; }
      .p-system .box-p .text .top_text {
        font-size: 1.3rem;
        font-weight: 700;
        line-height: 150%;
        letter-spacing: 1.7px;
        margin-bottom: 10px; }
      .p-system .box-p .text .slidedown {
        position: relative;
        width: 100%;
        z-index: 2;
        overflow: hidden; }
        .p-system .box-p .text .slidedown p {
          position: relative;
          z-index: 1;
          height: 84px;
          max-height: 84px;
          overflow: hidden; }
          .p-system .box-p .text .slidedown p:after {
            position: absolute;
            display: block;
            content: "";
            opacity: 1;
            z-index: 2;
            bottom: 0;
            left: 0;
            width: 100%;
            height: 30px;
            background: linear-gradient(180deg, rgba(255, 255, 255, 0.5) 0%, rgba(255, 255, 255, 0.5) 100%);
            -webkit-transition: .35s ease-in-out;
            -moz-transition: .35s ease-in-out;
            transition: .35s ease-in-out; }
        .p-system .box-p .text .slidedown .off {
          animation: box03_slidedown_off 0.5s ease-in-out forwards; }
        .p-system .box-p .text .slidedown .active {
          animation: box03_slidedown_active 0.5s ease-in-out forwards; }
          .p-system .box-p .text .slidedown .active:after {
            opacity: 0;
            -webkit-transition: .35s ease-in-out;
            -moz-transition: .35s ease-in-out;
            transition: .35s ease-in-out; }
}

@keyframes box03_slidedown_off {
  0% {
    height: 100%;
    max-height: 400px;
    overflow: visible; }
  100% {
    height: 84px;
    max-height: 84px;
    overflow: hidden; } }

@keyframes box03_slidedown_active {
  0% {
    height: 84px;
    max-height: 84px;
    overflow: hidden; }
  100% {
    height: 100%;
    max-height: 400px;
    overflow: visible; } }
      .p-system .box-p .text .p-system_btn {
        position: absolute;
        display: block;
        left: 56%;
        transform: translateX(-50%);
        -webkit-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
        bottom: -25px; }
        .p-system .box-p .text .p-system_btn a {
          position: relative; }
          .p-system .box-p .text .p-system_btn a span {
            display: block;
            position: absolute;
            border-bottom: solid 2px #111419;
            -webkit-transition: .35s ease-in-out;
            -moz-transition: .35s ease-in-out;
            transition: .35s ease-in-out;
            width: 10px;
            right: 14px; }
          .p-system .box-p .text .p-system_btn a span:nth-child(1) {
            top: 8px; }
          .p-system .box-p .text .p-system_btn a span:nth-child(2) {
            top: 8px;
            -webkit-transform: rotate(-90deg);
            -moz-transform: rotate(-90deg);
            transform: rotate(-90deg); }
          .p-system .box-p .text .p-system_btn a:after {
            position: absolute;
            z-index: 1;
            display: block;
            content: "";
            top: -10px;
            right: 0;
            width: 35px;
            height: 35px;
            border: 1px solid rgba(17, 20, 25, 0.3);
            border-radius: 50%;
            transition: all 0.12s ease-in 0s; }
        .p-system .box-p .text .p-system_btn .active span:nth-child(1) {
          top: 8px;
          -webkit-transform: rotate(45deg);
          -moz-transform: rotate(45deg);
          transform: rotate(45deg); }
        .p-system .box-p .text .p-system_btn .active span:nth-child(2) {
          top: 8px;
          -webkit-transform: rotate(-45deg);
          -moz-transform: rotate(-45deg);
          transform: rotate(-45deg); }
	
}
/*----------------------------------------------------
  product-top
--------------------------------------------------- */
.pro-top .c-imgTexts.adv-career {
  margin-top: 130px;
}

.pro-top .c-imgTexts.adv-career .bg {
  width: 46.8%;
}

.pro-top .c-imgTexts.adv-career .bg .main {
  width: 42%;
}

.pro-top .c-imgTexts.adv-career .bg .sub {
  width: 78.2%;
}

.pro-top .c-imgTexts.adv-career .c-imgTexts__texts {
  width: 38.5%;
}

@media screen and (max-width: 767px) {
  .pro-top .c-imgTexts.adv-career {
    margin-top: 80px;
  }
  .pro-top .c-imgTexts.adv-career .bg {
    margin: 36px 15% 0;
    width: 69.5%;
  }
  .pro-top .c-imgTexts.adv-career .bg .main {
    top: 25px;
  }
}
.c-imgTexts {
  max-width: 1440px;
  margin: 0 auto;
}

.c-imgTexts:after {
  position: relative;
  content: "";
  display: block;
  clear: both;
}

.c-imgTexts .bg {
  display: block;
  position: relative;
}

.c-imgTexts .bg .main {
  position: absolute;
  z-index: 2;
}

.c-imgTexts .bg .sub {
  z-index: 1;
}

@media screen and (max-width: 767px) {
  .c-imgTexts .bg {
    float: none !important;
  }
  .c-imgTexts .bg:after {
    display: block;
    content: "";
    clear: both;
  }
  .c-imgTexts .bg .main {
    position: relative;
    float: right;
    -webkit-transform: unset !important;
    transform: unset !important;
  }
  .c-imgTexts .bg .sub {
    position: absolute;
  }
}

.c-imgTexts__texts .sub {
  font-size: 1rem;
  font-weight: bold;
  color: #006AB8;
  letter-spacing: 0;
}

.c-imgTexts__texts .sub .copy::-moz-selection {
  background: #B4D5FE;
  color: #006AB8;
}

.c-imgTexts__texts .sub .copy::selection {
  background: #B4D5FE;
  color: #006AB8;
}

.c-imgTexts__texts .sub .copy::-moz-selection {
  color: #006AB8;
}

.c-imgTexts__texts .title {
  position: relative;
  margin-top: 11px;
  padding-bottom: 36px;
  font-size: 2.4rem;
  font-weight: bold;
  line-height: 1.4;
}

.c-imgTexts__texts .title:after {
  position: absolute;
  display: block;
  content: "";
  width: 60px;
  height: 2px;
  background: #006AB8;
  bottom: 0;
  left: 0;
}

.c-imgTexts__texts .texts {
  margin-top: 38px;
}

.c-imgTexts__texts .texts p {
  font-size: 1rem;
  line-height: 2.3;
}

.c-imgTexts__texts .texts p.note {
  padding-top: 5px;
  font-size: 1.3rem;
}

.c-imgTexts__texts .link {
  margin-top: 26px;
}

.c-imgTexts__texts .link a {
  position: relative;
  display: inline-block;
  padding: 10px;
  margin-left: -10px;
  font-size: 1.6rem;
  font-weight: bold;
}

.c-imgTexts__texts .link a:before {
  position: absolute;
  display: inline-block;
  content: "";
  background: #FFF;
  top: 50%;
  right: 22px;
  width: 10px;
  height: 12px;
  margin: -7px 0 0 2.5em;
}

.c-imgTexts__texts .link a:after {
  position: static;
  display: inline-block;
  content: "";
  margin-left: 20px;
  width: 12px;
  height: 12px;
  background: url(../../assets/images/common/arrow_r_bl.png) no-repeat 100% 50%/12px auto;
}

.c-imgTexts__texts .link a:hover {
  opacity: 1;
}

.c-imgTexts__texts .link a:hover:before {
  -webkit-animation: c-imgTexts-link .5s linear forwards;
  animation: c-imgTexts-link .5s linear forwards;
}

@-webkit-keyframes c-imgTexts-link {
  0% {
    right: 22px;
  }
  100% {
    right: 0;
  }
}

@keyframes c-imgTexts-link {
  0% {
    right: 22px;
  }
  100% {
    right: 0;
  }
}

@media screen and (max-width: 767px) {
  .c-imgTexts__texts {
    padding: 0 7%;
    float: none !important;
    width: 100% !important;
  }
  .c-imgTexts__texts .sub {
    margin-top: 0 !important;
    font-size: 0.9rem;
  }
  .c-imgTexts__texts .title {
    margin-top: 5px;
    padding-bottom: 8px;
    font-size: 1.6rem;
    line-height: 1.45;
  }
  .c-imgTexts__texts .title:after {
    width: 40px;
  }
  .c-imgTexts__texts .texts {
    margin-top: 16px;
  }
  .c-imgTexts__texts .texts p {
    font-size: 0.9rem;
    line-height: 2.2;
  }
  .c-imgTexts__texts .link {
    margin-top: 23px;
  }
  .c-imgTexts__texts .link a {
    font-size: 1.4rem;
    padding-right: 25px;
  }
  .c-imgTexts__texts .link a:before {
    display: none;
  }
}

.c-imgTexts.img-left .bg {
  float: left;
}

.c-imgTexts.img-left .bg .main {
  right: 0;
}

.c-imgTexts.img-left .c-imgTexts__texts {
  float: right;
  margin-right: 9.4%;
}

@media screen and (max-width: 767px) {
  .c-imgTexts.img-left .c-imgTexts__texts {
    margin-right: 0;
  }
}

.c-imgTexts.img-right .bg {
  float: right;
}

.c-imgTexts.img-right .bg .sub {
  float: right;
}

.c-imgTexts.img-right .c-imgTexts__texts {
  float: left;
  margin-left: 9.4%;
}

@media screen and (max-width: 767px) {
  .c-imgTexts.img-right .c-imgTexts__texts {
    margin-left: 0;
  }
}
.product-number {
	margin-top: 15px;
    font-size: 13px;
    margin-bottom: 8px;
	color: #006AB8;
    font-weight: 500;
}

.product-name {
    font-size: 20px;
    margin-bottom: 8px;
	line-height: 1.5;
    font-weight: 600;
}

.product-feature {
    font-size: 11px;
	color: #8a878a;
    line-height: 1.36364;
}


@media(max-width:768px) {
.product-number {
	margin-top: 15px;
    font-size: 3.46667vw;
    margin-bottom: 2.13333vw;
	width: 100%!important;
}

.product-name {
    font-size: 4.26667vw;
    margin-bottom: 2.13333vw;
}
.product-feature {
    font-size: 2.93333vw;
}	


}	
/*----------------------------------------------------
  product-dt
--------------------------------------------------- */
.product-dt-article__grid {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding: 80px 0 0
}
.product-dt-article__item {
    width: 50%
}
.product-dt-article__item--meta {
    padding-left: 70px
}


.product-dt-article__item--meta .info {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin: 0 0 1em
}
.product-dt-article__item--meta .info .catb {
    vertical-align: top;
    font-family: 'Roboto', sans-serif;
    font-size: 13px;
    font-weight: 500;
    width: 200px;
    text-align: center;
    padding: 2px 10px;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    -o-box-sizing: border-box;
    -ms-box-sizing: border-box;
    box-sizing: border-box;
    letter-spacing: 0.05em;
    background-color: #000;
    border: 1px solid #000;
    color: #FFFFFF;
}


.product-dt-article__item--meta .info-title {
    font-size: 18px
}
.product-dt-article__item--meta .info-title:after {
    padding: 0 1em;
    content: '/'
}
.product-dt-article__item--meta .feature .subject {
    font-size: 30px;
    line-height: 1.733333333333333;
    font-weight: 700;
	margin-bottom: 20px}

.product-dt-article__item--meta .intro {
    font-size: 14px;
	line-height: 2.285714285714286;
	color: #006AB8;
}
.product-dt-article__item--meta .intro:before {
    padding: 0 1em;
    content: '-'
}

.product-dt-article__item--meta .intro:after {
    padding: 0 1em;
    content: '-'
}

.product-dt-article__item--meta .feature .desc {
    font-size: 14px;
    line-height: 2.285714285714286;
    margin: 2em 0 0
}
.product-dt-article__item--btn {
    margin: 80px 0 0
}
.product-dt.goods-mit .product-dt-article__item--meta {
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
    padding-left: 0;
    padding-right: 70px
}
.product-dt.goods-mit .product-dt-article__item--media {
    -webkit-box-ordinal-group: 3;
    -ms-flex-order: 2;
    order: 2
}






@media(max-width:768px) {
    .product-dt-article__keyvisual {
        display: none
    }
    .product-dt-article__grid {
        display: block;
        padding: 0
    }
    .product-dt-article__item {
        width: 100%
    }
    .product-dt-article__item--meta {
        padding: 0 !important
    }
    .product-dt-article__item--meta .info {
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
		margin-top: 15px;
    }
	.product-dt-article__item--meta .intro {
		text-align: center;
}
.product-dt-article__item--meta .intro:before {
    content: none;
}

.product-dt-article__item--meta .intro:after {
    content: none;
}

    .product-dt-article__item--meta .info-title {
        font-size: 14px
    }
    .product-dt-article__item--meta .feature .subject {
        text-align: center;
        font-size: 20px
    }
    .product-dt-article__item--meta .feature .desc {
        margin: 1em 0 0
    }
    .product-dt-article__item--btn {
        margin: 30px 0 0
    }
}
/* -----------------------------------------------
 top__contact
 -------------------------------------------------- */


.top__contact {
	box-shadow: 0 0 13px 0 rgba(51,51,51,.1)
}

@media screen and (min-width:768px), print {
.top__contact {
	max-width: 1170px;
	width: 93%;
	padding: 36px 47px;
	margin: 10px auto 60px;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex
}
}

@media screen and (max-width:767px), print {
.top__contact {
	width: 84.211%;
	padding: 45px 30px 30px;
	margin: 50px auto 51px
}
}
.top__contact h3 {
	font-family: Poppins, sans-serif;
	font-weight: 700;
	font-size: 20px;
	line-height: 1
}

@media screen and (min-width:768px), print {
.top__contact h3 {
	width: 27.9%;
	text-align: center;
	box-sizing: content-box;
	-webkit-transform: translate(0, 16px);
	transform: translate(0, 16px)
}
}

@media screen and (max-width:767px), print {
.top__contact h3 {
	margin-bottom: 1.5em
}
}
.top__contact b {
	font-family: Poppins, sans-serif;
	font-weight: 700;
	display: block
}

@media screen and (min-width:768px), print {
.top__contact b {
	line-height: 1;
	font-size: 24px
}
}

@media screen and (max-width:767px), print {
.top__contact b {
	line-height: 1.6;
	font-size: 20px
}
}

@media screen and (min-width:768px), print {
.top__contact small {
	font-size: 12px
}
}

@media screen and (min-width:768px), print {
.top__contact_tel {
	text-align: center;
	width: 221px;
	padding-right: 70px;
	padding-left: 4%;
	box-sizing: content-box;
	white-space: nowrap;
	position: relative
}
/* -----------------------------------------------
	.top__contact_tel:after {
	content: '';
	position: absolute;
	width: 1px;
	height: 30px;
	background: #000;
	right: 37px;
	top: 50%;
	-webkit-transform: translate(0, -50%) rotate(16deg);
	transform: translate(0, -50%) rotate(16deg)
}
 -------------------------------------------------- */	
}

.top__contact_links a{color:#fff!important}
.top__contact_links a:hover{color:#000!important}

@media screen and (max-width:767px), print {
.top__contact_tel {
	padding-bottom: 30px;
	margin-bottom: 30px;
	border-bottom: 1px solid #000
}
.top__contact_tel small {
	font-size: 13px
}
}

@media screen and (min-width:768px), print {
.top__contact_links {
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	width: 41%
}
}

@media screen and (min-width:768px), print {
.top__contact_links .btn {
	width: 100%;
	line-height: 40px;
	height: 48px;
	padding: 0
}
}

@media screen and (max-width:767px), print {
.top__contact_links .btn {
	width: 100%
}
}

@media screen and (min-width:768px), print {
.top__contact_links .red {
	margin-left: 8px
}
}

@media screen and (max-width:767px), print {
.top__contact_links .red {
	margin-top: 8px
}
}
/******************************************************************************
 * btn_com_info
*******************************************************************************/


@media screen and (min-width: 769px), print {

  .btn_com_info {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .btn_com_info a {
    width: 260px;
    height: 50px;
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    background: #333333;
    font-size: 1rem;
    font-weight: bold;
    color: #fff;
    -moz-border-radius: 25px;
         border-radius: 25px;
    position: relative;
    -webkit-transition: all 0.3s ease;
    -moz-transition: all 0.3s ease;
    transition: all 0.3s ease;
  }
  .btn_com_info a:hover {
    opacity: 1;
    -moz-box-shadow: 0 9px 10px 0 rgba(0, 0, 0, 0.1);
         box-shadow: 0 9px 10px 0 rgba(0, 0, 0, 0.1);
    -webkit-transform: translateY(-3px);
       -moz-transform: translateY(-3px);
        -ms-transform: translateY(-3px);
            transform: translateY(-3px);
    background: #00b5a5;
	text-decoration: none;
  }
  .btn_com_info a::after {
    position: absolute;
    content: "";
    width: 9px;
    height: 15px;
    background: url("../images/btn_arrow.png") 0 0 no-repeat;
    -moz-background-size: contain;
         background-size: contain;
    top: 50%;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    right: 22px;
  }
}
@media screen and (max-width: 768px) {


  .btn_com_info {
	width: 260px;  
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin-top: 10.93333vw;
  }
  .btn_com_info a {
    width: 100%;
    height: 11.73333vw;
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    background: #333333;
    font-size: 3.73333vw;
    font-weight: bold;
    color: #fff;
    -moz-border-radius: 5.86667vw;
         border-radius: 5.86667vw;
    position: relative;
    -webkit-transition: all 0.3s ease;
    -moz-transition: all 0.3s ease;
    transition: all 0.3s ease;
  }
  .btn_com_info a::after {
    position: absolute;
    content: "";
    width: 2vw;
    height: 3.6vw;
    background: url("../images/btn_arrow.png") 0 0 no-repeat;
    -moz-background-size: contain;
         background-size: contain;
    top: 50%;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    right: 5.33333vw;
  }
}
.btn {
	background: #000;
	color: #fff;
	display: block;
	text-align: center;
	text-decoration: none;
	position: relative;
	line-height: 1
}

@media screen and (min-width:768px), print {
.btn {
	width: 240px;
	font-size: 14px;
	box-sizing: border-box;
	border: 3px solid #000;
	padding: 1.36em 0
}
.btn:hover {
	background: #fff;
	color: #000
}
.btn:hover:before, .btn:hover:after {
	border-color: #000
}
}

@media screen and (max-width:767px), print {
.btn {
	width: 160px;
	font-size: 13px;
	font-weight: 700;
	padding: 1.4em 0 1.6em
}
}
.btn:before {
	content: "";
	width: 7px;
	height: 7px;
	border-top: 1px solid #fff;
	border-right: 1px solid #fff;
	display: block;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	position: absolute;
	right: 20px;
	top: 50%;
	margin-top: -4px
}
.btn:after {
	content: "";
	width: 7px;
	height: 7px;
	border-top: 1px solid #fff;
	border-right: 1px solid #fff;
	display: block;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	position: absolute;
	right: 25px;
	top: 50%;
	margin-top: -4px
}


/*------------------------------------------------------------
	Construction-slide
------------------------------------------------------------*/
.office_photo{
/*width:91.77777vw;*/
margin-top:3rem;
/*margin-bottom:10rem*/}

.position-relative{
position:relative!important}

@media (max-width:1119.98px){
.office_photo{
margin-bottom:6rem;
width:auto}
}
.office_slider .slick-slide{
height:auto!important}
.office_slider .img-wrap{
margin:0 10px}
@media (max-width:575.98px){
.office_slider .img-wrap{
margin:0 5px}
.office_slider .img-wrap img{
height:150px}
}
.office_slider .slick-dots{
text-align:left;
bottom:-40px;
margin-left:-10px}
.office_slider .slick-dots li{
width:10px;
margin:0 3px}
@media (max-width:1119.98px){
.office_slider .slick-dots li{
margin:0 3px!important}
}
.office_slider .slick-dots li button:before{
-webkit-transform:scale(.5);
-o-transform:scale(.5);
transform:scale(.5);
-webkit-transition:.3s;
-o-transition:.3s;
transition:.3s}
.office_slider .slick-dots li.slick-active button:before{
-webkit-transform:scale(.8);
-o-transform:scale(.8);
transform:scale(.8);
-webkit-transition:.3s;
-o-transition:.3s;
transition:.3s}

.slider{
margin:20px auto;
width:100%;
height:336px;
opacity:0;
-webkit-transition:3s;
-o-transition:3s;
transition:3s;
overflow:hidden}
@media (max-width:1119.98px){
.slider{
height:400px}
}
@media (max-width:575.98px){
.slider{
height:123px}
}
.slider .slick-list{
height:100%}
.slider .slick-list .slick-track{
height:100%;
width:100%;
overflow:hidden}
.slider .slick-list .slick-track .slick-slide{
text-align:center}
.slider .slick-list .slick-track .slick-slide img{
max-width:auto;
max-height:100%;
height:100vh;
width:100%;
margin:0 auto;
-o-object-fit:cover;
object-fit:cover}
.slick-next:before,.slick-prev:before{
color:#000}
.slick-initialized{
opacity:1}
.img_01{
left:0;
top:0}
.img_01,.img_02{
position:absolute;
width:18%;
max-width:260px}
.img_02{
left:30%;
top:45%}
.img_03{
left:55%;
bottom:0}
.img_03,.img_04{
position:absolute;
width:18%;
max-width:260px}
.img_04{
left:80%;
top:-10%}
.content_slide:after{
content:"";
display:block;
width:50%;
height:1px;
border-bottom:1px solid #e3e4e5}
@media (max-width:1119.98px){
.content_slide:after{
content:none}
}
@media (max-width:575.98px){
.slick-dots li{
margin:0 .2px!important}
}
.slick-slider{
-webkit-box-sizing:border-box;
box-sizing:border-box;
-webkit-touch-callout:none;
-webkit-user-select:none;
-moz-user-select:none;
-ms-user-select:none;
user-select:none;
-ms-touch-action:pan-y;
touch-action:pan-y;
-webkit-tap-highlight-color:transparent}
.slick-list,.slick-slider{
position:relative;
display:block}
.slick-list{
overflow:hidden;
margin:0;
padding:0}
.slick-list:focus{
outline:none}
.slick-list.dragging{
cursor:pointer;
cursor:hand}
.slick-slider .slick-list,.slick-slider .slick-track{
-webkit-transform:translateZ(0);
-o-transform:translateZ(0);
transform:translateZ(0)}
.slick-track{
position:relative;
left:0;
top:0;
display:block;
margin-left:auto;
margin-right:auto}
.slick-track:after,.slick-track:before{
content:"";
display:table}
.slick-track:after{
clear:both}
.slick-loading .slick-track{
visibility:hidden}
.slick-slide{
float:left;
height:100%;
min-height:1px;
display:none}
[dir=rtl] .slick-slide{
float:right}
.slick-slide img{
display:block}
.slick-slide.slick-loading img{
display:none}
.slick-slide.dragging img{
pointer-events:none}
.slick-initialized .slick-slide{
display:block}
.slick-loading .slick-slide{
visibility:hidden}
.slick-vertical .slick-slide{
display:block;
height:auto;
border:1px solid transparent}
.slick-arrow.slick-hidden{
display:none}
.slick-loading .slick-list{
background:#fff url(/wp-content/themes/BitStar/dist/vendor/ajax-loader_c5cd7f53.gif) 50% no-repeat}

.slick-next,.slick-prev{
position:absolute;
display:block;
height:20px;
width:20px;
line-height:0;
font-size:0;
cursor:pointer;
top:50%;
-webkit-transform:translateY(-50%);
-o-transform:translateY(-50%);
transform:translateY(-50%);
padding:0;
border:none}
.slick-next,.slick-next:focus,.slick-next:hover,.slick-prev,.slick-prev:focus,.slick-prev:hover{
background:transparent;
color:transparent;
outline:none}
.slick-next:focus:before,.slick-next:hover:before,.slick-prev:focus:before,.slick-prev:hover:before{
opacity:1}
.slick-next.slick-disabled:before,.slick-prev.slick-disabled:before{
opacity:.25}
.slick-next:before,.slick-prev:before{
font-family:slick;
font-size:20px;
line-height:1;
color:#fff;
opacity:.75;
-webkit-font-smoothing:antialiased;
-moz-osx-font-smoothing:grayscale}
.slick-prev{
left:-25px}
[dir=rtl] .slick-prev{
left:auto;
right:-25px}
.slick-prev:before{
content:"\2190"}
[dir=rtl] .slick-prev:before{
content:"\2192"}
.slick-next{
right:-25px}
[dir=rtl] .slick-next{
left:-25px;
right:auto}
.slick-next:before{
content:"\2192"}
[dir=rtl] .slick-next:before{
content:"\2190"}
.slick-dotted.slick-slider{
margin-bottom:30px}
.slick-dots{
position:absolute;
bottom:-25px;
list-style:none;
display:block;
text-align:center;
padding:0;
margin:0;
width:100%}
.slick-dots li{
position:relative;
display:inline-block;
margin:0 5px;
padding:0}
.slick-dots li,.slick-dots li button{
height:20px;
width:20px;
cursor:pointer}
.slick-dots li button{
border:0;
background:transparent;
display:block;
outline:none;
line-height:0;
font-size:0;
color:transparent;
padding:5px}
.slick-dots li button:focus,.slick-dots li button:hover{
outline:none}
.slick-dots li button:focus:before,.slick-dots li button:hover:before{
opacity:1}
.slick-dots li button:before{
position:absolute;
top:0;
left:0;
content:"\2022";
width:20px;
height:20px;
font-family:slick;
font-size:6px;
line-height:20px;
text-align:center;
color:#000;
opacity:.25;
-webkit-font-smoothing:antialiased;
-moz-osx-font-smoothing:grayscale}
.slick-dots li.slick-active button:before{
color:#000;
opacity:.75}






/*------------------------------------------------------------
	products
------------------------------------------------------------*/
.works_top {
    /*padding-bottom: 175px;*/
    overflow: hidden;
}
.works_top .sp {
    display: none !important;
}
.works_top .pc {
    display: block !important;
}

@media screen and (max-width: 767px) {
	
	.works_top {
		/*padding-bottom: 120px;*/
	}
.works_top .pc {
    display: none !important;
}
.works_top .sp {
    display: block !important;
}
}
	
.works_top .products .comMainImg .slickBox {
	background: url(img/products/main_img.jpg?201902261) no-repeat center center;
}

.works_top .products .topTxt {
	margin-bottom: 92px;
	font-size: 18px;
	line-height: 2;
	text-align: center;
	font-weight: bold;
	letter-spacing: 6px;
}

.works_top .products .secBox {
	margin: 0 auto 50px;
	max-width: 1420px;
}

.works_top .products .secBox .imgBox {
	/*margin-bottom: 100px;*/
}

.works_top .products .secBox .imgBox:nth-child(2) {
	margin-bottom: 0;
}

.works_top .products .secBox .photoBox {
	position: relative;
	width: 54.2%;
	float: right;
	overflow: hidden;
}

.works_top .products .secBox .photoBox img {
	width: 100%;
}

.works_top .products .secBox .textBox {
	padding: 20px 0 0 4.1%;
	width: 43%;
	float: left;
	display: table;
	border-top: 1px solid #ccc;
	/*border-bottom: 1px solid #ccc;*/
	box-sizing: border-box;
}

.works_top .products .secBox .textBox .textBox-cts {
	display: table-cell;
	vertical-align: middle;
	padding-right: 5%;
	width: 100%;
	transition: all 0.15s;
	-webkit-transition: all 0.15s;
	box-sizing: border-box;
	text-decoration: none;
}

.works_top .products .secBox .textBox .num {
	margin-bottom: 12px;
	position: relative;
	color: #af9b50;
	font-family: 'Lato', sans-serif;
	font-weight: 900;
	font-size: 12px;
	text-align: left;
}

.works_top .products .secBox .textBox .num:before {
	position: absolute;
	width: 30px;
	left: 75px;
	top: 10px;
	border-top: 1px solid #af9b50;
	content: "";
}

.works_top .products .secBox .textBox p {
	font-size: 15px;
	line-height: 1.8;
	letter-spacing: 4px;
	font-weight: bold;
	text-align: left;
}

.works_top .products .secBox .textBox .txt {
	margin-bottom: 14px;
	display: block;
	font-size: 12px;
	font-family: 'Lato', sans-serif;
	font-weight: 900;
	letter-spacing: 2.9px;
}

.works_top .products .secBox .textBox .textImg {
	margin-bottom: 31px;
	display: block;
	font-size: 30px;
	color: #af9b50;
	font-weight: 900;
	/*font-family: 'Lato', sans-serif;*/
	line-height: 1;
}

.works_top .products .secBox .textBox .textImg img {
	max-width: 100%;
}


.works_top .products .scroll {
	display: none;
}

.works_top .products .comLink {
	display: none;
}
.works_top .comLink a {
    padding: 7px 0 8px;
    text-align: center;
    display: block;
    font-size: 13px;
    font-weight: 700;
    font-family: 'Lato', sans-serif;
    background-color: #AE9B4F;
    transition: all .3s;
    -webkit-transition: all .3s;
}

.works_top .comLink a:visited {
    color: #000;
}

.works_top .comLink a, a:link {
    color: #000;
    text-decoration: none;
}

.works_top .comLink .comLink a .arrow {
    display: inline-block;
    position: absolute;
    left: -12px;
    top: 12px;
}
@media all and (min-width: 768px) and (max-width: 1424px) {
	.works_top .products .secBox {
		margin: 0 20px 20px;
	}
}

@media all and (min-width: 768px) and (max-width: 1000px) {
	.works_top .products .secBox .textBox a {
		background-size: 24px 47px !important;
	}
}

@media all and (min-width: 768px) and (max-width: 1040px) {
	.works_top .products .secBox .textBox {
		padding-left: 1%;
	}
.works_top .products .secBox .textBox .textImg {
    margin-bottom: 31px;
    display: block;
    font-size: 20px!important;
    color: #af9b50;
    font-weight: 900;
    /* font-family: 'Lato', sans-serif; */
    line-height: 1;
}	
	.works_top .products .secBox .textBox p {
    font-size: 13px!important;
    line-height: 1.4!important;
    letter-spacing: 4px;
    font-weight: bold;
    text-align: left;
}	
}

@media screen and (max-width: 767px) {
	.works_top .products .scroll {
		display: block;
		font-size: 11px;
		position: absolute;
		left: 0;
		text-align: center;
		right: 0;
		bottom: 14px;
	}
	
	.works_top .products .scroll a {
		padding-top: 28px;
		display: block;
		background: url(img/common/icon07.png) no-repeat top center;
		background-size: 65px auto;
		font-family: 'Lato', sans-serif;
	}

	.works_top .products .topTxt {
		margin: 0 30px 43px;
		text-align: left;
		line-height: 1.55;
	}
	
	.works_top .products .secBox {
		margin: 0 30px 0px;
		border-bottom: 1px solid #ccc;
	}

	.works_top .products .secBox .imgBox {
		margin: 0 0 33px;
	}
	
	.works_top .products .secBox .photoBox {
		margin-bottom: 19px;
	display: block;
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
    height: auto;
	float: none;
	}
	
	.works_top .products .secBox .textBox {
		padding: 0 5%;
		display: block;
		float: none;
		width: auto;
		border: none;
	}
	
	
	.works_top .products .secBox .textBox .textImg {
		margin-bottom: 25px;
		font-size: 20px!important;
	}
	
	
	.works_top .products .secBox .textBox .textImg img {
		height: 26px;
	}
	
	.works_top .products .secBox .textBox p {
		font-size: 13px!important;
		letter-spacing: 1px;
		line-height: 1.4!important;
		font-size: 18px;
	}
	
	.works_top .products .secBox .textBox .txt {
		margin-bottom: 9px;
		font-size: 14px
	}
	
	.works_top .products .secBox .textBox .num {
		margin-bottom: 12px;
		font-size: 13px;
	}
	
	.works_top .products .comLink {
		display: block;
		margin: 0 0 77px;
	}
	.works_top  .comLink a {
    padding: 17px 0 18px;
    font-size: 12px;
}

	.works_top .comLink a .bg {
    padding: 0 42px;
    background: url("https://morter.org/wp-content/themes/morter/images/icon06.png") no-repeat left center;
    background-size: 16px auto !important;
}	
	.works_top .comLink a .arrow {
    display: none;
}
}

/*------------------------------------------------------------
	pattern
------------------------------------------------------------*/
.pt-section {
  padding: 10px 0; }
  @media (max-width: 767px) {
    .pt-section {
      padding: 48px 0; } }
  .pt-section--glay {
    background: #F7F7F7; }
  .pt-section--pt0 {
    padding-top: 0; }
  .pt-section .pt-section__wrap {
    max-width: 1100px;
    margin: 0 auto; }
    @media (max-width: 767px) {
      .pt-section .pt-section__wrap {
        padding: 0 4%; } }



.pt-update {
  display: flex;
  flex-wrap: wrap;
  margin-top: 48px;
  margin-left: -20px; }
  @media (max-width: 767px) {
    .pt-update {
      margin-left: -12px; } }
  .pt-update .pt-update__item {
    margin-top: 80px;
    width: calc(25% - 20px);
    margin-left: 20px;
    text-align: center; }
    @media (max-width: 767px) {
      .pt-update .pt-update__item {
        margin-top: 40px;
        width: calc(50% - 12px);
        margin-left: 12px; } }
    .pt-update .pt-update__item img {
      width: 100%;
		height: auto;
      margin: 0 auto; }
    .pt-update .pt-update__item h3 {
      margin: 24px 0 16px;
      font-size: 1.2rem; }
    .pt-update .pt-update__item p {
	   margin: 24px 0 0px;	
      font-size: .9rem;
	  font-weight: 600;}
  .pt-update .pt-update__item:nth-child(-n+4) {
    margin-top: 0; }
    @media (max-width: 767px) {
      .pt-update .pt-update__item:nth-child(-n+4) {
        margin-top: 40px; } }
  @media (max-width: 767px) {
    .pt-update .pt-update__item:nth-child(-n+2) {
      margin-top: 0; } }


/*----------------------------------------------------
  #works-receive
--------------------------------------------------- */

.works-r-title {
    position: absolute;
    /* top: 0; */
    /* left: 0; */
    /* width: 100%; */
    /* height: 100%; */
	width: calc((100% - 176px)/12*8 + 112px);
    background-color: #fff;
    padding: 20px 0 60px;
    margin: -60px auto 0;
    background: #fff;
    /*width: 750px;*/	
  }

.works-r-title h2 {
	font-size: 24px;
	padding-left: 5px;
	color: #333;
}
.works-r-title h2 span {
	margin-left: 15px;
	font-size: 12px;
	color: #949494;
	 vertical-align: middle;
}
  @media (max-width: 767px) {
	
.works-r-title {
	position: relative;
    width: 100%;
    padding: 20px 0 0px;
    margin: 0px auto 0;
  }

.works-r-title h2 {
	font-size: 20px;
	padding-left: 5px;
	color: #333;
}
.works-r-title h2 span {
	margin-left: 12px;
	font-size: 12px;
	color: #949494;
	 vertical-align: middle;
}
	  
	  
 }
/*----------------------------------------------------
  #company-received
--------------------------------------------------- */

.com-list {
	margin: 60px 0 127px;
	border-top: 1px solid #e5e5e5;
	border-bottom: 1px solid #e5e5e5;
}

.com-list li {
	width: 33.333333%;
	box-sizing: border-box;
	position: relative;
	float: left;
	border-right: 1px solid #e5e5e5;
}

.com-list li a {
	padding: 60px 26px 62px;
	display: block;
	transition: background 1.6s ease, color 1.6s ease;
}

.com-list li:last-child {
	border: none;
}

.com-list .pic {
	width: 100%;
	overflow: hidden
}

.com-list .pic img {
	width: 100%;
	transition: transform 1.6s ease;
}

.com-list li a:hover {
	background-color: #f1f4f7;
}

.com-list li a:hover img {
	transform: scale(1.2);
}

.com-list h4 {
	margin: 37px 0 21px 0;
	font-size: 21px;
	color: #000;
	letter-spacing: 2px;
	/*font-family: 'Marcellus', serif;*/
	font-weight: 400;
	text-align: center;
	word-break: break-all;
}

.com-list h4 span {
	margin-top: 9px;
	display: block;
	font-size: 13px;
	/*font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HGS明朝E", "メイリオ", Meiryo, serif;*/
}

.com-list p {
	text-align: center;
	font-size: 13px;
	line-height: 2;
	letter-spacing:1px;
}

.com-list p span {
	display: inline-block;
	text-align: left;
}
@media all and (min-width: 0) and (max-width: 767px) {
	
	.com-list {
		margin: 30px 0 65px;
	}

	.com-list li {
		width: 100%;
		float: none;
		border-bottom: 1px solid #e5e5e5;
		border-right: none;
	}

	.com-list li a {
		padding: 30px 37px 23px;
	}

	.com-list li a:hover {
		background-color: #fff;
	}

	.com-list li a:hover img {
		transform: scale(1);
	}

	.com-list h4 {
		margin: 16px 0 12px 0;
		font-size: 21px;
		font-weight: normal
	}

	.com-list h4 span {
		margin-top: 2px;
		font-size: 12px;
	}

	.com-list p {
		font-size: 12px;
		line-height: 1.8;
	}
	
	
	
	
	
	
	
}	
/*----------------------------------------------------
  #COMPANY PROFILE
--------------------------------------------------- */

.com-pro dl {
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    margin-bottom: 20px;
    overflow: hidden;
    -webkit-box-lines: multiple;
    -ms-flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: stretch;
    -ms-flex-align: stretch;
    -webkit-align-items: stretch;
    align-items: stretch;
}
.com-pro dl.border-set {
    border-bottom: solid 1px #eaeaea;
}


.com-pro dl.border-set > dt {
    border-top: solid 1px #eaeaea;
    padding: 28px 0;
}


.com-pro dl.border-set > dd {
    border-top: solid 1px #eaeaea;
    padding: 28px 0 28px 30px;
	line-height: 1.6;
}


.com-pro dt {
    width: 200px;
    padding: 0 0 10px;
    font-weight: bold;
    color: #222;
}


.com-pro dd {
    width: calc(100% - 200px);
    padding: 0 0 10px 30px;


}
@media screen and (max-width: 767px){
.com-pro dl {
    display: block;
    margin-bottom: 15px;
}	
.com-pro dl.border-set {
    border-bottom: 0 none;
    border-top: solid 1px #e5e9e9;
}	
.com-pro dl.border-set > dt {
    padding: 15px 0 5px;
    border-top: 0 none;
    font-size: 14px;
}
.com-pro dl.border-set > dd {
    width: auto;
    padding: 0 0 15px;
    border-top: 0 none;
    border-bottom: solid 1px #e5e9e9;
}	
	
.com-pro dt {
    width: auto !important;
    padding-bottom: 5px !important;
}	
.com-pro dd {
    width: auto !important;
    padding: 0 0 15px;
}
}	
/*----------------------------------------------------
  #about-us
--------------------------------------------------- */

.ggmap {
position: relative;
padding-bottom: 50%;
padding-top: 30px;
height: 0;
overflow: hidden;
}
 
.ggmap iframe,
.ggmap object,
.ggmap embed {
position: absolute;
top: 0;
left: 0;
width: 100%!important;
height: 100%!important;
}

/*----------------------------------------------------
  #works-top
--------------------------------------------------- */
.w-tp-img {
	max-width: 100%;
    height: auto;
}


.w-article__body_ttl {
	margin: 10px 0 30px;
    font-size: 16px;
    margin-bottom: 8px;
	line-height: 1.5;
    font-weight: 600;
	color: #212121;
}

.w-article__body_date {
    font-size: 13px;
    margin-bottom: 8px;
	color: #8a878a;
    font-family: Open Sans,sans-serif;
    font-weight: 300;
}

.w-article__body_note {
    font-size: 11px;
	color: #8a878a;
    line-height: 1.36364;
}


@media(max-width:768px) {

	
.w-article__body_ttl {
	margin-top: 15px;
    font-size: 4.26667vw;
    margin-bottom: 2.13333vw;
}
.w-article__body_date {
    font-size: 3.46667vw;
    margin-bottom: 2.13333vw;
}
.w-article__body_note {
    font-size: 2.93333vw;
}	
	
	
}


.w-list__cate, .w-list__date {
    display: flex;
    align-items: center;
    line-height: 1;
}

.w-list__date {
    margin-top: 1.48438vw;
    font-family: Roboto,sans-serif;
    font-size: .8375vw;
    font-weight: 700;
}

.w-list__date, .w-list__ttl {
    color: #a7a8ab;
    letter-spacing: 0;
    transition: color .15s cubic-bezier(.25,.25,.75,.75);
}

.w-list__cate {
    height: 1.25vw;
    padding: 1px .46875vw 0;
    margin-left: .625vw;
    font-size: .70312vw;
    font-weight: 400;
    color: #fff;
    text-transform: uppercase;
    background: #9c9c9c;
    border-radius: .78125vw;
    transition: background .15s cubic-bezier(.25,.25,.75,.75);
}
/*----------------------------------------------------
  faq
--------------------------------------------------- */
.web-faqList {}

.web-faqItem {
    border-bottom: 1px solid #e6eaed;
}

.web-faqItem:first-child {
    border-top: 1px solid #e6eaed;
}

.web-accordionHead {
    position: relative;
    padding: 36px 50px 32px;
}

.web-accordionTtl {
    font-size: 1rem;
    line-height: 1.8;
}

.web-accordionBody {
    display: none;
    padding: 0 50px 32px;
}
.web-accordionCopy {
    font-size: 1.4rem;
    line-height: 2;
    letter-spacing: 0.04em;
}

.web-accordionCopy+.web-accordionCopy {
    margin: 16px 0 0;
}

.u-accordionBody__btn {
    margin: 14px 0 0;
}

@media screen and (max-width: 768px) {
    .web-accordionHead {
        padding: 26px 30px 25px 0;
    }
    .web-accordionTtl {
        font-size: 1.3rem;
    }
    .web-faqList .web-faqItem .web-accordionBody {
        padding: 0 30px 27px 10px;
    }
    .web-accordionCopy {
        font-size: 1.2rem;
    }
    .web-accordionCopy+.web-accordionCopy {
        margin: 5px 0 0;
    }
}

/* accordion
/*------------------------*/
.c-accordionItem:after {
	position: absolute;
	bottom: -.15em;
	left: 0;
	display: block;
	width: 100%;
	height: 1px;
	content: "";
	-webkit-transition: -webkit-transform .7s cubic-bezier(.19, 1, .22, 1);
	     -o-transition:         transform .7s cubic-bezier(.19, 1, .22, 1);
	        transition: -webkit-transform .7s cubic-bezier(.19, 1, .22, 1);
	        transition:         transform .7s cubic-bezier(.19, 1, .22, 1);
	        transition:         transform .7s cubic-bezier(.19, 1, .22, 1), -webkit-transform .7s cubic-bezier(.19, 1, .22, 1);
	-webkit-transform: scaleX(0);
	    -ms-transform: scaleX(0);
	        transform: scaleX(0);
	-webkit-transform-origin: right top;
	    -ms-transform-origin: right top;
	        transform-origin: right top;
	background-color: #666;
	background-color: rgb(17 17 17 / 70%);
}
.c-accordionItem:hover:after {
	-webkit-transition: -webkit-transform .7s cubic-bezier(.19, 1, .22, 1);
	     -o-transition:         transform .7s cubic-bezier(.19, 1, .22, 1);
	        transition: -webkit-transform .7s cubic-bezier(.19, 1, .22, 1);
	        transition:         transform .7s cubic-bezier(.19, 1, .22, 1);
	        transition:         transform .7s cubic-bezier(.19, 1, .22, 1), -webkit-transform .7s cubic-bezier(.19, 1, .22, 1);
	-webkit-transform: scaleX(1);
	    -ms-transform: scaleX(1);
	        transform: scaleX(1);
	-webkit-transform-origin: left top;
	    -ms-transform-origin: left top;
	        transform-origin: left top;
}


.c-accordionItem {
	position: relative;
	overflow: visible;
}
.c-accordionItem:after {
	bottom: -1px;
}
.c-accordionBody > * {
	-webkit-transition: opacity .6s cubic-bezier(.4, 0, .2, 1) .2s, -webkit-transform .6s cubic-bezier(.4, 0, .2, 1) .2s;
	     -o-transition: opacity .6s cubic-bezier(.4, 0, .2, 1) .2s, transform .6s cubic-bezier(.4, 0, .2, 1) .2s;
	        transition: opacity .6s cubic-bezier(.4, 0, .2, 1) .2s, -webkit-transform .6s cubic-bezier(.4, 0, .2, 1) .2s;
	        transition: opacity .6s cubic-bezier(.4, 0, .2, 1) .2s, transform .6s cubic-bezier(.4, 0, .2, 1) .2s;
	        transition: opacity .6s cubic-bezier(.4, 0, .2, 1) .2s, transform .6s cubic-bezier(.4, 0, .2, 1) .2s, -webkit-transform .6s cubic-bezier(.4, 0, .2, 1) .2s;
	-webkit-transform: translateY(5px);
	    -ms-transform: translateY(5px);
	        transform: translateY(5px);
	opacity: 0;

	webkit-transition: opacity .6s cubic-bezier(.4, 0, .2, 1) .2s, -webkit-transform .6s cubic-bezier(.4, 0, .2, 1) .2s;
}

.c-accordionBody.is-fade > * {
	-webkit-transform: translateY(0);
	    -ms-transform: translateY(0);
	        transform: translateY(0);
	opacity: 1;
}

.c-accordionHead {
	position: relative;
}

.c-accordionHead:before, .c-accordionHead:after {
	position: absolute;
	display: inline-block;
	content: "";
	-webkit-transform: translate(0, -50%);
	    -ms-transform: translate(0, -50%);
	        transform: translate(0, -50%);
	background: #2c2c2c;
}

.c-accordionHead:before {
	top: 50%;
	right: 40px;
	width: 12px;
	height: 2px;
}

.c-accordionHead:after {
	top: 50%;
	right: 45px;
	width: 2px;
	height: 12px;
}

.c-accordionHead.is-active:after {
	display: none;
}


@media screen and (max-width: 768px) {
	.c-accordionHead::before {
		right: 9px;
		-webkit-transform: translate(0, -50%);
		    -ms-transform: translate(0, -50%);
		        transform: translate(0, -50%);
	}
	.c-accordionHead::after {
		right: 14px;
		-webkit-transform: translate(0, -50%);
		    -ms-transform: translate(0, -50%);
		        transform: translate(0, -50%);
	}
}
/*----------------------------------------------------
  .works_title
--------------------------------------------------- */


.works_title p {

  margin: 0 0 20px;
  font-size: 40px;
  font-weight: bold;
  line-height: 1;
  letter-spacing: .1em;
  font-family: 'Open Sans', sans-serif;	
  }

.works_title h2, .works_title p.txt_title {
  margin: 0;
  font-size: 15px;
  font-weight: bold;
  line-height: 1;
  font-family: 'Noto Sans JP', sans-serif;
  color:#9a9a9a;
  }
@media screen and (max-width: 769px) and (min-width: 600px) {
	
.works_title {

  padding: 20px 0 40px;
	margin: 0px auto 0;
    background: #fff;
	width: auto;
	
  }

.works_title p {

  font-size: 30px;
  }
	
	
}

@media screen and (max-width: 600px) {
.works_title {
  padding: 20px 0 40px;
	margin: 0px auto 0;
    background: #fff;
	width: auto;
  }

.works_title p {

  font-size: 24px;
  margin: 0 0 4px;
  }

.works_title h2 {

  font-size: 12px;
  }

}
/******************************************************************************
 * contact
*******************************************************************************/
 .l-contact {
  position: relative;
  padding: 96px 0;
  background: #f5f7f8; }
  @media (max-width: 767px) {
    .l-contact {
      padding: 48px 4%; } }



  .l-contact .l-contact__wrap {
    max-width: 1100px;
    margin: 0 auto; }
    .l-contact .l-contact__wrap h2 {
      position: relative;
      margin: 0 0 48px;
      font-size: 2.2rem;
      line-height: 1.4em;
      text-align: center;
      z-index: 1; }
      @media (max-width: 767px) {
        .l-contact .l-contact__wrap h2 {
          margin: 0 0 32px;
          font-size: 1.4rem; } }

/*----------------------------------------------------
  #INFO欄
--------------------------------------------------- */


.banner-links {
    position: relative;
    display: block;
    text-align: center;
    padding: 40px 0;
    word-spacing: nowrap;
    border: 1px solid #f0f0f0;
	border-radius: 5px;
    font-weight: bold;
    margin-bottom: 20px;
    letter-spacing: 2px;
    line-height: 100%;
	background: #fff;
    -webkit-transition: all 400ms cubic-bezier(0.165, 0.84, 0.44, 1);
    -moz-transition: all 400ms cubic-bezier(0.165, 0.84, 0.44, 1);
    -o-transition: all 400ms cubic-bezier(0.165, 0.84, 0.44, 1);
    transition: all 400ms cubic-bezier(0.165, 0.84, 0.44, 1);
    -webkit-transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
    -moz-transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
    -o-transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
    transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
    -webkit-transition-property: color;
    -moz-transition-property: color;
    -ms-transition-property: color;
    -o-transition-property: color;
    transition-property: color
}
@media(max-width: 991px) {
    .banner-links {
        padding: 30px 0;
        margin-bottom: 10px;
        letter-spacing: 1px
    }
}
@media(max-width: 767px) {
    .banner-links {
        padding: 15px 0;
        margin-bottom: 5px
    }
}
.banner-links.insta {
    letter-spacing: 0 !important;
    font-weight: normal;
    font-size: 0.8rem;
    padding: 30px 0
}
@media(max-width: 991px) {
    .banner-links.insta {
        padding: 20px 0
    }
}
@media(max-width: 767px) {
    .banner-links.insta {
        padding: 15px 0
    }
}
.banner-links svg {
    width: 50px;
    height: 50px;
    vertical-align: middle;
    fill: #000;
	margin-bottom: 15px;
    -webkit-transition: all 400ms cubic-bezier(0.165, 0.84, 0.44, 1);
    -moz-transition: all 400ms cubic-bezier(0.165, 0.84, 0.44, 1);
    -o-transition: all 400ms cubic-bezier(0.165, 0.84, 0.44, 1);
    transition: all 400ms cubic-bezier(0.165, 0.84, 0.44, 1);
    -webkit-transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
    -moz-transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
    -o-transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
    transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1)
}
@media(max-width: 767px) {
    .banner-links svg {
        width: 15px;
        height: 15px;
        margin-right: 10px
    }
}
.banner-links span {
    position: relative;
    z-index: 2
}
.banner-links:before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background: #000;
    opacity: 0;
	border-radius: 5px;
    -webkit-transform: scale(0.8);
    -moz-transform: scale(0.8);
    -ms-transform: scale(0.8);
    transform: scale(0.8);
    -webkit-transition: all 400ms cubic-bezier(1, 0, 0, 1);
    -moz-transition: all 400ms cubic-bezier(1, 0, 0, 1);
    -o-transition: all 400ms cubic-bezier(1, 0, 0, 1);
    transition: all 400ms cubic-bezier(1, 0, 0, 1);
    -webkit-transition-timing-function: cubic-bezier(1, 0, 0, 1);
    -moz-transition-timing-function: cubic-bezier(1, 0, 0, 1);
    -o-transition-timing-function: cubic-bezier(1, 0, 0, 1);
    transition-timing-function: cubic-bezier(1, 0, 0, 1);
    -webkit-transition-property: opacity, transform;
    -moz-transition-property: opacity, transform;
    -ms-transition-property: opacity, transform;
    -o-transition-property: opacity, transform;
    transition-property: opacity, transform
}
.banner-links:hover,
.banner-links:active,
.banner-links:focus {
    text-decoration: none;
    color: #fff
}
.banner-links:hover svg,
.banner-links:active svg,
.banner-links:focus svg {
    fill: #fff
}
.banner-links:hover:before,
.banner-links:active:before,
.banner-links:focus:before {
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1);
    opacity: 1
}
.banner-links .con_en {
font-family: futura-pt,sans-serif;
    font-size: 1.7rem;
    font-weight: 700;
    line-height: 1.5;
	letter-spacing: .12em;
}

.banner-links .con_jp 
{
    font-size: .9rem;
    font-weight: 500;
    line-height: 1.5;
	color: #9a9a9a;
}

p.con_en:hover,
p.con_en:active,
p.con_en:focus,
p.con_jp:hover,
p.con_jp:active,
p.con_jp:focus
{
    text-decoration: none;
    color: #fff
}
/*
  product-pdf
------------------------------------------------------------------------------*/
.product-pdf {
    border : 1px solid #eeefef;
    color : #222;
    display : flex;
    flex-basis : 100%;
    flex-direction : column;
    flex-shrink : 0;
    height : 100%;
	width: 100%;
    background-color: #ff0000;
    padding : 20px;
    position : relative;
    text-decoration : none;
    transition : border-color .3s  cubic-bezier(.25, .8, .25, 1),
    box-shadow .3 s cubic-bezier(.25, .8, .25, 1)
}
.product-pdf:after,.product-pdf:before {
    content : "";
    display : block;
    height : 30px;
    position : absolute;
    transition : border-color .3s cubic-bezier(.25, .8, .25, 1);
    width : 15px
}
.product-pdf:before {
   /*border-left : 2px solid #979d9d;
    border-top : 2px solid #979d9d;
    left : -1px;
    top : -1px*/
}
.product-pdf:after {
    /*border-bottom : 2px solid #979d9d;
    border-right : 2px solid #979d9d;
    bottom : -1px;
    right : -1px*/
}
.product-pdf:focus,.product-pdf:hover {
    border-color : #fff;
    box-shadow : 0 0 10px rgba(234, 0, 42, .36);
    text-decoration : none
}
.product-pdf:focus:after,.product-pdf:focus:before,.product-pdf:hover:after,.product-pdf:hover:before {
    border-color : #ea002a
}
.product-pdf:focus.product-pdf_title,.product-pdf:hover.product-pdf_title {
    color : #c01;
    text-decoration : underline
}
.product-pdf:focus.product-pdf_text,.product-pdf:hover.product-pdf_text {
    color : #222
}
.product-pdf_title {
    color : #fff;
    display : inline-block;
    font-size : 1.2rem;
    line-height : 1.5;
    order : -2;
    padding-left : 20px;
    position : relative;
    text-decoration : none
}
.product-pdf_title span {
    font-size: 20px;
    line-height: 0;
    margin-right: 5px;
    position: relative;
    top: 3px;
    color: #fff;
}


@media only screen and (max-width: 767px) {
.product-pdf_title {
    color : #fff;
    display : inline-block;
    font-size : .7rem;
    line-height : 1.5;
    order : -2;
    padding-left : 0px;
    position : relative;
    text-decoration : none
}
.product-pdf_title span {
    font-size: 15px;
    line-height: 0;
    margin-right: 5px;
    position: relative;
    top: 3px;
    color: #fff;
}
	
	
	
}
.product-pdf_text {
    font-size : 1.3rem;
    margin-top : 10px
}

.product-pdf_title span{
	
	color: white;
	
}

