@charset "utf-8";
/* CSS Document */
/* =============================
Common 
===============================*/
html{
}
body{
  font-family: 'Noto Sans JP', sans-serif, 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', Meiryo, メイリオ, Osaka, 'MS PGothic', arial, helvetica, sans-serif;
  margin-bottom: 60px;
  line-height: 1.9;
  color: #3B4043;
}
a{
  color: #343a40;
}
a:hover img{
  opacity: 0.7;
}
h2{
  font-weight: 700;
  font-size: 2.3rem;
  line-height: 1.4;
  color: rgba(59,64,67,1);
}
h3{
  font-weight: 700;
  font-size: 1.8rem;
  line-height: 1.4;
  color: rgba(59,64,67,1);
}

.container>div{
  min-height: 10rem;
}
.con_s{
  max-width: 1010px;
  margin: inherit;
}
.con_ss{
  max-width: 900px;
  margin: inherit;
}

/* =============================
Header 
===============================*/
.navbar-brand {
  font-size: 1.4rem;
}
.navbar-brand img{
  margin-right: 10px;
}
.navbar a{
  font-weight: 700;
}
.navbar-light .navbar-nav .nav-link {
    color: rgba(0,0,0,1);
}
.nav-item:last-child{
  margin-top: 3px;
}
/* =============================
Footer 
===============================*/
.footer {
  position: absolute;
  width: 100%;
  height: 60px;
  padding-top: 20px;
  background-color: #3B4043;
  color: #fff;
  text-align: center;
  font-size: 0.7rem;
}


/* =============================
Contents 
===============================*/
#blk_kv.jumbotron{
  background: url("/img/img01.jpg") center center no-repeat;
  background-size: cover;
  color: #fff;
  min-height: 470px;
}
#blk_kv.jumbotron h1{
  font-weight: 700;
  margin-top: 60px;
  text-shadow: #000 2px 2px 0;
  font-family: 'Noto Serif JP', serif;
  letter-spacing: 0.1rem;
}

#blk_ceo .ceo_sub{
  font-size: 1.4rem;
  font-family: Montserrat;
}

#blk_info dl{
  border-top: 2px solid #98A6B5;
  max-width: 800px;
  margin: 0 auto;
  padding-top: 12px;
}
#blk_info dt,#blk_info dd {
  padding-bottom: 8px;
  font-size: 1rem;
}
@media screen and (min-width: 768px) {
  #blk_info dt {
    clear: left;
    float: left;
    width: 20%;
    font-weight: normal;
    border-bottom: 1px solid #CDD6DD;;
  }
  #blk_info dd {
    margin-left: 20.1%;
    border-bottom: 1px solid #CDD6DD;;
  }
}

#blk_ytb{
  line-height: 1.4;
  font-size: 0.9rem;
}
#blk_ytb .itm_ytb .aa a::before{
  content: '';
  background-image: url("/img/icn_ytb.png");
  background-repeat: no-repeat;
  background-size: contain;
    position:absolute;
    top: 30%;
    left: 37%;
    content: '';/*何も入れない*/
    width: 100%;/*画像の幅*/
    height: 50px;/*画像の高さ*/
}
#blk_ytb .itm_ytb .itm_ytb_img{
  position: relative;
}
#blk_ytb .itm_ytb .itm_ytb_img::before{
    content: '';
    position: absolute;
    width: 100%;
    height: 100%;
    background: transparent url(/img/icn_ytb.png) center center no-repeat;
    background-size: 30%;
}

#blk_works .works_card>div{
  margin-bottom: 20px;  
}
#blk_works .card{
  background-color: #F7F7F7;
}
#blk_works .card-title{
  font-weight: bold;
  border-bottom: 1px solid #ccc;
  padding-bottom: 8px;
}

#blk_company dl{
  border-top: 2px solid #98A6B5;
  border-bottom: 1px solid #CDD6DD;
  max-width: 800px;
  margin: 0 auto;
  padding-top: 12px;
}
#blk_company dt,#blk_company dd {
  padding-bottom: 8px;
  font-size: 1rem;
}
@media screen and (min-width: 768px) {
  #blk_company dt {
    clear: left;
    float: left;
    width: 20%;
    font-weight: normal;
    border-bottom: 1px solid #CDD6DD;;
  }
  #blk_company dd {
    margin-left: 20.1%;
    border-bottom: 1px solid #CDD6DD;;
  }
}
#blk_company .no_bdr{
  border: none;
}
#blk_company dd p{
  text-indent: -1em;
  padding-left: 1em;
  margin-bottom: 0.5rem;
}

/* MAP */
.blk_map .ggmap {
position: relative;
width: 100%;
padding-bottom: 56.25%;
padding-top: 30px;
height: 0;
overflow: hidden;
}
 
.blk_map .ggmap iframe,
.ggmap object,
.ggmap embed {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
}

/* FORM */
#blk_form{
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
  padding: 60px;
  border: 10px solid #F0F3F5;
}
#blk_form h3{
  text-align: center;
}
#blk_form .col-form-label{
  font-weight: bold;
  color: #707F89;
}
#blk_form .form-group{
  margin-bottom: 30px;
}


/* ToTOP */
#page_top {
    position: fixed;
    bottom: 30px;
    right: 20px;
}
#page_top a {
    background-color: #999;
    color: #fff;
    text-align: center;
    text-decoration: none;
    padding: 20px 20px;
}
#page_top a:hover {
    background-color: #666;
    text-decoration: none;
}