@charset "UTF-8";
@import url(https://fonts.googleapis.com/icon?family=Material+Icons);
/* CSS Document */ :root {
  --transitionShort: 0.2s;
  --transitionLong: 0.5s;
}
html {
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  font-size: 62.5%;
  line-height: 100%;
  color: #111111;
}
/*-------------------------------------------------------------------
	mainvisual
-------------------------------------------------------------------*/
.slide-arrow {
  position: absolute;
  top: 50%;
  width: 18px;
  height: auto;
  cursor: pointer;
  z-index: 1;
}
  .prev-arrow {
    left: 10%;
  }
  .next-arrow {
    right: 10%;
  }

/*-------------------------------------------------------------------
	content
-------------------------------------------------------------------*/
.content {
}
.content-inner {
  width: 1160px;
  margin: 0px auto;
}
.content h3 {
  font-size: 3.6rem;
  line-height: 1.15;
  font-weight: 800;
  margin-bottom: 2.0rem;
}
.content h3 span {
  display: block;
  font-size: 38.88888%;
  color: #084e9b;
  letter-spacing: 0.1em;
  font-weight: bold;
}
/*-------------------------------------------------------------------
	Animation
-------------------------------------------------------------------*/
.animation.active .delay1, .animation.active .delay2, .animation.active .delay3, .animation.active .delay4 {
  opacity: 1;
  -webkit-transform: translateY(0);
  -ms-transform: translateY(0);
  transform: translateY(0);
}
.animation .delay1, .animation .delay2, .animation .delay3, .animation .delay4 {
  -webkit-transition: opacity 0.5s ease-out, -webkit-transform 0.5s ease-out;
  transition: opacity 0.5s ease-out, -webkit-transform 0.5s ease-out;
  -o-transition: opacity 0.5s ease-out, transform 0.5s ease-out;
  transition: opacity 0.5s ease-out, transform 0.5s ease-out;
  transition: opacity 0.5s ease-out, transform 0.5s ease-out, -webkit-transform 0.5s ease-out;
  -webkit-transform: translateY(2.5rem);
  -ms-transform: translateY(2.5rem);
  transform: translateY(2.5rem);
  opacity: 0;
}
.animation .delay1 {
  -webkit-transition: opacity 0.5s ease-out .5s, -webkit-transform 0.5s ease-out .5s;
  transition: opacity 0.5s ease-out .5s, -webkit-transform 0.5s ease-out .5s;
  -o-transition: opacity 0.5s ease-out .5s, transform 0.5s ease-out .5s;
  transition: opacity 0.5s ease-out .5s, transform 0.5s ease-out .5s;
  transition: opacity 0.5s ease-out .5s, transform 0.5s ease-out .5s, -webkit-transform 0.5s ease-out .5s;
}
.animation .delay2 {
  -webkit-transition: opacity 0.5s ease-out .6s, -webkit-transform 0.5s ease-out .6s;
  transition: opacity 0.5s ease-out .6s, -webkit-transform 0.5s ease-out .6s;
  -o-transition: opacity 0.5s ease-out .6s, transform 0.5s ease-out .6s;
  transition: opacity 0.5s ease-out .6s, transform 0.5s ease-out .6s;
  transition: opacity 0.5s ease-out .6s, transform 0.5s ease-out .6s, -webkit-transform 0.5s ease-out .6s;
}
.animation .delay3 {
  -webkit-transition: opacity 0.5s ease-out .65s, -webkit-transform 0.5s ease-out .65s;
  transition: opacity 0.5s ease-out .65s, -webkit-transform 0.5s ease-out .65s;
  -o-transition: opacity 0.5s ease-out .65s, transform 0.5s ease-out .65s;
  transition: opacity 0.5s ease-out .65s, transform 0.5s ease-out .65s;
  transition: opacity 0.5s ease-out .65s, transform 0.5s ease-out .65s, -webkit-transform 0.5s ease-out .65s;
}
.animation .delay4 {
  -webkit-transition: opacity 0.5s ease-out .7s, -webkit-transform 0.5s ease-out .7s;
  transition: opacity 0.5s ease-out .7s, -webkit-transform 0.5s ease-out .7s;
  -o-transition: opacity 0.5s ease-out .7s, transform 0.5s ease-out .7s;
  transition: opacity 0.5s ease-out .7s, transform 0.5s ease-out .7s;
  transition: opacity 0.5s ease-out .7s, transform 0.5s ease-out .7s, -webkit-transform 0.5s ease-out .7s;
}
/*-------------------------------------------------------------------
	btn
-------------------------------------------------------------------*/
.content_btn.oval a {
  font-size: 140%;
  letter-spacing: 0.1em;
  display: inline-block;
  border-radius: 150px;
  color: #ffffff;
  background: #084e9b;
  text-align: center;
  padding: 0.8em 1.5em;
  font-weight: bold;
  min-width: 150px;
  line-height: 1.2;
}
.content_btn.oval a .site_window {
  margin-left: 0.5em;
}
/*-------------------------------------------------------------------
	page_animation
-------------------------------------------------------------------*/
.md_transition {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transition: transform 0.5s cubic-bezier(.39, .575, .565, 1) 0s;
  z-index: 999999;
}
.md_transition::before {
  background: -webkit-gradient(linear, left bottom, left top, from(hsla(0, 0%, 100%, 0)), color-stop(33.33333%, #fff), color-stop(66.66667%, #fff), to(hsla(0, 0%, 100%, 0)));
  background: -o-linear-gradient(bottom, hsla(0, 0%, 100%, 0) 0, #fff 33.33333%, #fff 66.66667%, hsla(0, 0%, 100%, 0) 100%);
  background: linear-gradient(0deg, hsla(0, 0%, 100%, 0), #fff 33.33333%, #fff 66.66667%, hsla(0, 0%, 100%, 0));
  content: "";
  display: block;
  width: 100%;
  height: 300%;
  position: absolute;
  left: 0;
  top: -100%;
}
body.is_remove .md_transition {
  -webkit-animation: maskCloseTransition .3s cubic-bezier(.47, 0, .745, .715) 0s 1 forwards;
  animation: maskCloseTransition .3s cubic-bezier(.47, 0, .745, .715) 0s 1 forwards;
}
body:not(.is_fade) .md_transition {
  transform: translateY(-200%);
}
@-webkit-keyframes maskCloseTransition {
  0% {
    transform: translateY(200%);
  }
  to {
    transform: translate(0);
  }
}
@keyframes maskCloseTransition {
  0% {
    transform: translateY(200%);
  }
  to {
    transform: translate(0);
  }
}
/*-------------------------------------------------------------------
	icon
-------------------------------------------------------------------*/
i.site_window:before {
  content: url("../images/window.svg");
  display: inline-block;
  width: 1em;
}
/*-------------------------------------------------------------------
	nav-banner
-------------------------------------------------------------------*/
#nav-banner {
  max-width: 1160px;
  margin: 64px auto;
}
#nav-banner .banner-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  max-width: 1160px;
  margin: auto;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}
#nav-banner .banner-list li {
  position: relative;
  border-radius: 4px;
  overflow: hidden;
}
#nav-banner .banner-list li{
  width: 49%;
  margin-top: 2.8em;
}
#nav-banner .banner-list li.banner_l a {
  display: flex;
  justify-content: center;
  align-items: center;
  color: #ffffff;
}
#nav-banner .banner-list li a .banner_txt {
  position: absolute;
  text-align: center;
  z-index: 1;
  font-size: 320%;
  line-height: 1.4;
  padding-top: 10px;
  font-weight: 800;
  text-shadow: 0px 0px 3px rgb(0 0 0 / 60%);
}
#nav-banner .banner-list li a .banner_txt span {
  display: block;
  font-size: 43.75%;
  letter-spacing: 0.1em;
  font-weight: bold;
}
#nav-banner .banner-list i.site_window:before {
  width: 0.65em;
  display: block;
  margin: auto;
  margin-top: -0.2em;
}
#nav-banner .banner-list li a .img_wrap {
  border-radius: 6px;
  overflow: hidden;
  position: relative;
}
#nav-banner .banner-list li.banner_l a .img_wrap {
  border-radius: 6px;
  overflow: hidden;
  position: relative;
  height: 160px;
}
#nav-banner .banner-list li.banner_l a .img_wrap img{
  width: 102%;
}
  @media screen and (max-width:1060px){
    #nav-banner .banner-list li.banner_l a .img_wrap img{
      width: 110%;
    }
  }
#nav-banner .banner-list li a .img_wrap:before {
  content: "";
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  background: rgb(17 17 17 / 20%);
  transition: all 500ms ease;
}
#nav-banner .banner-list li a:hover .img_wrap:before {
  background: rgb(17 17 17 / 0%);
  transition: all 200ms ease;
}
#nav-banner .banner-list li a .img_wrap img {
  width: 100%;
}
#nav-banner .banner-list li.no-image{
  margin-top: 1.2rem;
}
#nav-banner .banner-list li.no-image-s{
  margin-top: 1.2rem;
  width: 32.4%;
}
#nav-banner .banner-list li.no-image a {
  color: #084e9b;
  border-radius: 4px;
  border: 1px solid #084e9b;
  text-align: center;
  font-weight: normal;
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  -ms-transition: all 0.3s ease;
}
#nav-banner .banner-list li.no-image a{
  height: 102px;
  display: flex;
  align-items: center;
  justify-content: center;
}
#nav-banner .banner-list li.no-image a:hover {
  color: #FFF;
  background-color: #084e9b;
}
#nav-banner .banner-list li.no-image a .banner_txt {
  font-size: 1.8rem;
  padding-top: 0;
  text-shadow: none;
  font-weight: normal;
}
/*-------------------------------------------------------------------
	banner-l
-------------------------------------------------------------------*/
.fullcontent {
  width: 100%;
  height: auto;
  max-height: 400px;
  background-repeat: no-repeat;
  background-size: cover;
}
.ir-banner-l {
  background-image: url(../images/ir_banner_bg.jpg);
  margin-bottom: 6.4rem;
  margin-top: 9.4rem;
  }
  .ir-banner-l a {
    display: block;
  }
    .ir-banner-l .ir-banner-inner {
      width: 1160px;
      margin: 0px auto;
      padding-top: 120px;
      padding-bottom: 120px;
      display: flex;
      align-items: center;
      justify-content: space-between;
    }
    @media screen and (max-width:1200px) {
      .ir-banner-l .ir-banner-inner {
        width: 88%;
        max-width: 1160px;
      }
    }
    .ir-banner-l .ir-banner-inner .txt{
      text-shadow: 0px 0px 3px rgb(0 0 0 / 60%);
    }
    .ir-banner-l .ir-banner-inner .txt h3{
      color: #FFF;
      font-size: 3.8rem;
      margin-bottom: 1.4rem;
      line-height: 1.2;
    }
    .ir-banner-l .ir-banner-inner .txt p{
      color: #FFF;
      font-size: 2.4rem;
    }
    .ir-banner-l .ir-banner-inner .btn{
      background-color: #111;
      display: flex;
      align-items: center;
      justify-content: space-between;
      width: 248px;
      height: 82px;
      border-radius: 9999px;
      color: #FFF;
      padding: 24px;
      font-size: 1.6rem;
      font-weight: 700;
      box-sizing: border-box;
      box-shadow: 0px 0px 3px rgb(0 0 0 / 60%);
    }
  .recruit-banner-l {
    background-image: url(../images/recruit-banner-bg.jpg);
    margin-bottom: 8.4rem;
    margin-top: 240px;
    }
    .recruit-banner-l a {
      display: block;
      padding-top: 120px;
      margin-top: -120px;
      padding-bottom: 90px;
    }
      .recruit-banner-l .recruit-banner-inner {
        width: 1160px;
        margin: 0px auto;
      }
    .recruit-banner-l .recruit-banner-inner .txt{
      text-shadow: 0px 0px 3px rgb(0 0 0 / 60%);
    }
      .recruit-banner-l .recruit-banner-inner .txt h3{
        color: #FFF;
        font-size: 3.8rem;
        margin-bottom: 2.2rem;
      }
      .recruit-banner-l .recruit-banner-inner .txt p{
        color: #FFF;
        font-size: 2.0rem;
      }
      .recruit-banner-l .recruit-banner-inner .txt p.message {
        margin-top: 2.0rem;
        margin-bottom: 2.0rem;
        font-size: 1.8rem;
        line-height: 1.4;
      }
      .recruit-banner-l .recruit-banner-inner .btn{
        background-color: #084e9b;
        display: flex;
        align-items: center;
        justify-content: space-between;
        width: 248px;
        height: 82px;
        border-radius: 12px;
        color: #FFF;
        padding: 24px;
        font-size: 1.6rem;
        font-weight: 700;
        box-sizing: border-box;
        box-shadow: 0px 0px 3px rgb(0 0 0 / 60%);
      }
/*-------------------------------------------------------------------
	footer
-------------------------------------------------------------------*/
footer {
  background: #084e9b;
  color: #ffffff;
  padding-top: 64px;
  padding-bottom: 64px;
}
footer .footer-inner {
  max-width: 1160px;
  margin: 0px auto;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}
footer .footer-inner .company-info {

}
footer .footer-inner .company-info img{
  width: 170px;
  margin-bottom: 2.0rem;
}
footer .footer-inner .company-info .company-data{
  font-size: 1.4rem;
  line-height: 2.0;
}
footer .footer-nav {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
}
footer .footer-nav div:first-child {
  margin-right: 68px;
}
footer .footer-nav .footer-nav-one{
  margin-right: 68px;
}
footer .footer-nav .footer-nav-one p{
  font-size: 1.8rem;
  font-weight: bold;
  color: #cedceb;
  margin-bottom: 2.0rem;
}
footer .footer-nav .footer-nav-one ul{
}
footer .footer-nav .footer-nav-one ul li{
  line-height: 2.4;
  font-size: 1.4rem;
}
footer .footer-nav .footer-nav-one ul li a{
  display: flex;
  align-items: center;
  justify-content: flex-start;
}
footer .footer-nav .footer-nav-one ul li a span.fs-s{
  font-size: 1.6rem;
  margin-left: 0.2rem;
}
footer .copy {
  width: 1160px;
  display: block;
  text-align: left;
  margin: 0px auto;
  font-size: 120%;
  font-weight: normal;
}