@charset "utf-8";
@media (max-width: 750px) {
  #topArea {
    position: relative;
    width: 100%;
    height: calc(100vw * (375 / 763));
    height: -webkit-calc(100vw * (375 / 763));
    z-index: 98;
  }
  #topArea #mainImg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: calc(100vw * (375 / 763));
    height: -webkit-calc(100vw * (375 / 763));
    z-index: 101;
    overflow: hidden;
  }
  #topArea #mainImg .kv {
    position: relative;
    overflow: hidden;
    z-index: 102;
  }
  #topArea #mainImg .kv img {
    position: absolute;
    top: 0;
    left: 0;
    width: auto;
    height: 100%;
  }
  #topArea .top1 {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: calc(100vw * (375 / 763));
    height: -webkit-calc(100vw * (375 / 763));
    z-index: 102;
    color: #ffffff;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  #topArea .top1 .textwrap {
    padding-left: 2.66vw;
    padding-right: 2.66vw;
    position: absolute;
    right: 0;
    left: 0;
    top: calc(100vh - 100vw);
    top: -webkit-calc(100vh - 100vw);
    bottom: auto;
  }
  #topArea .top1 .lead {
    font-size: 8.53vw;
    line-height: 1.4;
  }
  @media screen and (min-width: 600px) and (max-width: 750px) {
    #topArea .top1 .lead br.spOnly {
      display: none !important;
    }
  }
  #topArea .top1 .sub_lead {
    margin-top: 20px;
    font-size: 4.26vw;
  }
  /* scrollDown */
  #scrollDown {
    position: absolute;
    width: 22px;
    top: calc(100vh - 156px);
    top: -webkit-calc(100vh - 156px);
    right: 0;
    bottom: auto;
    left: 0;
    z-index: 13;
    margin: 0 auto;
    transition: all 0.2s linear;
    display: none;
  }
  #scrollDown.none {
    opacity: 0
  }
  #scrollDown .scroll-btn {
    display: block;
    text-align: center;
  }
  #scrollDown .scroll-btn .mouse {
    display: block;
    position: relative;
    width: 22px;
    height: 43px;
    margin: 0 auto;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    background-image: url("/initiatives/img/icon_scroll.png");
    background-position: center;
    background-repeat: no-repeat;
    background-size: 22px auto;
  }
  #scrollDown .scroll-btn .mouse > * {
    display: block;
    position: absolute;
    top: 6px;
    left: 7px;
    width: 8px;
    height: 8px;
    background: white;
    border-radius: 50%;
    -webkit-animation: ani-mouse_sp 2.5s linear infinite;
    -moz-animation: ani-mouse_sp 2.5s linear infinite;
    animation: ani-mouse_sp 2.5s linear infinite;
  }
  /* initiativesArea */
  #initiativesArea .unit, #initiativesArea .unit.alignR, #initiativesArea .unit.alignL {
    width: 100%;
    display: block;
    position: relative;
    margin: 12vw auto 68vw;
  }
  #initiativesArea .unit:nth-of-type(2) {
    margin: 12vw auto 77vw;
  }
  #initiativesArea .unit:nth-of-type(3) {
    margin: 12vw auto 76vw;
  }
  #initiativesArea .unit:nth-of-type(4) {
    margin: 12vw auto 0;
  }
  #initiativesArea .unit .img {
    max-width: 96vw;
    position: absolute;
    bottom: -58vw;
    right: -26vw;
  }
  #initiativesArea .unit:nth-of-type(2) .img {
    bottom: -67vw;
    left: -31vw;
  }
  #initiativesArea .unit:nth-of-type(3) .img {
    bottom: -66vw;
  }
  #initiativesArea .unit .txt h3 {
    font-size: 9.6vw;
  }
  #initiativesArea .unit .txt h3 span {
    font-size: 3.2vw;
  }
  #initiativesArea .unit .txt p {
    font-size: 3.2vw;
    margin-top: 9.333333333vw;
  }
  #initiativesArea .unit .txt {
    margin-left: 0;
  }
  #initiativesArea .unit .txt .icon {
    max-width: 24vw;
    margin-bottom: 2.66vw;
  }
  /* manufacturingArea */

#mainContents #manufacturingArea {
  padding: 80px 0 ;
}
#manufacturingArea .contents:nth-of-type(2) {
  justify-content: space-between;
}
  #manufacturingArea .contents .unit {
    width: 42.133333333vw;
    margin-right: 0;
    margin-bottom: 0;
  }
  #manufacturingArea .contents .unit:nth-of-type(3), #manufacturingArea .contents .unit:nth-of-type(4) {
    margin-top: 5.333333333vw;
  }
  #manufacturingArea .contents .unit p {
    padding: 0 2.4vw;
    font-size: 2.56vw;
  }
  /* snsArea */
  #snsArea h4 {
    font-size: 4.8vw;
  }
  #snsArea h4 span {
    font-size: 3.2vw;
  }
  #snsArea .contents {
    display: block;
  }
  #snsArea .sns {
    display: block;
    margin-top: 8vw;
  }
  #snsArea .sns .unit {
    border-right: none;
    border-bottom: 1px solid #3f3f3f;
    padding: 6vw 0 6vw 12vw;
  }
  #snsArea .sns .unit:first-of-type {
    padding-top: 0;
  }
  #snsArea .sns .unit:last-of-type {
    border-bottom: none;
  }
  #snsArea .sns .unit .sns_link {
    width: 12vw;
    padding: 0 6vw;
  }
  #snsArea .sns .unit.suzuki::before,  #snsArea .sns .unit.car::before, #snsArea .sns .unit.moter::before, #snsArea .sns .unit.marine::before {
    width: 8vw;
    height: 8vw;
    left: 0;
  }
}
/*デバイスが横長かつ、横幅が750px以内、の場合*/
@media screen and (orientation: landscape) and (max-width: 750px) {
  #topArea {
    height: calc(100vh - 50px);
    height: -webkit-calc(100vh - 50px);
  }
  #topArea #mainImg {
    height: calc(100vh - 50px);
    height: -webkit-calc(100vh - 50px);
  }
  #topArea .cover {
    height: calc(100vh - 50px);
    height: -webkit-calc(100vh - 50px);
  }
  #topArea #mainImg .kv {
    top: 50px;
    height: calc(100vh - 50px);
    height: -webkit-calc(100vh - 50px);
  }
  #topArea #mainImg .kv img {
    height: 100%;
  }
  #topArea .top1 {
    height: calc(100vh - 50px);
    height: -webkit-calc(100vh - 50px);
    color: #ffffff;
  }
  #topArea .top1 .textwrap {
    padding-top: 1vw;
    padding-bottom: 6vw;
    top: calc(100vh - (156px + 20vw));
    top: -webkit-calc(100vh - (156px + 20vw));
  }
  #topArea .top1 .lead {
    font-size: 2.2rem;
  }
  #topArea .top1 .sub_lead {
    font-size: 1.2rem;
  }
  #topArea .top1 .lead br.spOnly {
    display: none !important;
  }
  /* scrollDown */
  #scrollDown {
    display: block;
    top: auto;
    bottom: 10px;
  }
}
/* scrollDown アニメ */
@-webkit-keyframes ani-mouse_sp {
  0% {
    opacity: 1;
    top: 6px;
  }
  50% {
    opacity: 1;
    top: 18px;
  }
  100% {
    opacity: 1;
    top: 6px;
  }
}