@charset "UTF-8";
/* -----

   set module

---------------------------------------------------- */
/*-- トップページパーツ
---------------------------------------------------- */
.home .asnav {
  display: none;
}
@media screen and (max-width: 899px) {
  .home .asnav {
    display: block;
  }
}

.home_visual {
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 640px;
}
@media screen and (max-width: 479px) {
  .home_visual {
    /*height: 512px;*/
    height: calc( 100vh - 70px );
    max-height: 640px;
    min-height: 470px;
  }
}
.home_visual__inner {
  position: relative;
  background: #fff;
  width: 100%;
  height: 100%;
}
.home_visual__inner > ul {
  position: absolute;
  left: 50%;
  width: 100%;
  height: 100%;
  transform: translateX(-50%);
}
.home_visual__inner > ul > li {
  background-repeat: no-repeat;
  background-position: center;
  width: 100%;
  height: 100%;
}
.home_visual__inner > ul > li:nth-child(1) {
  background-image: url(../images/home/bg_home_top_visual_01.jpg);
}
.home_visual__inner > ul > li:nth-child(2) {
  background-image: url(../images/home/bg_home_top_visual_02.jpg);
}
.home_visual__inner > ul > li:nth-child(3) {
  background-image: url(../images/home/bg_home_top_visual_03.jpg);
}
.home_visual__inner > ul > li:nth-child(4) {
  background-image: url(../images/home/bg_home_top_visual_04.jpg);
}
@media screen and (max-width: 899px) {
  .home_visual__inner > ul > li {
    background-size: cover;
  }
  .home_visual__inner > ul > li:nth-child(3) {
    background-position-x: calc( 78.571vw - 1576.35px );
  }
}
@media screen and (max-width: 479px) {
  .home_visual__inner > ul > li {
    background-position: top;
  }
  .home_visual__inner > ul > li:nth-child(1) {
    background-image: url(../images/home/sp/bg_home_top_visual_01_sp.jpg);
  }
  .home_visual__inner > ul > li:nth-child(2) {
    background-image: url(../images/home/sp/bg_home_top_visual_02_sp.jpg);
  }
  .home_visual__inner > ul > li:nth-child(3) {
    background-image: url(../images/home/sp/bg_home_top_visual_03_sp.jpg);
    background-position-x: 0;
  }
  .home_visual__inner > ul > li:nth-child(4) {
    background-image: url(../images/home/sp/bg_home_top_visual_04_sp.jpg);
  }
}
.home_visual__first {
  position: absolute;
  top: 0;
  width: 100%;
  height: 100%;
}
@keyframes background_frame {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
.home_visual__first::before {
  content: '';
  display: block;
  position: relative;
  background: #fff;
  width: 100%;
  height: 100%;
  animation-name: background_frame;
  animation-duration: 1500ms;
  animation-timing-function: ease-in-out;
  animation-delay: 3000ms;
  animation-fill-mode: both;
  animation-iteration-count: 1;
}
@keyframes copy_frame {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.home_visual__first > .copy {
  position: absolute;
  bottom: 96px;
  left: calc( 50% - 350px );
  transform: translateX(-50%);
  animation-name: copy_frame;
  animation-duration: 1500ms;
  animation-timing-function: ease-in-out;
  animation-delay: 1000ms;
  animation-fill-mode: both;
  animation-iteration-count: 1;
  z-index: 100;
}
@media screen and (max-width: 899px) {
  .home_visual__first > .copy {
    left: 28px;
    bottom: 70px;
    transform: translateX(0);
  }
}
@media screen and (max-width: 479px) {
  .home_visual__first > .copy {
    top: 200px;
    top: calc( 35.29% + 34.11px );
    bottom: auto;
    left: 24px;
    transform: translateX(0);
  }
}
.home_visual__first > .copy > img {
  display: block;
  width: 445px;
}
@media screen and (max-width: 899px) {
  .home_visual__first > .copy > img {
    width: calc( 28.957vw + 184.67px );
  }
}
@media screen and (max-width: 479px) {
  .home_visual__first > .copy > img {
    display: none;
  }
}
.home_visual__first > .copy > img + img {
  display: none;
}
@media screen and (max-width: 479px) {
  .home_visual__first > .copy > img + img {
    display: block;
    width: 267px;
  }
}
@media screen and (max-width: 359px) {
  .home_visual__first > .copy > img + img {
    width: 240px;
  }
}
.home_visual__first > .obj_left,
.home_visual__first > .obj_right {
  position: absolute;
}
.home_visual__first > .obj_left::before, .home_visual__first > .obj_left::before,
.home_visual__first > .obj_right::before,
.home_visual__first > .obj_right::before {
  content: '';
  position: absolute;
  display: block;
  background: #fff;
  z-index: 100;
  animation-duration: 2500ms;
  animation-timing-function: cubic-bezier(1, 0.25, 0.05, 1);
  animation-delay: 200ms;
  animation-fill-mode: both;
  animation-iteration-count: 1;
}
@keyframes obj_left_frame {
  0% {
    height: 1944px;
  }
  100% {
    height: 0;
  }
}
.home_visual__first > .obj_left {
  transform: rotate(75.8deg);
  top: -819px;
  left: calc( 50% - 540px );
}
@media screen and (max-width: 479px) {
  .home_visual__first > .obj_left {
    transform: rotate(70.8deg);
    top: -390px;
    left: calc( 50% - 273px );
  }
}
@media screen and (max-width: 479px) {
  .home_visual__first > .obj_left > img {
    width: 128px;
  }
}
.home_visual__first > .obj_left::before {
  width: 241px;
  animation-name: obj_left_frame;
}
@media screen and (max-width: 479px) {
  .home_visual__first > .obj_left::before {
    width: 128px;
  }
}
@keyframes obj_right_frame {
  0% {
    height: 1332px;
  }
  100% {
    height: 0;
  }
}
.home_visual__first > .obj_right {
  transform: rotate(30deg);
  top: -250px;
  right: calc( 50% - 526px );
}
@media screen and (max-width: 479px) {
  .home_visual__first > .obj_right {
    top: 140px;
    right: calc( 50% - 186px );
  }
}
@media screen and (max-width: 479px) {
  .home_visual__first > .obj_right > img {
    width: 164px;
  }
}
.home_visual__first > .obj_right::before {
  width: 328px;
  animation-name: obj_right_frame;
}
@media screen and (max-width: 479px) {
  .home_visual__first > .obj_right::before {
    width: 164px;
  }
}

.home_headline {
  text-align: center;
  margin-bottom: 24px;
}
.home_headline > .ttl {
  display: inline-block;
}
.home_headline > .ttl > .main {
  position: relative;
  display: block;
  width: 256px;
  padding: 0 0 10px 0;
  margin: 0 0 9px 0;
  border-bottom: solid 1px #b5b5b5;
  font-size: 28px;
  font-style: normal;
  font-weight: 500;
}
@media screen and (max-width: 899px) {
  .home_headline > .ttl > .main {
    font-size: 22px;
    width: 148px;
  }
}
.home_headline > .ttl > .main::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -1px;
  display: block;
  background: #00469b;
  height: 1px;
  width: 128px;
}
@media screen and (max-width: 899px) {
  .home_headline > .ttl > .main::after {
    width: 74px;
  }
}
.home_headline > .ttl > .sub {
  display: block;
  font-family: "Roboto";
  color: #00469b;
  font-size: 14px;
  font-feature-settings: 'palt';
  font-weight: 500;
  letter-spacing: .08em;
}
@media screen and (max-width: 899px) {
  .home_headline > .ttl > .sub {
    font-size: 11px;
  }
}

.home_products {
  background: #e6e8ec;
  padding: 35px 0 42px 0;
}
@media screen and (max-width: 899px) {
  .home_products {
    padding: 35px 0 25px 0;
  }
}
.home_products__inner {
  background: url(../images/home/bg_products_link.jpg) no-repeat center top;
  background-color: #99b5d7;
  overflow-x: hidden;
}
@media screen and (max-width: 899px) {
  .home_products__inner {
    background: #e6e8ec;
  }
}
.home_products__link_box {
  font-size: 0;
  width: 1200px;
  margin: 0 auto;
}
@media screen and (max-width: 899px) {
  .home_products__link_box {
    width: auto;
    text-align: center;
    padding: 0 12px;
  }
}
.home_products__link_box > li {
  position: relative;
  display: inline-block;
  vertical-align: top;
}
.home_products__link_box > li:nth-child(1) {
  z-index: 110;
  box-shadow: 5px 0px 20px 0px rgba(0, 0, 0, 0.4);
  transform: skew(-18deg);
}
@media screen and (max-width: 899px) {
  .home_products__link_box > li:nth-child(1) {
    width: calc( 50% - 5px );
    transform: skew(0);
    box-shadow: none;
  }
}
@media screen and (max-width: 639px) {
  .home_products__link_box > li:nth-child(1) {
    width: 100%;
    max-width: 360px;
  }
}
.home_products__link_box > li:nth-child(2) {
  z-index: 100;
  transform: skew(-18deg);
}
@media screen and (max-width: 899px) {
  .home_products__link_box > li:nth-child(2) {
    width: calc( 50% - 5px );
    transform: skew(0);
    margin: 0 0 0 10px;
  }
}
@media screen and (max-width: 639px) {
  .home_products__link_box > li:nth-child(2) {
    width: 100%;
    max-width: 360px;
    margin: 12px 0 0 0;
  }
}
.home_products__link_cnt {
  position: relative;
  display: block;
  width: 450px;
  height: 240px;
  /*background: #fff;*/
  overflow: hidden;
}
@media screen and (max-width: 899px) {
  .home_products__link_cnt {
    width: 100%;
    height: 200px;
  }
}
@media screen and (max-width: 639px) {
  .home_products__link_cnt {
    height: 140px;
  }
}
.home_products__link_cnt::after {
  position: absolute;
  top: 0;
  left: 50%;
  display: block;
  content: '';
  background: #00469b;
  width: 0;
  height: 100%;
  z-index: 100;
  opacity: 0.2;
}
.home_products__link_cnt:hover::after {
  left: 0%;
  width: 100%;
  transition: left 0.4s cubic-bezier(0.4, 0, 0.2, 1), width 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}
.home_products__link_dsc {
  position: relative;
}
.home_products__link_dsc > .ttl {
  position: relative;
  background: #00469b;
  padding: 12px 0 12px 0;
  color: #fff;
  font-feature-settings: 'palt';
  font-size: 18px;
  font-weight: 500;
  letter-spacing: .04em;
  text-align: center;
  z-index: 110;
}
@media screen and (max-width: 899px) {
  .home_products__link_dsc > .ttl {
    padding: 10px 0 12px 0;
    font-size: 16px;
  }
}
.home_products__link_dsc > .ttl > span {
  position: relative;
  display: inline-block;
  transform: skew(18deg);
  margin-right: 44px;
}
@media screen and (max-width: 899px) {
  .home_products__link_dsc > .ttl > span {
    transform: skew(0);
  }
}
.home_products__link_dsc > .ttl > span::before, .home_products__link_dsc > .ttl > span::after {
  content: '';
  position: absolute;
  background: #fff;
  height: 1px;
}
.home_products__link_dsc > .ttl > span::before {
  top: 9px;
  right: -50px;
  width: 32px;
}
@media screen and (max-width: 899px) {
  .home_products__link_dsc > .ttl > span::before {
    top: 10px;
    right: -40px;
    width: 28px;
  }
}
.home_products__link_dsc > .ttl > span::after {
  top: 5px;
  right: -52px;
  width: 12px;
  transform: rotate(45deg);
}
@media screen and (max-width: 899px) {
  .home_products__link_dsc > .ttl > span::after {
    top: 7px;
    right: -41px;
    width: 8px;
  }
}
.home_products__link_dsc > .photo {
  position: absolute;
  z-index: 100;
  transform: skew(18deg);
  top: 0;
}
@media screen and (max-width: 899px) {
  .home_products__link_dsc > .photo {
    transform: skew(0);
  }
}
@media screen and (max-width: 639px) {
  .home_products__link_dsc > .photo {
    position: static;
    height: 102px;
    background-repeat: no-repeat;
    background-size: cover;
  }
  .home_products__link_dsc > .photo > img {
    display: none;
  }
}
.home_products__link_dsc > .photo.industry {
  right: -38px;
}
@media screen and (max-width: 899px) {
  .home_products__link_dsc > .photo.industry {
    left: -24%;
  }
}
@media screen and (max-width: 639px) {
  .home_products__link_dsc > .photo.industry {
    background-image: url(../images/home/sp/photo_products_link_industry_sp.jpg);
  }
}
.home_products__link_dsc > .photo.space {
  left: -43px;
}
@media screen and (max-width: 899px) {
  .home_products__link_dsc > .photo.space {
    right: -20%;
  }
}
@media screen and (max-width: 639px) {
  .home_products__link_dsc > .photo.space {
    background-image: url(../images/home/sp/photo_products_link_space_sp.jpg);
  }
}
@media screen and (max-width: 899px) {
  .home_products__link_search_box {
    display: block !important;
  }
}
.home_products__link_search {
  width: 240px;
  margin-left: 48px;
}
@media screen and (max-width: 899px) {
  .home_products__link_search {
    width: 100%;
    margin-left: 0;
    font-size: 0;
  }
}
.home_products__link_search > dt {
  padding: 12px 0 12px 0;
  margin-bottom: 22px;
  border-bottom: solid 1px rgba(255, 255, 255, 0.5);
  color: #fff;
  font-feature-settings: 'palt';
  font-size: 18px;
  font-weight: 500;
  letter-spacing: .04em;
  text-align: center;
}
@media screen and (max-width: 899px) {
  .home_products__link_search > dt {
    padding: 24px 0 12px 0;
    margin-bottom: 12px;
    color: #333333;
    border-bottom-color: #d4d6d9;
  }
}
.home_products__link_search > dd {
  display: inline-block;
  width: 100%;
}
@media screen and (max-width: 899px) {
  .home_products__link_search > dd {
    width: calc( 50% - 5px );
  }
}
.home_products__link_search > dd:last-child {
  margin-top: 10px;
}
@media screen and (max-width: 899px) {
  .home_products__link_search > dd:last-child {
    margin: 0 0 0 10px;
  }
}
.home_products__link_search > dd > a {
  display: block;
  background: #fff;
  padding: 26px 0 26px 0;
  text-align: center;
  transition: background 0.2s ease-out;
}
@media screen and (max-width: 899px) {
  .home_products__link_search > dd > a {
    padding: 24px 0 24px 0;
  }
}
.home_products__link_search > dd > a > span {
  position: relative;
  display: block;
  padding-left: 23px;
  font-feature-settings: 'palt';
  font-size: 16px;
  font-weight: 500;
  letter-spacing: .04em;
  text-align: left;
  font-style: normal;
}
@media screen and (max-width: 899px) {
  .home_products__link_search > dd > a > span {
    padding-left: 0;
    text-align: center;
  }
}
.home_products__link_search > dd > a > span::before, .home_products__link_search > dd > a > span::after {
  content: '';
  position: absolute;
  background: #838383;
  height: 1px;
}
.home_products__link_search > dd > a > span::before {
  top: 9px;
  right: 10px;
  width: 30px;
}
@media screen and (max-width: 899px) {
  .home_products__link_search > dd > a > span::before {
    top: 30px;
    right: 10px;
    width: 20px;
  }
}
.home_products__link_search > dd > a > span::after {
  top: 5px;
  right: 8px;
  width: 12px;
  transform: rotate(45deg);
}
@media screen and (max-width: 899px) {
  .home_products__link_search > dd > a > span::after {
    top: 27px;
    right: 8px;
    width: 8px;
  }
}
.home_products__link_search > dd > a:hover {
  background: rgba(255, 255, 255, 0.8);
}
.home_products__link_search > dd > a:hover > em {
  color: #00469b;
}

.home_news {
  position: relative;
  padding: 56px 0 0 0;
}
@media screen and (max-width: 899px) {
  .home_news {
    padding: 32px 0 0 0;
  }
}
.home_news__list {
  width: 1080px;
  margin: 0 auto;
}
@media screen and (max-width: 899px) {
  .home_news__list {
    width: auto;
  }
}
.home_news__link {
  position: absolute;
  top: 50px;
  right: 0;
}
@media screen and (max-width: 899px) {
  .home_news__link {
    position: static;
    margin-top: 20px;
    text-align: center;
  }
}
.home_news__link > a {
  position: relative;
  background: #fff;
  display: inline-block;
  width: 180px;
  border: solid 1px #00469b;
  border-radius: 24px;
  padding: 12px 0 13px 0;
  color: #00469b;
  font-size: 15px;
  font-weight: 500;
  text-align: center;
  transition: all 0.2s ease-out;
}
@media screen and (max-width: 899px) {
  .home_news__link > a {
    width: 270px;
  }
}
@media screen and (max-width: 639px) {
  .home_news__link > a {
    width: 180px;
  }
}
.home_news__link > a:hover {
  background: #f8f9fb;
}

/*# sourceMappingURL=common_home.css.map */
