@charset "UTF-8";

/* 会社情報 
-------------------- */
.company .content-wrap.bussiness-index{
 padding-bottom:40px;
}
@media screen and (max-width: 768px){
 .company .content-wrap.bussiness-index{
  padding-bottom:30px;
 }
}
.menu-in.first{
 padding-bottom: 0;
}
@media screen and (max-width: 768px){
 .menu-in.first{
  padding: 0;
 }
}
.menu-in .link-col{
 max-width:420px;
 width:100%;
 border-radius: 20px;
 overflow: hidden;
 box-shadow:8px 8px 0px rgb(102 102 102 / 6%);
 transition:0.3s all;
 display:block;
}

.menu-in > .link-col:first-child{
 margin-right:calc(100% - 840px);
}
@media screen and (max-width: 768px){
 .menu-in > .link-col:first-child{
  margin-right:0;
  margin-bottom:30px;
 }

}

.menu-in .menu-text span.bus-link{
 display:inline-block;
 font-size:20px;
 font-weight:bold;
}
.link-col .menu-img{
 height:236px;
 overflow:hidden;
}

@media screen and (max-width: 768px){
 .link-col .menu-img{
  height:auto;
 }

}
.link-col .menu-img img{
  transform:scale(1);
  opacity:1;
  display:block;
  transition:0.3s all;
}
.link-col:hover .menu-img img{
  transform:scale(1.05);
  opacity:0.7;
  display:block;
  transition:0.3s all;
}


@media screen and (max-width: 768px){
 .menu-in .menu-text span.bus-link{
  font-size:18px;
 }
 .link-col:hover .menu-img img{
  transform:scale(1);
  transition:0.3s all;
  }

}

.company .menu-in .menu-text {
 padding:28px 30px ;
}
@media screen and (max-width: 768px){

.company .pankuzu{
  max-width:initial;
  padding:10px 15px 15px;
 }
}


/* 商品開発サポート 
-------------------- */

@media screen and (max-width: 768px){
.support .container-in {
    max-width: initial;
    width: 100%;
    padding: 50px 10px 0;
 }
 .h3-subhead-txt.subhead-area{
   text-align:center;
 }
}
.spport-content{
 display:flex;
 align-items: center;
 position:relative;
 margin-bottom:80px;
}
@media screen and (max-width: 768px){
 .spport-content{
  display:block;
  margin-bottom:50px;
 }
}
.spport-content.last{
 margin-bottom:60px;
}
@media screen and (max-width: 768px){
.spport-content.last{
 margin-bottom:50px;
}

}
.spport-content.reverse{
 flex-flow: row-reverse;
 justify-content: start;
}

.spport-content .text{
 text-align:left;
 background: #FBF6EC;
 border-radius: 10px;
 max-width:500px;
 width:100%;
 height:330px;
 position:relative;
 margin-right: -100px;
 padding:50px 40px;
}
@media screen and (max-width: 768px){
 .spport-content .text{
   margin:-30px 16px 0;
   max-width: inherit;
   box-sizing: border-box;
   width: auto;
   padding:30px ;
   height:auto;
  }
}

.spport-content:not(.reverse) .text{
 margin-left: -100px;
}

@media screen and (max-width: 768px){
 .spport-content:not(.reverse) .text{
  margin-left: 16px;
 }

}

.spport-content .text:before{
 content:url(/materials/common/img/company/spport-content-line-top.svg);
 position:absolute;
 top:0;
 left:0;
}
.spport-content .text:after{
 content:url(/materials/common/img/company/spport-content-line-bottom.svg);
 position:absolute;
 bottom:-6px;
 right:0;
}

.spport-content .img{
 max-width:600px;
 width:100%;
 flex-shrink: 0;
}

.spport-content .text .h3-subhead-txt{
 font-size: 28px;
 text-align:left;
 line-height:1.4;
 font-feature-settings: "palt";
 margin-bottom:23px;
}

@media screen and (max-width: 768px){
 .spport-content .text .h3-subhead-txt{
  font-size: 22px;
  margin-bottom:14px;
  }
}

.spport-content .text .article{
 font-size:16px;
 line-height:32px;
 font-feature-settings: "palt";
}

/* 各部門の業務内容 
-------------------- */
.department .h2-title-img{
 margin-bottom:20px;
}
.department .container-in{
 background:#fff;
}

.department-flex{
 display:flex;
 flex-wrap:wrap;
 background:#fff;
 padding-bottom:0;
 margin-bottom: 54px ;
}

@media screen and (max-width: 768px){
 .department-flex{
   padding-right:0;
   padding-left:0;
 }
}

.department-in{
 background: #FBF6EC;
 border-radius: 10px;
 padding: 50px 30px 30px;
 font-size: 16px;
 max-width:420px;
 width:100%;
 position:relative;
}

.dep-01:before , .dep-02:before, .dep-03:before, .dep-04:before{
 content:url(/materials/common/img/company/img-dep01.svg);
 position:absolute;
 top:-40px;
 left: calc((100% - 70px) / 2);
 width:70px;
 height:70px;
}
.dep-02:before{
 content:url(/materials/common/img/company/img-dep02.svg);
}
.dep-03:before{
 content:url(/materials/common/img/company/img-dep03.svg);
}
.dep-04:before{
 content:url(/materials/common/img/company/img-dep04.svg);
}
.dep-01 , .dep-02{
 margin-bottom:80px;
}
@media screen and (max-width: 768px){
 .dep-01:before , .dep-02:before, .dep-03:before, .dep-04:before{
 width:64px;
 height:64px;
}
 .dep-01 , .dep-02 , .dep-03{
  margin-bottom:54px;
 }


}
.department-in .h3-subhead-txt{
 margin-bottom:14px;
}
@media screen and (max-width: 768px){
 .department-in .h3-subhead-txt{
  text-align:center;
 }

}

.department-flex .department-in:nth-of-type(odd){
  margin-right:40px;
}
@media screen and (max-width: 768px){
 .department-flex .department-in:nth-of-type(odd){
   margin-right:0;
 }
}

.department-in .txt{
 margin-bottom:20px;
}

/* 企業理念 
-------------------- */
.philosophy .last-content-box{
 font-size:26px;
 max-width:880px;
 width:100%;
 background-image: url(/materials/common/img/company/border-al.svg), url(/materials/common/img/company/border-bl.svg), url(/materials/common/img/company/border-bl.svg), url(/materials/common/img/company/border-al.svg);
 margin-bottom:50px;
 line-height:1.4;
}
@media screen and (max-width: 768px){
 .philosophy .last-content-box{
  font-size:20px;
   background-image: url(/materials/common/img/bussiness/border-a-sp.svg), url(/materials/common/img/bussiness/border-b-sp.svg), url(/materials/common/img/bussiness/border-b-sp.svg), url(/materials/common/img/bussiness/border-a-sp.svg);
    margin-bottom:36px;
 }

}


.philosophy .content-wrap{
 margin-bottom:80px;
}
.philosophy .p-mb{
 margin-bottom:20px;
}
@media screen and (max-width: 768px){
 .philosophy .content-wrap{
  margin-bottom:50px;
 }
 .philosophy .p-mb{
  margin-bottom:16px;
 }
}
.inner-flex{
 display:flex;
 margin-bottom:80px;
}

.inner-flex .txt{
 margin-right:30px;
}
.inner-flex.shirota .txt{
 margin-right:0;
 margin-left:30px;
}
.inner-flex .img{
 flex-shrink: 0;
 max-width: 250px;
 width: 100%;
}

@media screen and (max-width: 768px){
 .inner-flex .img{
  margin-top:30px;
 }
}

.philosophy .note{
 color:#666666;
 font-size:14px;
 margin-top:14px;
}

.philosophy .txt .note{
 color:#3C3C3C;
}

.shirota-ism{
 background:#fff;
 padding:20px 150px 30px;
 border-radius: 10px
}

@media screen and (max-width: 768px){
 .inner-flex{
  flex-flow: column;
  margin-bottom: 50px
 }
 .inner-flex .txt{
  margin-right:0;
 }
 .inner-flex.shirota{
  flex-direction: column-reverse;
 }
 .inner-flex.shirota .txt{
  margin-right:0;
  margin-left:0;
 }
 .inner-flex .img{
  flex-shrink: 0;
  max-width: initial;
  width: 100%;
 }
 .shirota .img{
  padding:0 18px;
 }
 .shirota-ism{
  background:#fff;
  padding:20px 10px 30px;
 }
 .content-wrap .shirota .note{
  margin-bottom:0;
 }
}

/* 会社概要 
-------------------- */
.company-overview .content-wrap{
 background:#fff;
 padding:0 60px;
 margin-bottom:50px;
}
@media screen and (max-width: 768px){
.company-overview .content-wrap{
  padding:0;
  margin-bottom:30px;
 }
}
.overview{
 display:flex;
 border-top:1px solid #DDDDDD;
}
@media screen and (max-width: 768px){
.overview{
  display:block;
 }
}
.overview.last{
 border-bottom:1px solid #DDDDDD;
}
.overview dt{
 max-width:280px;
 width:100%;
 padding:24px;
 color:#666666;
 font-size:14px;
}
.overview dd{
 font-size:14px;
 padding:24px 0;
 color:#282828;
}
@media screen and (max-width: 768px){
 .overview dt{
  max-width:initial;
  padding:20px 0 12px 0;
 }
 .overview dd{
  padding:0 0  22px 0;
 }
}

.map > div:first-child{
 margin-bottom:40px;
}
.map-flex{
 display:flex;
}
.map-flex > div{
 max-width:420px;
 width:100%;
}
.map-flex > div:first-child{
 margin-right:40px;
}

@media screen and (max-width: 768px){
 .map-flex{
  display:block;
  margin-bottom:40px;
 }
 .map-flex > div{
   max-width:initial;
  }
 .map-flex > div:first-child{
   margin-right:0;
   margin-bottom:20px;
  }
}

.map-h3-txt{
 display:block;
 font-size:16px;
 margin-bottom:10px;
 position:relative;
 padding-left:14px;
}
.map-h3-txt:before{
 content:"";
 display:block;
 background:#E62334;
 width:4px;
 height:20px;
 position: absolute;
 top: 4px;
 left:0;
}
.map .address{
 display:table;
}
.map .address span{
 display:table-cell;
}
.map .address span:first-child{
 width:50px;
}

/* 沿革 */

.history{
 display:flex;
 align-items: center;
 font-size:14px;
}
@media screen and (max-width: 768px){
.history{
  display:block;
 }
}
.company-overview .content-wrap.history-list{
 margin-bottom: 60px
}

@media screen and (max-width: 768px){
  .company-overview .content-wrap.history-list{
   margin-bottom: 50px
  }

}
.history-list .history:nth-of-type(odd){
 background:#F6F6F6;
}
.history{
 padding:20px 30px;
}
.history dt{
  padding-right:30px;
  max-width:122px;
  width:100%;
  border-right:2px solid #666666;
  color:#666;
}
.history dd{
 padding-left:30px;
 color:#282828;
}

@media screen and (max-width: 768px){
 .history{
   padding:20px 20px;
  }
 .history dt{
  padding-bottom:10px;
  border-right:none;
  position:relative;
 }
 .history dt:after{
  content:"";
  display:block;
  width:30px;
  height:2px;
  background:#666666;
  position:absolute;
  bottom:0;
 }
 .history dd{
  padding-left:0;
  padding-top:12px;
 }
}
