#key {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 117vw;
}
#key .left, #key .right {
  width: 50%;
  min-height: 70vw;
}

#key .left .slider_kv, #key .right .slider_kv {
  min-height: 100%;
  background-size: 120% auto;
}
#key .left .slider_kv {
  background-image: url('../img/index_re/key_left.jpg');
  animation: top-bottom 6s linear;
  animation-iteration-count: 1;
  background-position: center center;
  
}

#key .right .slider_kv {
  background-image: url('../img/index_re/key_right.jpg');
  animation: bottom-top 6s linear;
  animation-iteration-count: 1;
  background-position: center center;
  
}
@keyframes top-bottom {
  from {background-position: top center;}
  to {background-position: center center;}
}
@keyframes bottom-top {
  from {background-position: bottom center;}
  to {background-position: center center;}
}
#key .left h2, #key .right h2 {
  position: absolute;
  width: 23%;
  z-index: 2;
  padding: 0;
}
#key .left h2 {
  bottom: 0;
  left: 0;
  top: auto;
}
#key .right h2 {
  right: 0;
  top: 80px;
  left: auto;
}
#key .key1 {
  background-image: url("../img/index_re/key_left.jpg");
}
#key .key2 {
  background-image: url("../img/index_re/key_right.jpg");
}
#key .slick-slide > div > div {
  height: 117vw;
  position: relative;
  overflow: hidden;
  background-size: auto 170%;
  background-repeat: no-repeat;
}

#header .logo {
  position: absolute;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 32%;
  top: 45vw;
}

h2, .block p {
  padding-bottom: 0;
}

#sec1 {
  padding-bottom: 40vw;
  background: url("../img/index_re/s2_deco.png") no-repeat bottom center/100% auto;
}
#sec1 .img {
  padding-bottom: 10%;
}
#sec1 .txt {
  padding: 0 3%;
}
#sec1 .btn {
  margin: 10% 3.5% 0;
}

#sec2 {
  background: url("../img/index_re/s1_deco.png") no-repeat top center/100% auto, url("../img/index_re/bg.jpg") repeat top center/100% auto;
  color: #000;
  position: relative;
  padding-bottom: 12vw;
}
#sec2 h3 {
  position: absolute;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  top: -28vw;
  z-index: 2;
}
#sec2 h2 {
  padding: 33vw 0 0;
  position: relative;
  z-index: 2;
}
#sec2 h4 {
  font-size: 7vw;
  line-height: 1.5;
  margin: 5% 3%;
  letter-spacing: 0.1em;
}
#sec2 .txt {
  margin: 0 3%;
}
#sec2 .info {
  margin: 8% 3% 10%;
  border-top: 1px solid rgba(0, 0, 0, 0.5);
  padding: 8% 0 0;
}
#sec2 .info .tel {
  font-size: 25px;
  line-height: 1.5;
  letter-spacing: 0.1em;
}
#sec2 .info .tel small {
  display: block;
  font-size: 15px;
}
#sec2 .info .txt {
  margin: 10px 0 0;
}
#sec2 .group {
  position: relative;
  padding-bottom: 15%;
}
#sec2 .group:before {
  content: '';
  position: absolute;
  left: -5%;
  right: -5%;
  top: -7vw;
  bottom: 0;
  background-color: rgba(127, 127, 127, 0.1);
}
#sec2 .group p, #sec2 .group h4, #sec2 .group .info {
  position: relative;
  z-index: 2;
}
#sec2 .group.group2 {
  margin-top: 17vw;
}
#sec2 .group3 {
  margin: 12vw 0 0;
  background: url("../img/shared/bg.jpg");
  color: #fff;
  padding: 12vw 0;
}
#sec2 .group3 .logo {
  padding: 0 20%;
}
#sec2 .group3 h4 {
  margin: 4vw 5% 3%;
}
#sec2 .group3 .txt {
  margin: 0 5%;
}
#sec2 .group3 .info {
  padding: 8% 2% 0;
  margin-bottom: 0;
  border-top: 1px solid rgba(255, 255, 255, 0.5);
}
#sec2 .group3 .info .txt {
  margin: 0;
}
#sec2 .group3 .info .btn {
  margin: 8vw 3% 0;
}
#sec2 .note {
  background-color: #000;
  margin: 10% 0 10% 0%;
  text-align: center;
  /* width: 100%; */
  border-radius: 8px;
}
#sec2 .note .txt{
	font-size: 5vw;
	padding: 5% 0 5% 0;
	color: #fff;
	/* text-align: left; */
	margin-bottom: 5%;
}
#sec2 .note .txt span{
	font-size: 6vw;
	color: #d5c69a;
	font-weight: 700;
}

#sec3 {
  background: url("../img/index_re/s3_deco.png") no-repeat top center/100% auto, url("../img/index_re/s2_deco2.png") no-repeat top center/100% auto;
}
#sec3 h2 {
  position: relative;
  z-index: 2;
}
#sec3 h4 {
  font-size: 7vw;
  line-height: 1.5;
  margin: 0 3% 4%;
  letter-spacing: 0.1em;
}
#sec3 .txt {
  margin: 0 3%;
}
#sec3 .info {
  margin: 8% 3% 10%;
  border-top: 1px solid rgba(255, 255, 255, 0.5);
  padding: 8% 0 0;
}
#sec3 .info .tel {
  font-size: 25px;
  line-height: 1.5;
  letter-spacing: 0.1em;
}
#sec3 .info .tel small {
  display: block;
  font-size: 15px;
}
#sec3 .info .txt {
  margin: 10px 0 0;
}
#sec3 .btn {
  margin: 0 1%;
}
#sec3 .group {
  position: relative;
  padding-bottom: 12vw;
}
#sec3 .group:before {
  content: '';
  position: absolute;
  left: -5%;
  right: -5%;
  top: -7vw;
  bottom: 0;
  background-color: #000;
}
#sec3 .group p, #sec3 .group h4, #sec3 .group .info {
  position: relative;
  z-index: 2;
}

#sec4 {
  background: url("../img/index_re/s4_deco.png") no-repeat top center/100% auto, url("../img/index_re/bg.jpg") repeat top center/100% auto;
  color: #000;
  padding: 13vw 0 15vw;
}
#sec4 .wrap {
  padding: 0 6%;
}
#sec4 h2 {
  text-align: center;
  font-size: 10vw;
  line-height: 1.5;
  margin: 0 0 5vw;
  letter-spacing: 0.1em;
}
#sec4 dl {
  margin: 0 auto 0;
  background: url("../img/index_re/sec4_img_sp.jpg") no-repeat top center;
  background-size: cover;
  width: 100%;
  height: auto;
  padding: 10% 3% 10%;
}

#sec4 dl dt {
  font-size: 7vw;
  line-height: 1.5;
  margin-bottom: 3vw;
}
#sec4 dl dt small {
  font-size: 4vw;
}
#sec4 dl + dl {
  margin-top: 7vw;
  border-top: 1px solid;
  padding-top: 7vw;
}
#sec4 .btn {
  margin: 12vw -1% 0;
}

#sec5 {
  background-color: #fff;
  color: #000;
  padding: 10vw 0 12vw;
}
#sec5 h2 {
  text-align: center;
  font-size: 9vw;
  line-height: 1.5;
  margin-bottom: 10vw;
  letter-spacing: 0.1em;
  padding: 0;
}
#sec5 .group {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  text-align: center;
  margin: 0 3%;
}
#sec5 .group + .group {
  border-top: 1px solid rgba(0, 0, 0, 0.5);
  margin-top: 5vw;
  padding-top: 10vw;
}
#sec5 .group h3 {
  width: 120px;
  height: 38px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  border-radius: 5px;
  color: #fff;
  background-color: #920000;
  font-size: 15px;
  font-weight: 500;
  margin: 0 auto;
}
#sec5 .group .btn-more {
  margin-bottom: 3vw;
  text-align: left;
}
#sec5 .group .btn-more a {
  font-weight: bold;
  color: #920000;
  font-size: 13px;
  line-height: 1.5;
  padding: 0 0 1vw 0;
  background: url(../img/index_re/arrow2.png) no-repeat bottom right/100% auto;
  width: 55px;
  display: block;
}
#sec5 .group .feed {
  width: calc(100% - 70px);
  padding: 10px 0 0;
  text-align: left;
}
#sec5 .group .feed dl {
  line-height: 1.5;
}
#sec5 .group .feed dl dt {
  font-weight: 700;
  letter-spacing: 0;
}
#sec5 .group .feed dl dd {
  letter-spacing: 0;
}
