/*================== blog ====================*/
.slide01 {
  background: url(../img/scene/key.jpg) no-repeat center bottom;
  height: 350px;
  background-size: cover;
}

.slide01 span {
  position: absolute;
  bottom: 8vw;
  right: 0;
  width: 50%;
}

.slide01::before {
  background: url(../img/scene/line.png) no-repeat center bottom;
  background-size: 120% auto;
  width: 100%;
  height: 183px;
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  content: "";
}

#f-pc1 {
  position: absolute;
  bottom: 8.4vw;
  right: 0;
}

/*================== sec1 ====================*/
#sec1 {
  padding: 15vw 0 15vw;
  background: url(../img/scene/sec3_bg.jpg) repeat top center;
}

#sec1 h2 {
  margin: 4% 0 5vw;
}

#sec1 .photo {
  box-shadow: 0 0 6px rgba(0, 0, 0, 0.25);
  margin: 6vw 1% 0;
}

#sec1 .txt {
  font-weight: bold;
  text-align: justify;
}

@media screen and (min-width: 767px) {
  #keyvisual {
    padding-top: 119px;
  }
  .slide01 {
    background: url(../img/scene/key.jpg) no-repeat center bottom;
    height: 980px;
    background-size: cover;
  }
  .slide01 span {
    position: absolute;
    bottom: 198px;
    right: 0;
    width: 465px;
  }
  .slide01::before {
    background: url(../img/scene/line.png) no-repeat center bottom;
    background-size: 100% auto;
    width: 100%;
    height: 283px;
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    content: "";
  }
  #sec1 {
    padding: 80px 0 12px;
    background: url(../img/scene/sec3_bg.jpg) repeat top center;
  }
  #sec1 h2 {
    margin: 0 0 6px;
    position: relative;
    top: -10px;
  }
  #sec1 .photo {
    box-shadow: none;
    margin: 0;
    position: absolute;
    top: 25px;
    right: -125px;
    z-index: 5;
  }
  #sec1 .txt {
    font-weight: bold;
    text-align: left;
    width: 495px;
  }
}

/*================== sec2 ====================*/
#sec2 {
  position: relative;
  background: url(../img/scene/line1.png) no-repeat top center, url(../img/scene/sec2_ng.jpg) no-repeat center;
  background-size: 120% auto, cover;
  padding: 25vw 0 15vw;
}

#sec2::before {
  background: url(../img/scene/sec2_deco.png) no-repeat bottom right;
  background-size: 100px auto;
  width: 398px;
  height: 609px;
  content: "";
  position: absolute;
  right: 0;
  bottom: 75vw;
}

#sec2 h2 {
  margin: 0 10% 5vw 0;
}

#sec2 dl {
  margin-bottom: 5vw;
}

#sec2 dl dt {
  font-size: 18px;
  margin-bottom: 10px;
}

#sec2 dl dt span {
  font-size: 12px;
  margin-left: 15px;
}

#sec2 dl dd {
  text-align: justify;
}

#sec2 dl dd span {
  display: block;
  font-size: 12px;
}

@media screen and (min-width: 767px) {
  #sec2 {
    position: relative;
    background: url(../img/scene/line1.png) no-repeat top center, url(../img/scene/sec2_ng.jpg) no-repeat center;
    background-size: 100% auto, cover;
    padding: 260px 0 160px;
    margin-top: -20px;
  }
  #sec2::before {
    background: url(../img/scene/sec2_deco.png) no-repeat bottom right;
    background-size: 100% auto;
    width: 398px;
    height: 609px;
    content: "";
    position: absolute;
    right: 0;
    bottom: -210px;
    z-index: 1;
  }
  #sec2 h2 {
    margin: 0 0 28px 610px;
  }
  #sec2 .photo {
    position: absolute;
    top: 0;
    left: -250px;
  }
  #sec2 dl {
    margin-left: 610px;
    margin-bottom: 0;
    position: relative;
    z-index: 5;
  }
  #sec2 dl dt {
    font-size: 30px;
    margin-bottom: 25px;
  }
  #sec2 dl dt span {
    font-size: 12px;
    margin-left: 22px;
  }
  #sec2 dl dd {
    text-align: left;
    width: 456px;
  }
  #sec2 dl dd span {
    display: block;
    font-size: 12px;
  }
}

/*================== sec3 ====================*/
#sec3 {
  position: relative;
  background: url(../img/scene/sec3_bg.jpg) repeat center top;
  background-size: 120% auto;
  padding: 15vw 0 8vw;
}

#sec3 .wrap {
  z-index: 1;
}

#sec3 .wrap::before {
  background: url(../img/scene/sec3_deco.jpg) no-repeat bottom right;
  width: 257px;
  height: 253px;
  background-size: 120px auto;
  position: absolute;
  bottom: -15vw;
  right: 0;
  content: "";
  z-index: -1;
}

#sec3 h2 {
  margin: 0 15% 6vw;
  text-align: center;
  font-size: 22px;
  font-weight: bold;
}

#sec3 h3 {
  margin: 0 10% 12vw;
}

#sec3 dl {
  margin: 0 5%;
}

#sec3 dl dt span {
  position: relative;
  margin: 0 15% -10vw 3%;
  display: block;
}

#sec3 dl dd {
  text-align: justify;
  padding: 6vw 0 5vw;
}

#sec3 dl dd span {
  display: block;
  font-size: 11px;
}

@media screen and (min-width: 767px) {
  #sec3 {
    position: relative;
    background: url(../img/scene/sec3_bg.jpg) repeat center top;
    background-size: auto;
    padding: 125px 0 50px;
  }
  #sec3 .wrap {
    z-index: 1;
  }
  #sec3 .wrap::before {
    background: url(../img/scene/sec3_deco.jpg) no-repeat bottom right;
    width: 257px;
    height: 253px;
    background-size: 100% auto;
    position: absolute;
    bottom: -85px;
    right: -100px;
    content: "";
    z-index: -1;
  }
  #sec3 h2 {
    margin: 0 0 30px;
    text-align: center;
    font-size: 40px;
    font-weight: bold;
    width: 463px;
  }
  #sec3 h3 {
    margin: 0;
    position: absolute;
    top: 238px;
    left: 5px;
  }
  #sec3 dl {
    margin: -95px 0 0 500px;
    width: 513px;
  }
  #sec3 dl dt {
    position: relative;
  }
  #sec3 dl dt span {
    position: absolute;
    margin: 0;
    display: block;
    top: -106px;
    left: -50px;
  }
  #sec3 dl dd {
    text-align: left;
    padding: 16px 0 5px 5px;
    line-height: 40px;
  }
  #sec3 dl dd span {
    display: block;
    font-size: 12px;
  }
}

/*================== sec4 ====================*/
#sec4 {
  position: relative;
  padding: 20vw 0 14vw;
  position: relative;
  background: url(../img/scene/line_2.png) no-repeat center top, url(../img/scene/sec4_bg.jpg) no-repeat center top;
  background-size: 120% auto, cover;
}

#sec4 h2 {
  margin: 0 5% -10vw;
  position: relative;
}

#sec4 h2 span {
  position: absolute;
  bottom: -6vw;
  right: 0;
  width: 30%;
}

#sec4 .box {
  display: flex;
  flex-wrap: wrap-reverse;
}

#sec4 .box .item {
  background: url(../img/scene/sec4_box.png) no-repeat center top;
  background-size: 100% 100%;
  padding: 15vw 10% 10vw;
  box-sizing: border-box;
  width: 100%;
}

#sec4 .box .item h3 {
  text-align: center;
  font-weight: bold;
  font-size: 24px;
  margin-bottom: 8px;
}

#sec4 .box .item ul {
  font-size: 12px;
}

#sec4 .box .item ul i {
  font-style: normal;
}

#sec4 .box .item ul span {
  display: block;
  margin-bottom: 15px;
  text-align: center;
}

#sec4 .box dl {
  margin-top: 8vw;
}

#sec4 .box dl dd {
  text-align: justify;
  padding: 5vw 5% 0;
}

@media screen and (min-width: 767px) {
  #sec4 {
    position: relative;
    padding: 150px 0 100px;
    position: relative;
    background: url(../img/scene/line_2.png) no-repeat center top, url(../img/scene/sec4_bg.jpg) no-repeat center top;
    background-size: 100% auto, cover;
  }
  #sec4::before {
    background: url(../img/scene/sec3_bg.jpg) repeat center top;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 190px;
    content: "";
  }
  #sec4 .wrap {
    z-index: 2;
  }
  #sec4 h2 {
    margin: 0;
    position: absolute;
    top: -80px;
    right: -22px;
  }
  #sec4 h2 span {
    position: absolute;
    bottom: -130px;
    right: 0;
    width: 279px;
  }
  #sec4 .box {
    display: flex;
    flex-wrap: wrap;
  }
  #sec4 .box .item {
    background: url(../img/scene/sec4_box.png) no-repeat center top;
    height: 411px;
    background-size: 100% 100%;
    padding: 75px 50px 50px;
    box-sizing: border-box;
    width: 609px;
  }
  #sec4 .box .item h3 {
    text-align: center;
    font-weight: bold;
    font-size: 48px;
    margin-bottom: 20px;
  }
  #sec4 .box .item ul {
    font-size: 20px;
  }
  #sec4 .box .item ul span {
    display: block;
    margin-bottom: 15px;
    text-align: center;
  }
  #sec4 .box .item ul i {
    padding: 26px 0 10px 59px;
    display: inline-block;
  }
  #sec4 .box dl {
    margin-top: 0;
  }
  #sec4 .box dl dt {
    margin-left: -51px;
    position: relative;
    top: -138px;
    margin-bottom: -133px;
  }
  #sec4 .box dl dd {
    text-align: left;
    line-height: 40px;
    padding: 10px 10px 10px 20px;
  }
}

#sec5 {
  position: relative;
  background: url(../img/scene/sec3_bg.jpg) repeat center top;
  background-size: 120% auto;
  padding: 15vw 0 8vw;
}

#sec5 h2 {
  margin: 0 10% 5vw 0;
}

#sec5 .txt {
  text-align: justify;
  margin-bottom: 4vw;
}

@media screen and (min-width: 767px) {
  #sec5 {
    position: relative;
    background: url(../img/scene/sec3_bg.jpg) repeat center top;
    background-size: auto;
    padding: 15px 0 75px;
  }
  #sec5 .slide-box {
    width: 479px;
    position: absolute;
    top: -58px;
    left: 0;
  }
  #sec5 .slide-box .slick-dots {
    display: none !important;
  }
  #sec5 h2 {
    margin: 0 0 20px 515px;
    width: 514px;
  }
  #sec5 .txt {
    text-align: left;
    margin-bottom: 0;
    margin-left: 510px;
  }
}

#sec6 {
  position: relative;
  background: url(../img/scene/sec5_img.png) no-repeat center top 58vw, url(../img/scene/line_3.png) no-repeat center top;
  background-size: 120% auto, 140% auto;
  padding: 25vw 0 15vw;
}

#sec6 h2 {
  margin: 0 10% 52vw 10%;
}

#sec6 .txt {
  text-align: justify;
  margin-bottom: 4vw;
}

#sec6 .btn-move {
  margin: 0 15%;
}

#sec6 .btn-move a {
  padding: 7px;
  background: #fa7100;
}

@media screen and (min-width: 767px) {
  #sec6 {
    position: relative;
    background: url(../img/scene/sec5_img.png) no-repeat center top 378px, url(../img/scene/line_3.png) no-repeat center top;
    background-size: 100% auto, 100% auto;
    padding: 205px 0 69px;
    margin-top: -1px;
  }
  #sec6 h2 {
    margin: 0 auto 514px;
    width: 500px;
  }
  #sec6 .btn-move {
    margin: 0 auto;
    width: 340px;
  }
  #sec6 .btn-move a {
    font-size: 22px;
    height: 70px;
    padding: 0;
    background: #fa7100;
  }
  #sec6 .btn-move span:nth-child(1) {
    transform-origin: 0 50% -35px;
  }
  #sec6 .btn-move span.pc {
    transform-origin: 0 50% -35px;
  }
}

@media screen and (max-width: 767px) {
  #sec1, #sec2 {
    margin: -1px 0;
  }
}
