@charset "UTF-8";
.fnt-zen-kaku-gothic {
  font-family: "Zen Kaku Gothic New";
}

.db {
  display: block;
}

.object-cover {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover;
  object-position: 50%;
}

.d-ttl-common {
  font-size: 9.3vw;
  line-height: 12.7vw;
  letter-spacing: 0.15em;
  color: #280d07;
}
.d-ttl-common small {
  display: block;
  font-family: "ZCOOL XiaoWei";
  color: #b1a46a;
  font-size: 5.3vw;
  line-height: 6vw;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  margin-bottom: 2vw;
}
.d-ttl-common .fz40 {
  font-size: 6.6vw;
  line-height: 9.3vw;
  letter-spacing: 0.15em;
}

.btn-popup a::before {
  width: 13px;
  background-image: url("../img/lunch/icon_popup.png");
}

/* popup */
.remodal-overlay {
  background: url("../img/shared/main_bg2.jpg");
}

.remodal-wrapper {
  padding: 2%;
}

.remodal {
  background: url("../img/shared/main_bg1.jpg");
  padding: 4vw 4vw 8vw;
  color: #000;
}

.remodal-close {
  width: 35px;
  height: 35px;
  background: url("../img/lunch/close.png") no-repeat center/100%;
  position: sticky;
  top: 0;
  margin-left: auto;
}

.remodal-close:before {
  display: none;
}

.remodal-close:hover {
  opacity: 0.8;
}

.menu-popup #pdf-container {
  height: 100% !important;
}
.menu-popup canvas {
  width: 100%;
}
.menu-popup .d-ttl-common {
  margin: 3vw 0;
}
.menu-popup .d-ttl-common small {
  margin-bottom: 0;
}
.menu-popup .note {
  font-size: 14px;
  letter-spacing: 0.2em;
  margin-bottom: 10vw;
}
.menu-popup .menulist .item {
  margin-bottom: 40px;
}
.menu-popup .menu_lunchset {
  margin-bottom: 10vw;
}
.menu-popup .menulist h3,
.menu-popup .menulist h4 {
  font-size: 20px;
  line-height: 30px;
  font-weight: 500;
  letter-spacing: 0.1em;
  position: relative;
  padding-left: 23px;
  margin-bottom: 20px;
  text-align: left;
  color: #291000;
}
.menu-popup .menulist h3:before {
  content: "";
  width: 15px;
  height: 1.5px;
  background: #291000;
  position: absolute;
  left: 0;
  top: 14px;
}
.menu-popup .menulist h3 .note2 {
  display: block;
  font-family: "Zen Kaku Gothic New";
  font-size: 14px;
  line-height: 20px;
  letter-spacing: 0.05em;
  margin-left: -23px;
}
.menu-popup .menulist dl {
  width: 100%;
  display: table;
  font-size: 14px;
  line-height: 20px;
  letter-spacing: 0.05em;
  border-bottom: 1px dotted #55504e;
  padding-bottom: 10px;
  margin-bottom: 10px;
}
.menu-popup .menulist dl dt {
  display: table-cell;
  text-align: left;
  font-family: "Zen Kaku Gothic New";
}
.menu-popup .menulist dl dd {
  display: table-cell;
  text-align: right;
  white-space: nowrap;
  font-family: "游ゴシック", YuGothic, "ヒラギノ角ゴ Pro",
    "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", Osaka, "ＭＳ Ｐゴシック",
    "MS PGothic", sans-serif;
  font-weight: bold;
}
.menu-popup .menulist .note3 {
  font-family: "Zen Kaku Gothic New";
  font-size: 14px;
  line-height: 20px;
  letter-spacing: 0.05em;
  text-align: left;
}

.en-all {
  text-transform: uppercase;
  font-size: 5.3vw;
  font-weight: 400;
  font-family: var(--zcool);
  color: #b1a46a;
  line-height: 1.6em;
  letter-spacing: 0.05em;
  margin-bottom: 1.7vw;
}

.h2-all {
  font-size: 9.3vw;
  font-weight: 400;
  color: #280d07;
  line-height: 1.4em;
  letter-spacing: 0.13em;
  margin-bottom: 8.3vw;
}

.bg {
  box-sizing: border-box;
  margin: 0 0 14vw;
  min-height: 90.7vw;
  position: relative;
}
.bg .img_parallax {
  position: absolute;
  inset: 0;
  clip: rect(0, auto, auto, 0);
  margin-bottom: 0;
}
.bg .img_parallax img {
  position: fixed;
  width: 100%;
  height: 100vh;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  object-fit: cover;
}

#sec1 {
  padding: 25vw 0 15vw;
  position: relative;
  z-index: 1;
}
#sec1::before {
  content: "";
  position: absolute;
  background: url(../img/lunch/sec1_deco1.png) no-repeat;
  background-size: contain;
  aspect-ratio: 223/123;
  width: 30vw;
  height: auto;
  top: 5vw;
  left: 5%;
  z-index: -1;
}
#sec1::after {
  content: "";
  position: absolute;
  background: url(../img/lunch/sec1_deco2.png) no-repeat;
  background-size: contain;
  aspect-ratio: 307/181;
  width: 30vw;
  height: auto;
  top: 5vw;
  right: 5%;
  z-index: -1;
}
#sec1 .desc {
  position: relative;
}
#sec1 .desc::before {
  content: "";
  position: absolute;
  background: url(../img/lunch/sec1_deco3.png) no-repeat;
  background-size: contain;
  aspect-ratio: 518/600;
  width: 50vw;
  height: auto;
  top: 10vw;
  right: -3.33%;
  z-index: -1;
}
#sec1 .desc .en-all {
  letter-spacing: 0.065em;
}
#sec1 .desc .ct .txt {
  margin-bottom: 24px;
}
#sec1 .desc .ct .txt:last-child {
  margin-bottom: 0;
}

#sec2 {
  padding-bottom: 15vw;
}
#sec2 .scroller {
  position: relative;
  min-height: 90.7vw;
  margin-bottom: 14vw;
}
#sec2 .scroller h2 {
  width: 60vw;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 3;
}
#sec2 .scroller .set {
  position: absolute;
  inset: 0;
}
#sec2 .scroller .set img {
  object-fit: cover;
  width: 100%;
  height: 100%;
  border-radius: 13.3vw 0 13.3vw 0;
}
#sec2 .scroller .set1 {
  z-index: 2;
}
#sec2 .scroller .set2 {
  z-index: 1;
}
#sec2 .note {
  text-align: center;
  margin-bottom: 14vw;
}
#sec2 .row {
  margin-bottom: 15vw;
}
#sec2 .row:last-child {
  margin-bottom: 0;
}
#sec2 .row .img {
  margin-bottom: 5vw;
}
#sec2 .row .desc .h2-all {
  display: inline-block;
  border-bottom: 1px solid #280d07;
  margin-bottom: 5.3vw;
}
#sec2 .row .desc .tit {
  font-size: 7.3vw;
  font-weight: 400;
  color: #280d07;
  line-height: 1.2em;
  letter-spacing: 0.13em;
  margin-bottom: 6.3vw;
}
#sec2 .row .desc .tit .small {
  font-size: 55.5555555556%;
  letter-spacing: 0.15em;
}
#sec3 {
  padding-bottom: 25vw;
  position: relative;
  z-index: 1;
}
#sec3::before {
  content: "";
  position: absolute;
  background: url(../img/lunch/sec3_deco1.png) no-repeat;
  background-size: contain;
  aspect-ratio: 705/231;
  width: 50vw;
  height: auto;
  bottom: 5vw;
  right: 5%;
  z-index: -1;
}
#sec3 .row-para {
  position: relative;
  background: url(../img/shared/main_bg1.jpg);
}
#sec3 .row-para h2 {
  font-size: 9.3vw;
  font-weight: 400;
  color: #fff;
  line-height: 1.4em;
  letter-spacing: 0.13em;
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  text-align: center;
  transform: translateY(-50%);
  z-index: 2;
}
#sec3 .row-para h2 .sub {
  position: absolute;
  top: -14vw;
  left: 5%;
  width: 22vw;
  z-index: -1;
}
#sec3 .bg .img_parallax {
  clip-path: inset(0 0 0 0 round 13.3vw 0 13.3vw 0);
}
#sec3 .txt {
  margin-bottom: 8vw;
}
#sec4 {
  padding: 10vw 0 20vw;
  position: relative;
  z-index: 1;
}
#sec4::before {
  content: "";
  position: absolute;
  background: url(../img/lunch/sec4_deco1.png) no-repeat;
  background-size: contain;
  aspect-ratio: 367/85;
  width: 30vw;
  height: auto;
  bottom: 5vw;
  left: 5%;
  z-index: -1;
}
#sec4 .row {
  padding-bottom: 10vw;
  position: relative;
  z-index: 1;
}
#sec4 .row::before {
  content: "";
  position: absolute;
  inset: 50vw -3.33% 0;
  background: url(../img/shared/main_bg6.jpg) repeat;
  z-index: -1;
}
#sec4 .row .img {
  margin-bottom: 8vw;
}
#sec4 .row .desc dl {
  color: #280d07;
  text-align: center;
  padding: 5vw 5%;
  margin-bottom: 10vw;
  position: relative;
  z-index: 1;
  font-size: 6vw;
  line-height: 1.6em;
  letter-spacing: 0.15em;
}
#sec4 .row .desc dl::before {
  content: "";
  position: absolute;
  inset: 0;
  border: 3vw solid #bbc3a4;
  mix-blend-mode: multiply;
  opacity: 0.35;
  z-index: -1;
}
#sec4 .row .desc dl::after {
  content: "";
  position: absolute;
  inset: 0;
  background: #bbc3a4;
  mix-blend-mode: multiply;
  opacity: 0.35;
  z-index: -2;
}
#sec4 .row .desc dl dt span {
  font-size: 71.4285714286%;
}
#sec4 .row .desc dl dd {
  font-size: 4vw;
}
#sec4 .row .desc dl dd span {
  font-size: 130.4347826087%;
}
#sec4 .row .desc .ct {
  margin-bottom: 5vw;
}
#sec4 .row .desc .ct .txt {
  margin-bottom: 24px;
}
#sec4 .row .desc .ct .txt:last-child {
  margin-bottom: 0;
}
#sec5 {
  padding: 15vw 0 15vw;
  position: relative;
  z-index: 1;
}
#sec5::before {
  content: "";
  position: absolute;
  background: url(../img/lunch/sec5_deco1.png) no-repeat;
  background-size: contain;
  aspect-ratio: 254/437;
  width: 30vw;
  height: auto;
  top: -20vw;
  right: 5%;
  z-index: -1;
}
#sec5 .row {
  display: flex;
  flex-direction: column-reverse;
  margin-bottom: 15vw;
}
#sec5 .row .img {
  display: flex;
  align-items: flex-start;
}
#sec5 .row .img .photo {
  margin-right: 2%;
}
#sec5 .row .img .photo:last-child {
  margin-right: 0;
}
#sec5 .row .img .photo:nth-child(1) {
  margin-top: 10vw;
}
#sec5 .row .desc {
  margin-bottom: 8vw;
}
#sec5 .row .desc dl {
  color: #280d07;
  text-align: center;
  padding: 5vw 5%;
  margin-bottom: 10vw;
  position: relative;
  z-index: 1;
  font-size: 6vw;
  line-height: 1.6em;
  letter-spacing: 0.15em;
}
#sec5 .row .desc dl::before {
  content: "";
  position: absolute;
  inset: 0;
  border: 3vw solid #bbc3a4;
  mix-blend-mode: multiply;
  opacity: 0.35;
  z-index: -1;
}
#sec5 .row .desc dl::after {
  content: "";
  position: absolute;
  inset: 0;
  background: #bbc3a4;
  mix-blend-mode: multiply;
  opacity: 0.35;
  z-index: -2;
}
#sec5 .row .desc dl dt span {
  font-size: 71.4285714286%;
}
#sec5 .row .desc dl dd {
  font-size: 4vw;
}
#sec5 .row .desc dl dd span {
  font-size: 130.4347826087%;
}
#sec5 .row .desc .ct .txt {
  margin-bottom: 24px;
}
#sec5 .row .desc .ct .txt:last-child {
  margin-bottom: 0;
}
#sec5 .dish {
  border: 1px solid #67806b;
  position: relative;
  padding: 10vw 5% 8vw;
}
#sec5 .dish h3 {
  font-size: 6vw;
  font-weight: 400;
  color: #280d07;
  text-align: center;
  line-height: 1.6em;
  position: absolute;
  left: 0;
  right: 0;
  top: -5.5vw;
  letter-spacing: 0.15em;
}
#sec5 .dish h3 span {
  background: url(../img/shared/main_bg1.jpg) repeat;
  padding: 0 2%;
}
#sec5 .dish .list {
  margin-bottom: 5vw;
}
#sec5 .dish .note {
  text-align: center;
  text-decoration: underline;
  text-underline-offset: 2px;
}

#sec6 {
  padding: 18vw 0 20vw;
  position: relative;
  z-index: 1;
}
#sec6::before {
  content: "";
  position: absolute;
  background: url(../img/lunch/deco.png) repeat-x;
  background-size: contain;
  aspect-ratio: 73/31;
  width: 100%;
  height: 8vw;
  top: 0;
  left: 0;
  right: 0;
}
#sec6 .banner a {
  display: block;
  position: relative;
}
#sec6 .banner a .ttl {
  font-family: "ZCOOL XiaoWei";
  font-size: 14vw;
  letter-spacing: 0.1em;
  font-weight: 400;
  line-height: 10vw;
  color: #fff;
  position: absolute;
  left: 3vw;
  top: 11vw;
  z-index: 1;
}
#sec6 .banner a .ttl small {
  font-family: "Noto Serif JP";
  font-size: 3vw;
  font-weight: 500;
  line-height: 6vw;
  letter-spacing: 0.15em;
  margin-bottom: 3vw;
}

@media only screen and (min-width: 768px) {
  .d-ttl-common {
    font-size: 60px;
    line-height: 85px;
  }
  .d-ttl-common small {
    font-size: 30px;
    line-height: 50px;
    margin-bottom: 16px;
  }
  .d-ttl-common .fz40 {
    font-size: 40px;
    line-height: 60px;
  }
  .remodal {
    max-width: 1200px;
    padding: 40px 36px 50px;
  }
  .remodal-close {
    width: 59px;
    height: 59px;
  }
  .remodal-close:before {
    display: none;
  }
  .menu-popup {
    max-width: 1000px;
    width: 100%;
    margin: 0 auto;
  }
  .menu-popup .d-ttl-common {
    margin: -14px 0 0px;
  }
  .menu-popup .d-ttl-common small {
    margin-bottom: -26px;
  }
  .menu-popup .note {
    margin-bottom: 58px;
  }
  .menu-popup .menu_lunchset {
    margin-bottom: 60px;
  }
  .menu-popup .menulist {
    display: flex;
    justify-content: center;
    gap: 50px;
  }
  .menu-popup .menulist .col {
    width: 300px;
  }
  .menu-popup .menulist .item {
    margin-bottom: 54px;
  }
  .menu-popup .menulist h3,
  .menu-popup .menulist h4 {
    padding-left: 23px;
    margin-bottom: 23px;
  }
  .menu-popup .menulist h3:before {
    top: 16px;
  }
  .menu-popup .menulist dl {
    padding-bottom: 9px;
    margin-bottom: 9px;
  }
  .en-all {
    font-size: 30px;
    margin-bottom: 7px;
  }
  .h2-all {
    font-size: 60px;
    line-height: 1.4em;
    margin-bottom: 66px;
  }
  .bg {
    min-height: 680px;
  }
  .bg .img_parallax {
    clip-path: inset(0 0 0 0 round 100px 0 100px 0);
  }
  #sec1 {
    padding: 197px 0 135px;
  }
  #sec1::before {
    width: 223px;
    top: 109px;
    left: calc(50% - 65px);
  }
  #sec1::after {
    width: 307px;
    top: 507px;
    right: calc(50% + 347px);
  }
  #sec1 .desc {
    margin: 0 -80px 0 -92px;
    display: flex;
    justify-content: flex-end;
    padding-top: 72px;
    position: relative;
  }
  #sec1 .desc::before {
    width: 518px;
    top: -177px;
    right: -178px;
  }
  #sec1 .desc .en-all {
    position: absolute;
    top: 0;
    left: 0;
  }
  #sec1 .desc .h2-all {
    margin-right: 124px;
    width: 168px;
    height: 414px;
    letter-spacing: 0.15em;
  }
  #sec1 .desc .ct {
    margin-top: 112px;
    width: 575px;
  }
  #sec1 .desc .ct .txt {
    width: 100%;
    margin-bottom: 41px;
  }
  #sec2 {
    padding-bottom: 217px;
  }
  #sec2 .scroller {
    position: relative;
    min-height: 800px;
    margin-bottom: 111px;
  }
  #sec2 .scroller h2 {
    width: 372px;
  }
  #sec2 .scroller .set img {
    border-radius: 100px 0 100px 0;
  }
  #sec2 .note {
    margin-bottom: 103px;
  }
  #sec2 .row {
    display: flex;
    justify-content: space-between;
    flex-direction: row-reverse;
    margin: 0 -173px 92px -100px;
    gap: 73px;
  }
  #sec2 .row.reverse {
    flex-direction: row;
    margin: 0 -138px 0 -177px;
  }
  #sec2 .row.reverse .desc {
    width: 490px;
    margin-top: 24px;
  }
  #sec2 .row .img {
    height: 530px;
    margin-bottom: 0;
  }
  #sec2 .row .img img {
    object-fit: cover;
    width: 100%;
    height: 100%;
  }
  #sec2 .row .desc {
    width: 460px;
    flex-shrink: 0;
  }
  #sec2 .row .desc .en-all {
    margin-bottom: 25px;
  }
  #sec2 .row .desc .h2-all {
    line-height: 1.2em;
    margin-bottom: 35px;
    border-bottom-width: 2px;
  }
  #sec2 .row .desc .tit {
    font-size: 45px;
    line-height: 1em;
    margin-bottom: 63px;
  }
  #sec2 .row .desc .txt {
    width: 100%;
  }
  #sec3 {
    padding-bottom: 240px;
  }
  #sec3::before {
    width: 705px;
    bottom: 42px;
    right: calc(50% - 807px);
  }
  #sec3 .row-para h2 {
    margin: 0 auto;
    width: fit-content;
    font-size: 60px;
  }
  #sec3 .row-para h2 .sub {
    width: 129px;
    top: -76px;
    left: -75px;
  }
  #sec3 .bg {
    min-height: 800px;
    margin-bottom: 136px;
  }
  #sec3 .bg .img_parallax {
    clip-path: inset(0 0 0 0 round 100px 0 100px 0);
  }
  #sec3 .txt {
    text-align: center;
    margin-bottom: 93px;
  }
  #sec3 .btn-popup {
    text-align: center;
  }
  #sec3 .btn-popup a {
    width: 536px;
    margin: 0 auto;
  }
  #sec3 .btn-popup a::before {
    width: 19px;
  }
  #sec4 {
    padding: 123px 0 0;
  }
  #sec4::before {
    width: 367px;
    bottom: 247px;
    left: calc(50% - 807px);
  }
  #sec4 .row {
    display: flex;
    justify-content: space-between;
    margin: 0 -142px 0 -250px;
    gap: 103px;
    padding-bottom: 121px;
  }
  #sec4 .row::before {
    inset: -122px -50vw 0 calc(50% - 297px);
  }
  #sec4 .row .img {
    height: auto;
    position: relative;
    margin-bottom: 0;
    top: -205px;
  }
  #sec4 .row .img img {
    object-fit: contain;
    width: 100%;
    height: 100%;
  }
  #sec4 .row .desc {
    flex-shrink: 0;
  }
  #sec4 .row .desc .h2-all {
    margin-bottom: 58px;
  }
  #sec4 .row .desc dl {
    max-width: 510px;
    width: 100%;
    box-sizing: border-box;
    padding: 31px 20px;
    font-size: 35px;
    line-height: 1.2em;
    margin-bottom: 55px;
  }
  #sec4 .row .desc dl::before {
    border-width: 10px;
  }
  #sec4 .row .desc dl dd {
    font-size: 23px;
  }
  #sec4 .row .desc .ct {
    margin-bottom: 0;
    width: 594px;
  }
  #sec4 .row .desc .ct .txt {
    width: 100%;
    margin-bottom: 41px;
  }
  #sec4 .btn-popup {
    position: absolute;
    bottom: 133px;
    right: calc(50% - 14px);
  }
  #sec4 .btn-popup a::before {
    width: 19px;
  }
  #sec5 {
    padding: 174px 0 131px;
  }
  #sec5::before {
    width: 254px;
    top: 0;
    right: calc(50% + 40px);
  }
  #sec5 .row {
    margin: 0 -250px 104px -100px;
    flex-direction: row-reverse;
    justify-content: space-between;
    gap: 80px;
  }
  #sec5 .row .img {
    margin-bottom: 0;
  }
  #sec5 .row .img .photo {
    margin-right: 7px;
  }
  #sec5 .row .img .photo:nth-child(1) {
    margin-top: 76px;
  }
  #sec5 .row .desc {
    width: 520px;
    margin-bottom: 0;
    flex-shrink: 0;
    margin-top: 11px;
  }
  #sec5 .row .desc .h2-all {
    margin-bottom: 50px;
  }
  #sec5 .row .desc dl {
    max-width: 510px;
    width: 100%;
    box-sizing: border-box;
    padding: 31px 20px;
    font-size: 35px;
    line-height: 1.2em;
    margin-bottom: 55px;
  }
  #sec5 .row .desc dl::before {
    border-width: 10px;
  }
  #sec5 .row .desc dl dd {
    font-size: 23px;
  }
  #sec5 .dish {
    box-sizing: border-box;
    padding: 63px 70px 46px;
    max-width: 980px;
    margin: 0 auto;
  }
  #sec5 .dish h3 {
    font-size: 35px;
    top: -32px;
  }
  #sec5 .dish h3 span {
    padding: 0 10px;
  }
  #sec5 .dish .list {
    display: flex;
    flex-flow: column wrap;
    align-content: space-between;
    max-height: 225px;
    max-width: 740px;
    margin: 0 auto 45px;
  }
  #sec5 .dish .list li {
    font-size: 20px;
    line-height: 2.25em;
  }
  #sec5 .dish .list li span {
    padding-left: 20px;
  }
  #sec5 .dish .note {
    text-underline-offset: 10px;
  }
  #sec6 {
    padding: 89px 0 143px;
  }
  #sec6::before {
    height: 31px;
  }
  #sec6 .banner {
    width: 1020px;
    margin: 0 auto;
  }
  #sec6 .banner a .ttl {
    font-size: 170px;
    line-height: 120px;
    left: 40px;
    top: 140px;
  }
  #sec6 .banner a .ttl small {
    font-size: 30px;
    line-height: 50px;
    margin: 0 0 27px 7px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1440px) {
  #sec2 .row.reverse {
    margin-right: -100px;
  }
  #sec4 .row {
    margin-right: -85px;
    gap: 47px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1280px) {
  #sec1 .desc .h2-all {
    margin-right: 50px;
  }
  #sec1 .desc {
    margin: 0 -20px 0 -22px;
  }
  #sec2 .row {
    margin-right: -40px;
    margin-left: -20px;
    gap: 30px;
  }
  #sec2 .row.reverse {
    margin-right: -20px;
    margin-left: -40px;
  }
  #sec4 .btn-popup {
    right: calc(50% + 78px);
  }
  #sec4 .row {
    margin-right: -49px;
    margin-left: -43px;
    gap: 47px;
  }
  #sec5 .row {
    margin-left: -20px;
    margin-right: -32px;
    gap: 40px;
  }
  #sec5 .row .img {
    width: 50%;
  }
}
