@charset "utf-8";

/* --------------------------------
  コンテンツ
-------------------------------- */
.menu-wrap {
  padding: 16rem 20rem 24rem;
}

.menu-headline {
  font-size: 4rem;
  line-height: 1.45;
  text-align: center;
}

.menu-headline::before {
  content: "MENU";
  display: block;
  font-family: var(--font-en);
  font-size: 2.6rem;
  font-weight: var(--font-weight-base);
  letter-spacing: .05em;
  line-height: 1;
  margin-bottom: .6em;
}

.menu {
  margin-top: 18rem;
}

.menu__ttl {
  color: var(--sub-color);
  font-size: 5rem;
  font-weight: var(--font-weight-bold);
  text-align: center;
}

.menu__ttl-deco {
  background-color: var(--body-color);
  display: block;
  height: 1px;
  position: relative;
}

.menu__ttl-deco::before,
.menu__ttl-deco::after {
  background-color: var(--body-color);
  bottom: 0;
  content: "";
  height: 1rem;
  margin-block: auto;
  position: absolute;
  top: 0;
  transform: rotate(45deg);
  width: 1rem;
}

.menu__ttl-deco::before {
  left: 0;
}

.menu__ttl-deco::after {
  right: 0;
}

.menu__ttl-deco.--head {
  margin-bottom: .2em;
}

.menu__ttl-deco.--foot {
  margin-top: .3em;
}

.menu__body {
  display: grid;
  gap: 7rem;
  grid-template-columns: 80rem 1fr;
  margin-top: 14rem;
}

.menu__dl {
  align-items: center;
  border-bottom: 1px dashed;
  display: flex;
  flex-wrap: wrap;
  margin: 0 0 1.3rem;
  padding-bottom: 1.4rem;
}

.menu__dl-ttl {
  font-size: 2.6rem;
  font-weight: var(--font-weight-base);
  flex: 1;
}

.menu__dl-txt {
  margin: 0;
}

.menu__dl-txt .num {
  font-size: 4.4rem;
}

.menu__dl-txt .yen {
  font-size: 2.4rem;
}

.menu__subttl {
  border-bottom: 1px dashed var(--body-color);
  font-size: 3rem;
  font-weight: var(--font-weight-base);
  margin: 6rem 0 1.3rem;
  padding-bottom: 3rem;
}

.menu__subttl .sm {
  font-size: .65em;
}

.menu__read {
  font-size: 2.4rem;
  margin-top: 10rem;
  text-align: center;
}

.menu__read+.menu__body {
  margin-top: 10.5rem;
}

.menu-box {
  background-color: #fff;
  border: 1px solid;
  margin-top: 24rem;
  padding: 1rem 10rem 10rem;
}

.menu-box__lists {
  display: grid;
  gap: 0 10rem;
  grid-template-columns: 1fr 1fr;
}

.menu-wrap .btn-wrap {
  margin-top: 10rem;
}

/* ================================================================
  スマホ版レイアウト
================================================================ */
@media screen and (max-width: 750px) {

  /* --------------------------------
    コンテンツ
  -------------------------------- */
  .menu-wrap {
    padding: 7rem 2rem 10rem;
  }

  .menu-headline {
    font-size: 2.2rem;
    letter-spacing: -.04em;
  }

  .menu-headline::before {
    font-size: 1.6rem;
  }

  .menu {
    margin-top: 9rem;
  }

  .menu.--first {
    margin-top: 6rem;
  }

  .menu__ttl {
    font-size: 2rem;
  }

  .menu__ttl-deco::before,
  .menu__ttl-deco::after {
    height: .5rem;
    width: .5rem;
  }

  .menu__body {
    display: block;
    margin-top: 4rem;
  }

  .menu__imgs {
    display: grid;
    gap: 2rem;
    margin-bottom: 2rem;
    padding-inline: 1.5rem;
  }

  .menu__dls {
    padding-inline: 1.5rem;
  }

  .menu__dl {
    padding-bottom: .8rem;
  }

  .menu__dl.--img {
    margin-bottom: 4rem;
  }

  .menu__dl-img {
    flex: 100%;
    margin-bottom: 1rem;
  }

  .menu__dl-ttl {
    font-size: 1.6rem;
  }

  .menu__dl-txt .num {
    font-size: 2.6rem;
  }

  .menu__dl-txt .yen {
    font-size: 1.4rem;
  }

  .menu__subttl {
    font-size: 1.8rem;
    margin: 4rem 0 .8rem;
    padding-bottom: 2rem;
  }

  .menu__read {
    font-size: 1.4rem;
    margin-top: 3.5rem;
    padding-inline: 1.5rem;
    text-align: left;
  }

  .menu__read+.menu__body {
    margin-top: 3.5rem;
  }

  .menu-box {
    margin-top: 10rem;
    padding: 0 3rem 4rem;
  }

  .menu-box__lists {
    grid-template-columns: 1fr;
  }

  .menu-wrap .btn-wrap {
    margin-top: 6rem;
  }

}