/*==========================
::ver 0.1

　　** TOC **
　　00. Common
　　01. Header
　　02. main
　　03. Footer
　　04. Index
　　05. Page
　　06. Media Query
	

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

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

   00:Common;

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

*{
   box-sizing: border-box;
   margin:0;
   letter-spacing: 0.15rem;
}
.clear{
  clear: both;
}
body{
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 1rem;
  line-height: 1.6;
}
header,.hero-block,main,footer{
  min-width: 1286px;
}
ul{
  text-decoration: none;
}
p{
   font-size: 16px;
   letter-spacing: 0.15rem;
   margin-bottom: 0;
}
.fig{
   width: 100%;
}
a,a:hover{
   text-decoration: none;
}
section.inner-block{
  padding: 120px 0;
}
section.inner-block h3.ttl{
  height: 80px;
  border: 2px solid #000;
  font-size: 19px;
  letter-spacing: 0.2rem;
  margin-bottom: 70px;
  text-align: center;
  line-height: 80px;
  font-weight: normal;
  }
.flt-l{
  float: left;
}
.flt-r{
  float: right;
}
.pA0{
  display: 
}
.col-0{
    padding-left: 0px;
    padding-right: 0px;
}
.bgc-white{
  background-color: rgba(255,255,255,0.5);
}
/* ==========================================================================

   01:Header;

   ========================================================================== */
.toggle {
    position: fixed; /* bodyに対しての絶対位置指定 */
    top: 15px;
    width: 50px;
    right: 15px;
    height: 60px;
    display: block;
    cursor: pointer;
    z-index: 3;
    background: rgba(255,255,255,0.9);
} 
.toggle span {
    display: block;
    position: absolute;
    width: 78%;
    border-bottom: 5px solid #0068b7;
    -webkit-transition: .35s ease-in-out;
    -moz-transition: .35s ease-in-out;
    transition: .35s ease-in-out;
    padding-top: 4px;
    right: 6px;
}
.toggle span:nth-child(1) {
    border: none;
    top: -2px;
    left: 8px;
    font-size: 10px;
    font-weight: bold;
    color: #0068b7;
}
.toggle span:nth-child(2) {
    top: 18px;
}
.toggle span:nth-child(3) {top: 30px;}
.toggle span:nth-child(4) {
    top: 42px;
}
/* 最初のspanをマイナス45度に */
.toggle.active span:nth-child(2) {
      top: 32px;
    left: 4px;
    -webkit-transform: rotate(-45deg);
    -moz-transform: rotate(-45deg);
    transform: rotate(-45deg);
}
/* 2番目と3番目のspanを45度に */
.toggle.active span:nth-child(3),
.toggle.active span:nth-child(4) {
    top: 32px;
    right: 4px;
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    transform: rotate(45deg);
}
.toggle.active span:nth-child(3){
  display: none;
}

/* .global_nav */
.global_nav {
    position: fixed;
    /*top: 0;*/
    top: -100vh;
    left: 0;
    width: 100%;
    /*transform: translateY(-100%);*/
    z-index: 2;
    /* padding-top: 50px; */
    text-align: center;
    padding-top: 40%;
    height: 100%;
    color: #000;
    background: rgba(255,255,255,0.9);
    transition: all 0.8s;
}
.global_nav .nav_li {
    width: 100%;
    /* padding: 10px; */
    list-style-type: none;
    border-top: 1px solid #0267b7;
}
.global_nav .nav_li:last-child{
  border-bottom: 1px solid #0267b7;
}
.global_nav .nav_li a {
    display: block;
    color: #337ab7;
    padding: 20px;
    font-size: 18px;
}
/* .global_navに.activeが追加 */
.global_nav.active {
    /*transform: translateY(0%);*/
    top:0;
}

/* .nav-block
--------------------------- */
.nav-block{
  z-index: 177;
  height: 80px;
  background-color: rgba(255,255,255,0.9);
  position: fixed;
  top:0;
  width: 100%;
  text-align: center;
}
.nav-block h1{
  margin:0;
  display: inline-block;
}
.nav-block h1 a{
  display: table-cell;
  vertical-align: middle;
  height: 80px;
}
.nav-block h1 a img{
  height: 60px;
}
.nav-block #nav {
  line-height: 80px;
  font-size: 14px;
  text-align: center;
  position: relative;
}
.nav-block #nav ul {
  list-style-type: none;
}
.nav-block #nav ul li{
  width: calc(100% / 4);
  float: left;
  text-decoration: none;
}
.nav-block #nav ul li a{
  display: block;
}
#slide-line{
    position: absolute;
    bottom: 0;
    height: 5px;
    background-color:#337ab7;
    -webkit-transition: all .3s ease;
    transition: all .3s ease;
    width: 100%;
}
/*.nav-block #nav a{
  width: 25%;
  float: left;
    box-sizing: border-box;
    height: 80px;
}

.nav-block #nav li {
  position: relative;
  display: inline-block;
  text-decoration: none;
}
.nav-block #nav a::after {
  position: absolute;
  bottom: 0;
  left: 0;
  content: '';
  width: 100%;
  height: 3px;
  background: #0000FF;
  transform: scale(0, 1);
  transform-origin: left top;
  transition: transform .3s;
}
.nav-block #nav a:hover::after {
  transform: scale(1, 1);
}*/

/* .hero-block
--------------------------- */
  .hero-block{
    height: 100vh;
    background-image: url(../img/hero-block_bg.jpg);
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: cover;
    background-size: cover;
    position: relative;
    text-align: center;
    background-attachment: fixed;
  }
  .hero-block .main-logo{
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    margin:auto;
  }
  .hero-block .main-logo{
    height: 360px;
  }
  .hero-block .target{
    position: absolute;
    right: 0;
    left: 0;
    bottom: 0;
    margin:auto;
  }
  .hero-block .target img{
    height: 84px;
    width: auto;
  }
/* ==========================================================================

   02:nain;

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

/* #concept
------------------------------------------------------  */
  #concept{
    background-image: url(../img/concept_bg.jpg);
    background-position: center;
    background-repeat:no-repeat;
    -webkit-background-size: cover;
    background-size: cover;
  }
  
  /* .lead-area
  --------------------------- */
  #concept .lead-area p{
    margin-bottom: 80px;
    line-height: 2;
    font-size: 14px;
  }

  /* .message-area
  --------------------------- */
  .message-area{
    overflow-x: hidden;
  }
  .message-area .col-sm-2column ~ .col-sm-2column {
    margin-top: 50px;
  }
  .message-area .col-sm-2column img{
    width: 100%;
  }
  .message-area .col-sm-2column .copy .copy-inner{
    display: table-cell;
    vertical-align: middle;
    position: relative;
  }
  .message-area .col-sm-2column .copy img.copy-img{
    height: 180px;
    width: auto;
  }
  .message-area .col-sm-2column .copy .pict-hito img.copy-img{
    height: 85px;
    background-image: url();
  }
  .message-area .col-sm-2column .copy{
    display: table;
    width: 100%;
    height: 100%;

  }
  .message-area .col-sm-2column .copy .pict{
    width: 200px;
    display: table-cell;
    vertical-align: middle;
    overflow: hidden;
  }
  .message-area .col-sm-2column .copy .pict-hito{
    text-align: right;
    padding-bottom: 40px;
  }
  .message-area .col-sm-2column .copy .text{
    text-align: center;
    display: table-cell;
    vertical-align: middle;
  }
  .message-area .col-sm-2column .copy p{
    font-size: 21px;
    letter-spacing: 0.15em;
    line-height: 2.3;
  }
  .message-area .col-sm-2column .copy .pict:nth-child(odd){
    padding-left: 70px;
  }
  .message-area .col-sm-2column .copy .pict:nth-child(even){
    padding-right: 70px;
  }
  .message-area .col-sm-2column .copy .text:nth-child(odd){}
  .message-area .col-sm-2column .copy .text:nth-child(even){}
  
/* .slider-box
------------------------------------------------------  */
.slick-arrow{
position:absolute;
top:35%;
width:18px;
height:31px;
text-indent: -9999px;
z-index: 1;
border:0 none;
}
.slick-prev.slick-arrow{
left:5px;
background:url(../img/arrow_left.png) no-repeat center center;
background-size: contain;
}
.slick-next.slick-arrow{
right:5px;
background:url(../img/arrow_right.png) no-repeat center center;
background-size: contain;
}
/* #work
------------------------------------------------------  */
  #work{
    background-image: url(../img/work_bg.jpg);
    background-position: center;
    background-repeat:no-repeat;
    -webkit-background-size: cover;
    background-size: cover;
  }
  #work h3.ttl{
    border-color: #fff;
    color:#fff;
  }
  #work .row-pict_box ~ .row-pict_box{
    margin-top: 40px;
  }
  #work p.text{
    background-color: #fff;
    letter-spacing: 0.05em;
    padding: 15px;
  }
  #work p.text span{}
  #work .pict{
    background-position: center center;
    background-repeat: no-repeat;
    -webkit-background-size: cover;
    background-size: cover;
  }
  #work .pict:hover{
    -webkit-background-size: 120%;
    background-size: 120%;
    -webkit-transition: all 0.1s;
  -moz-transition: all 0.1s;
  -ms-transition: all 0.1s;
  -o-transition: all 0.1s;
  transition: all 0.1s;
  }
  #work .pict img{
    width: 100%;
  }
  #work .pict-1{
    background-image: url(../img/work_pict-box_fig_01.jpg);
  }
  #work .pict-2{
    background-image: url(../img/work_pict-box_fig_02.jpg);
  }
  #work .pict-3{
    background-image: url(../img/work_pict-box_fig_03.jpg);
  }
  #work .pict-4{
    background-image: url(../img/work_pict-box_fig_04.jpg);
  }
  #work .pict-5{
    background-image: url(../img/work_pict-box_fig_05.jpg);
  }
  #work .pict-6{
    background-image: url(../img/work_pict-box_fig_06.jpg);
  }

/* #company
------------------------------------------------------ */
  #company {
    padding-bottom: 0;
  }
  #company .table{
    font-size: 18px;
    width: 100%;
  }
  #company .table tr{
  }
  #company .table tr + tr{
    border-top: 1px solid #999;
  }
  #company .table tr td{
    font-size: 14px;
    vertical-align: top;
    padding:10px 0;
  }
  #company .table tr td:first-child{
    width: 180px;
  }
  #company .table tr td　+ td{

   }
  #company .table tr td span{
    font-size: 12px;
  }

  /* #contact
------------------------------------------------------ */
#contact{
  background-color: #e3e3e3;
}
#contact h3.ttl{
  background-color: #666666;
  border: none;
  color: #fff;
}
#contact .form-area{
  width: 100%;
  margin-top: 95px;
}
#contact .form-area dl{
    font-size: 16px;
}
#contact .form-area dl dt{
  padding: 24px;
  background-color: #969696;
  display: block;
  color: #fff;
}
#contact .form-area dl dt span{
  font-size: 0.6em;
  vertical-align: top;
}
#contact .form-area dl dd{
  padding: 30px;
  background-color: #fff;
  display: block;
}
#contact .form-area dl dd input{
  width: 100%;
  border: 2px solid #969696;
  border-radius: 3px;
  color: #969696;
  height: 54px;
  padding: 18px 0px 18px 18px; 
}
#contact .form-area dl dd textarea{
  width: 100%;
  border: 2px solid #969696;
  border-radius: 3px;
  color: #969696;
  padding: 12px 0px 0px 18px; 
}
input::placeholder, textarea::placeholder{
  color: #e3e3e3;
}

/* IE */
input:-ms-input-placeholder, textarea:-ms-input-placeholder {
  color: #e3e3e3;
}

/* Edge */
input::-ms-input-placeholder, textarea::-ms-input-placeholder {
  color: #e3e3e3;
}


#contact .form-area .button-area{
  margin-top: 60px;
  width: 100%;
  text-align: center;
}
#contact .form-area .button-area .button{
  background-color: #0068b7;
  border-radius: 18px;
  color: #fff;
  font-size: 19px;
  width: 400px;
  text-align: center;
  padding: 30px 0;
  letter-spacing: 0.2em;
}
#contact .form-area .button-area .button:hover{
  opacity: 0.6;
  -webkit-transition: all 0.3s;
  -moz-transition: all 0.3s;
  -ms-transition: all 0.3s;
  -o-transition: all 0.3s;
  transition: all 0.3s;
}

/* #banner
------------------------------------------------------ */
#banner a img{}
#banner a p.note{
  font-size: 12px;
  text-align: center;
  margin-top: 10px;
}



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

   03:Footer;

   ========================================================================== */
/* #contact
------------------------------------------------------ */
  footer {
    background-color:#337ab7;
  }
  footer .map{}
  footer .map img{}
  footer small{
    display: block;
    text-align: center;
    line-height: 60px;
    color: #fff;
  }

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

   04:Index;

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


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

   05:Page;

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

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

   06:Meadia Query;

   ========================================================================== */
/*--------- max-width ---------*/

@media (max-width: 1199px) {

}

@media (max-width: 991px) {

}

@media (max-width: 767px) {
  .container {
      width: 100%;
  }
  header,.hero-block,main,footer{
  min-width: 100%;
  }
  .hero-block{
    background-position: bottom center;
    background-attachment: initial;
  }
  .hero-block .main-logo {
    height: 230px;
  }


  section.inner-block {
    padding: 60px 0;
  }
  section.inner-block h3.ttl {
    font-size: 13px;
    height: 60px;
    line-height: 60px;
    margin-bottom: 60px;
  }

/* #concept
------------------------------------------------------ */
  #concept .lead-area p {
    margin-bottom: 60px;
  }

/*#company
------------------------------------------------------ */
#company .table tr td:first-child {
    width: 100px;
}


/* #work
------------------------------------------------------ */
  #work p.text {
    font-size: 13px;
}
#work .row-pict_box .col-pict_box + .col-pict_box {
    margin-top: 40px;
}


/* #work
------------------------------------------------------ */
#company .table tr td {
    font-size: 12px;
}



#banner a p.note span.naoshiya {
    display: inline-block;
    text-align: justify;
}

}




@media (max-width: 599px) {
  #contact .form-area .button-area .button {
  width: 100%;
}
}


/*--------- min-width ---------*/
@media (min-width: 600px) {

}

@media (min-width: 768px) {

}

@media (min-width: 992px) {

}

@media (min-width: 1200px) {

}
@media (min-width: 768px){
