@charset "UTF-8";
/*
メニューページ用
============================================== */

/* 共通
-----------------*/

/* レイアウト */
.column2 {
  grid-template-columns: repeat(2, 1fr);
}
@media (min-width: 769px) {
  .pc-column2 {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 768.98px) {
  .sp-column2 {
    grid-template-columns: repeat(2, 1fr);
  }
}
.menuItems.column2 {
  column-gap: 1.5rem;

  row-gap: 4rem;
}
@media (min-width: 769px) {
  .menuItems.column2 {
    column-gap: 6rem;

    row-gap: 10rem;
  }
}

/* パーツ */
.category_name {
  font-weight: 500;
  font-size: clamp(2.2rem, 3.88vw + .75rem, 5.4rem);
  text-align: center;
  letter-spacing: 6px;
}
.menuItemList {
  padding-top: 3rem;
  padding-bottom: 3rem;
  border-bottom: 1px solid #c4c4c4;
}
@media (min-width: 769px) {
  .menuItemList {
    display: flex ;
    justify-content: space-between;
    align-items: center;
    padding-top: 4rem;
    padding-bottom: 4rem;
    border-bottom: 1px solid #c4c4c4;
  }
  .menuItemList:has(.note){
    display: block;
  }
}
@media (min-width: 769px) {
.menuItemListBox {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
}
.menuItem_name {
  font-weight: 500;
  font-size: clamp(1.6rem, 1.45vw + 1.05rem, 2.8rem);
}
.menuItemList > .menuItem_name {
  margin-bottom: 5px;
}
@media (min-width: 769px) {
  .menuItemList > .menuItem_name {
    margin-bottom: 0;
  }
}
.menuItem_price {
  font-weight: 500;
  font-size: clamp(1.6rem, .73vw + 1.13rem, 2rem);
}
.menuItem_price > .tax {
  margin-left: .5em;
  font-size: clamp(1.3rem, .61vw + 1.07rem, 1.8rem);
}
/* 下層ページタイトル */
.pageHeader.-hasimg > .pageTitle {
  margin-bottom: 3rem;
  margin-left: 5rem;
}
@media (min-width: 769px) {
  .pageHeader.-hasimg {
    width: min(1560px, 100% - 30px);
    margin-left: auto;
  }
  .pageHeader.-hasimg {
    display: flex;
    justify-content: space-between;
  }
  .pageHeader.-hasimg > .pageTitle {
    margin-right: 3em;
    margin-bottom: 0;
    margin-left: 0;
  }
}
.sandwich .pageTitle {
  width: min(16.6%, 137px);
}
.toast .pageTitle {
  width: min(27%, 203px);
}
.desert .pageTitle {
  width: min(16%, 203px);
}
.drink .pageTitle {
  width: min(16%, 115px);
}
.season .pageTitle {
  width: min(17%, 137px);
}
.soup .pageTitle {
  width: min(25%, 199px);
}
.salad .pageTitle {
  width: min(17%, 136px);
}
/* アイコン */
.icon-note {
  display: inline-block;
  padding: .4em .6em;
  font-weight: 500;
  font-size: clamp(1.3rem, .61vw + 1.07rem, 1.8rem);
  color: #fff;
  background-color: #a31a1a;
}

/* KIDS MENU
-----------------*/
.kidsContainer {
  width: 100%;
  padding: 2.5rem 2rem;
  background-color: #fff;
  outline: 1px solid #c4c4c4;
  outline-offset: -5px;
}
@media (min-width: 769px) {
  .kidsContainer {
    width: min(560px, 49%);
    padding: 4rem;
    outline-offset: -10px;
  }
}
.kidsTtl {
  font-weight: 500;
  font-size: clamp(1.8rem, 1.21vw + 1.35rem, 2.8rem);
  text-align: center;
}
.kidsItems {
  margin-top: 3rem;
  margin-top: 2rem;
  padding-top: 2.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid #c4c4c4;
}
@media (min-width: 769px) {
  .kidsItems {
    margin-top: 3rem;
    padding-top: 2.5rem;
  }
}
.kidsItem {
  font-size: clamp(1.4rem, .97vw + 1.04rem, 2.2rem);
  line-height: 2;
}
.kidsItem::before {
  content: "・";
  color: #a31a1a;
}

/* DRINK MENU
-----------------*/
.drink-column2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  column-gap: 2rem;

  grid-template-areas: "icon-drink icon-drink";
}
.icon-drink {
  grid-area: icon-drink;
}
@media (min-width: 769px) {
  .drink-column2 {
    column-gap: 6rem;
  }
}
.menuItemLists.-drink .menuItemList {
  padding-top: 2rem;
  padding-bottom: 2rem;
}
@media (min-width: 769px) {
  .menuItemLists.-drink .menuItemList {
    padding-top: 4rem;
    padding-bottom: 4rem;
  }
}
.menuItemLists.-drink .menuItemList .menuItem_name {
  font-weight: 400;
  font-size: clamp(1.6rem, .97vw + 1.24rem, 2.4rem);
}
.icon-drink {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 60px;
  height: 28px;
  font-size: clamp(1.8rem, .85vw + 1.48rem, 2.5rem);
  line-height: 1;
  letter-spacing: 3px;
  border-radius: 3px;
}
@media (min-width: 769px) {
  .icon-drink {
    width: 95px;
    height: 45px;
  }
}
.cup::after,
.cup-before::before {
  content: "";
  display: inline-block;
  width: 18px;
  height: 20px;
  margin-left: .3em;
  vertical-align: middle;
  background-image: url(../img/menu/icon-cup.svg);
  background-size: contain;
}
.cup-before::before {
  margin-right: .3em;
  margin-left: 0;
}
@media (min-width: 769px) {
  .cup::after,
  .cup-before::before {
    width: 31px;
    height: 33px;
  }
}
.decaf {
  width: fit-content;
  margin-top: .5rem;
  margin-bottom: .5rem;
  padding: .1em .6em;
  background: #fff;
  border-radius: 15px;
}
.decaf::after {
  content: "";
  display: inline-block;
  width: 13px;
  height: 11px;
  margin-left: .3em;
  background-image: url(../img/menu/icon-decaf.svg);
  background-size: contain;
}
@media (min-width: 769px) {
  .decaf {
    margin-top: 1rem;
    margin-bottom: 0;
    padding: .2em .7em;
  }
  .decaf::after {
    width: 16px;
    height: 15px;
  }
}
.limited {
  width: fit-content;
  margin-top: .5rem;
  margin-bottom: .5rem;
  padding: .1em .6em;
  font-size: clamp(1.3rem, 1.118rem + 0.485vw, 1.7rem);
  font-weight: 700;
  background: #fff;
  color: #A31A1A;
}
@media (min-width: 769px) {
  .limited {
    margin-top: 1rem;
    margin-bottom: 0;
    padding: .2em .7em;
  }
}


/* SET MENU
-----------------*/
.setContainer {
  position: relative;
  display: flex;
  justify-content: center;
  margin-top: 15px;
  padding-top: 3.5rem;
  padding-bottom: 3rem;
  background-color: #fff;
}
.setContainer::before {
  content: "";
  position: absolute;
  top: -15px;
  width: 35px;
  height: 30px;
  background-color: #fff;
  clip-path: polygon(50% 0, 0 100%, 100% 100%);
}
@media (min-width: 769px) {
  .setContainer {
    max-width: 1200px;
    margin-right: auto;
    margin-left: auto;
    padding-top: 10rem;
    padding-bottom: 10rem;
  }
}
.setContainer_inner {
  width: min(960px, 100% - 60px);
}
.setTtl {
  font-weight: 400;
  font-size: clamp(2.6rem, 2.18vw + 1.78rem, 4.4rem);
  text-align: center;
  letter-spacing: 4px;
}
.setsubTtl {
  font-size: clamp(1.4rem, .97vw + 1.04rem, 2.2rem);
}
.setmenuItems {
  display: flex;
  flex-direction: column;
  row-gap: 1.5rem;
}
@media (min-width: 769px) {
  .setmenuItems {
    row-gap: 4rem;
  }
}
.setmenuItem_name {
  font-weight: 500;
  font-size: clamp(1.6rem, 1.09vw + 1.09rem, 2.4rem);
  flex-shrink: 0;
}
.setmenuItem_note {
    font-size: clamp(1.3rem, .61vw + 1.07rem, 1.6rem);
    line-height: 1.5;
    display: block;
}
.setmenuItem .menuItem_price {
    text-align: right;
}
.setmenuItem .menuItem_price > .tax {
  font-weight: 500;
  font-size: clamp(1.3rem, .61vw + 1.07rem, 1.6rem);
}


.setchoiceContainer {
  border: 1px solid #a31a1a;
}
.setchoiceTtl {
  font-weight: 500;
  font-size: clamp(1.4rem, .97vw + 1.04rem, 2.2rem);
  line-height: 2.7;
  text-align: center;
  color: #fff;
  letter-spacing: 1.5px;
  background-color: #a31a1a;
}
@media (min-width: 769px) {
  .setchoiceTtl {
    line-height: 3;
    letter-spacing: 3px;
  }
}
.setchoiceContainer_inner {
  width: min(900px, 100% - 40px);
  padding-top: 2.5rem;
  padding-bottom: 2.5rem;

  margin-inline: auto;
}
@media (min-width: 769px) {
  .setchoiceContainer_inner {
    width: min(900px, 100% - 90px);
    padding-top: 5rem;
    padding-bottom: 5rem;
  }
}
.setchoiceItem {
  font-size: clamp(1.4rem, .97vw + 1.04rem, 2.2rem);
  vertical-align: middle;
  word-break: keep-all;
}
.setchoiceItem::before {
  content: "・";
  color: #a31a1a;
}

.setchoiceItem_note {
  font-size: clamp(1.3rem, .48vw + 1.12rem, 1.7rem);
}
.pot::after,
.pot-before::before {
  content: "";
  display: inline-block;
  width: 20px;
  height: 16px;
  margin-left: .3em;
  vertical-align: middle;
  background-image: url(../img/menu/icon-pot.svg);
  background-size: contain;
}
.pot-before::before {
  margin-right: .3em;
  margin-left: 0;
}
@media (min-width: 769px) {
  .pot::after,
  .pot-before::before {
    width: 33px;
    height: 23px;
  }
}
.setchoiceItems_addContainer{
  background-color: #DDCECE;
}
.setchoiceItems_addContainer > .setchoiceItems_addContainer_inner{
  padding:1em;
}
@media(max-width:420px) {
  .setchoiceItems_addContainer > .setchoiceItems_addContainer_inner{
    padding-right:.3em;
    padding-left: .3em;
  }
}
.addContainerTtl{
  font-weight: 500;
  color: #fff;
  text-align: center;
  background-color: #a31a1a;
  font-size: clamp(1.3rem, 0.24vw + 1.21rem, 1.5rem);
  line-height: 2.5;
}
@media (min-width: 769px){
  .setchoiceItems_addContainer > .setchoiceItems_addContainer_inner{
    padding:1.5em;
  }
  .addContainerTtl{
    line-height: 3;
  }
}
.setchoiceItem .decaf,
.setchoiceItem .limited{
  display: inline-block;
  white-space: nowrap;
  margin-left: .7em;
}
.setchoiceItem .decaf {
  font-size: clamp(1.3rem, 1.209rem + 0.242vw, 1.5rem);
}
@media(max-width:420px) {
  .setchoiceItem .decaf,
.setchoiceItem .limited {
  margin-left: .5em;
}
}
.decafTxt {
  display: block;
  padding-left: 1.3em;
}
.setchoiceItem .decafTxt::after {
  content: "";
  display: inline-block;
  width: 1em;
  height: .8em;
  margin-left: .3em;
  background-image: url(../img/menu/icon-decaf.svg);
  background-size: contain;
}
.setchoiceItem .decaf::after {
  background-image: none;
  width: 0;
  display: none;
}
.limitedTxt {
  padding-left: .6em;
}
@media(min-width:769px) {
  .decafTxt{
  padding-left: 1.7em;
}
.limitedTxt {
  padding-left: .7em;
}
}
/* メニュー一覧ページ
-----------------*/
body.menu_all {
  background: #fff;
}
/* 装飾 */
.pineapple {
  position: absolute;
  right: -1.7em;
  bottom: 0;
  width: max(40%, 160px);
}
.menu_deco-fruitsandwich {
  right: 0;
  bottom: -4em;
  width: 140px;
  width: max(25%, 140px);
}
.menu_deco-mealsandwich {
  top: -5em;
  left: -1em;
  z-index: 1;
  width: max(25%, 150px);
}
.menu_deco-toast {
  right: 0;
  bottom: -3em;
  width: max(20%, 150px);
}
.menu_deco-dessert {
  right: -.7em;
  bottom: -3em;
  width: max(18%, 111px);
  pointer-events: none;
}
.menu_deco-drink {
  right: 2em;
  bottom: -4.5em;
  width: max(25%, 177px);
}
[class^="menu_deco-"]{
  pointer-events: none;
}
@media (min-width: 960px) {
  .pineapple {
    right: -4em;
    width: min(40%, 442px);
  }
  .menu_deco-fruitsandwich {
    right: 2em;
    bottom: -12em;
    width: min(18%, 246px);
  }
  .menu_deco-mealsandwich {
    top: -3em;
    left: auto;
    width: min(25%, 316px);
  }
  .menu_deco-toast {
    right: 7em;
    bottom: -9em;
    width: min(14%, 200px);
  }
  .menu_deco-dessert {
    top: -5em;
    left: 1.5em;
    width: min(18%, 252px);
  }
  .menu_deco-drink {
    right: 1.5em;
    bottom: -13em;
    width: min(25%, 352px);
  }
}
/* title */
.menu_all .pageTitle {
  width: min(20%, 137px);
}
/* head */
.menu_all .pageHeader {
  padding-bottom: 3rem;
}
@media (min-width: 769px) {
  .menu_all .pageHeader {
    padding-bottom: 13rem;
  }
}
/* menuコンテンツ */
.menu {
  position: relative;
  display: flex;
  flex-direction: column-reverse;
}
@media (min-width: 960px) {
  .menu {
    flex-direction: row;
  }
  .menu._reverse {
    flex-direction: row-reverse;
  }
}
.menu + .menu {
  margin-top: 8rem;
}
@media (min-width: 960px) {
  .menu + .menu {
    margin-top: 26rem;
  }
}
.menu > .menu_body {
  position: relative;
  margin-top: -150px;
  padding: 175px 30px 40px 30px;
}

@media (min-width: 960px) {
  .menu > .menu_body {
    top: 90px; /*元の位置を基準に単純に90px下にずらす*/
    display: flex;
    flex-direction: column;
    justify-content: center;
    width: calc(50% + 460px);
    min-height: 580px;
    margin-top: 0;
    padding: 30px;
  }
  .menu > .menu_thumb {
    position: relative;
    z-index: 1;
  }
  .menu > .menu_thumb {
    height: 100%;

    object-fit: cover;
  }
}
@media (min-width: 1300px) {
  .menu > .menu_body {
    min-height: 640px;
  }
}
.menu_ttl {
  margin-bottom: 1rem;
  font-weight: 500;
  font-size: clamp(2.2rem, 2.18vw + 1.38rem, 4rem);
  letter-spacing: 4px;
}
.menu_text {
  margin-bottom: 2rem;
  font-size: clamp(1.3rem, .85vw + .98rem, 2rem);
  line-height: 1.7;
}
@media (min-width: 960px) {
  .menu_ttl {
    margin-bottom: 4rem;
  }
  .menu_text {
    margin-bottom: 4rem;
    line-height: 2;
  }
  .menu_bodyInner {
    width: min(95%, 490px);
  }
}
.menu > .menu_thumb{
  z-index: 1;
}
.menu._normal .menu_thumb {
  margin-left: 30px;
}
.menu._reverse .menu_thumb {
  margin-right: 30px;
}
@media (min-width: 960px) {
  .menu._normal .menu_thumb {
    margin-left: 0;
  }
  .menu._reverse .menu_thumb {
    margin-right: 0;
  }
  .menu._normal .menu_body {
    margin-right: -460px;
    padding-right: 460px;
  }
  .menu._reverse .menu_body {
    margin-left: -460px;
    padding-left: 460px;
  }
  .menu._normal .menu_bodyInner {
    margin-right: 12%;
    margin-left: auto;
  }
  .menu._reverse .menu_bodyInner {
    margin-left: 12%;
  }
}

/* NEWS(旬果実ページのみ)
-----------------*/
.newsSection {
  padding-top: 6rem;
  padding-bottom: 6rem;
}
@media (min-width: 769px) {
  .newsSection {
    padding-top: 12rem;
    padding-bottom: 12rem;
  }
}
.newsContainer {
  width: min(1200px, 100% - 60px);
  margin-inline: auto;
}
.newsItem_date {
  font-size: clamp(1.3rem, 1.12vw + .88rem, 2rem);
  color: #333;
}
.newsItem_text {
  margin-top: 10px;
  font-weight: 400;
  font-size: clamp(1.3rem, 1.12vw + .88rem, 2rem);
}
@media (min-width: 769px) {
  .newsItem_text {
    margin-top: 5px;
  }
}

/* SOUP MENU
-----------------*/
.soupMenu {
}
.soupMenu_name {
  font-size: clamp(1.8rem, 2.67vw + 0.8rem, 4rem);
  font-weight: 500;
  letter-spacing: .1em;
  margin-bottom: .6em;
}

.soupMenu p{
  font-size: clamp(1.5rem, 1.09vw + 1.09rem, 2.4rem);
}

.soupMenu .menuItem_price {
  text-align: right;
  font-size: clamp(2rem, 1.21vw + 1.55rem, 3rem);
}
.soupMenu .soupMenu_note {
  margin-top: 1em;
  letter-spacing: 0.5px;
  font-size: clamp(1.3rem, 0.85vw + 0.98rem, 2rem);
}
@media (min-width: 769px) {
  .soupMenu .soupMenu_note {
    margin-top: 2em;
  }
}
.soupContainer {
  width: 100%;
  padding: 3rem;
  background-color: #fff;
}
@media (min-width: 769px) {
  .soupContainer {
    width: min(560px, 48%);
    padding: 4rem;
  }
}
@media (min-width: 960px) {
  .soupContainer {
    padding: 5rem;
  }
}
.soupTtl {
  font-size: clamp(2rem, 1.58vw + 1.41rem, 3.3rem);
  font-weight: 700;
  letter-spacing: .05em;
  text-align: center;
  color: #A31A1A;
  margin-bottom: 1em;
  padding-bottom: .8em;
  border-bottom: 1px solid #A31A1A;
  display: flex;
  justify-content: center;
  align-items: center;
}
.soupTtl span {
  margin-left: .2em;
  font-size: 1.5em;
  font-weight: 400;
  line-height: 1;
}
.soupName {
  margin-top: 1.2em;
  font-size: clamp(1.5rem, 1.09vw + 1.09rem, 2.4rem);
  font-weight: 500;
}
.soupPrice {
  margin-top: 1.1em;
  font-size: clamp(1.4rem, 0.97vw + 1.04rem, 2.2rem);
  font-weight: 500;
  text-align: right;
}
.soupPrice .menuItem_price {
  display: inline;
  font-size: clamp(1.3rem, 0.85vw + 0.98rem, 2rem);
}

.soupContainer--accent {
    background-color: #DBCFCE;
    padding: 0;
}

.soupContainer--accentInner {
    padding:0 5rem 5rem;
}

.soupContainer--accent .soupTtl {
    color: #fff;
    border:none;
    background-color: #A31A1A;
}
.soupContainer--accent .soupTtl {
    padding-top: 3rem;
    padding-right: 3rem;
    padding-left: 3rem;

}
@media (min-width: 960px) {
    .soupContainer--accent .soupTtl {
        padding-top: 5rem;
        padding-right: 5rem;
        padding-left: 5rem;
    }
}
@media (min-width: 769px) {
    .soupContainer--accentInner .soupTtl {
        padding: 4rem 4rem 0;
    }
}

.soupContainer__note {
    color: #A31A1A;
}


/* テイクアウトショップ
-----------------*/
.takeout {
  figure img {
    width: 100%;
    height: auto;
  }
}
.takeout .pageTitle {
  width: min(27%, 237px);
}
.takeout figure div {
  position: relative;
}
.takeout figure div .note {
  position: absolute;
  right: 1em;
  bottom: 0.5em;
  font-size: clamp(1.2rem, 1.018rem + 0.485vw, 1.6rem);
  color: #fff;
}
.takeout figcaption {
  margin-top: 0.8em;
  width: min(1200px, 100%);
  margin-inline: auto;
}

.takeout .pageHero figcaption {
  width: 100%;
}

@media (max-width: 769px) {
.takeout .px-30 {
  padding-left: 30px;
  padding-right: 30px;
}
}

.takeout .note--red {
  color: #A31A1A;
}

.takeout .text-center {
  text-align: center;
}

.takeout .menuItem_name span {
  font-size: 0.7em;
}

.takeout .flex-center {
  display: flex;
  justify-content: center;
  align-items: center;
  width: min(1200px, 100% - 60px);
  margin-inline: auto;
}

@media (min-width: 769px) {
.takeout .menuItemList {
  display: flex!important;
}
}

.takeout .setchoiceContainer  {
  background-color: #fff;
}
.takeout .setchoiceContainer .setchoiceContainer_inner {
  width: 100%;
  padding-left: 5%;
  padding-right: 5%;
}
.takeout .setchoiceContainer .icon-drink {
  width: auto;
  justify-content: start;
}
.takeout .setchoiceContainer .icon-drink span {
  display: inline-block;
  padding: 0.2em 0.8em 0.3em 0.8em;
  line-height: 1;
  border: 1px solid #000;
  border-radius: 0.1em;
}

.takeout .setchoiceContainer .menuItemList {
  flex-wrap: wrap;
  padding: 1.3em 0;
  align-items: flex-start;
  justify-content: space-between;
}
.takeout .setchoiceContainer .menuItemList .menuItemList__footer {
  width: 100%;
  font-size: 1.6rem;
}

@media (max-width: 768.98px) {
.takeout .setchoiceContainer_inner .drink-column2 {
  display: block;
}
}


.w-full {
    width: 100%;
}
.mb_150  {
  margin-bottom: 15rem;
}
.soupMenu_name_detail {
    display: flex;
    align-items: center;
    gap: 3em;
    justify-content: flex-end;
}
.soupMenu_name_detail .menuItem_price {
    flex-shrink: 0;
}
@media (max-width: 768.98px) {
    .soupMenu_name_detail {
        margin-top: 2em;
        flex-direction: column;
        align-items: flex-start;
        gap: 0;
    }
    .menuItem_price {
        width: 100%;
    }
}

.soupMenu_name_detail p{
    font-size: clamp(2rem, 1.21vw + 1.55rem, 3rem);
}

.items-center {
  align-items: center;
}
.gap-x-20  {
    gap: 2em;
}

@media (min-width: 767px) {
    .md\:flex {
        display: flex;
    }
}
.justify-between {
    justify-content: space-between;
}


