

/* ==========================================================================
Global Styles
========================================================================== */

/* ==========================================================================
Base
========================================================================== */


body,html, button, input, select, textarea {
    font-family: sans-serif;
    line-height: 1.8;
    font-size: 14px;
}

html, body { 
  height: 100%;
  width: 100%;
}

#wrapper {
  overflow: hidden;
}

.text-top {
  display: inline-block;
  text-align: center;
  vertical-align: middle;
}

.btn{
  background: transparent;
  color: #F2F2F2;

  /* CSS Transition */
  -webkit-transition: background .2s ease-in-out, border .2s ease-in-out;
  -moz-transition: background .2s ease-in-out, border .2s ease-in-out;
  -ms-transition: background .2s ease-in-out, border .2s ease-in-out;
  -o-transition: background .2s ease-in-out, border .2s ease-in-out;
  transition: background .2s ease-in-out, border .2s ease-in-out;
}

a {color: #1E2E50;}

.pm0 {padding: 0px;
margin: 0px;}


.my-thumb {height: 220px;
overflow: hidden;}

.my-thumb {margin-bottom: 10px;}

.img-alpha a:hover img {
  opacity: 0.7;
  filter: alpha(opacity=70);
  -ms-filter: "alpha(opacity=70)";
}

.sp-kaigyo {display: block;}


.news-feed a {color:#ccc;
border-bottom: 2px dotted #ccc;}




/* ==========================================================================
共通
========================================================================== */


/*767px以下の場合*/
@media (max-width: 767px) {

/* //////////// スマホサイズ表示時の改行 /////////////// */
.concept-block br {display: none;}
.kaigyou {display: block;}
.sp-none {display: none;}
/* ///////////////////////////////////////////////// */

#navbar br {display: none;}

#navbar ul li {text-align: left;
font-family: 'Noto Serif', serif;
font-size: 94%;
font-weight:100;
}

.nav-sm {margin-left: 20px;}

#oem {margin-top: 30px;}


#oem h3,#information h3,#news h3 {
  font-size: 90%;
font-weight: 100;
line-height: 1.8;
color: #999999;
margin: 10px 15px 20px;
padding:0px 15px }

#home {background: url(../img/bg/main-img.jpg) no-repeat fixed; 
  background-position: top center; 
    width: 100%;
/*        -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;*/
}

.logo {padding-bottom: 12px;
margin-left:15px; }


.navbar-default .navbar-collapse, .navbar-default .navbar-form {border-color:#000000;}


.blog-box {margin: 0 auto;
width:100%;
text-align: center;
}

.blogbox img {max-width: 100%;
height:auto;}

#information {margin-top: 20px;}

/*下層メインイメージ*/

#mainimg {
color: #fff;
  background: url(../img/bg/page_mainback.jpg) no-repeat;
  background-position: center center; 
height: 240px;
width: 100%;
margin: 0px auto;
-webkit-background-size: cover;
  -moz-background-size: cover;
  background-size: cover;
  -o-background-size: cover;
position: relative;
}

#recruit-mainimg {
color: #fff;
  background: url(../img/bg/recruit_mainback.jpg) no-repeat;
  background-position: center center; 
height: 240px;
width: 100%;
margin: 0px auto;
-webkit-background-size: cover;
  -moz-background-size: cover;
  background-size: cover;
  -o-background-size: cover;
position: relative;
}

.dark-wrapp {
  background-color: rgba(0,0,0,.6);
  height: 240px;
}

.title-wrapp {
  width:240px;
position: absolute;
    top: 50%;
    left: 50%;
        -moz-transform: translate(-50%,-50%);
    -webkit-transform: translate(-50%,-50%);
    transform: translate(-50%, -50%);
  }




}


/*768px以上の場合*/
@media (min-width: 768px) {


#navbar ul li {text-align: center;
font-family: 'Noto Serif', serif;
font-size: 100%;
font-weight:100;
}

#home {background: url(../img/bg/main-img.jpg) no-repeat; 
  background-size: cover;
  background-position: center center; 
}

#top {
  margin: 0px auto;
}

#oem {margin-top: 60px;
margin-bottom: 20px;}

#oem h3,#information h3,#news h3 {
  text-align: center;
  font-size: 90%;
font-weight: 100;
line-height: 1.8;
color: #999999;
margin: 10px auto 40px;}



/*下層ページメインイメージ*/

#mainimg {
color: #fff;
  background: url(../img/bg/page_mainback.jpg) no-repeat;
  background-position: center center; 
height: 360px;
width: 100%;
margin: 0px auto;
-webkit-background-size: cover;
  -moz-background-size: cover;
  background-size: cover;
  -o-background-size: cover;
position: relative;
}

#recruit-mainimg {
color: #fff;
  background: url(../img/bg/recruit_mainback.jpg) no-repeat;
  background-position: center center; 
height: 360px;
width: 100%;
margin: 0px auto;
-webkit-background-size: cover;
  -moz-background-size: cover;
  background-size: cover;
  -o-background-size: cover;
position: relative;
}

.dark-wrapp {
  background-color: rgba(0,0,0,.6);
  height: 360px;
}

.light-wrapp {
  background-color: rgba(255,255,255,.6);
  height: 360px;
}

.title-wrapp {
  width:300px;
position: absolute;
    top: 50%;
    left: 50%;
        -moz-transform: translate(-50%,-50%);
    -webkit-transform: translate(-50%,-50%);
    transform: translate(-50%, -50%);
  }


}

/*992px以下の場合*/
@media (max-width: 992px) {

#top .container {width: 100%;}
.navbar-header .logo {float: left;}
.navbar-toggle {float:right;}

.navbar-brand {text-align: center;}


#information-detail .col-md-3,#information-detail .col-sm-6 {margin-bottom: 20px}

.blog-box {margin: 0 auto;
width:100%;
text-align: center;
}


.access-osaka {margin-bottom: 40px;}

/*googlemapをレスポンシブ対応*/
.ggmap iframe,
.ggmap object,
.ggmap embed {

width: 100%;
height: 320px;
}


}

/*993px以上の場合*/
@media (min-width: 993px) {

  #top .logo {float:left;}

}



/* ==========================================================================
下層ページ
========================================================================== */

/* ----------------------------------------------
共通
---------------------------------------------- */


#mainimgArea h2 {
text-align: center;
font-family: 'Noto Serif', serif;
font-size: 240%;
font-weight:100;
padding-bottom: 20px;
border-bottom: 1px solid #ccc;
}

#mainimgArea h3 {
  text-align: center;
  font-family: 'Noto Serif', serif;
    font-size: 100%;
    font-weight: 100;
  }

#Subpage-Area {margin-top: 60px;}

#Subpage-Area h2 {
    text-align: center;
    font-family: 'Noto Serif', serif;
    font-size: 160%;
    font-weight: 100;
    margin: 0px;
}

#Subpage-Area h3 {
    text-align: center;
    font-family: 'Noto Serif', serif;
    font-size: 100%;
    font-weight: 100;
    margin: 0px;
    color: #999;
}


/* ----------------------------------------------
OEM
---------------------------------------------- */

.oem-concept {margin-top:32px; 
margin-bottom: 60px;}

/*767px以下の場合*/
@media (max-width: 767px) {
.oem-concept {margin-top:32px; }

.service {margin-bottom: 20px;}

.boxinbox h3 {font-size: 18px;
  padding: 12px;
background-color: #000;
color: #ffffff;
}

.white {color:#fff; 
margin-bottom: 18px;}

.setsumei {
margin-top: 18px;
}


.oembox {margin-top: 60px;
}

.oembox img {max-width:100%; }

.oem-title {font-size: 18px;
padding: 10px 0 ;
border-bottom: 1px #ccc solid;
border-top: 1px #ccc solid;
margin-bottom: 18px;
color: #000;}

.oembox .textArea {margin-top: 40px;}

}



  /*768px以上の場合*/
@media (min-width: 768px) {

.oem-concept {width:60%;
margin: 0 auto; }

.oem-concept {margin-top:32px; }

.oem-service {
width: 100%;
height: 100%;
margin-top: 40px;
}

.servicebox {overflow: hidden;
width: 100%;}

.service {
width: 50%;
float: left;
}

.service2 {
width: 50%;
float: right;
/*position: absolute;
left:50%;*/}

.boxinbox h3 {font-size: 24px;
  text-align: left;
  width: 15%;
  padding: 20px 10px;
background-color: #000;
color: #ffffff;
}

.white {color:#fff; }

.setsumei {
position: relative;
top:-20px;
  border: 1px #ccc solid;
  width: 80%;
  margin-left: 10%;
  padding: 40px;
  z-index: -1;
}


.oembox {margin-top: 60px;
  overflow: hidden;
height: 100%;
position: relative;
background-color: #ECECEC;}

.oembox img {max-width:100%; }

.oembox .textbox {background-color: #ECECEC;
height: 50%;
padding: 30px;
z-index: 1;}

.oem-title {font-size: 24px;
display: inline-block;
border-bottom: 1px #ccc solid;
margin-bottom: 18px;
color: #000;}

.oembox .leftbox {width: 50%;
  float: left;}

.oembox .image-lb {position: absolute;
left:0;
bottom: 0;
max-width: 100%;
width: 50%;
}

.oembox .image-rb {
z-index: 1;
}

  .oembox .rightbox {width: 50%;
  float: right;}

}


/* ----------------------------------------------
会社案内
---------------------------------------------- */


.mapbox-bfont { font-family: 'Noto Serif', serif;
    font-size: 140%;
    font-weight: 100;}

.mapbox-sfont { font-family: 'Noto Serif', serif;
    font-size: 100%;
    font-weight: 100;}

.shikiri {
  margin: 8px auto 8px;
    border-top: 1px solid #999;
    width: 100px;}

.kaisya-annai {overflow: hidden;
}

.kaisya-annai tr {
padding: 0px;
margin: 0px;
border-bottom: #ccc 1px solid;
width: 100%;
}

.kaisya-annai tr:first-child {
    margin-top: 0;
    margin-bottom: 24px;
}


.map {margin-top: 40px;
margin-bottom: 60px;}

.access-osaka,.access-tokyo {text-align: center;}

.map-box {margin-bottom: 20px}


/*767px以下の場合*/
@media (max-width: 767px) {
.kaisya-annai th {width: 100%;
float: left;
margin-top: 24px;
margin-bottom: 8px;}

.kaisya-annai td {width: 100%;
margin-bottom: 24px;
float: right;}
}

  /*768px以上の場合*/
@media (min-width: 768px) {
.kaisya-annai th {width: 14%;
float: left;
margin-top: 24px;
margin-bottom: 24px;}

.kaisya-annai td {width: 84%;
float: right;
margin-top: 24px;
margin-bottom: 24px;}
  }


/* ----------------------------------------------
採用
---------------------------------------------- */

.bosyuu {border: 1px #ff0000 solid;
padding: 30px 0 30px;
text-align: center;
margin: 0px auto;
color:#ff0000;
margin-top: 60px;
}

.saiyou-annai {overflow: hidden;
width: 100%;
margin-bottom: 60px;}

.saiyou-annai tr {
padding: 0px;
margin: 0px;
border-bottom: #ccc 1px solid;
}




/*767px以下の場合*/
@media (max-width: 767px) {
.saiyou-annai tr:first-child {
    margin-top: 0;
    margin-bottom: 24px;
}

.saiyou-annai th {width: 100%;
float: left;
margin-top: 24px;
margin-bottom: 8px;}

.saiyou-annai td {width: 100%;
float: right;
margin-bottom: 24px;}
}


  /*768px以上の場合*/
@media (min-width: 768px) {
.saiyou-annai tr:first-child {
    margin-top: 0;
    margin-bottom: 24px;
}

.saiyou-annai th {width: 14%;
float: left;
margin-top: 24px;
margin-bottom: 24px;}

.saiyou-annai td {width: 84%;
float: right;
margin-top: 24px;
margin-bottom: 24px;}
}


/* ----------------------------------------------
ブログ
---------------------------------------------- */

#blogArea {
  margin-top: 60px;
}


/*767px以下の場合*/
@media (max-width: 767px) {
.title-box {overflow: hidden;
padding-bottom: 16px;
margin-bottom: 24px;
border-bottom: 1px #ccc solid;}

  .title-a {padding-bottom: 4px;
    text-decoration: underline;}


  }

/*768px以上の場合*/
@media (min-width: 768px) {

.title-box {overflow: hidden;
padding-bottom: 16px;
margin-bottom: 32px;
border-bottom: 1px #ccc solid;}

  .time-a {display: block;
    float: left;
    width: 140px;
    margin-right: 20px;}

  .category-a {float:left;
    width: 140px;
    text-align: center;
    vertical-align: middle;
    color: #fff;
  padding: 0px 6px 0px 6px;
background-color: #999;
display: inline-block;
    margin-right: 40px;}


.category-a a {
color: #fff;
font-size: 11px;}

  .title-a {vertical-align: middle;
    display: inline-block;
    margin: 0;
    font-weight: 500;}



.blogbox {width: 740px;
margin: 0 auto;}
  }

.blogbox h4 {font-size: 21px;
font-weight: 400;
width: 100%;
padding-bottom: 12px;
border-bottom: 1px solid #ccc;}

.blogbox time {width: 100%;}

.category-d {
  margin-bottom: 30px;
padding: 0px 6px 0px 6px;
background-color: #000;
display: inline-block;}

.category-d a {
color: #fff;
font-size: 11px;}

.postNav {position: relative;
  padding-bottom: 16px;
  margin: 60px 0 60px;
border-bottom: 1px solid #ccc;
overflow: hidden;
text-align: center;}

.prev {left:0;
  text-align: left;
  display: inline-block;
  width: 45%;
position: absolute;}
.ichiran {padding: 0px 20px 0px 20px;
  display: inline-block;
  border-left: 1px solid #ccc;
  border-right: 1px solid #ccc;
width: 10%;}
.next {right:0;
  text-align: right;
  display: inline-block;
  width: 45%;
position: absolute;}



/* --------------------- ページ送り ---------------------- */

.pagination{
    text-align: center;
}
a.page-numbers,
.pagination .current{
    background: #fff;
    border: solid 1px #ccc;
    padding:5px 8px;
    margin:0 2px;
    text-decoration: none;
}
.pagination .current{
    background: #000;
    border: solid 1px #000;
    color: #fff;
}





/* ----------------------------------------------
お問い合わせ
---------------------------------------------- */

.form-wrap {margin-top: 40px;
margin-bottom: 60px;}

.mailform {width: 100%;
margin: 0 auto;
}

.mailform tbody {margin: 0;
    padding: 0;
    border: 0;
    outline: 0;
    font-size: 100%;
    vertical-align: baseline;
    background: 0 0;
    overflow: hidden;}

.mailform tr {
  display: table-row;
    vertical-align: inherit;
    border-color: inherit;}



input {padding: 12px 10px;
    border-radius: 1px;
    margin: 0;
    background-color: #fff;}

.simple-box {border: 1px solid #ccc;}

.btn {background-color: #000;
    color: #fff;
    margin-top: 60px;}


    /*767px以下の場合*/
@media (max-width: 767px) {
.mailform th {width: 100%;
  padding: 10px;
    vertical-align: middle;
    float: left;}

.mailform td {width: 100%;
  padding: 10px;
border-style : none;
float: right;
}

.mailform form .mwform-zip-field input[type=text]{ width:auto;}
.mailform form input[type="text"] {width:90%;}

.simple-box {width:100%;}

}

/*768px以上の場合*/
@media (min-width: 768px) {
.mailform th {width: 20%;
  padding: 10px;
    vertical-align: middle;}

.mailform td {width: 70%;
  padding: 10px;
border-style : none;
}
}


/* --------------------- 確認画面 ---------------------- */

    .mw_wp_form_preview .mailform th {padding-bottom: 8px;
      border-bottom: 1px solid #ccc; }

    .mw_wp_form_preview .mailform td {padding-bottom: 8px;
      border-bottom: 1px solid #ccc; }


 /* --------------------- 完了画面 ---------------------- */

    .mw_wp_form_complete a {padding: 4px;
      border: 1px #ccc solid;
      margin-top: 20px;}


/* ========================================================================== */



#information figure {height: 240px;
overflow: hidden;}


#top .logo {
vertical-align: middle;
margin-top: 12px;}
#top h2 {margin:0;
  padding: 0;
overflow: hidden;
height: 100%;
font-family: 'Source Sans Pro', sans-serif;
font-weight: 10;
margin-bottom: 8px;
line-height: 100%;
}
#top h2 a {color: #fff;
padding: 0;
margin: 0;
height: 100%;
font-size: 88%;
line-height: 100%;}
#top h2 a:hover {color: #ccc;}
#top .logo h3 {font-size: 74%;
overflow: hidden;
padding: 0;
margin:0;
color: #666;}


.navbar {
    position: relative;
    min-height: 50px;
    padding-bottom: 6px;
    margin-bottom: 0px;
    border: 1px solid transparent;
}

.navbar-default .navbar-toggle {border-color: #000;}

.navbar-default {color:#999;}
.navbar-default a {color:#999;}




.nav-sm {font-size: 78%;}

/*OEM*/

#oem h2,#information h2,#news h2 {text-align: center;
font-family: 'Noto Serif', serif;
font-size: 160%;
font-weight:100;}

#oem h4 {color:#fff;
    text-align: center;
  vertical-align: middle;
display:table-cell;
text-shadow: 1px 1px 4px #000;
}

#oem a {color: #fff;
    text-align: center;
  vertical-align: middle;
display:block;
line-height: 200px;
}

#oem  a:hover { 
background-color:rgba(255,255,255,0.3); 
color:#ffffff;
} 

.oem-cate {margin-bottom: 20px;}

#oem .container {margin-top:30px; }

.oc01 {background: url(../img/bg/oc01bg.jpg)no-repeat;
  display:table;
background-position: center center;
height: 200px;
}

.oc02 {background: url(../img/bg/oc02bg.jpg)no-repeat;
  display:table;
  background-position: center center;
height: 200px;
}

.oc03 {background: url(../img/bg/oc03bg.jpg)no-repeat;
display:table;
  background-position: center center;
height: 200px;
}

.oc04 {background: url(../img/bg/oc04bg.jpg)no-repeat;
display:table;
  background-position: center center;
height: 200px;
}

.oc05 {background: url(../img/bg/oc05bg.jpg)no-repeat;
display:table;
  background-position: center center;
height: 200px;
}

.oc06 {background: url(../img/bg/oc06bg.jpg)no-repeat;
display:table;
  background-position: center center;
height: 200px;
}


/* //////////// blog /////////////// */



/*767px以下の場合*/
@media (max-width: 767px) {
.blog-box h4 {font-size: 14px;
line-height: 1.2;
text-align: left;
text-decoration: underline;}
}

/*768px以上の場合*/
@media (min-width: 768px) {
.blog-box h4 {font-size: 16px;
line-height: 1.4;
text-decoration: underline;}
}


/* //////////// NEWS /////////////// */


.news-wrapper {
  background: url(../img/bg/news-back.jpg) no-repeat;
  background-position: center center; 
height: 360px;
width: 100%;
margin: 0px auto;
-webkit-background-size: cover;
  -moz-background-size: cover;
  background-size: cover;
  -o-background-size: cover;
position: relative;
margin-bottom: 60px;
}

.dark-wrapp2 {
  background-color: rgba(0,0,0,.6);
  height: 360px;
}

/*767px以下の場合*/
@media (max-width: 767px) {
    .news-box {
color: #fff;
margin-top: 30px;}
}

/*768px以上の場合*/
@media (min-width: 768px) {

  #news {margin-top: 60px;}

  .news-box {
color: #fff;
top:150px;
  width: ;
position: absolute;
 left: 50%;
        -moz-transform: translate(-50%,-50%);
    -webkit-transform: translate(-50%,-50%);
    transform: translate(-50%, -50%);}
}



.news-feed {margin-bottom: 18px;}

.news-topics {font-family: 'Noto Serif', serif;
    font-size: 130%;
    font-weight: 100;
    margin-bottom: 20px;
    text-align: center;
    padding-bottom: 4px;
    border-bottom: 1px dotted #999;}

time {font-size: 90%;}

figure p {margin-top:6px;}



/* //////////// footer /////////////// */


/*767px以下の場合*/
@media (max-width: 767px) {
    }
}

.foot-title {font-size: 14px;
color: #fff;
padding: 4px;
border: 1px #ccc solid;}

.f-nav {color: #ccc;}

.f-nav a {color: #ccc;
text-decoration: underline;}

.f-nav a:hover {color: #999;}

.f-nav h3 {font-size: 11px;
color: #ccc;
padding: 4px;
border: 1px #ccc solid;
display: inline-block;}



/*etc*/


#contents h2 {margin-bottom: 40px;}

#top-mainimg {border-bottom: 1px #cccccc solid;
margin-bottom:120px;}


#contents {width: 980px;
margin: 0 auto;}

#top-concept {
  padding-bottom: 120px;
margin-bottom: 120px;
border-bottom: 1px #cccccc solid;
}


.tsukugo {
  font-family: 'TsukuGoPr5-L';
}

.concept-jp {font-size: 120%;
  font-weight: 100;
  line-height:2;
}

.concept-en {
  font-size: 300%;
  font-family: 'Quicksand', sans-serif;
font-weight: 400;
line-height: 1;
margin: 0px 0px 6px 0px;
}

#map {
    padding-bottom: 120px;
margin-bottom: 40px;
border-bottom: 1px #cccccc solid;
}

.adress {margin-top: 16px;}

.tel {margin: 40px auto 0px;
  border:1px #cccccc solid;
padding: 40px 0px;
text-align:center;}

.denwa {font-size: 200%;
  font-family: 'Quicksand', sans-serif;
font-weight: 400;}

  #topics_d {
    background: url(../img/topics/topics-back.jpg) no-repeat top center;
    display: table;
    height: 200px;
    position: relative;
    width:100%;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
    margin-bottom: 0px
  }

#gototop {margin-bottom: 40px;}

#gototop i {width:100%; text-align: center;}

  #footer {
    padding-top: 30px;
background-color: #333;
  }




/*gridのgutter調整*/
.row-0{
    margin-left:0px;
    margin-right:0px;

    > div{
        padding-right:0px;
        padding-left:0px;
    }
}
.row-10{
    margin-left:-5px;
    margin-right:-5px;

    > div{
        padding-right:5px;
        padding-left:5px;
    }
}
.row-20{
    margin-left:-10px;
    margin-right:-10px;

    > div{
        padding-right:10px;
        padding-left:10px;
    }
}
.row-30{
    margin-left:-15px;
    margin-right:-15px;

    > div{
        padding-right:15px;
        padding-left:15px;
    }
}
.row-40{
    margin-left:-20px;
    margin-right:-20px;

    > div{
        padding-right:20px;
        padding-left:20px;
    }
}

  .mb40 {margin-bottom: 40px;}
  .mb20 {margin-bottom: 20px;}


.contact-footer {color:#ccc;}

.red {color: #f00;}


  /* 戻るボタン */

input.r-btn {
    background-color: #fff;
    color: #000;
    margin-top: 60px;
    margin-left: 40px;
    border: 1px #ccc solid;
  }

input.r-btn {
    background: transparent;
    color: #000;
    border: 1px #ccc solid;
    -webkit-transition: background .2s ease-in-out, border .2s ease-in-out;
    -moz-transition: background .2s ease-in-out, border .2s ease-in-out;
    -ms-transition: background .2s ease-in-out, border .2s ease-in-out;
    -o-transition: background .2s ease-in-out, border .2s ease-in-out;
    transition: background .2s ease-in-out, border .2s ease-in-out;
}

input.r-btn {
    display: inline-block;
    padding: 6px 12px;
    margin-bottom: 0;
    font-size: 14px;
    font-weight: 400;
    line-height: 1.42857143;
    text-align: center;
    white-space: nowrap;
    vertical-align: middle;
    -ms-touch-action: manipulation;
    touch-action: manipulation;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    background-image: none;
    border: 1px solid transparent;
    border-radius: 4px;
    border: 1px #ccc solid;
}

