@charset "utf-8";
/* CSS Document */

/* dining-PAGE--------------------------------------------- */

.page_dining .l-submv01 {
  &::after {
    background-image: url("../img/dining/mv.jpg");
  }
}

.wrapper_bc {
  background: #293534;
  color: #fdfcfb;
  overflow: hidden;
}

.l-concept {
  padding: 32rem 0 4.6rem;
  color: #fdfcfb;
  .inner {
    margin: 0 auto 18rem;
    width: 121.6rem;

    .ttl02 {
      position: relative;
      z-index: 0;
      margin-bottom: 6.2rem;
      font-size: 1.9rem;
      font-weight: 400;
      line-height: 103%;
      &::after {
        content: "";
        display: block;
        position: absolute;
        z-index: 0;
        background-color: #fdfcfb;
        bottom: 0;
        left: 50%;
        transform: translate(0, 0);
        width: 1px;
        height: 15rem;
      }
    }
    .text-head {
      margin-bottom: 4.8rem;
      text-align: center;
      .en {
        margin-bottom: 3rem;
        display: block;
        font-size: 1.7rem;
        font-weight: 400;
        line-height: 120%;
        letter-spacing: 0.07em;
      }
      strong {
        overflow: hidden;
        display: inline-block;
        font-size: 3rem;
        font-weight: 700;
        line-height: 159%;
      }
    }
    .text_concept {
      font-size: 1.6rem;
      font-weight: 400;
      line-height: 200%;
      letter-spacing: 0.07em;
      text-align: center;
      & + .text_concept {
        margin-top: 2em;
      }
    }
  }
  .block_img {
    position: relative;
    z-index: 0;
    margin: 0 auto;
    width: 144rem;
    aspect-ratio: 1440/1124;
    .box_img {
      position: absolute;
      z-index: 1;
      overflow: hidden;
      will-change: transform;

      &.img01 {
        width: 40.4rem;
        top: -17.8rem;
        left: 0;
      }
      &.img02 {
        width: 56.4rem;
        top: 32.2rem;
        left: 22.9rem;
      }
      &.img03 {
        width: 54.6rem;
        top: 13.5rem;
        right: 0;
      }
      &.img04 {
        width: 28rem;
        top: 77.2rem;
        right: 28.1rem;
      }
      img {
        display: block;
        width: 100%;
        height: auto;
        will-change: transform;
        transform: scale(1.2);
      }
    }
  }
  @media screen and (max-width: 768px) {
    padding: 24rem 0 4.6rem;
    .inner {
      margin: 0 auto 6rem;
      width: 32.6rem;
      .text-head {
        margin-bottom: 4.8rem;
        text-align: center;
        strong {
          font-size: 2.8rem;
        }
      }
      .text_concept {
        font-size: 1.4rem;
        text-align: left;
        & + .text_concept {
          margin-top: 1.6em;
        }
      }
    }
    .block_img {
      z-index: 1;
      width: 39rem;
      aspect-ratio: 390/400;
      .box_img {
        position: absolute;
        z-index: 1;
        overflow: hidden;
        will-change: transform;

        &.img01 {
          width: 15.9rem;
          top: 2rem;
          left: 0;
        }
        &.img02 {
          width: 20.2rem;
          top: 30rem;
          left: 2rem;
        }
        &.img03 {
          width: 20.2rem;
          top: -3rem;
          right: 0;
        }
        &.img04 {
          width: 12.53rem;
          top: 22rem;
          right: 2rem;
        }
      }
    }
  }
}
.l-same00 {
  .text01 {
    font-size: 1.6rem;
    font-weight: 400;
    line-height: 200%;
    letter-spacing: 0.07em;
    strong {
      margin-bottom: 2.4rem;
      display: block;
      font-size: 24px;
      font-weight: 700;
      line-height: 120%;
      letter-spacing: 0;
    }
    & + .text01 {
      margin-top: 3.2rem;
    }
    .cap {
      margin-top: 0.5em;
      display: block;
      font-size: 0.8em;
      line-height: 1.4;
      text-indent: -1em;
      padding-left: 1em;
    }
  }
}

.l-same01 {
  .inner {
    margin: 0 auto;
    width: 139.2rem;
  }
  .duining_image {
    overflow: hidden;
    width: 100vw;
    margin: 0 calc(50% - 50vw);
    display: flex;

    flex-shrink: 0;
    .duining_anime00 {
      display: flex;
      animation: duining_bc 80s linear infinite;

      li {
        width: 60vw;
        padding: 0 0.2rem;
      }
    }
  }

  .box_explanation {
    position: relative;
    z-index: 1;
    margin: -26rem 0 3.2rem;
    background: #293534;
    padding: 9.6rem 9.6rem 9.6rem 4rem;
    width: 82.9em;
    display: flex;
    justify-content: space-between;

    .parts_text {
      width: 39.8rem;
      padding-top: 1.3rem;
    }

    .ttl02_1 {
      display: flex;
      align-items: center;
      gap: 2.4rem;
      align-self: baseline;
      width: 19.6rem;
      .en {
        font-size: 1.9rem;
        font-weight: 400;
        line-height: 103%;
      }
      .jp01 {
        padding: 0.6rem;
        border: 1px solid rgba(255, 255, 255, 0.3);
        font-size: 3.6rem;
        font-weight: 600;
        letter-spacing: 0.2em;
        writing-mode: vertical-rl;
      }
    }
  }
  .ttl03 {
    margin-bottom: 3.2rem;
    margin-left: 4.8rem;
    font-size: 3rem;
    font-weight: 700;
    line-height: 166%;

    .size_s {
      margin-top: 1.2rem;
      display: block;
      font-size: 1.4rem;
      font-weight: 700;
      line-height: 120%;
    }
  }
  .wrapper_text {
    padding-left: 27rem;
  }
  @media screen and (max-width: 768px) {
    .duining_image {
      .duining_anime00 {
        animation: duining_bc 40s linear infinite;
        li {
          width: 60vw;
          padding: 0 0.1rem;
        }
      }
    }

    .inner {
      width: 100%;
    }
    .box_explanation {
      margin: -4.8rem 0 3.2rem;
      padding: 2.4rem 1.6rem;
      width: 36rem;
      flex-flow: column;
      gap: 4.8rem;
      .parts_text {
        width: 100%;
        padding-top: 0;
      }
    }
    .ttl03 {
      margin-left: 0;
    }
    .wrapper_text {
      padding-left: 0;
    }
  }
}

@keyframes duining_bc {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-100%);
  }
}

/* Breakfast Section */
.l-breakfast {
  /* padding: 0 0 33.6rem; */
  padding: 0 0 0;
  .inner {
    .list_dining_b {
      margin: 0 15.7rem 0 33.5rem;
      width: 94.8rem;
      display: flex;
      flex-flow: column;
      gap: 8rem;
      .card_b {
        display: flex;
        justify-content: space-between;
        figure {
          width: 28rem;
        }
        .text01 {
          width: 62rem;
          padding-top: 2.4rem;
        }
      }
    }
  }
  @media screen and (max-width: 768px) {
    /* padding: 0 0 16rem; */
    padding: 0 0 0;
    .inner {
      .list_dining_b {
        margin: 0 auto;
        width: 32.6rem;
        display: flex;
        flex-flow: column;
        gap: 8rem;
        .card_b {
          flex-flow: column;
          align-items: center;
          figure {
            width: 100%;
          }
          .text01 {
            width: 90%;
            padding-top: 2.4rem;
          }
        }
      }
    }
  }
}

/* Dinner Section */

.l-dinner {
  margin: 0 auto;
  width: 144rem;
  padding-bottom: 22.7rem;
  .list_dining_d {
    margin: 0 17.7rem 0 35.9rem;
    width: 90.4rem;
    display: flex;
    flex-flow: column;
    gap: 14.4rem;
    .card_d {
      figure {
        margin-bottom: 4.8rem;
      }
      .wrapper_d-content {
        margin: 2.4rem 0;
        padding: 2.4rem 3.2rem 3.2rem;
        border-radius: 1.2rem;
        background: rgba(70, 83, 82, 0.3);
        .list_d-content {
          margin-top: 1.6rem;
        }
      }
      .cap {
        font-size: 1.2rem;
        font-weight: 400;
        line-height: 187%;
        letter-spacing: 0.07em;
      }
    }
  }
  @media screen and (max-width: 768px) {
    width: 100%;
    padding-bottom: 16rem;
    .list_dining_d {
      margin: 0 auto;
      width: 32.6rem;
      gap: 12rem;
      .card_d {
        figure {
          margin-bottom: 4.8rem;
        }
        .wrapper_d-content {
          padding: 2.4rem;
        }
      }
    }
  }
}

/* Other Section */
.l-other {
  margin: 0 auto;
  width: 117.4rem;
  padding: 8rem 0 16rem;
  .inner {
    display: flex;
    justify-content: space-between;
    .ttl02_2 {
      font-size: 2.9rem;
      font-weight: 700;
      line-height: 120%;
    }
    .list_other {
      width: 94.8rem;
      .card_other {
        padding: 4.8rem 0;
        font-size: 1.4rem;
        font-weight: 400;
        line-height: 192%;
        letter-spacing: 0.07em;
        display: flex;
        justify-content: space-between;
        border-top: 1px solid rgba(158, 173, 171, 0.4);
        dt {
          width: 20rem;
          font-size: 2.4rem;
          font-weight: 700;
          line-height: 120%;
          letter-spacing: 0;
        }
        dd {
          width: 71.6rem;
          padding-right: 3.2rem;
        }
      }
    }
  }
  @media screen and (max-width: 768px) {
    width: 32.6rem;
    padding: 0rem 0 12.8rem;
    .inner {
      flex-flow: column;
      .ttl02_2 {
        margin-bottom: 3.2rem;
      }
      .list_other {
        width: 100%;
        .card_other {
          padding: 3.2rem 0;
          font-size: 1.4rem;
          font-weight: 400;
          line-height: 192%;
          letter-spacing: 0.07em;
          flex-flow: column;
          dt {
            margin-bottom: 2.4rem;
            width: 100%;
            font-size: 2.4rem;
            font-weight: 700;
            line-height: 120%;
            letter-spacing: 0;
          }
          dd {
            width: 100%;
            padding-right: 0;
          }
        }
      }
    }
  }
}
