/* Scss Document */
/* Scss Document */

#sec1 .sec1_img1 {
  z-index: 1;
}

#sec1 .sec1_img1:before {
  content: "";
  top: 8px;
  left: 8px;
  position: absolute;
  border: 1px solid #000;
  width: calc(100% - 18px);
  height: calc(100% - 18px);
  z-index: 1;
}

#sec3 {
  color: #fff;
}

#sec4 {
  background: url(../img/index/sec4_bg.jpg);
  position: relative;
}

#sec4:before {
  content: "";
  top: 8px;
  left: 8px;
  position: absolute;
  border: 1px solid #000;
  width: calc(100% - 18px);
  height: calc(100% - 18px);
  pointer-events: none;
}

#sec4 h2 {
  text-align: center;
}

#sec4 .feed_img span {
  transition: all 0.3s;
}

#sec4 .feed_img span:hover {
  opacity: 0.8;
}

#sec4 .feed_txt {
  line-height: 26px;
  font-size: 15px;
}

#sec4 .feed_txt span {
  display: block;
  color: #877e6e;
  font-size: 13px;
  line-height: 28px;
}

#sec4 #instafeed {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}

#sec4 #instafeed li {
  margin: 0 4px;
}

#sec5 .sec5Info dl {
  font-size: 15px;
  line-height: 25px;
  letter-spacing: 1px;
  font-weight: 600;
  padding: 12px 0 12px;
}

#sec6 .slick-dots {
  position: absolute;
  left: 0;
  width: 100%;
}

#sec6 .slick-dots li button {
  border: 2px solid #fff;
  width: 14px;
  height: 14px;
  background: #000;
}

#sec6 .slick-dots li.slick-active button {
  background: #fff;
}

#gmap {
  width: 100%;
  height: 530px;
}

@media only screen and (min-width: 1081px) {
  .key_fade .key_img1 {
    background: url(../img/index/key_img1.jpg) no-repeat center/cover;
  }
  .key_fade .key_img2 {
    background: url(../img/index/key_img2.jpg) no-repeat center/cover;
  }
  .key_fade .key_img3 {
    background: url(../img/index/key_img3.jpg) no-repeat center/cover;
  }
  .key_fade .key_img4 {
    background: url(../img/index/key_img4.jpg) no-repeat center/cover;
  }
  .key_fade img {
    display: none;
  }
  #sec1 {
    padding: 275px 0 72px;
    position: relative;
    font-weight: 600;
  }
  #sec1 .sec1_img1 {
    top: 189px;
    left: 0;
    position: absolute;
    width: 48.89%;
    height: 500px;
    background: url(../img/index/sec1_img1.jpg) no-repeat bottom right/cover;
  }
  #sec1 .sec1_img1 img {
    display: none;
  }
  #sec1 h2 {
    text-align: right;
  }
  #sec1 .wrap:before {
    content: url(../img/index/sec1_deco.png);
    top: -185px;
    right: -32px;
    position: absolute;
  }
  #sec1 .sec1_txt1 {
    top: 76px;
    right: 242px;
    position: absolute;
    width: 250px;
    height: 410px;
  }
  #sec1 .sec1_img3 {
    bottom: -68px;
    left: -194px;
    position: absolute;
  }
  #sec1 .sec1_img2 {
    bottom: -205px;
    right: -132px;
    position: absolute;
  }
  #sec1 .sec1_txt2 {
    width: 461px;
    height: 270px;
    margin-top: -10px;
  }
  #sec1_2 {
    padding-bottom: 88px;
    z-index: 1;
  }
  #sec1_2:before {
    content: url(../img/index/sec1_deco3.jpg);
    height: 154px;
    bottom: 80px;
    left: -155px;
    position: absolute;
  }
  #sec1_2 h3 {
    margin-left: -274px;
  }
  #sec1_2 .sec1_deco2 {
    top: 199px;
    right: -360px;
    position: absolute;
  }
  #sec1_2 .sec1_txt3 {
    margin-top: 40px;
    width: 473px;
    line-height: 32px;
    letter-spacing: 0.5px;
    text-align: justify;
  }
  #sec1_2 .sec1_img4 {
    margin: 57px 0 0 97px;
  }
  #sec1_2 .sec1_deco3 {
    bottom: -16px;
    right: 85px;
    position: absolute;
  }
  #sec2 {
    background-image: url(../img/index/para.jpg);
    min-height: 450px;
  }
  #sec3 {
    background: url(../img/index/sec3_bg2.jpg) repeat-x bottom center, url(../img/index/sec3_bg.jpg);
    padding-top: 182px;
    padding-bottom: 130px;
    line-height: 32px;
  }
  #sec3 .wrap:before {
    content: url(../img/index/sec3_deco1.png);
    top: -81px;
    right: -167px;
    position: absolute;
  }
  #sec3 .sec3_img1 {
    top: -112px;
    left: -298px;
    position: absolute;
  }
  #sec3 h2 {
    text-align: right;
  }
  #sec3 .sec3_txt1 {
    margin: 52px 12px 70px auto;
    width: 388px;
  }
  #sec3 .sec3_img2 {
    float: right;
    margin-right: -243px;
  }
  #sec3 .sec3_txt2 {
    float: left;
    width: 355px;
    margin: 140px 0 0 23px;
    letter-spacing: 0.8px;
    text-align: justify;
    position: relative;
  }
  #sec3 .sec3_txt2:before {
    content: url(../img/index/sec3_deco2.png);
    top: 59px;
    left: -236px;
    position: absolute;
  }
  #sec3 .sec3_txt2 p:nth-child(2) {
    margin: 32px 0 49px;
  }
  #sec3 .sec3Slider {
    position: relative;
    margin-top: 61px;
  }
  #sec3 .sec3Slider dd {
    position: absolute;
    letter-spacing: 0.4px;
    text-align: justify;
  }
  #sec3 .sec3Slider .sec3Item1 {
    float: left;
    margin-left: -222px;
    margin-top: 81px;
    position: relative;
  }
  #sec3 .sec3Slider .sec3Item1 dd {
    left: 222px;
    bottom: 74px;
    width: 326px;
  }
  #sec3 .sec3Slider .sec3Item2 {
    float: right;
    margin-right: -220px;
    margin-bottom: 12px;
    position: relative;
  }
  #sec3 .sec3Slider .sec3Item2 dd {
    left: 70px;
    bottom: 82px;
    width: 317px;
  }
  #sec3 .sec3_btn2 {
    margin-left: 4px;
  }
  #sec4 {
    padding: 98px 0 102px;
  }
  #sec4 #instafeed {
    margin-top: 31px;
  }
  #sec4 .sec4_h2_2 img {
    width: 168px;
  }
  #sec5 {
    background: url(../img/index/sec5_bg.jpg) repeat top center;
    padding: 93px 0 82px;
  }
  #sec5 .wrap {
    display: flex;
    justify-content: space-between;
  }
  #sec5 .wrap .sec5_img {
    margin-right: -209px;
  }
  #sec5 .wrap .sec5Info {
    width: 570px;
  }
  #sec5 .wrap h2 {
    margin: 28px 0 32px 181px;
    width: 145px;
  }
  #sec5 .wrap h2 img {
    width: 100%;
  }
  #sec5 .wrap dl {
    border-top: 1px solid rgba(0, 0, 0, 0.16);
  }
  #sec5 .wrap dl:last-child {
    border-bottom: 1px solid rgba(0, 0, 0, 0.16);
  }
  #sec5 .wrap dl dt {
    width: 152px;
    float: left;
  }
  #sec5 .wrap dl dd {
    float: left;
    width: 418px;
  }
  #sec6 {
    padding: 117px 0 106px;
  }
  #sec6 .sec6_map {
    float: left;
    margin: 11px 0 0 -208px;
  }
  #sec6 .sec6Info {
    float: right;
    width: 614px;
    height: 621px;
    line-height: 32px;
    position: relative;
    font-weight: 600;
  }
  #sec6 .sec6Info h2 {
    margin-bottom: 31px;
  }
  #sec6 .sec6Info:before {
    content: url(../img/index/sec6_deco.jpg);
    top: -48px;
    right: -38px;
    position: absolute;
  }
  #sec6 .sec6Info .sec6Slider {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 596px;
    height: 344px;
  }
  #sec6 .sec6Info .sec6Slider .slick-dots {
    bottom: 32px;
  }
  #sec7 .wrap {
    padding: 65px 0 57px;
  }
  #sec7 .wrap .fl {
    margin-left: 105px;
  }
  #sec7 .wrap .link3 {
    margin: 8px 0 0 3px;
    letter-spacing: -1px;
  }
  #sec7 .wrap .link3 a {
    text-decoration: underline;
  }
  #sec7 .wrap .fr {
    margin-right: 105px;
  }
}
@media only screen and (min-width: 980px) {
  #sec4 #feed {
    margin-bottom: 72px;
    margin-top: 31px;
    display: flex;
    justify-content: center;
  }
  #sec4 #feed .feedItem {
    width: 260px;
    margin: 0 25px;
  }
  #sec4 #feed .feedItem .feed_img {
    margin-bottom: 10px;
  }
}
@media only screen and (max-width: 979px) {
  #sec4 #feed {
    margin-bottom: 7%;
    margin-top: 5%;
  }
  #sec4 #feed .feedItem {
    margin-bottom: 5%;
    display: flex;
    align-items: center;
  }
  #sec4 #feed .feed_img {
    width: 260px;
  }
  #sec4 #feed .feed_txt {
    width: calc(100% - 280px);
    margin-left: 20px;
  }
}
@media only screen and (max-width: 1080px) {
  #sec1 {
    font-weight: 500;
  }
  #sec1 .sec1_img1 {
    position: relative;
    margin-bottom: 3%;
  }
  #sec1 .sec1_txt1 {
    margin-bottom: 10%;
  }
  #sec1 .sec1_img {
    position: relative;
  }
  #sec1 .sec1_img .sec1_img3 {
    width: 38.59%;
    position: relative;
    z-index: 1;
  }
  #sec1 .sec1_img .sec1_img2 {
    width: 73.2%;
    margin: -36% 0 5% auto;
  }
  #sec1_2 {
    padding: 0 0 28% 0;
    position: relative;
    z-index: 1;
  }
  #sec1_2 .sec1Group {
    margin: 5% 0 0 3.2%;
    position: relative;
  }
  #sec1_2 .sec1_txt3 {
    width: 54%;
    float: left;
  }
  #sec1_2 .sec1_deco2 {
    width: 44.65%;
    position: absolute;
    bottom: 0;
    right: 0;
  }
  #sec1_2 .sec1_img4 {
    margin: 3% auto 0;
    position: relative;
    top: -5%;
    width: 85.87%;
  }
  #sec1_2 .sec1_deco3 {
    width: 37.6%;
    bottom: -3.5%;
    left: 3%;
    position: absolute;
  }
  #sec2 {
    background-image: url(../img/index/para.jpg);
    min-height: 460px;
  }
  #sec3 {
    background: url(../img/index/sec3_bg_sp.jpg) repeat-y top center/100% auto;
    padding-bottom: 10%;
  }
  #sec3 .sec3_img2 {
    margin: 13% 0 9%;
  }
  #sec3 .sec3_txt2 p:nth-child(2) {
    margin: 26px 0 35px;
  }
  #sec3 .sec3_btn1 {
    margin: 0 auto 13%;
    width: 69%;
    max-width: 490px;
  }
  #sec3 dd {
    margin: 5% 0;
  }
  .sec3_btn2 {
    margin: 10% auto 12%;
    width: 72.96%;
    max-width: 518px;
  }
  #sec4 {
    padding: 10% 1%;
  }
  #sec4 .sec4_h2_1 {
    margin: 0 auto 5%;
    width: 16%;
    max-width: 100px;
  }
  #sec4 .sec4_h2_2 {
    margin: 0 auto 5%;
    width: 33.7%;
    max-width: 223px;
  }
  #sec4 #instafeed li {
    width: 30.4%;
    margin: 0 0 4% 3.5%;
  }
  #sec4 #instafeed li:nth-child(3n+1) {
    margin-left: 0;
  }
  #sec4 #instafeed li img {
    width: 100%;
    height: auto;
  }
  #sec5 {
    background: url(../img/index/sec5_bg_sp.jpg) repeat-y top center/100% auto;
    padding: 12% 0 17%;
    font-weight: 400;
  }
  #sec5 h2 {
    margin: auto;
    width: 28.92%;
  }
  #sec5 .sec5Info dl {
    border-bottom: 1px solid rgba(0, 0, 0, 0.16);
    padding: 20px 0;
    font-size: 13.5px;
    letter-spacing: 0;
  }
  #sec5 .sec5Info dl dd a {
    font-size: 18px;
  }
  #sec5 .sec5_img {
    margin: 12% auto 0;
    width: 84.1%;
  }
  #sec6 {
    padding: 17% 0 10% 0;
  }
  #sec6 .sec6Slider {
    margin: auto;
    width: 83.9%;
  }
  #sec6 .sec6Slider .slick-dots {
    bottom: 13%;
  }
  #sec6 .sec6_txt {
    margin-top: 5%;
  }
  #gmap {
    height: 350px;
  }
  #sec7 .fr {
    float: none !important;
    margin: 9% auto 10%;
    max-width: 518px;
    width: 73.9%;
  }
}
@media only screen and (max-width: 1080px) and (min-width: 481px) {
  #sec1_2 h3 {
    transform: translateX(-30%);
  }
}
@media only screen and (max-width: 480px) {
  #sec1_2 .sec1_deco2 {
    float: right;
    position: static;
    margin-top: -2%;
    margin-right: 0;
  }
  #sec4 #feed .feed_img {
    width: 130px;
    height: 82px;
  }
  #sec4 #feed .feed_img span {
    width: 130px !important;
    height: 82px !important;
  }
  #sec4 #feed .feed_txt {
    width: calc(100% - 150px);
    margin-left: 20px;
  }
}
@media only screen and (min-width: 480px) {
  .reserve_bnr {
    display: none;
  }
}
@media only screen and (max-width: 480px) {
  .reserve_bnr a {
    width: 30%;
    display: block;
    color: #fff;
    text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.1);
    text-align: center;
    font-size: 12px;
    background-color: #000;
    border-radius: 0px;
    padding: 10px 0;
    text-decoration: none;
    box-sizing: border-box;
    line-height: 15px;
    letter-spacing: 2px;
    position: absolute;
    top: 15px;
    left: 5px;
  }
}
.mb20 {
  margin-bottom: 20px;
}

#sec_takeout {
  padding-top: 96px;
}
#sec_takeout .wrap {
  width: 1300px;
  margin: 0 auto;
  background: #000000;
  position: relative;
  padding-top: 60px;
  padding-bottom: 57px;
}
#sec_takeout .wrap .sec-info .title {
  width: 447px;
  height: 137px;
  position: relative;
  z-index: 1;
}
#sec_takeout .wrap .sec-info .title img {
  width: 100%;
  height: 100%;
}
@media only screen and (max-width: 1080px) {
  #sec_takeout .wrap .sec-info .title {
    width: 90%;
    height: auto;
  }
}
#sec_takeout .wrap .sec-info .content {
  position: relative;
  z-index: 2;
  color: #fff;
  margin-left: 160px;
  font-weight: 600;
  font-size: 16px;
  line-height: 32px;
  letter-spacing: 0.3px;
  width: 472px;
  margin-bottom: 46px;
  margin-top: -20px;
}
#sec_takeout .wrap .sec-info .sec-takeout-btn {
  margin-left: 150px;
  width: 350px;
}
#sec_takeout .wrap .sec-info .sec-takeout-btn a img {
  height: auto;
}
#sec_takeout .wrap .sec-takeout-img {
  position: absolute;
  right: 7px;
  top: -30px;
  width: 674px;
  height: 623px;
}
#sec_takeout .wrap .sec-takeout-img img {
  width: 100%;
  height: 100%;
}
@media only screen and (max-width: 1080px) {
  #sec_takeout .wrap {
    width: 100%;
    padding: 0 3.2%;
    padding-top: 54px;
  }
  #sec_takeout .wrap .sec-info .title {
    margin-left: -3.2%;
    margin-bottom: 40px;
  }
  #sec_takeout .wrap .sec-info .content {
    margin-left: 0;
    width: 100%;
    font-size: 14px;
    line-height: 26px;
    font-weight: 500;
    margin-bottom: 30px;
  }
  #sec_takeout .wrap .sec-info .sec-takeout-btn {
    margin: 0 auto;
    width: 80%;
  }
  #sec_takeout .wrap .sec-takeout-img {
    position: relative;
    right: unset;
    top: unset;
    width: 100%;
    height: auto;
    z-index: 10;
    margin-bottom: -20px;
  }
}
@media only screen and (max-width: 1080px) {
  #sec_takeout {
    padding-top: 60px;
  }
}

#sec_course {
  padding-bottom: 120px;
  position: relative;
  margin-top: -10px;
}
#sec_course .wrap {
  position: relative;
}
#sec_course .wrap .section-info {
  width: 100%;
  position: relative;
  display: flex;
  justify-content: flex-end;
}
#sec_course .wrap .section-info h2 {
  width: 103px;
  height: 337px;
  padding-bottom: 80px;
}
#sec_course .wrap .section-info h2 img {
  width: 100%;
  height: 100%;
}
#sec_course .wrap .section-info .content {
  height: 278px;
  position: absolute;
  right: 140px;
  top: 100px;
  font-size: 16px;
  line-height: 32px;
  letter-spacing: 0.3px;
  font-weight: 600;
}
#sec_course .wrap .sec-course-btn {
  display: flex;
  justify-content: flex-end;
}
#sec_course .wrap .sec-course-btn a {
  width: 370px;
}
#sec_course .wrap .sec-course-btn a img {
  width: 100%;
  height: auto;
}
#sec_course .wrap::before {
  position: absolute;
  content: "";
  top: -107px;
  right: -197px;
  width: 584px;
  height: 176px;
  background: url(../img/index/sec_course_deco.png) no-repeat center;
}
@media only screen and (max-width: 1080px) {
  #sec_course .wrap {
    padding-top: 0;
    z-index: 20;
    margin-top: -10vw;
  }
  #sec_course .wrap .section-info {
    display: flex;
    flex-direction: row-reverse;
    justify-content: space-between;
  }
  #sec_course .wrap .section-info h2 {
    width: 24vw;
    height: unset;
    padding-bottom: 30px;
  }
  #sec_course .wrap .section-info h2 img {
    width: 100%;
    height: auto;
  }
  #sec_course .wrap .section-info .content {
    position: relative;
    right: unset;
    top: unset;
    height: auto;
    font-size: 14px;
    line-height: 30px;
    width: calc(100% - 28vw);
    margin-top: 16vw;
    padding-right: 10px;
  }
  #sec_course .wrap .sec-course-btn {
    justify-content: center;
  }
  #sec_course .wrap .sec-course-btn a {
    width: 72%;
  }
  #sec_course .wrap::before {
    display: none;
  }
}
#sec_course .sec-course-img {
  position: absolute;
  top: -56px;
  left: 0;
  width: 56%;
  height: 592px;
  background: url(../img/index/sec_course_img.jpg) no-repeat bottom right/cover;
  z-index: 10;
}
#sec_course .sec-course-img img {
  display: none;
}
@media only screen and (max-width: 1080px) {
  #sec_course .sec-course-img {
    position: relative;
    top: unset;
    left: unset;
    width: 100%;
    height: 110vw;
    background: url(../img/index/sec_course_img_sp.jpg) no-repeat bottom right/cover;
  }
}
@media only screen and (min-width: 1900px) {
  #sec_course .sec-course-img {
    width: 53%;
  }
}
#sec_course::before {
  position: absolute;
  content: "";
  width: 1px;
  height: 100%;
  background: #000;
  top: -20vw;
  left: 13vw;
  transform: rotate(-45deg);
  z-index: 2;
}
@media only screen and (max-width: 1080px) {
  #sec_course::before {
    display: none;
  }
}
@media only screen and (max-width: 1080px) {
  #sec_course {
    margin-top: 0;
    padding-bottom: 50px;
  }
}

.news_box {
	background: url('../img/index/sec4_bg.jpg') repeat center top;
    width: 860px;
    margin: 50px auto 0;
    line-height: 2em;
    padding-bottom:39px;
    font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "メイリオ", Meiryo, "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	box-shadow: 0px 5px 8px 2px rgba(52, 28, 0, 0.25);
	border: 1px solid #000;
}
.news_box .ttl {
	color: #000;
    padding: 39px 50px 10px;
    text-align: center;
    font-size: 24px;
    width: 660px;
    border-bottom: 1px solid #000;
    margin: 0 auto;
}
.news_box .txt {
	color: #000;
	padding: 20px 50px 0;
	text-align: center;
	font-size: 18px;
}
@media only screen and (max-width: 768px) {
.news_box {
    width: 90%;
    margin: 20px auto;
}
.news_box .ttl {
    padding: 39px 10px 10px;
    font-size: 18px;
    width: 70%;
}
.news_box .txt {
	padding: 20px 10px 0;
	font-size: 14px;
}
}



/*# sourceMappingURL=index.css.map */