@charset "utf-8";



/*ヘッダー*/
#header{ /*position:relative; margin-top:-400px; z-index:25*/}


/*.headerImg{position:relative; z-index:10;}
.headerImg,
.headerImg p{height:318px;width:100%;}
.headerImg img{display:block;margin-right:1280px;}
.headerImg p{
  
  background-position: center center; 
  background-repeat: no-repeat;
}*/



#vegas{
  min-height: 600px !important;
 /* height: calc(100vh - 60px) !important;
  height: -webkit-calc(100vh - 60px) !important;*/
  /*height: calc(100vh - 80px) !important;
  height: -webkit-calc(100vh - 80px) !important;*/
  height: 100vh !important;
  max-height: 1080px;
  position: relative;
  letter-spacing: 0.06rem;
  z-index: 2;

}
.vegas-title-back{
  font-size: 5rem;
  height: 100%;
  top: 0;
  bottom: 0;
  margin: auto;
  width: 100%;
  /*background:hsla(0,0%,0%,0.24);*/
  background:hsla(0,0%,0%,0.00);
  position: absolute;

}
/*.vegas-title{
  color: #fff;
  position: absolute;
  top: 25%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  z-index: 3;
  width: 95%;
  text-shadow: 1px 1px 9px rgba(0, 0, 0, 0.2), -2px -2px 9px rgba(0, 0, 0, 0.02);
  text-align: center;
}*/
/*.index_title{
  width: 513px;

}*/

.vegas-navi{
    width: 100%;
    height: 60px;
    position: absolute;
    top: 50%;
    bottom: 0;
    margin: -30px 0;
    z-index: 3;
}
#previous{
  float: left;
      /* 要素自体の大きさは不要のため、0に設定する */
  width: 0px;
  height: 0px;
  /* border-topとborder-bottomの太さを同一にすると、三角形の頂点が真ん中になる */
  border-top: 30px solid transparent;
  border-bottom: 30px solid transparent;
  /* border-leftの大きさを大きくすると、三角形は横に大きくなる */
  border-right: 30px solid hsla(0,0%,100%,0.26);
  border-left: 0px solid transparent;
}
#next{
  float: right;
    /* 要素自体の大きさは不要のため、0に設定する */
  width: 0px;
  height: 0px;
  /* border-topとborder-bottomの太さを同一にすると、三角形の頂点が真ん中になる */
  border-top: 30px solid transparent;
  border-bottom: 30px solid transparent;
  /* border-leftの大きさを大きくすると、三角形は横に大きくなる */
  border-left: 30px solid hsla(0,0%,100%,0.26);
  border-right: 0px solid transparent;
}
#vegasM{
  min-height: 250px !important;
  height: 250px !important;
  max-height: 250px;
  position: relative;
  letter-spacing: 0.06rem;
  z-index: 3;

}
/*.vegas-t-t{
  font-size: 6rem;
  font-family: sans-serif;
  font-weight: 700;
}
.vegas-t-n{
  font-size: 2.0rem;
  font-family: sans-serif;
}
.vegas-t-m{
    font-size: 1.5rem;
}*/
.MobileTop{
/*  height: 250px;
  display: table;
  width: 100%*/
}
.MobileTopWrap{
  /*display: table-cell;
  vertical-align: middle;*/
}
.MobileTitle{

}

/*グループリンクボタン*/
/*.grouplink {
  position: absolute;
  font-size: 1.6rem;
  margin: 5rem auto 0 auto;
  top: 20rem;
  bottom: 0;
  left: 0;
  right: 0;
  background: rgba(0,0,0,0.4);
  width: 19rem;
  height: 4.8rem;
  line-height: 4.8rem;
//  padding: 1.1rem 1rem;
  border: 1px solid #7c7c7c;
  color: #fff;
}
.grouplink:hover{
  -webkit-transition: all 0.5s ease;
  -moz-transition: all 0.5s ease;
  -o-transition: all 0.5s ease;
  transition: all  0.5s ease;;
  background: rgba(95,95,95,0.75);
}*/

.side-menu {
  position: fixed;
  top: 20vh;
	right:0;
	z-index:1;
}

.side-menu li a{
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  font-size:1.4rem;
	padding:20px 10px;
  color:#FFFFFF;
	background-color: rgba(18,111,163,0.80);
  border-top-left-radius: 10px;
  border-bottom-left-radius: 10px;
}

/*.contenttwrap{
  margin: 0 auto;
  color: #fff;
// width: 53rem;
//  min-width: 53rem;
  font-size: 1.5rem;
  font-weight: 500;
  padding-bottom: 1rem;
  text-align: center;
}*/

/*.content-message{
  margin-bottom: 3rem;
  letter-spacing: 0.06rem;
  font-size: 1.6rem;
  font-weight: 300;
}*/
/*.jigyowrap{
  position: relative;
}*/
/*.jigyonaiyo {
  position: relative;
  left: 0;
  right: 0;
  bottom: 0;
  margin: 0 auto;
  max-width: 1300px;
  min-width: 1050px;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: center; 
  padding: 0px;
  -webkit-flex-wrap:wrap;
  -moz-flex-wrap:wrap;
  flex-wrap:wrap;
}
.jigyo-bnr div{
   margin: 10px 10px;
  background-size:32rem 18rem;
  background-position: top center;
  padding-bottom: 1.2rem;
  box-shadow: 0px 2px 10px rgba(34,34,34,0.3);
}
.jigyo-bnr div a{
 display: table-cell; // IE8から使用可能 
 vertical-align:bottom;
  font-size: 1.3rem;
  color: #000;
  left: 0;
  top: 0;
}
.jigyo-bnr .oem,.jigyo-bnr .pbm,.jigyo-bnr .nbw{
  background:rgba(255,255,255,1.00);
  background-position: 50% 0rem;
  background-repeat: no-repeat;
  background-size: 32rem 18rem;
}
.jigyo-bnr .oem{background-image:url(../img/index_jigyo_oem.jpg);}
.jigyo-bnr .pbm{background-image:url(../img/index_jigyo_pbm.jpg);}
.jigyo-bnr .nbw{background-image:url(../img/index_jigyo_nbw.jpg);}

.jigyo-bnr div,.jigyo-bnr div a{
  height:35rem;
  width:32rem;
}
.co{
  position: relative;
  background-image:url(../img/index_co_back.jpg);
  background-attachment: fixed;
  background-size:1920px 1080px;
  background-position: bottom center;
  height: 100vh;
  min-height: 85rem;
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}
.co::before{
  content: '';
  position: absolute;
  background-color: rgba(255,255,255,0.16);
  top: 0;
	right: 0;
	bottom: 0;
	left: 0;
}
.co-wrap{
  position: relative;
  display: table-cell;
  text-align: center;
  vertical-align: middle;
  box-shadow: 0px 2px 10px rgba(34,34,34,0.3);
}
.co a{
vertical-align: middle;
text-align: center;
}
.cotext{
  height: 40rem;
  width:60rem;
  display: table-cell; //
  vertical-align:middle;
  font-size: 4.0rem;
  background: rgba(255,255,255,0.90);
  font-weight: 600;
}
.cotext p{
  color: #000;
  font-weight: 700;
}
.cotext h1{
  font-size: 1.6rem;
  font-weight: 500;
  color: #000;
  margin-bottom: 5rem;
}
.cotextn{
  font-size: 1.6rem;
  font-weight: 300;
  color: #000;
  margin-bottom: 3rem;
}
.cobtn{
  font-size: 1.4rem;
  font-weight: 600;
  padding: 0.6rem 6rem;;
  border: solid 1px #1A317B;
  border-radius: 3px;
  -webkit-border-radius: 3px;
  -moz-border-radius: 3px;
  color: #1A317B;
  background: #fff;
}
.co a:hover > .cotext .cobtn
{
  -webkit-transition: all 0.2s;
	-moz-transition: all 0.2s;
	-o-transition: all 0.2s;
	-ms-transition: all 0.2s;
	transition: all 0.2s;
  color: rgba(255,0,0,1.00);
  border: solid 1px rgba(255,0,0,1.00) ;
}
*/
/*.bnr div,.bnr div a{
  height:35rem;
  width:25rem;
}

.bnrtext p{
  color: #05024C;
  font-weight: 700;
}
.bnrtext h1{
  font-size: 1.3rem;
  font-weight: 400;
  color: #000;
  margin-bottom: 3rem;
}
.bnrbtn{
  font-size: 1.4rem;
  font-weight: 400;
  padding: 0.6rem 6rem;;
  border: solid 1px #000;
  border-radius: 3px;
  -webkit-border-radius: 3px;
  -moz-border-radius: 3px;
  color: #000;
  background: #fff;
}
.jigyo-bnr a:hover > .bnrtext .bnrbtn,
.bnr a:hover > .bnrtext .bnrbtn
{
  -webkit-transition: all 0.2s;
	-moz-transition: all 0.2s;
	-o-transition: all 0.2s;
	-ms-transition: all 0.2s;
	transition: all 0.2s;
  color: rgba(255,0,0,1.00);
  border: solid 1px rgba(255,0,0,1.00) ;
}
.bnrtext{
  height:35rem !important;
  width:25rem;
  display: table-cell; // IE8から使用可能
  vertical-align:bottom;
  font-size: 2.8rem;
  //display: table-cell;
}
.bnrtext h1{
  font-size: 1.3rem;
  font-weight: 400;
  color: #000;
  margin-bottom: 3rem;
}
.bnr div{
    margin: 1rem 0.3rem;
  //border: 1px solid #eee;
  box-shadow: 0px 2px 10px rgba(34,34,34,0.3);
    padding-bottom: 1.2rem;
}
.bnr div a{
 display: table-cell; // IE8から使用可能
 vertical-align:bottom;
  font-size: 1.3rem;
  color: #000;
  //text-shadow: 0 0 40px #000;
  left: 0;
  top: 0;
}*/
.news{
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: center;
  /*position:absolute;*/
  width: 100%;
  height: 100%;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
  
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
     -ms-flex-direction: column;
         flex-direction: column;
}
.top-info{
  width: 100%;
  color: #FFFFFF;
  background:rgba(166,0,0,0.70);
  position:relative;
}
.top-info .top-info-link{
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.top-space{
  height: 100%;
}
.news-wrap{
  width: 100%;
  margin: -1px 0;
  /*padding: 27px 0 24px;*/
  /*box-shadow: 0px 2px 10px rgba(34,34,34,0.3);*/
  z-index: 1;
  color: #fff;
  background: rgba(0,0,0,0.40);
}
.news-block{
  width: 65rem;
  margin: 0 auto;
}
.news-n{
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  font-size: 1.4rem;
  padding-bottom: 1rem;
  -webkit-align-items: center; /* Safari */
  align-items:         center;
}
.newsdate{
  width: 10rem;
}
.new-icon{
  background-color: #E60000;
  font-size: 10px;
  
  color: #fff;
  padding: 4px 2px;
  vertical-align:middle;
  width: 3rem;
  text-align: center;
  margin-left: 2rem;
}
.new-icond{
  font-size: 0.5rem;
  padding: 4px 2px;
  width: 3rem;
  margin-left: 2rem;
}
.news-bunrui{
  width: 7rem;
  color: #fff;
  border: 1px solid #fff ;
  text-align: center;
  padding: 0 2rem;
  margin-left: 2rem;
  font-size: 12px;
  vertical-align: middle;
}
.news-s{
  margin-left: 2rem;
}
.news-link{
  color: #fff;
}
.other{
  background-color: rgba(236,236,236,1.00);
  width: 100%;

  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: center;
  align-items: center;
}
.other-wrap,.other_inner {
  /*width: 1500px;*/
}
.other_inner{
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  align-items: center;
  padding-bottom: 20px;
  max-width: 1750px;
}
.other_block{
  margin: 10px;
  padding: 10px 0 10px 0;
  width: 230px;
  height: 180px;
  background: rgba(255,255,255,1.00);
  text-align: center;
}
.other_block a ul li{
  text-decoration-line: underline;
  text-decoration-color: rgba(255,255,255,0.00);
}
.other_block a:hover ul li{
  text-decoration-line: underline;
  text-decoration-color: rgba(255,0,0,1.00);
}

.othertxt{
  font-size: 1.1rem;
  font-weight: 500;
  height: 50px;
  vertical-align: top;
  text-align: left;
}
.othertxtbiko{
  font-size: 1.0rem;
  /*font-weight: 500;*/
  /*padding-top: 65px;*/
  padding-left: 20px;
  padding-right: 10px;
  /*text-align: left;*/
}
.othertxt p{
  text-align:center;
  font-size: 1.6rem;
  font-weight: 700;
  padding: 2rem 0 1.5rem 0;
}

.othertxt ul li {
  position: relative;
  padding-left: 20px;
}
.othertxt ul li::after {
  display: block;
  content: '';
  position: absolute;
  top: 5px;
  left: 4px;
  width: 6px;
  height: 6px;
  border-right: 2px solid #FF310E;
  border-bottom: 2px solid #FF310E;
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}
.othertxt2{
  font-size: 1.1rem;
  font-weight: 500;
  height: 20px;
  vertical-align: top;
  text-align: left;
}
.othertxtbiko2{
  font-size: 1.0rem;
  /*font-weight: 500;*/
  /*padding-top: 65px;*/
  padding-left: 20px;
  padding-right: 10px;
  /*text-align: left;*/
}
.othertxt2 p{
  text-align:center;
  font-size: 1.6rem;
  font-weight: 700;
  padding: 2rem 0 1.5rem 0;
}

.othertxt2 ul li {
  position: relative;
  padding-left: 20px;
}
.othertxt2 ul li::after {
  display: block;
  content: '';
  position: absolute;
  top: 5px;
  left: 4px;
  width: 6px;
  height: 6px;
  border-right: 2px solid #FF310E;
  border-bottom: 2px solid #FF310E;
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}
.syogakusien{
  font-size: 1.1rem;
  bottom: -2px;
  width: 210px;
  background-color: rgba(0,0,0,0.80);
  left: 50%;
 -ms-transform: translate(-50%,-50%);/*ベンダープレフィックス*/
  -webkit-transform: translate(-50%,-50%);/*ベンダープレフィックス*/
  transform: translate(-50%,-50%);/*センター寄せの修正*/
}
.syogakusien_moji{
  color: #ffffff;
}
.syogakusien_moji:hover{
  color: #FF310E;
}

/*.mf_cross{
  background-image:url(../img/index_bnr_mfcross_on.gif);
  background-color: rgba(255,255,255,1.00);
  background-size: 299px 163px;
  width: 299px;
  height:163px;
  margin: 0 1.0rem;
    background-position: center center;
}*/
/*.mf_cross a{
  background-image:url(../img/index_bnr_mfcross.gif);
  background-color: rgba(255,255,255,1.00);
  background-size: 299px 163px;
  display: table-cell;
  width: 299px;
  height:163px;
}*/
/*.mf_cross a:hover{
  -webkit-transition: 0.2s;
	-moz-transition: 0.2s;
	-o-transition: 0.2s;
	-ms-transition: 0.2s;
	transition: 0.2s;
  filter:alpha(opacity=0);
  -moz-opacity: 0;
  opacity:0;
  background-color: rgba(255,255,255,1.00);
  width: 299px;
  height:163px;
}*/
.kgepc {}
.mf_cross { background-image:url(../img/index_bnr_mfcross.gif);}
.apfvideo{
  width: 80vw;
}
#apfvideo_1,#apfvideo_2{
  width: 100%;
}

/*###  20170321 add start ###*/
/* コンテンツレイアウト */

.contents {
  position: relative;
  left: 0;
  right: 0;
  bottom: 0;
  margin: 0 auto;
  max-width: 1300px;
  min-width: 1050px;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: center;  /*中央 */
  padding: 0px;
  -webkit-flex-wrap:wrap;
  -moz-flex-wrap:wrap;
  flex-wrap:wrap;
}
.contents2 {
  position: relative;
  left: 0;
  right: 0;
  bottom: 0;
  margin: 0 auto;
  max-width: 1300px;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  width: 80%;
  padding: 0px;
 /* -webkit-justify-content: space-around;*/ /* Safari */
/*  justify-content:         space-around;*/
    -webkit-flex-wrap:wrap;
    -moz-flex-wrap:wrap;
    flex-wrap:wrap;
}
/*
 * 空の子パネル
 * padding, margin の左右も 0 に指定してしまうと、
 * 最後の行のレイアウトが崩れるので注意。
 */
.cell.is-empty {
  height: 0;
  padding-top: 0;
  padding-bottom: 0;
  margin-top: 0;
  margin-bottom: 0;
}
.iso { height:52px; }

@media (max-width: 1750px) {
  .other-wrap,.other_inner{
    max-width: 1500px;
  }
}
@media (max-width: 1500px) {
  .other-wrap,.other_inner {
    width: 1250px;
  }
  .other_block{
    margin: 8px;
  }
}
@media screen and (min-width:1263px){
  .baseFrame{
    width:100%;
    max-width: 1920px;
  }
  .baseW {
    width:100%;
    margin: 0 auto;
  }
}
@media (max-width: 1250px) {
  .other-wrap,.other_inner {
    width: 1000px;
  }
}
@media screen and (min-width:951px) and  (max-width: 1262px) {
  .contents{
    /*width:950px;*/
    margin: 0 auto;
  }
}
@media (max-width: 1000px) {
  .other-wrap,.other_inner {
    width: 750px;
  }
}
@media (max-width: 1200px) {
  /*.kggroup,.contact {display: none;}*/
  .bnr div,.bnr div a{
    width:250px;
  }  
}
@media (max-width: 750px) {
  .other-wrap,.other_inner {
    width: 500px;
  }
}



@media screen and (min-width:651px) and  (max-width: 951px) {
  .contents{
    width:651px;
    margin: 0 auto;
  }
}
@media (max-width: 950px) {
  .contents:before {
    width: 180%;
    height: 113%;
    margin: -15.5% -50% 0;
  }
}
@media (max-width: 850px) {
  .news-n{
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  .news-block{
    width: 90%;
  }
/*@media (max-width: 750px) {
  .other_inner{
    width: 500px;
  }
  .other-wrap,.other_inner{
    width: 492px;
  }*/
}
@media (max-width: 700px) {
  .pc_onry{
    display: none;
  }
}
@media screen and (min-width:701px){
  .MobileTop{
    display: none;
  }
}
@media (max-width: 500px) {
/*@media (max-width: 480px) {*/
  .vegas-t-t{
      font-size: 4rem;
  }
  .vegas-t-n{
      font-size: 2.5rem;
  }
  .vegas-t-m{
      font-size: 1.5rem;
  }

  .contents:before {
    width: 180%;
    height: 107%;
    margin: -20.5% -50% 0;
  }
  .news-new-n,.news-n{
    margin-left: 0;
  }
  .break:before {
    content: "\A"; white-space: pre;
  }

  .other_inner{
    -webkit-flex-wrap:wrap;
    -moz-flex-wrap:wrap;
    flex-wrap:wrap;
  }
  .other_block{
    height: 110px;
    text-align: left;
    width: 400px;
    margin: 10px auto;
    padding: 0;
    box-shadow: 0px 2px 10px rgba(34,34,34,0.3);
  }
  .otherimg{
    float: left;
  }
  .othertxt,.othertxt2{
    height: 5.5rem;
    padding-left: 210px;
    padding-top: 10px;
    font-weight: 600;
  }
  .other-wrap,.other_inner{
    width: 100%;
  }
  .syogakusien {
    bottom: -120px;
    left: 26%;
    text-align: center;
  }
}


/*###  20170321 add end   ###*/