/* ---------------------------------------------------
	common
------------------------------------------------------ */
#pagetit::after {
  background: url(../img/dish/pagetit_bg.png) center;
  background-size: cover;
}

/* ---------------------------------------------------
		page_nav_wrap
------------------------------------------------------ */
.page_nav_wrap {
  position: relative;
  margin-top: 72px;
  padding: 192px 0 112px;
}
.page_nav_wrap::before {
  content: "";
  position: absolute;
  left: 0;
  bottom: -80px;
  display: block;
  width: 100%;
  height: 1000px;
  background: url(../img/common/bg_nami.png) no-repeat center bottom;
}
@media screen and (min-width: 2001px) {
  .page_nav_wrap::before {
    background-size: 100%;
  }
}

@media screen and (max-width: 810px) {
  .page_nav_wrap {
    margin-top: 0;
    padding: 72px 0 72px;
  }
  .page_nav_wrap::before {
    bottom: -48px;
    height: 100%;
    background: url(../img/common/bg_nami.png) no-repeat center bottom;
    background-size: 1000px;
  }
}
/* ---------------------------------------------------
		local
------------------------------------------------------ */
#local {
  margin-top: -320px;
  padding: 580px 0 96px;
  background: url(../img/dish/local_bg_01.png) no-repeat center top;
}
@media screen and (min-width: 2001px) {
  #local {
    background-size: 100%;
  }
}
#local .local_col {
  max-width: 1027px;
  margin: 374px auto 44px;
}
#local .local_col .col_img {
  width: 31.2%;
  max-width: 320px;
}

@media screen and (max-width: 810px) {
  #local {
    margin-top: -180px;
    padding: 280px 0 48px;
    background: url(../img/dish/local_bg_01.png) no-repeat center top;
    background-size: 1000px;
  }
  #local .local_col {
    margin: 140px auto 32px;
  }
}
/* ---------------------------------------------------
	dinner
------------------------------------------------------ */
#dinner {
  padding-top: 96px;
}
#dinner .page_nav {
  margin-top: 60px;
}
#dinner .dinner_sec {
  padding: 64px 0;
}
#dinner .dinner_mv {
  margin-top: 48px;
}
#dinner .dinner_mv .common_slide {
  margin-bottom: 104px;
}
#dinner .dinner_col {
  margin-top: 120px;
  gap: 60px 0;
  justify-content: flex-start;
  letter-spacing: 0.3em;
}
#dinner .dinner_col .col_item {
  width: 30.62%;
  max-width: 300px;
  margin-right: 3.3%;
  text-align: center;
}
#dinner .dinner_col .col_item:nth-of-type(3n) {
  margin-right: 0;
}
#dinner .dinner_col .col_item .item_img {
  margin-bottom: 24px;
}
#dinner .dinner_col .col_item .price {
  margin-top: 16px;
}
#dinner .dinner_col + p {
  margin-top: 40px;
}
#dinner .table {
  margin-top: 48px;
}
#dinner .dinner_menubtn {
  margin-top: 64px;
  font-size: 1.6rem;
  letter-spacing: 0;
}
#dinner .dinner_menubtn a {
  display: inline-block;
}
#dinner .dinner_menubtn a .icon_arrow_02 {
  margin-left: 8px;
}
#dinner .dinner_btn {
  margin-top: 64px;
}
#dinner .dinner_btn a {
  display: inline-block;
  min-width: 340px;
  padding: 26px 16px;
  line-height: 1.5;
  letter-spacing: 0.05em;
  text-align: center;
}
#dinner .dinner_btn a .icon_arrow_02 {
  margin-left: 8px;
}
#dinner .dinner_btn .btn_bonus {
  background: #bfaa64;
  color: #1e3c64;
  font-weight: 500;
}
#dinner .dinner_btn .btn_bonus .icon_bonus {
  margin-right: 8px;
}
#dinner .dinner_btn .btn_reserve {
  margin-left: 8px;
  background: #1e3c64;
  color: #fff;
}
#dinner .dinner_btn .btn_reserve .icon_reserve {
  margin-right: 8px;
  background: url(../img/common/icon_reserve_02.svg) no-repeat;
  background-size: 100%;
}
#dinner .dinner_btn .btn_reserve .icon_arrow_02 {
  stroke: #fff;
}
#dinner #biking {
  margin-top: 112px;
}
#dinner #kaiseki .page_subnav {
  margin-top: 64px;
}
#dinner #special {
  margin-top: 64px;
}
#dinner #additional {
  padding-bottom: 80px;
}
#dinner #additional .additional_col {
  margin-bottom: 96px;
}
#dinner #additional .additional_col .col_img {
  width: 55.6%;
  max-width: 600px;
}
#dinner #additional .additional_col .col_txt {
  width: 40.5%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
#dinner #additional .additional_col .col_txt .sec_lead {
  margin: 90px 0 32px;
}
#dinner #additional .additional_col .col_txt .txt_btn {
  margin-top: auto;
  padding-bottom: 16px;
  border-bottom: 1px solid #fff;
  letter-spacing: 0.1em;
  text-align: right;
}
#dinner #additional .additional_col .col_txt .txt_btn a {
  display: inline-block;
}
#dinner #additional .additional_col .col_txt .txt_btn a .icon_arrow_02 {
  margin-left: 8px;
}
#dinner #additional .dinner_col {
  margin-top: 90px;
  gap: 92px 0;
}
#dinner #additional .dinner_col .col_item {
  text-align: left;
}

@media screen and (max-width: 810px) {
  #dinner {
    padding-top: 48px;
  }
  #dinner .page_nav {
    margin-top: 0;
  }
  #dinner .dinner_sec {
    padding: 48px 0 64px;
  }
  #dinner .dinner_mv {
    width: 100%;
    margin-top: 32px;
  }
  #dinner .dinner_mv .common_slide {
    margin-bottom: 80px;
  }
  #dinner .dinner_mv .common_slide img {
    aspect-ratio: 16/9;
    object-fit: cover;
  }
  #dinner .dinner_col {
    margin-top: 64px;
    gap: 24px 16px;
    justify-content: space-between;
    letter-spacing: 0.1em;
  }
  #dinner .dinner_col .col_item {
    width: calc(50% - 8px);
    max-width: 100%;
    margin-right: 0;
  }
  #dinner .dinner_col .col_item .item_img {
    margin-bottom: 12px;
  }
  #dinner .dinner_col .col_item .price {
    margin-top: 4px;
    letter-spacing: 0.05em;
  }
  #dinner .dinner_col + p {
    margin-top: 32px;
    text-align: right;
  }
  #dinner .table {
    margin-top: 40px;
  }
  #dinner .dinner_menubtn {
    margin-top: 40px;
    font-size: 1.35rem;
  }
  #dinner .dinner_btn {
    margin-top: 40px;
  }
  #dinner .dinner_btn a {
    width: 100%;
    min-width: 0;
    padding: 20px 16px;
    letter-spacing: 0.05em;
  }
  #dinner .dinner_btn .btn_reserve {
    margin-top: 16px;
    margin-left: 0;
  }
  #dinner #biking {
    margin-top: 24px;
  }
  #dinner #kaiseki {
    padding-bottom: 0;
  }
  #dinner #kaiseki .page_subnav {
    margin-top: 0;
  }
  #dinner #special {
    margin-top: 0;
  }
  #dinner #additional {
    padding-bottom: 48px;
  }
  #dinner #additional .additional_col {
    margin-bottom: 48px;
  }
  #dinner #additional .additional_col .col_img {
    width: 100%;
    max-width: 100%;
  }
  #dinner #additional .additional_col .col_txt {
    width: 100%;
    display: block;
    margin-top: 32px;
  }
  #dinner #additional .additional_col .col_txt .sec_lead {
    margin: 0 0 24px;
  }
  #dinner #additional .additional_col .col_txt .sec_lead + p {
    text-align: right;
  }
  #dinner #additional .additional_col .col_txt .txt_btn {
    margin-top: 16px;
    padding-bottom: 8px;
  }
  #dinner #additional .dinner_col {
    margin-top: 48px;
    gap: 32px 0;
  }
}
/* ---------------------------------------------------
	sec
------------------------------------------------------ */
#breakfast {
  padding: 96px 0 192px;
}
#breakfast .breakfast_slide {
  margin-bottom: 96px;
}
#breakfast .breakfast_slide02 {
  margin-top: 92px;
  overflow: hidden;
}
#breakfast .breakfast_slide02 .slick-list {
  width: 90%;
  margin: 0 auto;
  overflow: visible;
}
#breakfast .breakfast_slide02 .slide_item {
  padding: 0 12px;
}
#breakfast .breakfast_slide02 .slide_item img {
  width: 100%;
}
#breakfast .breakfast_slide02 .slide_item.even {
  margin-top: 88px;
}

@media screen and (max-width: 810px) {
  #breakfast {
    padding: 72px 0 96px;
  }
  #breakfast .breakfast_slide {
    width: 100%;
    margin-bottom: 80px;
  }
  #breakfast .breakfast_slide img {
    aspect-ratio: 16/9;
    object-fit: cover;
  }
  #breakfast .breakfast_slide02 {
    margin-top: 48px;
  }
  #breakfast .breakfast_slide02 .slide_item {
    padding: 0 8px;
  }
  #breakfast .breakfast_slide02 .slide_item.even {
    margin-top: 48px;
  }
}
/* ---------------------------------------------------
		restaurant
------------------------------------------------------ */
#restaurant {
  padding: 96px 0 192px;
}
#restaurant .restaurant_col .col_img {
  width: 65.9%;
  max-width: 636px;
}
#restaurant .restaurant_col .col_txt {
  width: 30.2%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

@media screen and (max-width: 810px) {
  #restaurant {
    padding: 72px 0 96px;
  }
  #restaurant .restaurant_col .col_img {
    width: 100%;
    max-width: 100%;
    margin-bottom: 96px;
  }
  #restaurant .restaurant_col .col_txt {
    width: 100%;
    display: block;
  }
  #restaurant .restaurant_col .col_txt .sec_lead {
    margin-bottom: 48px;
    font-size: 1.8rem;
    letter-spacing: 0.6em;
    text-align: center;
  }
}