@charset "UTF-8";
/* コンテンツ最大幅 */
/* color */
/* ============================================ */
/* font-size */
/* ============================================ */
/* font-family */
/* ============================================ */
/* cuisine */
/* ============================================ */
.cuisine-wrapper {
  padding-bottom: 150px;
}
@media all and (max-width: 896px) {
  .cuisine-wrapper {
    padding-bottom: 80px;
  }
}
.cuisine-material {
  color: #fff;
  background: #2C2C66;
}
.cuisine-material__list {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
}
@media all and (max-width: 896px) {
  .cuisine-material__list {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media all and (max-width: 480px) {
  .cuisine-material__list {
    grid-template-columns: repeat(1, 1fr);
  }
}
.cuisine-material__list__item {
  container-type: inline-size;
  aspect-ratio: 480/540;
  overflow: hidden;
  position: relative;
}
@media all and (max-width: 480px) {
  .cuisine-material__list__item {
    aspect-ratio: 5/3;
  }
}
.cuisine-material__list__item::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.3);
  position: absolute;
  top: 0;
  left: 0;
  z-index: 5;
  transition: all 0.3s ease-out;
}
.cuisine-material__list__item.--active::before {
  background: rgba(0, 0, 0, 0.6);
}
.cuisine-material__list__item.--active .cuisine-material__list__txt {
  display: block;
  -webkit-animation: navOpen 0.3s ease-out;
          animation: navOpen 0.3s ease-out;
}
.cuisine-material__list__img {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}
.cuisine-material__list__img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 480/540;
}
@media all and (max-width: 480px) {
  .cuisine-material__list__img img {
    aspect-ratio: 5/4;
  }
}
.cuisine-material__list__block {
  text-align: center;
  width: calc(100% - 40px);
  max-width: 360px;
  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  z-index: 10;
}
@media all and (max-width: 896px) {
  .cuisine-material__list__block {
    max-width: 280px;
  }
}
.cuisine-material__list__name {
  font-size: clamp(1.5rem, -0.2778rem + 3.1746vw, 2.5rem);
  font-weight: 700;
  line-height: 1.4;
}
.cuisine-material__list__txt {
  display: none;
  font-size: clamp(0.875rem, 0.2083rem + 1.1905vw, 1.25rem);
  font-weight: 500;
  margin-top: 6.67cqw;
}
.cuisine-material__container {
  padding: 50px 0 150px;
}
@media all and (max-width: 896px) {
  .cuisine-material__container {
    padding: 32px 0 80px;
  }
}
.cuisine-material__inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 40px 3.57cqw;
}
@media all and (max-width: 896px) {
  .cuisine-material__inner {
    flex-direction: column;
    align-items: flex-start;
  }
}
.cuisine-material__ttl {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: 3.57cqw;
}
@media all and (max-width: 896px) {
  .cuisine-material__ttl {
    flex-wrap: wrap;
    gap: 16px 20px;
  }
}
.cuisine-material__ttl__jp {
  font-family: "Noto Serif JP", serif;
  font-style: normal;
  font-size: clamp(2rem, -3.3333rem + 9.5238vw, 5rem);
  font-weight: 500;
  line-height: 1;
}
.cuisine-material__ttl__en {
  font-family: "Montserrat", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  color: #747476;
  font-size: clamp(0.9375rem, 0.6042rem + 0.5952vw, 1.125rem);
  line-height: 1.4;
}
.cuisine-material__txt {
  line-height: 1.75;
}
.cuisine-main {
  padding-bottom: 150px;
}
@media all and (max-width: 896px) {
  .cuisine-main {
    padding-bottom: 80px;
  }
}
.cuisine-main__container {
  margin-top: 150px;
}
@media all and (max-width: 896px) {
  .cuisine-main__container {
    margin-top: 80px;
  }
}
.cuisine-main__container.--dinner {
  margin-left: 12.9cqw;
}
@media all and (max-width: 896px) {
  .cuisine-main__container.--dinner {
    margin-left: 0;
  }
}
.cuisine-main__container.--dinner .cuisine-main__contents {
  max-width: 356px;
}
@media all and (max-width: 896px) {
  .cuisine-main__container.--dinner .cuisine-main__contents {
    max-width: inherit;
  }
}
.cuisine-main__container.--dinner .cuisine-main__photo {
  width: 50.64cqw;
}
@media all and (max-width: 896px) {
  .cuisine-main__container.--dinner .cuisine-main__photo {
    width: 100%;
  }
}
.cuisine-main__container.--dinner .cuisine-main__img {
  width: 81.52cqw;
}
.cuisine-main__container.--dinner .cuisine-main__sub {
  width: 54.72cqw;
  margin-top: 0;
  margin-bottom: -3.39cqw;
}
.cuisine-main__container.--breakfast .cuisine-main__inner {
  flex-direction: row-reverse;
}
@media all and (max-width: 896px) {
  .cuisine-main__container.--breakfast .cuisine-main__inner {
    flex-direction: column;
  }
}
.cuisine-main__inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 40px 7.14cqw;
}
@media all and (max-width: 896px) {
  .cuisine-main__inner {
    flex-direction: column;
  }
}
.cuisine-main__contents {
  flex-grow: 1;
  max-width: 560px;
}
@media all and (max-width: 896px) {
  .cuisine-main__contents {
    max-width: inherit;
  }
}
.cuisine-main__ttl__jp {
  font-size: clamp(1.5rem, 0.2778rem + 2.1825vw, 2.1875rem);
  font-weight: 500;
  line-height: 1.4;
}
.cuisine-main__ttl__en {
  font-family: "Montserrat", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-size: clamp(0.75rem, 0.4167rem + 0.5952vw, 0.9375rem);
  font-weight: 600;
  color: #747476;
  margin-top: 12px;
}
.cuisine-main__txt {
  font-size: clamp(0.9375rem, 0.6042rem + 0.5952vw, 1.125rem);
  line-height: 2;
  margin-top: 48px;
}
@media all and (max-width: 896px) {
  .cuisine-main__txt {
    margin-top: 24px;
  }
}
.cuisine-main__note {
  font-size: clamp(0.9375rem, 0.6042rem + 0.5952vw, 1.125rem);
  margin-top: 32px;
}
.cuisine-main__note > li {
  padding-left: 1em;
  position: relative;
}
.cuisine-main__note > li::before {
  content: "※";
  position: absolute;
  top: 0;
  left: 0;
}
.cuisine-main__photo {
  container-type: inline-size;
  flex-shrink: 0;
  width: 54cqw;
}
@media all and (max-width: 896px) {
  .cuisine-main__photo {
    width: 100%;
  }
}
.cuisine-main__img {
  width: 92.59cqw;
}
.cuisine-main__img img {
  width: 100%;
  max-width: none;
}
.cuisine-main__sub {
  width: 40.21cqw;
  margin-top: -5.03cqw;
  margin-right: 0;
  margin-left: auto;
  position: relative;
  z-index: 10;
}
.cuisine-main__sub img {
  width: 100%;
  max-width: none;
}
.cuisine-photo {
  width: calc(100% - 64px);
  margin-inline: auto;
}
@media all and (max-width: 896px) {
  .cuisine-photo {
    width: 100%;
  }
}
.cuisine-photo__list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}
@media all and (max-width: 896px) {
  .cuisine-photo__list {
    gap: 8px;
  }
}
.cuisine-photo__item {
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 605/404;
}
.cuisine-restaurant {
  margin-top: 150px;
  position: relative;
}
@media all and (max-width: 896px) {
  .cuisine-restaurant {
    margin-top: 80px;
  }
}
.cuisine-restaurant__wrapper {
  max-width: 1620px;
  position: relative;
}
.cuisine-restaurant__bg {
  margin-right: calc(50% - 50vw);
  width: calc(100% + 50vw - 50%);
  height: calc(100% - 64px);
  background: url("../images/common/bg.jpg") top left/965px auto repeat;
  position: absolute;
  top: 0;
  right: 0;
}
.cuisine-restaurant__container {
  margin-inline: calc(50% - 50vw);
  padding-top: 100px;
  padding-right: calc(50vw - 50%);
  display: flex;
  flex-direction: row-reverse;
  justify-content: flex-end;
  align-items: center;
  gap: 40px min(7.29vw, 140px);
  position: relative;
  z-index: 10;
}
@media all and (max-width: 1025px) {
  .cuisine-restaurant__container {
    gap: 40px 5.46cqw;
  }
}
@media all and (max-width: 896px) {
  .cuisine-restaurant__container {
    padding-top: 64px;
    padding-right: 20px;
    flex-direction: column;
    align-items: flex-start;
  }
}
.cuisine-restaurant__inner {
  flex-grow: 1;
  max-width: 460px;
  padding-bottom: 100px;
}
@media all and (max-width: 896px) {
  .cuisine-restaurant__inner {
    padding-left: 40px;
    padding-bottom: 0;
    width: 100%;
  }
}
.cuisine-restaurant__ttl {
  font-family: "Noto Serif JP", serif;
  font-style: normal;
  font-size: clamp(1.375rem, -0.4028rem + 3.1746vw, 2.375rem);
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: 0.04em;
  color: #8A9BCE;
}
.cuisine-restaurant__txt {
  font-weight: 500;
  line-height: 1.75;
  margin-top: 24px;
}
@media all and (max-width: 896px) {
  .cuisine-restaurant__txt {
    margin-top: 20px;
  }
}
.cuisine-restaurant__schedule {
  padding: 20px 3.14cqw;
  border: 1px solid #A7842E;
  margin-top: 32px;
}
@media all and (max-width: 896px) {
  .cuisine-restaurant__schedule {
    padding: 20px;
    margin-top: 24px;
    max-width: 600px;
  }
}
.cuisine-restaurant__schedule__ttl {
  text-align: center;
  width: 100%;
  padding: 0.6em 1.2em;
  border-radius: 9999px;
  background: #A7842E;
  font-family: "Noto Sans JP", sans-serif;
  font-style: normal;
  font-size: 0.75rem;
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: 0.2em;
  color: #fff;
}
.cuisine-restaurant__schedule__block {
  margin-top: 16px;
}
@media all and (max-width: 896px) {
  .cuisine-restaurant__schedule__block {
    margin-top: 12px;
  }
}
.cuisine-restaurant__schedule__detail {
  inline-size: -webkit-fit-content;
  inline-size: -moz-fit-content;
  inline-size: fit-content;
  margin-inline: auto;
}
.cuisine-restaurant__schedule__detail__item {
  display: flex;
  align-items: flex-start;
  gap: 1em;
  font-weight: 500;
  line-height: 1.4;
}
.cuisine-restaurant__schedule__detail__item dt {
  flex-shrink: 0;
  margin-top: 0.8em;
  font-size: clamp(0.875rem, 0.5417rem + 0.5952vw, 1.0625rem);
}
.cuisine-restaurant__schedule__detail__item dd .txt_time {
  font-family: "Montserrat", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-size: clamp(1.375rem, -0.1806rem + 2.7778vw, 2.25rem);
  font-weight: 500;
  letter-spacing: 0.1em;
}
.cuisine-restaurant__img {
  flex-shrink: 0;
  width: 55.36vw;
}
@media all and (max-width: 896px) {
  .cuisine-restaurant__img {
    width: 100%;
    max-width: 720px;
  }
}
.cuisine-restaurant__img img {
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 1063/726;
}