#key .slide-fade-custom {
  overflow: hidden;
  position: relative;
}
#key .slide-fade-custom * {
  height: inherit !important;
}
#key .slide-fade-custom .slide {
  animation-duration: 7s;
  animation-delay: 0s;
  animation-timing-function: ease-out;
  animation-fill-mode: forwards;
  animation-iteration-count: 1;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  opacity: 0;
}
#key .slide-fade-custom .slide:nth-child(1) {
  opacity: 1;
  z-index: 1;
}
#key .slide-fade-custom .slide.active {
  animation-name: showImg;
  z-index: 2;
}
#key .slide-fade-custom .slide.active .slider-inner {
  animation: showTranslate 7s linear forwards;
}
#key .slide-fade-custom .slide.prev {
  animation-name: hideImg;
  z-index: 2;
}
#key .slide-fade-custom .slide.prev .slider-inner {
  animation: hideTranslate 7s linear forwards;
}
#key .slide-fade-custom .slide-img {
  transform: scale(1.3);
}
#key .slide-fade-custom .slide-img img {
  max-width: none !important;
  width: 100% !important;
  height: 100% !important;
  -o-object-fit: cover;
  object-fit: cover;
}
@media screen and (min-width: 768px) {
  #key .slide-fade-custom .slide {
    height: 930px !important;
  }
  #key .slide-fade-custom .slide-img1 {
    background: url("../img/index/key_01.jpg") center/cover;
  }
  #key .slide-fade-custom .slide-img2 {
    background: url("../img/index/key_02.jpg") center/cover;
  }
  #key .slide-fade-custom .slide-img3 {
    background: url("../img/index/key_03.jpg") center/cover;
  }
}

#sec1 {
  padding: 16vw 0px 20vw;
}
#sec1 h2 {
  width: 80%;
  margin: 0px auto;
}
#sec1 .sec1-txt {
  margin: 8vw 0px;
}
#sec1 .sec1-btn {
  margin: 0px auto;
}
@media screen and (min-width: 768px) {
  #sec1 {
    padding: 234px 0px 241px;
  }
  #sec1 h2 {
    width: 350px;
  }
  #sec1 .sec1-txt {
    margin: 98px 0px 65px;
    text-align: center;
    line-height: 45px;
  }
  #sec1 .sec1-btn {
    width: 270px;
  }
}

#sec2 .sec2-parallax {
  padding-top: 80vw;
}
#sec2 .sec2-2 {
  position: relative;
  padding: 10vw 0px 16vw;
}
#sec2 .sec2-2 h2 {
  position: relative;
  text-align: center;
}
#sec2 .sec2-2 h2::before {
  content: "";
  position: absolute;
  top: 14vw;
  left: 50%;
  transform: translateX(-50%);
  width: 10%;
  height: 1px;
  background: #000;
}
#sec2 .sec2-2 .sec2-txt {
  text-align: center;
  margin: 10vw 0px;
}
#sec2 .sec2-2 .sec2-txt P + p {
  margin: 4vw 0px 0px;
}
#sec2 .sec2-2 .sec2-btn {
  margin: 8vw auto 0px;
}
#sec2 .sec2-2::before {
  content: "";
  position: absolute;
  bottom: 0px;
  left: 0px;
  width: 100%;
  height: 68vw;
  background: #e8e8e6;
  z-index: -1;
}
@media screen and (min-width: 768px) {
  #sec2 .sec2-parallax {
    padding-top: 600px;
  }
  #sec2 .sec2-2 {
    padding: 188px 0px 177px;
  }
  #sec2 .sec2-2::before {
    width: calc(50% + 460px);
    height: 338px;
  }
  #sec2 .sec2-2 h2 {
    text-align: left;
    width: 400px;
  }
  #sec2 .sec2-2 h2::before {
    top: 50%;
    transform: translateY(-50%);
    left: 406px;
    width: 280%;
  }
  #sec2 .sec2-2 .sec2-txt {
    margin: 44px 0px 45px;
    text-align: left;
    width: 340px;
  }
  #sec2 .sec2-2 .sec2-txt p + p {
    margin: 35px 0px 0px;
  }
  #sec2 .sec2-2 .sec2-img {
    margin: 0px;
    width: 639px;
    top: 97px;
    right: -44px;
    position: absolute;
  }
  #sec2 .sec2-2 .sec2-btn {
    width: 300px;
    margin: 0px;
  }
}
@media only screen and (min-width: 999px) and (max-width: 1100px) {
  #sec2 .sec2-2 h2,
  #sec2 .sec2-2 .sec2-btn {
    margin: 0px 0px 0px 16px;
  }
  #sec2 .sec2-2 .sec2-txt {
    margin: 44px 0px 45px 16px;
  }
}

#sec3 {
  position: relative;
  padding: 16vw 0px 20vw;
}
#sec3 h2 {
  margin: 0px auto 10vw;
  height: 45vw;
  line-height: 2.4;
}
#sec3 .sec3-img1 {
  width: 80%;
  margin: 0px 0px 4vw -5%;
}
#sec3 .sec3-img2 {
  width: 85%;
  margin: 0px -5% 10vw auto;
}
#sec3 .sec3-list {
  margin: 10vw 4% 0px auto;
  width: 50%;
}
#sec3 .sec3-list .sec3-btn {
  margin: 0px 0px 4vw;
  width: 100%;
}
#sec3::before {
  content: "";
  position: absolute;
  bottom: 0px;
  left: 0px;
  width: 100%;
  height: 180vw;
  background: url("../img/shared/bg2.jpg") repeat top center;
  z-index: -1;
}
@media screen and (min-width: 768px) {
  #sec3 {
    padding: 244px 0px 160px;
  }
  #sec3::before {
    height: 810px;
  }
  #sec3 h2 {
    height: 200px;
    line-height: 70px;
    margin: 0px auto 101px;
  }
  #sec3 .sec3-img1 {
    width: 683px;
    margin: 0px 0px 0px -182px;
  }
  #sec3 .sec3-img2 {
    width: 683px;
    margin: 144px -186px 0px 0px;
  }
  #sec3 .sec3-row {
    margin: 127px 0px 0px;
  }
  #sec3 .sec3-txt {
    width: 640px;
    margin: 0px 0px 0px 39px;
  }
  #sec3 .sec3-list {
    width: 220px;
    margin: 27px 32px 0px 0px;
  }
  #sec3 .sec3-list .sec3-btn {
    margin: 0px 0px 31px;
    width: 206px;
  }
}

#sec4 {
  padding: 16vw 0px 20vw;
  position: relative;
}
#sec4::before {
  content: "";
  position: absolute;
  bottom: 0px;
  left: 0px;
  width: 100%;
  height: 62vw;
  background: #e8e8e6;
  z-index: -1;
}
#sec4 h2 {
  height: 56vw;
  margin: 0px auto 6vw;
}
#sec4 h3 {
  text-align: center;
}
#sec4 .sec4-slide1 {
  margin: 10vw -5% 6vw;
}
#sec4 .sec4-slide1 .slick-dots {
  justify-content: flex-start;
  margin: 2vw 0px 0px 4%;
}
#sec4 .sec4-slide2 {
  margin: 0px 4% 16vw;
}
#sec4 h3 {
  margin: 0px 0px 6vw;
}
@media screen and (min-width: 768px) {
  #sec4 {
    padding: 200px 0px 166px;
  }
  #sec4::before {
    width: 310px;
    height: 100%;
  }
  #sec4 .sec4-row {
    flex-direction: row-reverse;
  }
  #sec4 .sec4-box1 {
    width: 333px;
  }
  #sec4 h2 {
    height: 240px;
    margin: 0px auto 38px;
  }
  #sec4 .sec4-slide1 {
    width: 840px;
    margin: 102px 0px 0px -251px;
  }
  #sec4 .sec4-slide1 .slick-dots {
    margin: 12px 0px 0px;
    justify-content: center;
  }
  #sec4 .sec4-slide2 {
    width: 590px;
    z-index: 2;
    position: relative;
    margin: -113px -7px 0px auto;
  }
  #sec4 h3 {
    margin: -28px 0px 0px 116px;
    text-align: left;
    height: 230px;
  }
  #sec4 .sec4-txt2 {
    width: 640px;
    margin: 48px 115px 0px 0px;
  }
}
@media only screen and (min-width: 999px) and (max-width: 1100px) {
  #sec4 .sec4-box1 {
    margin: 0px 16px 0px 0px;
  }
}

#sec5 {
  background: url("../img/shared/bg2.jpg") repeat top center;
  padding: 16vw 0px;
}
#sec5 h2 {
  text-align: center;
}
#sec5 .sec5-btn {
  width: 30%;
  margin: 2vw auto 8vw;
}
#sec5 #feed {
  box-sizing: border-box;
  position: relative;
}
#sec5 #feed::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0px;
  transform: translateY(-50%);
  width: 100%;
  height: 1px;
  border-top: 1px dotted #000;
}
#sec5 #feed dl:nth-child(1) {
  margin: 0px 0px 8vw;
}
#sec5 #feed dl {
  padding: 0px 4%;
}
#sec5 .sec5-btn-insta {
  border: 1px solid #000;
  box-sizing: border-box;
  display: flex;
  justify-content: space-between;
  padding: 3vw 20%;
  font-size: 4.5vw;
  align-items: center;
  margin: 10vw 4% 0px;
}
#sec5 .sec5-btn-insta::before {
  opacity: 0.8;
}
#sec5 .sec5-btn-insta i {
  width: 42px;
}
@media screen and (min-width: 768px) {
  #sec5 {
    padding: 152px 0px;
  }
  #sec5 .sec5-row {
    align-items: center;
  }
  #sec5 .sec5-box {
    width: 140px;
    margin: 0px 0px 0px 26px;
  }
  #sec5 .sec5-btn {
    width: 100px;
    margin: 12px auto 0px;
  }
  #sec5 #feed {
    width: 390px;
  }
  #sec5 #feed dl:nth-child(1) {
    margin: 0px 0px 30px;
  }
  #sec5 #feed dl {
    padding: 0px 16px;
  }
  #sec5 .sec5-btn-insta {
    width: 250px;
    margin: 0px 30px 0px 0px;
    font-size: 19px;
    padding: 47px 40px;
  }
} /*# sourceMappingURL=index.css.map */

.txt_line {
  border: 1px solid;
  text-align: center;
  display: flex;
  justify-content: center;
  margin: 0 auto 10vw auto !important;
  padding: 30px 50px;
}
@media screen and (min-width: 768px) {
  .txt_line {
    width: 500px;
    margin: 0 auto 90px auto !important;
  }
}

.news_box {
    width: 700px;
    margin: 40px auto 30px;
    line-height: 2em;
    padding-bottom:39px;
    font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "メイリオ", Meiryo, "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	border: 1px solid #333333;
}
.news_box .ttl {
	color: #333333;
    padding: 39px 50px 10px;
    text-align: center;
    font-size: 20px;
    width: 500px;
    border-bottom: 1px solid #333333;
    margin: 0 auto;
}
.news_box .txt {
	color: #333333;
	padding: 20px 50px 0;
	text-align: center;
	font-size: 16px;
}

.news_box .txt2 {
	color: #333333;
	padding: 39px 50px 0;
	text-align: center;
	font-size: 16px;
}
@media only screen and (max-width: 480px) {
.news_box {
    width: 90%;
    margin: 30px auto 20px;
}
.news_box .ttl {
    padding: 39px 10px 10px;
    font-size: 18px;
    width: 70%;
}
.news_box .txt {
	padding: 20px 10px 0;
	font-size: 14px;
}
.news_box .txt2 {
	padding: 39px 10px 0;
	font-size: 14px;
}	
}

.btn_news {
	 width: 350px;
  margin: 30px auto;
}

.btn_news a {
  display: block;
	padding: 10px 20px;
	background: #3e1a1a;
  color: #fff;
  font-size: 17px;
	text-align: center;
  box-shadow: 0 0 10px 2px rgba(0, 0, 0, 0.45);
  letter-spacing: 0.2em;
  line-height: 30px;
  box-sizing: border-box;
}

.btn_news a:hover {
  text-decoration: none;
  opacity: .8;
}


@media only screen and (max-width: 767px) {
	.btn_news {
	 width: 80%;
  margin: 10px auto;
}
}