/*
hero
*/
.bsp.future #hero {
  font-size: min(1.25vw, 18px);
  background: #E5E2D9 url(../img/future/bg01.jpg) 0 0 no-repeat;
  background-size: 100%;
  height: 56.16em;
}
.bsp.future #hero .hero_wrap {
  position: relative;
  margin-top: 110px;
  text-align: left;
}
.bsp.future #hero .hero_wrap .hero_txt {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1;
  top: 9.17em;
  text-align: center;
}
.bsp.future #hero .hero_wrap .hero_txt .hero_lead {
  width: 16.7em;
  max-width: 300.68px;
  margin: auto;
}
.bsp.future #hero .hero_wrap .hero_txt h1 {
  font-size: min(2.78vw, 40px);
  line-height: 1.7;
  margin-top: 1em;
}
.bsp.future #hero .hero_wrap .hero_txt p {
  font-size: min(1.04vw, 15px);
  line-height: 2.73;
  margin-top: 3.33em;
  white-space: nowrap;
}
.bsp.future #hero .hero_wrap .hero_img {
  justify-content: space-between;
  align-items: flex-start;
}
.bsp.future #hero .hero_wrap .hero_img .hero_img_l {
  position: relative;
  left: -7.45%;
  width: 18.87%;
  max-width: 234px;
  margin-top: 25em;
}
.bsp.future #hero .hero_wrap .hero_img .hero_img_r {
  position: relative;
  right: -7.45%;
  width: 36.8%;
  max-width: 456px;
}

@media screen and (max-width: 1023px) {
  .bsp.future #hero .hero_wrap {
    margin-top: 85px;
  }
}
@media screen and (max-width: 767px) {
  .bsp.future #hero {
    background: #E5E2D9 url(../img/future/bg01_sp.jpg) 0 0 no-repeat;
    height: 269.6vw;
    background-size: 100%;
  }
  .bsp.future #hero .hero_wrap {
    margin-top: calc(60px + 6.67vw);
  }
  .bsp.future #hero .hero_wrap .hero_txt {
    top: 48vw;
    width: 84vw;
  }
  .bsp.future #hero .hero_wrap .hero_txt .hero_lead {
    width: 57.27vw;
    max-width: 57.27vw;
  }
  .bsp.future #hero .hero_wrap .hero_txt h1 {
    font-size: 5.33vw;
    margin-top: 5.33vw;
    white-space: nowrap;
  }
  .bsp.future #hero .hero_wrap .hero_txt p {
    font-size: 3.2vw;
    line-height: 2.67;
    margin-top: 16vw;
    white-space: inherit;
    text-align: left;
  }
  .bsp.future #hero .hero_wrap .hero_img .hero_img_l {
    left: -6.67vw;
    width: 33.33vw;
    max-width: 33.33vw;
    margin-top: 122.33vw;
  }
  .bsp.future #hero .hero_wrap .hero_img .hero_img_r {
    right: -6.67vw;
    width: 46.67vw;
    max-width: 46.67vw;
  }
}
/*
future
*/
.bsp.future #future {
  margin-top: -8.33em;
  font-size: min(1.25vw, 18px);
  background: #e5e2d9;
  padding-bottom: 8.33em;
}
.bsp.future #future:before {
  content: "";
  display: block;
  width: 100%;
  height: 8.33em;
  position: relative;
  top: -8.11em;
  background-image: linear-gradient(transparent, #e5e2d9);
  background-size: 100% 8.33em;
  background-repeat: no-repeat;
}
.bsp.future #future .future_wrap {
  margin-top: -25.94em;
  font-size: min(1.25vw, 18px);
}
.bsp.future #future .future_wrap .bl_future_list {
  display: flex;
  flex-wrap: wrap;
}
.bsp.future #future .future_wrap .bl_future_list .future_item {
  display: block;
  width: 31.45%;
  margin-top: 2.22em;
  overflow: hidden;
}
.bsp.future #future .future_wrap .bl_future_list .future_item + .future_item {
  margin-left: 2.825%;
}
.bsp.future #future .future_wrap .bl_future_list .future_item:nth-child(3n+1) {
  margin-left: 0;
}
.bsp.future #future .future_wrap .bl_future_list .future_item:hover img {
  transform: scale(1.1);
  transition: all 0.3s;
}

@media screen and (max-width: 767px) {
  .bsp.future #future {
    margin-top: -75.67vw;
    padding-bottom: 23vw;
  }
  .bsp.future #future:before {
    height: 40vw;
    top: -38.93vw;
    background-size: 100% 40vw;
    background-repeat: no-repeat;
  }
  .bsp.future #future .future_wrap {
    margin-top: -87.5vw;
  }
  .bsp.future #future .future_wrap .bl_future_list {
    flex-wrap: wrap;
  }
  .bsp.future #future .future_wrap .bl_future_list .future_item {
    width: 100%;
    margin-top: 5.33vw;
  }
  .bsp.future #future .future_wrap .bl_future_list .future_item + .future_item {
    margin-left: 0;
  }
}
/*
sns
*/
.bsp.future #sns {
  font-size: min(1.25vw, 18px);
  margin: 8.33em 0 8.06em;
}
.bsp.future #sns .sns_txt .sns_lead {
  width: 1.46em;
  max-width: 26.21px;
  margin: auto;
}
.bsp.future #sns .sns_txt h2 {
  font-size: min(2.78vw, 40px);
  line-height: 1.2;
  letter-spacing: 0.1em;
  margin-top: 1.2em;
  text-align: center;
}
.bsp.future #sns .sns_wrap {
  flex-wrap: wrap;
  justify-content: space-between;
  margin-top: 4.13em;
}
.bsp.future #sns .sns_wrap .btn {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: min(0.97em, 14px);
  border: 1px solid #000;
  width: 23.79%;
  height: 4.29em;
  margin-top: 1.43em;
  padding: 0;
}
.bsp.future #sns .sns_wrap .btn img {
  position: absolute;
  left: 1.84em;
  width: 2.14em;
  margin-right: auto;
}
.bsp.future #sns .sns_wrap .btn span {
  margin-left: 3em;
  letter-spacing: 0.05em;
}
.bsp.future #sns .sns_wrap .btn:nth-child(5), .bsp.future #sns .sns_wrap .btn:nth-child(6), .bsp.future #sns .sns_wrap .btn:nth-child(7), .bsp.future #sns .sns_wrap .btn:nth-child(8), .bsp.future #sns .sns_wrap .btn:nth-child(9) {
  height: 9.36em;
  text-align: center;
  flex-direction: column;
  align-items: center;
  /*width: 18.71%;*/
}
.bsp.future #sns .sns_wrap .btn:nth-child(5) img, .bsp.future #sns .sns_wrap .btn:nth-child(6) img, .bsp.future #sns .sns_wrap .btn:nth-child(7) img, .bsp.future #sns .sns_wrap .btn:nth-child(8) img, .bsp.future #sns .sns_wrap .btn:nth-child(9) img {
  position: relative;
  top: unset;
  left: unset;
  margin: 0;
}
.bsp.future #sns .sns_wrap .btn:nth-child(5) span, .bsp.future #sns .sns_wrap .btn:nth-child(6) span, .bsp.future #sns .sns_wrap .btn:nth-child(7) span, .bsp.future #sns .sns_wrap .btn:nth-child(8) span, .bsp.future #sns .sns_wrap .btn:nth-child(9) span {
  margin: 1em 0 0;
}
.bsp.future #sns .sns_wrap .btn:nth-child(3) {
  padding: 0;
}
.bsp.future #sns .sns_wrap .btn:nth-child(3) img {
  width: 1.43em;
  left: 2.13em;
}

@media screen and (max-width: 767px) {
  .bsp.future #sns {
    margin: 26.67vw 0;
  }
  .bsp.future #sns .sns_txt .sns_lead {
    width: 5.82vw;
    max-width: 5.82vw;
  }
  .bsp.future #sns .sns_txt h2 {
    font-size: 5.33vw;
    margin-top: 5.33vw;
  }
  .bsp.future #sns .sns_wrap {
    margin-top: 8vw;
    flex-wrap: wrap;
  }
  .bsp.future #sns .sns_wrap .btn {
    font-size: 3.2vw;
    width: 42.13vw;
    height: 10.67vw;
    margin-top: 2.67vw;
  }
  .bsp.future #sns .sns_wrap .btn img {
    position: absolute;
    left: 5.33vw;
    width: 5.33vw;
  }
  .bsp.future #sns .sns_wrap .btn span {
    margin-left: 2em;
  }
  .bsp.future #sns .sns_wrap .btn:nth-child(5), .bsp.future #sns .sns_wrap .btn:nth-child(6), .bsp.future #sns .sns_wrap .btn:nth-child(7), .bsp.future #sns .sns_wrap .btn:nth-child(8), .bsp.future #sns .sns_wrap .btn:nth-child(9) {
    height: 13.33vw;
    flex-direction: row;
    align-items: center;
    width: 100%;
  }
  .bsp.future #sns .sns_wrap .btn:nth-child(5) img, .bsp.future #sns .sns_wrap .btn:nth-child(6) img, .bsp.future #sns .sns_wrap .btn:nth-child(7) img, .bsp.future #sns .sns_wrap .btn:nth-child(8) img, .bsp.future #sns .sns_wrap .btn:nth-child(9) img {
    position: absolute;
    left: 5.33vw;
    width: 5.33vw;
  }
  .bsp.future #sns .sns_wrap .btn:nth-child(5) span, .bsp.future #sns .sns_wrap .btn:nth-child(6) span, .bsp.future #sns .sns_wrap .btn:nth-child(7) span, .bsp.future #sns .sns_wrap .btn:nth-child(8) span, .bsp.future #sns .sns_wrap .btn:nth-child(9) span {
    margin: 0 0 0 1em;
  }
  .bsp.future #sns .sns_wrap .btn:nth-child(3) {
    padding: 0;
  }
  .bsp.future #sns .sns_wrap .btn:nth-child(3) img {
    width: 4vw;
    left: 5.33vw;
  }
}
.bsp.future .fullpic {
  position: relative;
}
.bsp.future .fullpic h2 {
  position: absolute;
  bottom: 18.66vw;
  left: 5.33vw;
  color: #fff;
  font-size: 5.33vw;
  display: none;
}
.bsp.future .btn_movie {
  width: 24.79vw;
}
.bsp.future .btn_movie .title {
  width: 13.6vw;
  margin-left: 3.52vw;
}

@media screen and (max-width: 767px) {
  .bsp.future .fullpic h2 {
    display: block;
  }
  .bsp.future .btn_movie {
    width: 100%;
  }
  .bsp.future .btn_movie .title {
    width: 47vw;
    margin-left: 8.18vw;
  }
}