@media only screen and (min-width: 768px) {
  header #key .slide {
    background: url("../img/index/kv.jpg") center/cover;
  }
}

#rss {
  background: url("../img/shared/bg2.jpg") repeat top left;
  padding: 16vw 0px;
  color: #fff;
}
#rss h2 {
  font-size: 8vw;
  margin: 0px auto 8vw;
  font-weight: 400;
  text-align: center;
}
#rss #feed dl {
  margin: 0px 0px 6vw;
  display: flex;
  justify-content: space-between;
}
#rss #feed dl dt {
  width: 36%;
}
#rss #feed dl dt span, #rss #feed dl dt img {
  width: 100% !important;
  height: 120px !important;
  -o-object-fit: cover;
     object-fit: cover;
  cursor: pointer;
}
#rss #feed dl dt span:hover, #rss #feed dl dt img:hover {
  opacity: 0.8;
}
#rss #feed dl dd {
  width: 60%;
  align-self: center;
}
#rss #feed dl dd .rss-time {
  font-family: "Amiri";
  font-size: 400;
  margin-bottom: 1vw;
}
#rss .rss-btn a {
  margin: 10vw auto 0px;
}
@media only screen and (min-width: 768px) {
  #rss {
    padding: 147px 0px 95px;
  }
  #rss h2 {
    font-size: 42px;
    margin: 0px 0px 29px;
  }
  #rss #feed dl {
    display: block;
    width: 310px;
    margin: 0px;
  }
  #rss #feed dl dt {
    width: 100%;
  }
  #rss #feed dl dt span, #rss #feed dl dt img {
    height: 220px !important;
  }
  #rss #feed dl dd {
    width: 275px;
    margin: 21px auto 0px;
    font-size: 15px;
    line-height: 30px;
  }
  #rss #feed dl dd .rss-time {
    margin-bottom: 2px;
  }
  #rss #feed dl dd .rss-ttl:hover {
    cursor: pointer;
    text-decoration: underline;
  }
  #rss .rss-btn {
    position: absolute;
    top: 396px;
    right: 0px;
  }
  #rss .rss-btn a {
    margin: 0px;
    width: 107px;
    line-height: 37px;
  }
}

.txt-line {
  position: relative;
  font-size: 4vw;
  font-weight: 400;
  letter-spacing: 0.1em;
  display: inline-block;
  line-height: 1;
}
.txt-line::before {
  content: "";
  position: absolute;
  left: 0px;
  top: 0px;
  width: 1px;
  height: 20vw;
  border-left: 1px solid #fff;
}
.txt-line::after {
  content: "";
  position: absolute;
  left: 0px;
  top: 20vw;
  width: 1px;
  height: 6vw;
  border-left: 1px dashed #fff;
}
.txt-line.red {
  color: #5e1312;
}
.txt-line.red::before, .txt-line.red::after {
  border-color: #5e1312;
}
.txt-line.dark {
  color: #000;
}
.txt-line.dark::before, .txt-line.dark::after {
  border-color: #000;
}
@media only screen and (min-width: 768px) {
  .txt-line {
    font-size: 20px;
    line-height: 24px;
  }
  .txt-line::before {
    height: 125px;
  }
  .txt-line::after {
    top: 128px;
    height: 40px;
  }
  .txt-line2 {
    font-size: 20px;
    line-height: 24px;
    position: relative;
    font-weight: 400;
    letter-spacing: 0.1em;
    display: inline-block;
  }
  .txt-line2::before {
    height: 125px;
    content: "";
    position: absolute;
    left: 0px;
    top: 0px;
    width: 1px;
    border-left: 1px solid #fff;
  }
  .txt-line2::after {
    top: 128px;
    height: 40px;
    content: "";
    position: absolute;
    left: 0px;
    width: 1px;
    border-left: 1px dashed #fff;
  }
  .hrt_dec{
    left: 7px;
  }
}

#sec1 {
  position: relative;
  padding: 12vw 0px;
}
#sec1 .sec1-img1 {
  width: 95%;
  margin: 0px 0px 0px -6vw;
}
#sec1 h2 {
  height: 90vw;
  font-size: 6vw;
  color: #260c00;
  font-weight: 400;
  margin: 10vw 0px 4vw 9vw;
}
#sec1 h2 span {
  margin: 0px 0px 22vw;
}

#sec1::before {
  content: "";
  position: absolute;
  bottom: 0px;
  left: 0px;
  width: 80%;
  height: 90%;
  background: url("../img/shared/bg3.jpg") repeat top left;
}
@media only screen and (max-width: 768px) {
#sec1 .sec1-img2 {
  width: 60%;
  margin: 6vw 0px 0px auto;
  position: absolute;
  top: 60vw;
  right: 5vw;
}
}
@media only screen and (min-width: 768px) {
  #sec1 {
    padding: 88px 0px 234px;
  }
  #sec1::before {
    width: calc(50% - 110px);
    height: 724px;
  }
  #sec1 .sec1-img1 {
    width: 679px;
    margin: 108px 0px 0px -74px;
  }
  #sec1 .sec1-img2 {
    position: absolute;
    margin: 0px;
    top: 641px;
    right: -83px;
    width: 465px;
  }
  #sec1 h2 {
    height: 562px;
    margin: 0px 118px 0px 0px;
    font-size: 34px;
  }
  #sec1 h2 span {
    margin: 0px 0px 160px;
  }
  #sec1 .sec1-txt {
    /* width: 560px; */
    margin: 67px 0px 0px;
    width: calc(100% - 550px);
  }
}

#sec2 {
  background: url("../img/shared/bg2.jpg") repeat top left;
  color: #fff;
  position: relative;
  padding: 0px 0px 24vw;
}
#sec2 .sec2-1 {
  background: url("../img/index/sec2_bg1_sp.jpg") no-repeat top center/110%;
  padding: 3vw 0px 0px;
  position: relative;
  z-index: 1;
}
#sec2 .sec2-1 h2 {
  font-size: 6vw;
  margin: 0px auto 24px;
  height: 70vw;
  font-weight: 400;
}
#sec2 .wrap {
  z-index: 1;
}
#sec2 .sec2-img1 {
  width: 60%;
  margin: -35vw -16vw 0px auto;
}
#sec2 .sec2-img2 {
  width: 50%;
  margin: -38vw 0px 6vw -8vw;
}
#sec2 .sec2-btn a {
  margin: 8vw auto 0px;
}
#sec2::before {
  content: "";
  position: absolute;
  top: 0px;
  right: 0px;
  width: 20vw;
  height: 100%;
  background: url("../img/shared/bg4.jpg") repeat top left;
}
@media only screen and (min-width: 768px) {
  #sec2 {
    padding: 0px 0px 210px;
  }
  #sec2::before {
    width: 24%;
  }
  #sec2 .sec2-1 {
    background: url("../img/index/sec2_bg1.jpg") center/cover;
    padding: 69px 0px 114px;
  }
  #sec2 .sec2-1 h2 {
    font-size: 34px;
    line-height: 62px;
    height: 400px;
  }
  #sec2 .sec2-img1 {
    width: 498px;
    margin: -50px 0px 0px -12px;
  }
  #sec2 .sec2-img2 {
    width: 478px;
    margin: 0px;
    position: absolute;
    top: 532px;
    left: -150px;
  }
  #sec2 .sec2-box1 {
    width: 488px;
    margin: 81px -60px 0px 20px;
  }
  #sec2 .sec2-btn a {
    margin: 91px 0px 0px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1200px) {
  #sec2 .sec2-box1 {
    margin: 81px -20px 0px 20px;
  }
}

#sec3 {
  position: relative;
  background: url("../img/shared/bg4.jpg") repeat top left;
  padding: 16vw 0px;
  color: #fff;
}
#sec3::before {
  content: "";
  position: absolute;
  top: 0px;
  right: 0px;
  width: 20vw;
  height: 100%;
  background: #440a16;
}
#sec3 h2 {
  display: flex;
      /* flex-direction: row-reverse; */
      font-size: 6vw;
      height: 78vw;
      font-weight: 400;
      position: relative;
      z-index: 1;
      justify-content: flex-end;
      align-items: flex-end;
      margin: 0px 0px 16vw 18px;
}
/* #sec3 h2 {
  font-size: 6vw;
  line-height: 62px;
  flex-direction: row;
  align-items: center;
  justify-content: unset;
  height: 470px;
  margin: 0px 0px 40px 134px;
} */

/* #sec3 h2::before {
  content: "";
  position: absolute;
  left: 6vw;
  width: 30vw;
  height: 1px;
  bottom: 17vw;
  border-top: 1px dashed #fff;
} */
#sec3 .sec3-img {
  position: absolute;
  width: 89vw;
  top: -30vw;
  right: -27vw;
}
#sec3 .sec3-btn a {
  margin: 8vw auto 0px;
}
@media only screen and (max-width: 768px) {
  #sec3 h2 span {
    margin: 8vw 0px 0px 6vw;
    position: absolute;
    top: -10px;
    right: 25px;
  }
}
@media only screen and (min-width: 768px) {
  #sec3 {
    padding: 88px 0px 115px;
  }
  #sec3 .wrap {
    max-width: 1100px;
  }
  #sec3::before {
    width: 24%;
  }
  #sec3 h2 {
    font-size: 34px;
    line-height: 62px;
    flex-direction: row;
    align-items: center;
    justify-content: unset;
    height: 470px;
    margin: 0px 0px 40px 134px;
  }
  #sec3 h2::before {
    display: none;
  }
  #sec3 h2 span {
    margin: 0px 0px 167px 26px;
  }
  #sec3 .sec3-img {
    width: 833px;
    top: -179px;
    right: -240px;
  }
  #sec3 .sec3-txt {
    /* width: 380px; */
    margin: 0px 0px 53px 20px;
    width: calc(100% - 640px);
  }
  #sec3 .sec3-btn a {
    width: 380px;
    margin: 0px 0px 0px 20px;
  }
}

#sec4 {
  background: url("../img/shared/bg2.jpg") repeat top left;
  padding: 0px 0px 16vw;
  position: relative;
  color: #fff;
}
#sec4 .sec4-box {
  width: 90%;
  margin: 4vw auto 0px;
}
#sec4 .sec4-box h2 {
  text-align: center;
  font-size: 7vw;
  margin: 0px 0px 4vw;
  font-weight: 400;
}
#sec4 .sec4-box h2 span {
  position: absolute;
  top: 2vw;
  right: 3vw;
}
@media only screen and (min-width: 768px) {
  #sec4 {
    padding: 0px;
  }
  #sec4 .sec4-img {
    width: 64%;
    margin: 0px;
  }
  #sec4 .sec4-img img {
    width: 100%;
    height: 688px;
    -o-object-fit: cover;
       object-fit: cover;
  }
  #sec4 .sec4-box {
    width: 420px;
    margin: 60px 5% 0px;
  }
  #sec4 .sec4-box h2 {
    text-align: left;
    font-size: 30px;
    line-height: 72px;
    margin: 0px auto 30px;
    height: 380px;
  }
  #sec4 .sec4-box h2 span {
    position: relative;
    inset: 0;
  }
}

#space {
  position: relative;
}
#space .sec5-para {
  width: 100%;
  height: 70vw;
}
#space .sec5-2 {
  position: relative;
  padding: 16vw 0px;
}
#space .sec5-2 .sec5-box h2 {
  font-size: 6vw;
  height: 50vw;
  margin: 0px auto 4vw;
  color: #260c00;
  font-weight: 400;
}
#space .sec5-2 .sec5-img {
  margin: 8vw 0px 0px;
}
#space .sec5-2::before {
  content: "";
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 50vw;
  background: url("../img/shared/bg5.jpg") repeat top left;
}
@media only screen and (min-width: 768px) {
  #space .sec5-para {
    height: 500px;
  }
  #space .sec5-2 {
    padding: 158px 0px 150px;
  }
  #space .sec5-2::before {
    height: 375px;
  }
  #space .sec5-2 .wrap {
    max-width: 1300px;
  }
  #space .sec5-2 .sec5-box {
    width: 410px;
    margin: 2px 20px 0px 16px;
  }
  #space .sec5-2 .sec5-box h2 {
    font-size: 34px;
    margin: 0px auto 17px;
    height: 255px;
    letter-spacing: 0.2em;
  }
  #space .sec5-2 .sec5-img {
    width: 802px;
    margin: 0px 10px 0px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1300px) {
  #space .sec5-2 .sec5-img {
    margin: 0px -150px 0px 0px;
  }
}

#shopinfo {
  position: relative;
  z-index: 1;
  padding: 12vw 0px 10vw;
}
#shopinfo .wrap {
  z-index: 1;
}
#shopinfo::before {
  content: "";
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 50vw;
  background: url("../img/shared/bg2.jpg") repeat top left;
}
#shopinfo .sec6-1 {
  width: 92%;
  color: #fff;
  padding: 10vw 0px;
  margin: 0px auto;
  background: url("../img/index/sec6_bg.jpg") center/cover;
  position: relative;
  z-index: 1;
}
#shopinfo .sec6-1 h2 {
  height: 40vw;
  font-size: 7.5vw;
  margin: 0px 10vw;
  line-height: 1.2;
}
#shopinfo .sec6-1 h2 span {
  font-size: 3vw;
}
#shopinfo .sec6-1 h2 span::before {
  height: 35vw;
}
#shopinfo .sec6-1 h2 span::after {
  top: 34vw;
}
#shopinfo .sec6-2 {
  margin: 10vw 0px 0px;
}
#shopinfo .sec6-2 .sec6-logo {
  width: 20%;
  margin: 0px auto;
}
#shopinfo .sec6-2 .sec6-txt1 {
  text-align: center;
  margin: 6vw 0px;
}
#shopinfo .sec6-2 .sec6-insta {
  width: 68px;
  margin: 0px auto;
  display: flex;
}
#shopinfo .sec6-2 .sec6-list {
  margin: 8vw 0px;
}
#shopinfo .sec6-2 .sec6-list dl {
  margin: 0px 0px 3vw;
  padding: 0px 0px 3vw;
  border-bottom: 1px dashed #b5978d;
}
#shopinfo .sec6-2 .sec6-list dl dt {
  width: 25%;
}
#shopinfo .sec6-2 .sec6-list dl dd {
  width: 75%;
}
#shopinfo .sec6-2 .sec6-btn a {
  width: 100%;
  margin: 8vw 0px 0px;
}
#shopinfo .sec6-2 .sec6-row2 {
  padding-bottom: 6vw;
  border-bottom: 1px solid #b5948b;
}
#shopinfo .sec6-2 .sec6-tel {
  text-align: center;
  width: 85vw;
  margin: 8vw auto 4vw;
  padding: 5vw 0px;
  color: #fff;
  background: #5e1312;
  line-height: 1.2;
}
#shopinfo .sec6-2 .sec6-tel p:nth-child(1) {
  font-size: 3.5vw;
}
#shopinfo .sec6-2 .sec6-tel p:nth-child(2) {
  font-size: 8vw;
  font-weight: 700;
}
#shopinfo .sec6-2 .sec6-tel p:nth-child(2) i {
  display: inline-block;
  position: relative;
  width: 22px;
  top: -2px;
  margin-right: 2px;
}
#shopinfo .sec6-2 .sec6-btn2 a {
  background: #a7945d;
  width: 85vw;
  padding: 6vw 0px;
  text-align: center;
  font-size: 4.5vw;
  margin: 0px auto;
  color: #fff;
}
#shopinfo .sec6-2 .sec6-btn2 a i {
  display: inline-block;
  position: relative;
  width: 32px;
  margin-right: 6px;
  top: -2px;
}
#shopinfo .sec6-2 .sec6-txt2 {
  text-align: center;
  margin: 6vw 0px 0px;
}
#shopinfo .sec6-2 .sec6-txt2 p + p {
  margin: 3vw 0px 0px;
}
#shopinfo::after {
  content: "";
  position: absolute;
  top: 50vw;
  left: 0px;
  width: 40%;
  height: calc(100% + 40vw);
  background: url("../img/shared/bg5.jpg") repeat top left;
}
@media only screen and (min-width: 768px) {
  #shopinfo {
    padding: 90px 0px 53px;
  }
  #shopinfo::before {
    height: 524px;
  }
  #shopinfo::after {
    width: 33.5%;
    height: calc(100% - 149px);
    top: 524px;
  }
  #shopinfo .sec6-1 {
    width: 100%;
    max-width: 1300px;
    margin: 0px auto;
    padding: 49px 0px 61px;
  }
  #shopinfo .sec6-1 h2 {
    font-size: 38px;
    height: 440px;
    margin: 0px auto;
  }
  #shopinfo .sec6-1 h2 span {
    margin: 0px 0px 60px 10px;
    font-size: 16px;
    left: 8px;
  }
  #shopinfo .sec6-1 h2 span::before {
    height: 182px;
  }
  #shopinfo .sec6-1 h2 span::after {
    top: 182px;
  }
  #shopinfo .sec6-2 {
    margin: 104px 0px 0px;
  }
  #shopinfo .sec6-2 .wrap {
    max-width: 1160px;
  }
  #shopinfo .sec6-2 .sec6-box1 {
    width: 150px;
    margin: 0px 76px;
  }
  #shopinfo .sec6-2 .sec6-box2 {
    width: 685px;
    margin: 40px 0px 0px;
  }
  #shopinfo .sec6-2 .sec6-logo {
    width: 110px;
  }
  #shopinfo .sec6-2 .sec6-txt1 {
    height: 370px;
    margin: 45px auto 173px;
    line-height: 44px;
    font-size: 15px;
  }
  #shopinfo .sec6-2 .sec6-list {
    margin: 0px;
  }
  #shopinfo .sec6-2 .sec6-list dl {
    margin: 0px 0px 17px;
    padding: 0px 0px 13px;
    line-height: 30px;
    font-size: 15px;
  }
  #shopinfo .sec6-2 .sec6-list dl dt {
    width: 154px;
  }
  #shopinfo .sec6-2 .sec6-list dl dd {
    width: calc(100% - 154px);
  }
  #shopinfo .sec6-2 .sec6-btn a {
    margin: 57px 0px 0px;
    width: 430px;
  }
  #shopinfo .sec6-2 .sec6-row2 {
    padding: 42px 0px 42px;
    margin: 74px 0px 0px;
    border-top: 1px solid #b5948b;
  }
  #shopinfo .sec6-2 .sec6-box3 {
    width: 360px;
    margin: 0px 0px 0px 220px;
  }
  #shopinfo .sec6-2 .sec6-tel {
    width: 360px;
    padding: 16px 0px 24px;
    line-height: 32px;
    margin: 0px 0px 15px;
  }
  #shopinfo .sec6-2 .sec6-tel p:nth-child(1) {
    font-size: 12px;
  }
  #shopinfo .sec6-2 .sec6-tel p:nth-child(2) {
    font-size: 30px;
  }
  #shopinfo .sec6-2 .sec6-btn2 a {
    font-size: 20px;
    padding: 35px 0px 31px;
    width: 100%;
  }
  #shopinfo .sec6-2 .sec6-btn2 a:hover {
    opacity: 0.8;
  }
  #shopinfo .sec6-2 .sec6-btn2 a i {
    margin-right: 12px;
  }
  #shopinfo .sec6-2 .sec6-txt2 {
    width: 370px;
    margin: 30px 132px 0px 0px;
    line-height: 30px;
    font-size: 15px;
  }
  #shopinfo .sec6-2 .sec6-txt2 p + p {
    margin: 27px 0px 0px;
  }
}

#map {
  position: relative;
  background: url("../img/shared/bg2.jpg") repeat top left;
  color: #fff;
  padding: 0vw 0px 16vw;
}
#map .wrap {
  z-index: 2;
}
#map h2 {
  font-size: 8vw;
  margin: 0px 0px 4vw;
  color: #260c00;
  font-weight: 400;
}
#map .map {
  width: 100%;
  height: 480px;
}
#map .map iframe {
  width: 100%;
  height: 100%;
}
#map .btn-map1 a {
  margin: 8vw auto 0px;
}
@media only screen and (min-width: 768px) {
  #map {
    background: none;
    padding: 12px 0px 120px;
  }
  #map::before {
    content: "";
    position: absolute;
    top: 0px;
    right: 0px;
    width: calc(50% + 170px);
    height: 100%;
    background: url("../img/shared/bg2.jpg") repeat top left;
  }
  #map h2 {
    margin: 0px 0px 20px;
    font-size: 42px;
  }
  #map .wrap {
    max-width: 1160px;
    padding: 0px 20px;
  }
  #map .map {
    height: 480px;
  }
  #map .gmap-listbtn {
    width: 775px;
    margin: 37px 0px 0px;
  }
  #map .btn-map1 a {
    color: #000;
    border-color: #000;
    margin: 0px;
  }
  #map .btn-map1 a::before {
    background-image: url("../img/shared/arrow2.png");
  }
  #map .btn-sec a {
    width: 345px;
    line-height: 65px;
    font-size: 18px;
  }
}/*# sourceMappingURL=index.css.map */


@media only screen and (max-width: 768px) {
.txt-line2 {
  position: relative;
  font-size: 4vw;
  font-weight: 400;
  letter-spacing: 0.1em;
  display: inline-block;
  line-height: 1;
}
.txt-line2::before {
  content: "";
  position: absolute;
  left: 0px;
  top: 0px;
  width: 1px;
  height: 24vw;
  border-left: 1px solid #fff;
}
.txt-line2::after {
  content: "";
  position: absolute;
  left: 0px;
  top: 24vw;
  width: 1px;
  height: 6vw;
  border-left: 1px dashed #fff;
}
/* .txt-line2.red {
  color: #5e1312;
}
.txt-line2.red::before, .txt-line2.red::after {
  border-color: #5e1312;
}
.txt-line2.dark {
  color: #000;
}
.txt-line2.dark::before, .txt-line2.dark::after {
  border-color: #000;
} */
}

.line_i2{
  margin: 0 0 0 8px;
}

.pad_enj{
  letter-spacing: -8px;
}