main {
  width: 100%;
  height: 100vh;
  position: relative;
  z-index: 0;
  overflow: hidden;
  background-color: black; }
  main:after {
    content: '';
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 2;
    background-color: rgba(0, 0, 0, 0.2); }
  main .keyBlock {
    position: absolute;
    top: 35vh;
    left: 0;
    right: 0;
    z-index: 3; }
    main .keyBlock #svg-animation {
      width: 80vw;
      max-width: 60rem;
      /*transform: rotate(-10deg);*/ }
      main .keyBlock #svg-animation image, main .keyBlock #svg-animation mask {
        width: 100%; }
      main .keyBlock #svg-animation .st0 {
        fill: none;
        stroke: #FFFFFF;
        stroke-width: 14;
        stroke-linecap: round;
        stroke-linejoin: round;
        stroke-miterlimit: 10;
        stroke-dasharray: 1500;
        stroke-dashoffset: 1500; }
    main .keyBlock h2 {
      color: white;
      font-size: 130%;
      letter-spacing: 1rem;
      margin-top: 1rem;
      width: 95%;
      /*margin-top: 5rem;
      padding-left: 2rem;
      text-align: left;*/ }
  main .backBlock {
    width: 100%;
    height: 100vh;
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background-image: url("../images/keyVisual.jpg");
    background-repeat: no-repeat; }
  main .scrollBlock {
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 5; }
    main .scrollBlock .scrollTxt {
      display: block;
      color: white;
      font-size: 80%;
      line-height: 1;
      letter-spacing: 0.1em;
      -webkit-transform: rotate(90deg);
      transform: rotate(90deg); }
    main .scrollBlock .scrollLine {
      position: relative;
      margin: 7rem 0 0 5.5rem;
      width: 0.1rem;
      height: 5rem;
      overflow: hidden;
      z-index: 4; }
      main .scrollBlock .scrollLine:before, main .scrollBlock .scrollLine:after {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        display: block;
        width: .1rem;
        height: 100%; }
      main .scrollBlock .scrollLine:before {
        background: #FFF;
        z-index: 6;
        -webkit-animation: scroll 2.4s infinite normal;
        animation: scroll 2.4s infinite normal; }
      main .scrollBlock .scrollLine:after {
        background: transparent; }

.top_message {
  z-index: 5; }
  .top_message .row {
    width: 70vw;
    max-width: 50rem;
    padding: 6vw 7vw;
    background-color: #242324;
    position: absolute;
    top: 0;
    right: 3vw;
    display: block;
    z-index: 6;
    overflow: hidden; }
    .top_message .row:after {
      content: '';
      display: block;
      width: 100%;
      height: 100%;
      position: absolute;
      bottom: -100%;
      left: 0;
      -webkit-transition: 0.3s ease-in-out;
      -moz-transition: 0.3s ease-in-out;
      -o-transition: 0.3s ease-in-out;
      transition: 0.3s ease-in-out;
      background-color: black;
      opacity: 0.4;
      z-index: 7; }
    .top_message .row p, .top_message .row h3, .top_message .row h4 {
      color: white;
      text-align: left;
      position: relative;
      z-index: 8; }
    .top_message .row p {
      font-size: 3rem;
      font-weight: 900;
      margin-bottom: 2rem;
      color: white;
      line-height: 100%; }
    .top_message .row h3 {
      letter-spacing: .25rem;
      text-align: left; }
    .top_message .row h4 {
      font-size: 130%;
      letter-spacing: .25rem;
      margin-bottom: 3rem; }
    .top_message .row .btn.arrow {
      position: relative;
      z-index: 8; }
      .top_message .row .btn.arrow span {
        border-bottom-color: white; }
        .top_message .row .btn.arrow span:after {
          border-top-color: white; }
    .top_message .row:hover:after {
      bottom: 0; }

.top_vision {
  z-index: 4;
  width: 100%;
  overflow: hidden; }
  .top_vision .row {
    margin: 0;
    position: relative;
    z-index: 6;
    padding-bottom: 24rem; }
    .top_vision .row:before {
      content: '';
      display: block;
      z-index: 0;
      position: absolute;
      right: 5%;
      left: 15%;
      bottom: 5%;
      background-color: rgba(0, 0, 0, 0.1);
      width: 85%;
      max-width: 85rem;
      height: 70%; }
    .top_vision .row .wrap {
      display: block;
      padding: 5vw 5vw 5vw 8vw;
      width: 90%;
      min-width: 30rem;
      max-width: 80rem;
      position: relative;
      z-index: 7; }
      .top_vision .row .wrap h2, .top_vision .row .wrap h3, .top_vision .row .wrap p {
        text-align: left; }
      .top_vision .row .wrap h2 {
        font-weight: 700;
        font-size: 350%;
        line-height: 110%; }
        .top_vision .row .wrap h2 span {
          font-size: inherit;
          font-weight: inherit;
          font-family: inherit;
          display: inline-block;
          color: transparent;
          -webkit-text-stroke: 1px #242324;
          margin-left: .5rem; }
      .top_vision .row .wrap h3 {
        font-size: 200%;
        font-family: "Noto Serif JP",serif;
        margin-bottom: 4rem;
        line-height: 130%;
        letter-spacing: .5rem; }
      .top_vision .row .wrap p {
        font-size: 80%; }
      .top_vision .row .wrap .btn {
        display: block;
        max-width: 25rem;
        margin: 0;
        margin-top: 4rem;
        padding: 1rem 5rem;
        border: 1px solid #242324;
        position: relative;
        overflow: hidden;
        z-index: 0;
        font-size: 1.2rem; }
        .top_vision .row .wrap .btn:after {
          content: '';
          position: absolute;
          bottom: -100%;
          left: 0;
          z-index: -1;
          width: 100%;
          height: 100%;
          background-color: #242324;
          -webkit-transition: 0.3s ease-in-out;
          -moz-transition: 0.3s ease-in-out;
          -o-transition: 0.3s ease-in-out;
          transition: 0.3s ease-in-out; }
        .top_vision .row .wrap .btn:hover {
          color: white; }
          .top_vision .row .wrap .btn:hover:after {
            bottom: 0; }
  .top_vision .verticalTxt {
    position: absolute;
    right: -10rem;
    top: 15rem; }
    .top_vision .verticalTxt span {
      font-size: 15rem;
      display: block;
      letter-spacing: 0.1em;
      -webkit-transform: rotate(90deg);
      transform: rotate(90deg);
      color: #444644;
      font-weight: 900;
      line-height: 100%;
      text-align: left;
      opacity: 0.1; }

.top_business {
  z-index: 3;
  padding-bottom: 8rem;
  border: 1px solid transparent; }
  .top_business .imgWrap {
    height: 60vh;
    position: relative;
    width: 100%;
    background-color: dimgray; }
    .top_business .imgWrap .slider {
      width: 100%;
      height: 100%;
      position: relative;
      top: 0;
      z-index: 1; }
      .top_business .imgWrap .slider img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        font-family: 'object-fit:cover;';
        transform: scale(1, 1);
        transition: 0s; }
      .top_business .imgWrap .slider .slick-slide {
        opacity: 1 !important; }
        .top_business .imgWrap .slider .slick-slide img {
          opacity: 0;
          transition: 0s; }
      .top_business .imgWrap .slider .slick-active img {
        opacity: 1;
        transition: ease .5s;
        /*transform: scale(1.2, 1.2);*/
        transition: ease 10.0s; }
      .top_business .imgWrap .slider .slick-continue img {
        opacity: 0;
        transition: ease .5s;
        /*transform: scale(1.4, 1.4);*/
        transition: ease 10.0s; }
  .top_business .row {
    position: relative;
    top: 0;
    left: 0;
    right: 0;
    padding: 5vw 5vw 5vw 8vw;
    width: 90%;
    margin-top: -20vh;
    z-index: 1; }
    .top_business .row h2 {
      font-weight: 700;
      font-size: 280%;
      line-height: 110%;
      margin-bottom: 3rem;
      padding-left: 1rem;
      font-weight: 900;
      text-align: left; }
      .top_business .row h2 span {
        font-size: inherit;
        font-weight: inherit;
        font-family: inherit;
        display: inline-block;
        color: transparent;
        -webkit-text-stroke: 1px #242324;
        margin-left: .5rem; }
    .top_business .row ul li {
      height: 100%;
      position: relative;
      z-index: 0; }
      .top_business .row ul li a {
        display: block;
        padding: 1.5rem 1.5rem 4rem 1.5rem;
        margin: 1rem;
        border: 1px solid #f4f4f4;
        position: relative;
        z-index: 1;
        overflow: hidden; }
        .top_business .row ul li a p, .top_business .row ul li a em, .top_business .row ul li a h3 {
          text-align: left;
          position: relative;
          z-index: 3; }
        .top_business .row ul li a em {
          display: block;
          font-weight: bold;
          margin-bottom: 1rem;
          color: gainsboro;
          -webkit-transition: 0.3s ease-in-out;
          -moz-transition: 0.3s ease-in-out;
          -o-transition: 0.3s ease-in-out;
          transition: 0.3s ease-in-out; }
        .top_business .row ul li a p {
          font-weight: 900;
          font-size: 120%; }
        .top_business .row ul li a h3 {
          font-size: 1.2rem;
          line-height: 180%; }
        .top_business .row ul li a .btn.arrow {
          position: absolute;
          bottom: 2rem;
          z-index: 3; }
          .top_business .row ul li a .btn.arrow span {
            border-bottom-color: gainsboro; }
            .top_business .row ul li a .btn.arrow span:after {
              border-top-color: gainsboro; }
        .top_business .row ul li a .imgBlock {
          position: absolute;
          top: 0;
          right: 0;
          z-index: 2;
          overflow: hidden; }
          .top_business .row ul li a .imgBlock img {
            width: 100%;
            height: 100%;
            display: block;
            vertical-align: bottom;
            object-fit: cover;
            font-family: 'object-fit:cover;';
            -webkit-transition: 0.3s ease-in-out;
            -moz-transition: 0.3s ease-in-out;
            -o-transition: 0.3s ease-in-out;
            transition: 0.3s ease-in-out; }
        .top_business .row ul li a:hover em {
          color: #F5CB5C; }
        .top_business .row ul li a:hover .btn.arrow {
          padding-left: 2rem; }
    .top_business .row .verticalTxt {
      position: absolute;
      top: -30vh;
      left: 4vw;
      z-index: 5; }
      .top_business .row .verticalTxt span {
        display: block;
        letter-spacing: 0.1em;
        writing-mode: tb;
        color: gainsboro; }
        .top_business .row .verticalTxt span:after {
          content: '';
          display: inline-block;
          width: 1px;
          height: 8rem;
          border-left: 1px solid gainsboro;
          position: absolute;
          right: 1rem;
          bottom: -9rem; }

.top_about {
  z-index: 1;
  overflow: hidden; }
  .top_about .row {
    position: relative;
    z-index: 4;
    min-height: 60rem; }
  .top_about .backImg {
    width: 100%;
    height: 150%;
    position: absolute;
    top: 0;
    left: 0;
    background-image: url(/assets/images/top-about-bg.jpg);
    background-size: cover;
    background-position: center bottom;
    z-index: 2; }
  .top_about:after {
    content: '';
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    background-color: rgba(0, 0, 0, 0.4);
    z-index: 3; }
  .top_about h2 {
    font-size: 300%;
    padding-left: 6vw;
    font-weight: 900;
    text-align: left;
    color: white;
    margin-bottom: 4rem; }
    .top_about h2 span {
      font-size: inherit;
      font-weight: inherit;
      font-family: inherit;
      display: inline-block;
      color: transparent;
      -webkit-text-stroke: 1px white;
      margin-left: .5rem; }
  .top_about ul {
    position: relative;
    z-index: 5;
    padding: 4rem 0;
    justify-content: space-between; }
    .top_about ul li {
      padding: 0 1rem;
      max-width: 30rem; }
      .top_about ul li .wrap {
        display: block;
        background-color: #131213; }
        .top_about ul li .wrap img {
          width: 100%;
          height: 18rem;
          object-fit: cover;
          font-family: 'object-fit:cover;';
          display: block; }
        .top_about ul li .wrap .innerWrap {
          padding: 1.5rem;
          padding: 3rem; }
          .top_about ul li .wrap .innerWrap h3, .top_about ul li .wrap .innerWrap h4, .top_about ul li .wrap .innerWrap p {
            text-align: left; }
          .top_about ul li .wrap .innerWrap h3, .top_about ul li .wrap .innerWrap p {
            color: dimgray; }
          .top_about ul li .wrap .innerWrap h3 {
            font-weight: 900; }
          .top_about ul li .wrap .innerWrap h4 {
            color: #F5CB5C;
            font-size: 80%;
            letter-spacing: .2rem; }
          .top_about ul li .wrap .innerWrap p {
            margin-top: 1rem; }
          .top_about ul li .wrap .innerWrap .btn.arrow {
            position: relative; }
            .top_about ul li .wrap .innerWrap .btn.arrow span {
              border-bottom-color: gainsboro; }
              .top_about ul li .wrap .innerWrap .btn.arrow span:after {
                border-top-color: gainsboro; }
          .top_about ul li .wrap .innerWrap:hover em {
            color: #F5CB5C; }
          .top_about ul li .wrap .innerWrap:hover .btn.arrow {
            padding-left: 2rem; }
  .top_about .horisonTxt {
    position: absolute;
    left: 5%;
    bottom: 0;
    z-index: 4;
    font-size: 15rem;
    color: white;
    opacity: 0.3;
    writing-mode: tb;
    white-space: nowrap;
    font-weight: 900; }

.top_news .row {
  max-width: 1240px; }
.top_news .wrap {
  margin-top: 4rem; }
  .top_news .wrap h2, .top_news .wrap dl, .top_news .wrap .btnBlock {
    margin: 0; }
  .top_news .wrap h2 {
    flex-basis: 25%;
    position: relative; }
    .top_news .wrap h2:after {
      content: '';
      display: inline-block;
      height: 1px;
      background-color: gainsboro;
      position: relative;
      top: -.4rem; }
  .top_news .wrap dl {
    flex-basis: 60%; }
    .top_news .wrap dl dt, .top_news .wrap dl dd {
      padding: 1.5rem;
      font-size: 80%; }
      .top_news .wrap dl dt a, .top_news .wrap dl dd a {
        font-size: inherit; }
    .top_news .wrap dl dt {
      flex-basis: 30%;
      font-family: 'Montserrat', sans-serif;
      font-weight: 900;
      color: gainsboro; }
    .top_news .wrap dl dd {
      flex-basis: 70%;
      text-align: left;
      line-height: 160%; }
  .top_news .wrap .btnBlock {
    flex-basis: 10%;
    position: relative; }
    .top_news .wrap .btnBlock .btn {
      top: 4rem;
      display: block;
      width: 14rem;
      margin: 0;
      padding: 1rem 0;
      border: 1px solid #242324;
      overflow: hidden;
      z-index: 0;
      font-size: 1.2rem; }
      .top_news .wrap .btnBlock .btn:after {
        content: '';
        position: absolute;
        bottom: -100%;
        left: 0;
        z-index: -1;
        width: 100%;
        height: 100%;
        background-color: #242324;
        -webkit-transition: 0.3s ease-in-out;
        -moz-transition: 0.3s ease-in-out;
        -o-transition: 0.3s ease-in-out;
        transition: 0.3s ease-in-out; }
      .top_news .wrap .btnBlock .btn:hover {
        color: white; }
        .top_news .wrap .btnBlock .btn:hover:after {
          bottom: 0; }

@-webkit-keyframes scroll {
  0% {
    -webkit-transform: translate3d(0, -100%, 0); }
  15% {
    -webkit-transform: translate3d(0, -98%, 0); }
  85% {
    -webkit-transform: translate3d(0, 98%, 0); }
  100% {
    -webkit-transform: translate3d(0, 100%, 0); } }
@keyframes scroll {
  0% {
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0); }
  15% {
    -webkit-transform: translate3d(0, -98%, 0);
    transform: translate3d(0, -98%, 0); }
  85% {
    -webkit-transform: translate3d(0, 98%, 0);
    transform: translate3d(0, 98%, 0); }
  100% {
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0); } }
@media screen and (max-width: 480px) {
  main {
    overscroll-behavior: contain; }
    main .backBlock {
      background-size: auto 100%; }

  .top_about .backImg {
    background-image: none;
    background-color: white; }

  .top_news .wrap h2 {
    text-align: right; }
    .top_news .wrap h2:after {
      width: 13rem;
      margin-left: -3rem;
      right: -5rem; }
  .top_news .wrap dl, .top_news .wrap .btnBlock {
    min-width: 100%; }
    .top_news .wrap dl dt, .top_news .wrap dl dd, .top_news .wrap .btnBlock dt, .top_news .wrap .btnBlock dd {
      min-width: 100%; }
    .top_news .wrap dl dt, .top_news .wrap .btnBlock dt {
      padding-bottom: 0;
      text-align: left; }
  .top_news .wrap .btnBlock .btn {
    width: auto;
    padding: 2rem 0;
    margin-bottom: 4rem;
    position: relative; } }
@media screen and (min-width: 481px) {
  .top_news .wrap h2:after {
    width: 6rem;
    margin-left: 2rem;
    left: 0; }
  .top_news .wrap .btnBlock .btn {
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
    position: absolute;
    right: -5rem; } }
@media screen and (min-width: 481px) and (max-width: 769px) {
  .cnt_contact a {
    top: 45vh; } }
@media screen and (min-width: 481px) and (max-width: 1024px) {
  .top_news .wrap dl {
    min-width: 90%; }

  .top_aboute ul li .wrap img {
    min-height: 40vh; } }
@media screen and (max-width: 769px) {
  main .backBlock {
    background-size: auto 100%; }

  .top_message {
    height: 6rem; }

  .top_business .row ul li {
    min-width: 100%; }
    .top_business .row ul li a {
      padding-top: 30%; }
      .top_business .row ul li a .imgBlock {
        width: 100%;
        height: 20vw; }

  .top_about ul li:not(:last-of-type) {
    margin-bottom: 3rem; } }
@media screen and (min-width: 770px) {
  main .backBlock {
    background-size: cover; }

  .top_business .row ul li a {
    padding-right: 30%; }
    .top_business .row ul li a .imgBlock {
      height: 100%;
      width: 30%; }

  .cnt_contact a {
    top: 38vh; } }
@media screen and (max-width: 1024px) {
  .top_vision .row .wrap {
    margin: 0; }

  .top_news .wrap h2 {
    min-width: 100%;
    text-align: left;
    margin-bottom: 2rem; } }
@media screen and (min-width: 1025px) {
  .top_vision .row .wrap {
    margin: 0;
    margin-left: 8vw; }

  .top_business .row ul li a .imgBlock {
    min-width: 20rem; }

  .top_about ul {
    margin-left: 20%;
    max-width: 80%; } }
