/* GoPhoto - Milkbath Detail Styles */

.gp-mb {
  max-width: 780px;
  margin: 0 auto;
  font-family: "Hiragino Sans", "Yu Gothic", sans-serif;
  color: #3a2f24;
  line-height: 1.7;
  padding: 0 1rem;
}

/* ─── ヘッダー ─── */
.gp-mb-head {
  text-align: center;
  padding: 0 0 1.25rem;
  border-bottom: 1px solid #e4d9c0;
  margin-bottom: 1.25rem;
}
.gp-mb-eyebrow {
  font-family: Georgia, serif;
  font-size: 10.5px;
  letter-spacing: .3em;
  color: #be584b;
  margin: 0 0 .3rem;
}
.gp-mb-title {
  font-size: 19px;
  font-weight: 500;
  letter-spacing: .06em;
  margin: 0 0 .3rem;
  color: #2a2018;
}
.gp-mb-sub {
  font-size: 12px;
  color: #8a7560;
  margin: 0;
}

/* ─── セクション ─── */
.gp-mb-section {
  padding: 1rem 0;
  border-bottom: 1px solid #f0e8d8;
}
.gp-mb-section:last-child { border-bottom: none; }

.gp-mb-h {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .12em;
  color: #6b5a48;
  margin: 0 0 .8rem;
  padding-bottom: .35rem;
  position: relative;
  text-align: center;
}
.gp-mb-h::after {
  content: "";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 0;
  width: 20px; height: 1px;
  background: #be584b;
}

.gp-mb-p {
  font-size: 13.5px;
  color: #5a4a38;
  margin: 0 0 .4rem;
  line-height: 1.75;
}
.gp-mb-p:last-child { margin-bottom: 0; }

.gp-mb-note {
  font-size: 12px;
  color: #8a7560;
  margin: .65rem 0 0;
  line-height: 1.7;
}

/* ─── テーブル（料金表） ─── */
.gp-mb-table-wrap {
  border: 1px solid #e4d9c0;
  border-radius: 6px;
  overflow: hidden;
  margin: 0 0 .25rem;
}
.gp-mb-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.gp-mb-table th,
.gp-mb-table td {
  padding: .7rem .9rem;
  text-align: left;
  border-bottom: 1px solid #f0e8d8;
  vertical-align: middle;
  line-height: 1.65;
}
.gp-mb-table thead th {
  background: #faf6ee;
  font-size: 11px;
  font-weight: 600;
  color: #6b5a48;
  letter-spacing: .05em;
}
.gp-mb-table tbody tr:last-child td { border-bottom: none; }
.gp-mb-rowhead {
  background: #faf6ee;
  font-weight: 600;
  font-size: 12px;
  color: #6b5a48;
  text-align: center !important;
  letter-spacing: .03em;
  border-right: 1px solid #f0e8d8;
  width: 5em;
}
.gp-mb-price-cell {
  font-family: Georgia, serif;
  font-weight: 700;
  color: #be584b;
  white-space: nowrap;
  width: 6.5em;
}
.gp-mb-flower {
  font-weight: 600;
  color: #3a2f24;
  width: 12em;
}

/* ─── PREMIUM枠 ─── */
.gp-mb-premium {
  background: #faf6ee;
  border: 1px solid #e4d9c0;
  border-radius: 6px;
  padding: .85rem 1rem .75rem;
  margin-top: 1rem;
}
.gp-mb-premium-label {
  font-size: 11.5px;
  font-weight: 600;
  color: #6b5a48;
  margin: 0 0 .5rem;
  letter-spacing: .06em;
}
.gp-mb-premium-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: .35rem 0;
  border-bottom: 1px dotted #d4c4a8;
  font-size: 13px;
  color: #3a2f24;
}
.gp-mb-premium-row:last-of-type { border-bottom: none; }
.gp-mb-premium-val {
  font-family: Georgia, serif;
  font-weight: 600;
  color: #be584b;
  white-space: nowrap;
}
.gp-mb-premium-note {
  font-size: 11px;
  color: #8a7560;
  margin: .55rem 0 0;
  line-height: 1.6;
  padding-top: .5rem;
  border-top: 1px dotted #d4c4a8;
}

/* ─── 定義リスト ─── */
.gp-mb-dl {
  margin: 0;
  display: grid;
  grid-template-columns: 5em 1fr;
  gap: .25rem .9rem;
}
.gp-mb-dl dt {
  font-size: 11.5px;
  font-weight: 600;
  color: #6b5a48;
  letter-spacing: .06em;
  padding-top: .15rem;
}
.gp-mb-dl dd {
  font-size: 13.5px;
  color: #5a4a38;
  margin: 0 0 .35rem;
  line-height: 1.7;
}
.gp-mb-dl dd:last-of-type { margin-bottom: 0; }

/* ─── 順序リスト ─── */
.gp-mb-ol {
  list-style: none;
  padding: 0;
  margin: 0;
  counter-reset: step;
}
.gp-mb-ol li {
  display: flex;
  align-items: baseline;
  gap: .7rem;
  padding: .4rem 0;
  border-bottom: 1px dotted #e4d9c0;
  font-size: 13.5px;
  color: #3a2f24;
  counter-increment: step;
}
.gp-mb-ol li:last-child { border-bottom: none; }
.gp-mb-ol li::before {
  content: counter(step);
  font-family: Georgia, serif;
  font-size: 12.5px;
  color: #be584b;
  min-width: 1.2em;
}
.gp-mb-time {
  display: inline-block;
  min-width: 3.2em;
  font-family: Georgia, serif;
  font-size: 12px;
  color: #8a7560;
}

/* ─── スマホ：テーブルをカード形式に ─── */
@media (max-width: 600px) {
  .gp-mb { padding: 0 .5rem; }
  .gp-mb-title { font-size: 17px; }

  .gp-mb-table-wrap {
    border: none;
    border-radius: 0;
    overflow: visible;
  }
  .gp-mb-table,
  .gp-mb-table thead,
  .gp-mb-table tbody,
  .gp-mb-table tr,
  .gp-mb-table th,
  .gp-mb-table td {
    display: block;
    width: 100%;
  }
  .gp-mb-table thead { display: none; }
  .gp-mb-table tbody tr {
    background: #fff;
    border: 1px solid #e4d9c0;
    border-radius: 6px;
    padding: .85rem 1rem;
    margin-bottom: .6rem;
  }
  .gp-mb-table tbody tr:last-child { margin-bottom: 0; }
  .gp-mb-table td {
    border: none !important;
    padding: 0;
    width: auto !important;
  }
  .gp-mb-rowhead { display: none !important; }
  .gp-mb-flower {
    font-size: 13px;
    color: #3a2f24;
    margin-bottom: .25rem;
  }
  .gp-mb-price-cell {
    font-size: 15px;
    color: #be584b;
    margin-bottom: .35rem;
  }
  .gp-mb-table tbody tr td:last-child {
    font-size: 12.5px;
    color: #5a4a38;
    line-height: 1.7;
    padding-top: .35rem;
    border-top: 1px dotted #e4d9c0 !important;
    margin-top: .35rem;
  }

  .gp-mb-dl { grid-template-columns: 4.5em 1fr; gap: .2rem .65rem; }
}