/* =========================================================
   Ciel Dinner Menu Page
   Ciel v2
========================================================= */

/* =========================================================
   Page Layout
========================================================= */

.p-dinner-menu {
  background: var(--ciel-white);
  color: var(--ciel-ink);
}

.p-dinner-menu__article {
  display: grid;
  gap: 56px;
  min-width: 0;
}

/* =========================================================
   Menu Book
========================================================= */

.p-dinner-menu-book {
  display: grid;
  gap: 46px;
  padding: clamp(30px, 5vw, 56px);
  background: rgba(255, 255, 255, .78);
  border: 1px solid var(--ciel-line);
}

.p-dinner-menu-section {
  display: grid;
  gap: 22px;
}

.p-dinner-menu-section__header {
  position: relative;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(138, 99, 56, .24);
}

.p-dinner-menu-section__title {
  margin: 0;
  color: var(--ciel-wood);
  font-size: clamp(1.25rem, 2.3vw, 1.85rem);
  font-weight: 600;
  line-height: 1.4;
  letter-spacing: .12em;
}

.p-dinner-menu-list {
  display: grid;
  gap: 18px;
}

.p-dinner-menu-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 18px 28px;
  padding-bottom: 18px;
  border-bottom: 1px dashed rgba(138, 99, 56, .22);
}

.p-dinner-menu-item:last-child {
  padding-bottom: 0;
  border-bottom: 0;
}

.p-dinner-menu-item__body {
  min-width: 0;
}

.p-dinner-menu-item__title {
  margin: 0;
  color: var(--ciel-ink);
  font-size: 1.02rem;
  font-weight: 600;
  line-height: 1.65;
  letter-spacing: .045em;
}

.p-dinner-menu-item__subtitle {
  margin: 3px 0 0;
  color: var(--ciel-muted);
  font-size: .82rem;
  line-height: 1.6;
  letter-spacing: .08em;
}

.p-dinner-menu-item__description {
  margin: 10px 0 0;
  color: var(--ciel-muted);
  font-size: .88rem;
  line-height: 1.85;
  letter-spacing: .035em;
}

.p-dinner-menu-item__price {
  justify-self: end;
  padding-top: 2px;
  color: var(--ciel-wood);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1.02rem;
  font-style: italic;
  line-height: 1.5;
  text-align: right;
  white-space: nowrap;
}

.p-dinner-menu-empty {
  margin: 0;
  padding: 28px;
  border: 1px dashed rgba(138, 99, 56, .32);
  color: var(--ciel-muted);
  font-size: .9rem;
  line-height: 1.8;
  text-align: center;
}

/* =========================================================
   Responsive
========================================================= */

@media screen and (max-width: 720px) {
  .p-dinner-menu__article {
    gap: 42px;
  }

  .p-dinner-menu-book {
    gap: 38px;
    padding: 30px 22px;
  }

  .p-dinner-menu-item {
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 8px 16px;
  }

  .p-dinner-menu-item__price {
    justify-self: end;
    padding-top: 0;
    text-align: right;
  }

  .p-dinner-menu-item__description {
    grid-column: 1 / -1;
  }
}
