/*
hero
*/
.bsp.feature #hero {
  font-size: min(1.25vw, 18px);
  background: #0F2743;
  background-size: 100%;
}
.bsp.feature #hero .hero_wrap {
  position: relative;
  margin-top: 110px;
  text-align: left;
}
.bsp.feature #hero .hero_wrap .hero_txt {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1;
  top: 12.56em;
  text-align: center;
  color: #fff;
}
.bsp.feature #hero .hero_wrap .hero_txt .hero_lead {
  width: 8.78em;
  max-width: 158.07px;
  margin: auto;
}
.bsp.feature #hero .hero_wrap .hero_txt h1 {
  font-size: min(2.78vw, 40px);
  line-height: 1.7;
  margin-top: 1em;
}
.bsp.feature #hero .hero_wrap .hero_img {
  justify-content: space-between;
  align-items: flex-start;
}
.bsp.feature #hero .hero_wrap .hero_img .hero_img_l {
  position: relative;
  left: -7.45%;
  width: 33.87%;
  max-width: 420px;
  margin-top: 9.44em;
}
.bsp.feature #hero .hero_wrap .hero_img .hero_img_r {
  position: relative;
  right: -7.45%;
  margin-top: 4em;
  width: 33.15%;
  max-width: 411px;
}

@media screen and (max-width: 1023px) {
  .bsp.feature #hero .hero_wrap {
    margin-top: 85px;
  }
}
@media screen and (max-width: 767px) {
  .bsp.feature #hero .hero_wrap {
    margin-top: calc(60px + 6.67vw);
  }
  .bsp.feature #hero .hero_wrap .hero_txt {
    top: 19.2vw;
  }
  .bsp.feature #hero .hero_wrap .hero_txt .hero_lead {
    width: 30.11vw;
    max-width: 30.11vw;
  }
  .bsp.feature #hero .hero_wrap .hero_txt h1 {
    font-size: 5.33vw;
    margin-top: 5.33vw;
    white-space: nowrap;
  }
  .bsp.feature #hero .hero_wrap .hero_img .hero_img_l {
    left: -6.67vw;
    width: 29.07vw;
    max-width: 29.07vw;
    margin-top: 26.13vw;
  }
  .bsp.feature #hero .hero_wrap .hero_img .hero_img_r {
    margin-top: 7.47vw;
    right: -6.67vw;
    width: 25.86vw;
    max-width: 25.86vw;
  }
}
/*
feature
*/
.bsp.feature #feature {
  margin-top: -6em;
  font-size: min(1.25vw, 18px);
  background: #0F2743;
  padding-bottom: 5.11em;
}
.bsp.feature #feature .feature_wrap {
  font-size: min(1.25vw, 18px);
}
.bsp.feature #feature .feature_wrap .bl_feature_list {
  display: flex;
  flex-wrap: wrap;
}
.bsp.feature #feature .feature_wrap .bl_feature_list .feature_item {
  display: block;
  width: 31.45%;
  margin-top: 2.22em;
  overflow: hidden;
}
.bsp.feature #feature .feature_wrap .bl_feature_list .feature_item + .feature_item {
  margin-left: 2.825%;
}
.bsp.feature #feature .feature_wrap .bl_feature_list .feature_item:nth-child(3n+1) {
  margin-left: 0;
}
.bsp.feature #feature .feature_wrap .bl_feature_list .feature_item:hover img {
  transform: scale(1.1);
  transition: all 0.3s;
}

@media screen and (max-width: 767px) {
  .bsp.feature #feature {
    margin-top: -16vw;
    padding-bottom: 25.33vw;
  }
  .bsp.feature #feature .feature_wrap .bl_feature_list {
    flex-wrap: wrap;
  }
  .bsp.feature #feature .feature_wrap .bl_feature_list .feature_item {
    width: 100%;
    margin-top: 5.33vw;
  }
  .bsp.feature #feature .feature_wrap .bl_feature_list .feature_item + .feature_item {
    margin-left: 0;
  }
}
/*
sns
*/
.bsp.feature #sns {
  font-size: min(1.25vw, 18px);
  margin: 8.33em 0 8.06em;
}
.bsp.feature #sns .sns_txt .sns_lead {
  width: 1.46em;
  max-width: 26.21px;
  margin: auto;
}
.bsp.feature #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.feature #sns .sns_wrap {
  flex-wrap: wrap;
  justify-content: space-between;
  margin-top: 4.13em;
}
.bsp.feature #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.feature #sns .sns_wrap .btn img {
  position: absolute;
  left: 1.84em;
  width: 2.14em;
  margin-right: auto;
}
.bsp.feature #sns .sns_wrap .btn span {
  margin-left: 3em;
  letter-spacing: 0.05em;
}
.bsp.feature #sns .sns_wrap .btn:nth-child(5), .bsp.feature #sns .sns_wrap .btn:nth-child(6), .bsp.feature #sns .sns_wrap .btn:nth-child(7), .bsp.feature #sns .sns_wrap .btn:nth-child(8), .bsp.feature #sns .sns_wrap .btn:nth-child(9) {
  height: 9.36em;
  text-align: center;
  flex-direction: column;
  align-items: center;
  /*width: 18.71%;*/
}
.bsp.feature #sns .sns_wrap .btn:nth-child(5) img, .bsp.feature #sns .sns_wrap .btn:nth-child(6) img, .bsp.feature #sns .sns_wrap .btn:nth-child(7) img, .bsp.feature #sns .sns_wrap .btn:nth-child(8) img, .bsp.feature #sns .sns_wrap .btn:nth-child(9) img {
  position: relative;
  top: unset;
  left: unset;
  margin: 0;
}
.bsp.feature #sns .sns_wrap .btn:nth-child(5) span, .bsp.feature #sns .sns_wrap .btn:nth-child(6) span, .bsp.feature #sns .sns_wrap .btn:nth-child(7) span, .bsp.feature #sns .sns_wrap .btn:nth-child(8) span, .bsp.feature #sns .sns_wrap .btn:nth-child(9) span {
  margin: 1em 0 0;
}
.bsp.feature #sns .sns_wrap .btn:nth-child(3) {
  padding: 0;
}
.bsp.feature #sns .sns_wrap .btn:nth-child(3) img {
  width: 1.43em;
  left: 2.13em;
}

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

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