@charset "utf-8";

/*********  キービジュアル用パーツ  ********/

.kv-bg-glay {
    background: #e9ebe8;
}

/* トップ用  */

/*  カルーセル用ラッパー  */
.c-lyt-keyvisual {
    min-height: 400px;
    margin-top: 0 !important;
}
.hero-area-c {
    min-height: 400px;
}
/* 商品紹介用  */
.c-hero-area-c-service {
    min-height: 500px;
}

@media only screen and (min-width: 768px) {
.hero-area-c .content-inner {
    max-width: 50%;
}
}

.hero-area-c .content-inner .sub-txt, .hero-area-c .content-inner .sub-txt>* {
    font-size: 2.2rem;
    font-weight: normal;
}
.hero-area-c .content-inner .main-txt, .hero-area-c .content-inner .main-txt>* {
    font-size: 4rem;
    font-weight: normal;
    line-height: 1.1;
}
/*  リードテキスト  */
.hero-area-c .content-inner .kv-lead-txt{
	max-width: 70%;
}

/*  トップ用  */
.hero-area-c .visual{
    min-height: 400px;
}
/*  商品紹介用  */
.c-hero-area-c-service .visual{
    min-height: 500px;
}

@media only screen and (max-width: 1280px) {
/*  トップ用  */
.hero-area-c .visual {
    min-height: 400px;
    height: inherit;
}
/*  商品紹介用  */
.c-hero-area-c-service .visual {
    min-height: 500px;
    height: inherit;
}
}

@media only screen and (max-width: 767px) {
/*  トップ用  */
.kv-bg-glay {
    background: #57564f;
}
.slick-list {
    background: #57564f;
}
.hero-area-c .content-inner {
    color: #fff;
}

.hero-area-c .visual, .c-hero-area-c-service .visual {
    height: calc(220vw*100/320);
    min-height: inherit;
}
.hero-area-c .content-inner .kv-lead-txt{
    max-width: 100%;
}
}

/*  企業ロゴ  */
.kv-img-left {
    position: absolute;
    left: 16px;
    bottom: 16px;
    z-index: 100;
}


/*********  ナビゲーションバー用パーツ  ********/
.nav-header {
    position: relative;
    width: 100%;
}

.nav-c {
    background: #dad9d6;
    position: relative;
    z-index: 0;
    top: inherit;
    transition: top .2s;
}

.nav-c::before {
    display: block;
    position: absolute;
    content: "";
    top: 100%;
    left: 0;
    width: 100%;
    height: 40px;
    z-index: -1;
    pointer-events: none;
}

.nav-c ul>li::before {
    display: block;
    position: absolute;
    content: "";
    top: 50%;
    left: 0;
    width: 1px;
    height: 32px;
    margin-top: -16px;
    background: #b1b1ac;
}

.nav-c ul>li::after {
    display: block;
    position: absolute;
    content: "";
    top: 50%;
    right: -1px;
    width: 1px;
    height: 32px;
    margin-top: -16px;
    background: #b1b1ac;
}

.nav-c ul a {
    text-decoration: none;
    padding: 20px 20px;
    display: table;
    width: 100%;
}


.nav-header>ul>li {
    width: 16.6666%;
    display: -ms-flexbox;
    display: -webkit-box;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-flow: row;
    flex-flow: row;
    position: relative;
}

.nav-header>ul>li>a {
    color: #000;
    text-decoration: none;
    width: 100%;
    display: -ms-flexbox;
    display: -webkit-box;
    display: flex;
    -ms-flex-align: center;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-pack: center;
    -webkit-box-pack: center;
    justify-content: center;
    background-color: #dad9d6;
    -webkit-transition: all 0.3s ease 0s;
    transition: all 0.3s ease 0s;
    font-size: 1.4rem;
    font-weight: bold;
}

.nav-header-wrap {
    position: relative;
    margin-top: 34px;
    overflow: hidden;
}

.nav-header>ul {
    color: #fff;
    display: -ms-flexbox;
    display: -webkit-box;
    display: flex;
    height: 60px;
    max-width: 1280px;
    margin: 0 auto;
    position: relative;
}

.nav-header>ul {
    color: #fff;
    display: -ms-flexbox;
    display: -webkit-box;
    display: flex;
    height: 60px;
    max-width: 1280px;
    margin: 0 auto;
    position: relative;
}

.nav-header>ul>li.active>a, .nav-header>ul>li.js-hover>a {
    color: #a30b1a;
}



@media only screen and (min-width: 1218px){
   	.nav-header .menu-btn {
    		  display: none;
    	}
	.nav-header.is-close > ul, .child-wrap .child {
    		display: -ms-flexbox !important;
    		display: -webkit-flex !important;
    		display: flex !important;
	}
}

@media only screen and (max-width: 1217px){
	.nav-header>.menu-btn {
    		  width: 100%;
    		  padding: 11px 46px;
		  text-align: center;
		  text-decoration: none!important;
		  display: inline-block;
		  line-height: 1.4;
		  position: relative;
		  transition: background .2s;
		  box-shadow: 0 1px 2px rgba(0,0,0,.18);
		  color: #000 !important;
		  background: #dad9d6;
		  border: 1px solid #dad9d6;
		  white-space: nowrap;
	}

       .nav-header.is-open>.menu-btn::after {
                  display: block;
                  position: absolute;
                  content: "";
                  top: 50%;
                  right: 20px;
                  width: 2px;
                  height: 23px;
                  background: #000;
                  -webkit-transform: rotate(45deg);
                  transform: rotate(45deg);
                  margin-top: -11px;
        }

	.nav-header.is-open>.menu-btn::before {
    		display: block;
    		position: absolute;
    		content: "";
	   	top: 50%;
	    	right: 20px;
	    	width: 2px;
	    	height: 23px;
	    	margin-top: -11px;
	    	background: #000;
	    	-webkit-transform: rotate(-45deg);
	    	transform: rotate(-45deg);
	}

	.nav-header>ul>li>a {
    		text-decoration: none;
    		position: relative;
    		display: block;
    		padding: 11px 32px 11px 16px;
    		border-bottom: 1px solid #c6c6c0;
    		background: rgba(238,238,238,.96);
		color: #000;
		cursor: pointer;
	}

	.nav-c{
		background: #ffffff !important;
	}
	
	.nav-header {
	    display: block;
	    position: relative;
    	    max-width: 1280px;
	    width: 100%;
	    z-index: 100;
	    padding: 0 16px;
	    margin: 0 auto 12px;
	    background-color: inherit;
	}

	.nav-header.is-close>.menu-btn::before {
    		display: block;
    		position: absolute;
    		content: "";
    		top: 50%;
    		right: 12px;
    		width: 20px;
    		height: 14px;
    		margin-top: -7px;
    		background: linear-gradient(#000,#000 2px,transparent 2px,transparent 6px,#000 6px,#000 8px,transparent 8px,transparent 12px,#000 12px);
	}

      .nav-header .toggle-txt {
            position: absolute;
    　　　　top: 0;
   　　　　 right: 0;
　　　　    z-index: -1;
　　　　    font-size: 1rem;
　　　　    opacity: 0;
　　　　}

      .nav-header.is-open>ul {
          display: block !important;
          height: inherit;
       }

      .nav-header > ul > li {
         width: 100%;
         display: block;
      }

      .nav-header>ul>li a, .nav-header > ul > li.active > a, .nav-header > ul > li.js-hover > a {
          text-decoration: none;
          position: relative;
          display: block;
          padding: 11px 32px 11px 16px;
          border-bottom: 1px solid #c6c6c0;
          background: rgba(238,238,238,.96);
       }

      .nav-header > ul > li a, .nav-header > ul > li.active > a, .nav-header > ul > li.js-hover > a {
         color: #000;
         cursor: pointer;
      }

	.nav-header>ul {
    		display: none;
    		margin-top: 16px;
	}

	.nav-c ul>li::before, .nav-c ul>li::after {
		content: none;
	}
}


/*********  商品紹介用パーツ  ********/
.bg-glay {
    background: #f3f3f3!important;
}

.border-none {
    border: none!important;
}

.lyt-idx-b .text-box::before {
     content: none;
}
.service-case-link {
    text-decoration: none;
}
.service-case-link:hover {
  display: block;
  opacity: 0.7;
}

@media only screen and (max-width:767px){
	.lyt-idx-b.diff-col4.diff-sp-col2 > * {
	    width: 50%;
	}
}


@media only screen and (max-width:480px){
	.lyt-idx-b{
		flex-direction:column;
	}

	.lyt-idx-b.diff-sp-col2>* {
    		padding-left: 0px;
    		padding-bottom: 16px;
	}

	.text-box > .heightLine-group1 {
    		height: auto !important;
	}

	.text-box > .heightLine-group2 {
    		height: auto !important;
	}

	.lyt-idx-b.diff-col3.diff-sp-col2>* ,
	.lyt-idx-b.diff-col4.diff-sp-col2>*{
    		width: 100%;
	}

}


.img-new img::after {
    position:absolute;
    top:0;
    left:0;
}

.sap-icon-new{
    position:relative;
    display: block;
    z-index: 30;
}

.sap-icon-new img{
    position: absolute;
    max-width: 80px;
    top: 0;
    left: 0;
}

.sap-label{
    display: inline-block;
    background-color: #999999;
    color: #ffffff;
    padding: 2px 5px 1px;
    font-size: 1.6rem;
    font-weight: normal;
    line-height: 1.2;
    margin-top:10px;
}

@media only screen and (max-width: 767px) {
    .cs-sap-kv-img-pos {
        right: calc(-40vw*100/320)!important;
    }
}

.sap-section-inner__reason{
	max-width: 1280px;
	margin: 0 auto;
	padding: 56px 0 64px;
}


.sap-lyt-4col-wrap{
	display: flex;
	flex-wrap: wrap;
	justify-content: left;	
	margin: 0 auto;

	padding: 0 4px;
}
.sap-lyt-4col-wrap{
	margin:0 auto;
}
	
.sap-lyt-4col-wrap  .item{
	/*max-width:200px;*/
	/*margin: 0 8px;*/
	width: 294px;
}

.sap-lyt-4col-wrap  .item:not(:last-child){
	margin-right: 32px;
}

.sap-lyt-4col-wrap  .item img{
	max-width: 200px;
	display: block;
	margin: 0 auto;
}

.sap-lyt-4col-wrap  .item .title{
	font-size: 1.6rem;
	font-weight: bold;
	text-align: center;
}

.sap-lyt-4col-wrap  .item .txtlnk{
	position: relative;
    height: 48px;
}
.sap-lyt-4col-wrap  .item .txtlnk a{
	position: absolute;
	right: 0;
	bottom: 0;
	color:#fff;
}

.sap-lyt-4col-wrap  .item .txtlnk a:hover{
	opacity: 0.5
}

.sap-lyt-4col-wrap  .item .txtlnk.arrw-right a::after{
	display: inline-block;
	content: "";
	border-top: 2px solid #fff;
	border-right: 2px solid #fff;
    margin-left: 10px;
    margin-right: 14px;
    vertical-align: 0;
    width: 9px;
    height: 9px;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}


.diff-sap-fp-bg {
	background-image:url(/jp/imagesgig5/bg_sap_top_tcm102-4691941_tcm102-2750236-32.jpg);
	background-repeat:no-repeat;
	background-size:  cover;
	background-position:left top;
}


.sap-future-product .sap-future-product-inner{
    /*display: flex;*/
    /*padding: 30px;*/
	padding: 60px 0px 60px 0px;
}

.sap-future-product .sap-future-product-inner .sap-future-product-inner__inner{
	margin: 0 auto;
	max-width: 1280px;
	padding: 0 2px;	
}



.diff-sap-bg-a,
.diff-sap-bg-a::before{
	background-color: rgba(255, 255, 255, 0.2);
}
.diff-sap-bg-b,
.diff-sap-bg-b::before{
	background-color: rgba(185, 172, 140, 0.2);
}

.sap-future-product .sap-future-product-inner .title-area{
	width: 306px;
	/*padding: 0 8px;*/
	margin-right: 16px;
	float: left;
	float: left;
}

.sap-future-product .sap-future-product-inner .title-area .main-title{
        font-size: 2.5rem;
        font-weight: bold;
        display: block;
}

.sap-future-product .sap-future-product-inner .title-area .sub-title{

}

.sap-future-product .sap-future-product-inner .contents-area{
    /*display: flex;*/
    /*width: 80%;*/
    /*justify-content: space-between;*/
    /*flex-wrap: wrap;*/
	float:left;
	width: calc(100% - (306px + 16px))
}

.sap-future-product .sap-future-product-inner .contents-area .item{
    width:306px;
	float:left;
}
.sap-future-product .sap-future-product-inner .contents-area .item:not(:last-child){
	margin-right:14px;
}

.sap-future-product .sap-future-product-inner .contents-area .item .sub-title{
	font-size:1.6rem;
	text-align:center;
}
.sap-future-product .sap-future-product-inner .contents-area .item .title{
    font-size:2rem;
    font-weight:bold;
	text-align:center;
}
.sap-future-product .sap-future-product-inner .contents-area .item img{
	margin-bottom: 16px;
}
.sap-future-product .sap-future-product-inner .contents-area .item .lead{
	margin-top: 16px;
	padding:16px;
}

.hdg-b.diff-sap-accent-none::before {
    display: none;
}

@media only screen and (max-width: 768px) {

	.sap-lyt-4col-wrap  .item{
		margin: 0 auto !important;
	}
	
	.sap-future-product .sap-future-product-inner{
		display:block;
	}
	
	.sap-future-product .sap-future-product-inner .title-area,
	.sap-future-product .sap-future-product-inner .contents-area{
		display: block;
		margin: 0 auto;
		width: 100%;
		float:none;
	}
	
	.sap-future-product .sap-future-product-inner .title-area .title{
		text-align: center;
	}
	
	.sap-future-product .sap-future-product-inner .title-area{
		text-align: center;
		margin-bottom: 16px;
		float:none;
	}
	.sap-future-product .sap-future-product-inner .contents-area .item{
		width: 80%;
		margin: 0 auto;
		float:none;
		text-align: center;
	}
	.sap-future-product .sap-future-product-inner .contents-area .item:not(:last-child){
		margin: 0 auto 30px auto;
	}

}	

.u-mt-0{
	margin-top:0;
}

.u-mt-10{
	margin-top:10px;
}

.u-mt-20{
	margin-top:20px;
}

.u-mt-30{
	margin-top:30px;
}
