:root {
  --bg:#f5efe7; --ink:#3e3324; --line:#e7dfd5;
  --accent:#d8c8ad; --accent-ink:#3e2e1c;
  --glass: rgba(255,255,255,.72);
}
*{box-sizing:border-box}
body{
  margin:0; color:var(--ink); background:var(--bg);
  font-family:system-ui,"Noto Sans JP",sans-serif;
}

/* Hero */
.hero-reserve {
  position: relative;
  height: 70vh;
  min-height: 280px;
  background: url('/assets/img/hero/rsv-hero.webp') center/cover no-repeat;
  display: grid;
  place-items: center;
  color: #fff;
  text-align: center;
  font-family: 'Noto Serif JP', serif;
  overflow: hidden;
}
.hero-reserve::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.14);
}
.hero-content {
  position: relative;
  z-index: 1;
  padding: 0 6%;
}
.hero-content h1 {
  font-family: 'Montserrat', system-ui, 'Noto Sans JP', sans-serif;
  font-weight: 800;
  letter-spacing: .06em;
  font-size: clamp(1.8rem, 4vw, 3rem);
  text-transform: uppercase;
  margin-bottom: 0.5em;
}
.hero-content p {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 500;
  font-size: clamp(1rem, 1.6vw, 1.2rem);
  line-height: 1.9;
  opacity: .95;
}

/* ==========================
   同意ボックスのデザイン改善
   ========================== */
.agree-box {
  background: #fff;
  border: 2px solid var(--line);
  border-radius: 16px;
  padding: 16px 18px;
  box-shadow: 0 4px 18px rgba(0,0,0,.05);
  margin-top: 12px;
}
.agree-title {
  font-weight: 700;
  color: var(--accent-ink);
  font-size: 1rem;
  margin: 0 0 10px;
}
.agree-check {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  cursor: pointer;
  user-select: none;
}
.agree-check input[type="checkbox"] {
  appearance: none;
  width: 28px;
  height: 28px;
  border: 2px solid var(--accent);
  border-radius: 8px;
  background: #fff;
  display: grid;
  place-items: center;
  transition: all 0.2s ease;
  flex-shrink: 0;
}
.agree-check input[type="checkbox"] {
  appearance: none;
  width: 28px;
  height: 28px;
  border: 2px solid var(--accent);
  border-radius: 8px;
  background: #fff;
  display: inline-flex;              /* ← grid から変更 */
  align-items: center;               /* 垂直中央 */
  justify-content: center;           /* 水平中央 */
  transition: all 0.2s ease;
  flex-shrink: 0;
  position: relative;                /* ✓位置調整用 */
}

.agree-check input[type="checkbox"]:hover {
  background: #f5f1ea;
}

.agree-check input[type="checkbox"]:checked {
  background: var(--accent);
  border-color: var(--accent);
}

.agree-check input[type="checkbox"]:checked::after {
  content: "✓";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -52%);  /* ← ズレ補正（縦中央微調整） */
  color: var(--accent-ink);
  font-weight: 800;
  font-size: 1.2rem;
  line-height: 1;
}
/* ==============================
   子どもの年齢入力のレスポンシブ改善
   ============================== */
@media (max-width: 768px) {
  .kids-ages {
    grid-template-columns: repeat(2, 1fr); /* ← 2列に変更 */
    gap: 10px 12px; /* 横も少し余裕を持たせる */
  }

  .kids-ages .item {
    flex-direction: column; /* ラベルと入力を縦並びに */
    align-items: flex-start;
  }

  .kids-ages .item input {
    font-size: 1rem; /* 入力しやすく大きく */
    padding: 0.8rem;
  }

  .kids-ages .item label {
    font-size: 0.9rem;
    color: #7b6b57;
  }
}

@media (max-width: 480px) {
  .kids-ages {
    grid-template-columns: 1fr; /* さらに狭い画面では1列 */
  }
}

@media (max-width:640px){
  .hero-reserve{ height:60vh; }
}
/* ===== 入力UI：フォーカス演出（アクセシブル＆上品） ===== */
input, select, textarea {
  transition: border-color .2s ease, box-shadow .2s ease, background-color .2s ease;
  outline: none; /* キーボード操作には focus-visible を用意 */
}

input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  border-color: color-mix(in srgb, var(--accent) 70%, var(--line));
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 22%, transparent);
  background-color: #fff;
}

.btn:focus-visible,
.lang-btn:focus-visible,
.cal-prev:focus-visible,
.cal-next:focus-visible,
.time:focus-visible,
.course:focus-within {
  outline: none;
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 22%, transparent);
  border-color: color-mix(in srgb, var(--accent) 70%, var(--line));
}

/* チェックボックスにも同じ光（同意ボックス） */
.agree-check input[type="checkbox"]:focus-visible {
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 22%, transparent);
  border-color: color-mix(in srgb, var(--accent) 70%, var(--line));
}
/* 予約確認CTA：初期（無効） */
.btn.confirm-cta{
  width:100%;
  padding:1rem 1.2rem;
  border-radius:16px;
  font-weight:700;
  font-size:1.05rem;
  background:#d8d2ca;      /* 無効時は落ち着いたグレー */
  color:#fff;
  border:none;
  cursor:not-allowed;
  opacity:.65;
  transition:all .25s ease;
  box-shadow:none;
}

/* ========= ここがポイント =========
   disabled が外れたら自動で"点灯"（JSのクラス不要）
*/
.btn.confirm-cta:not([disabled]):not([aria-disabled="true"]) {
  background: linear-gradient(90deg, var(--accent), #bfa16d);
  color:#fff;
  opacity:1;
  cursor:pointer;
  box-shadow: 0 6px 24px rgba(191,161,109,.28);
}

/* hoverで少し強く */
.btn.confirm-cta:not([disabled]):not([aria-disabled="true"]):hover{
  transform: translateY(-1px);
  box-shadow: 0 10px 32px rgba(191,161,109,.38);
}

/* さりげない鼓動アニメ（有効化時のみ） */
@keyframes ctaPulse {
  0%   { box-shadow:0 0 0 0 rgba(191,161,109,.36); }
  70%  { box-shadow:0 0 0 14px rgba(191,161,109,0); }
  100% { box-shadow:0 0 0 0 rgba(191,161,109,0); }
}
.btn.confirm-cta:not([disabled]):not([aria-disabled="true"]):not(:hover){
  animation: ctaPulse 2.2s ease-out infinite;
}

/* アクセシビリティ：動きを減らす設定の人には無効化 */
@media (prefers-reduced-motion: reduce){
  .btn.confirm-cta:not([disabled]):not([aria-disabled="true"]){
    animation:none;
  }
}

/* キーボードフォーカス */
.btn.confirm-cta:not([disabled]):not([aria-disabled="true"]):focus-visible{
  outline:none;
  box-shadow:0 0 0 4px color-mix(in srgb, var(--accent) 28%, transparent), 0 8px 28px rgba(191,161,109,.38);
}


/* Layout */
.reserve .grid{display:grid; grid-template-columns:1fr; gap:22px; margin:22px 0 60px}
.panel{background:#fff; border:1px solid var(--line); border-radius:16px; padding:18px}
.step{font-size:1.05rem; margin:0 0 .6rem}
.block{margin:18px 0}
.two{display:grid; grid-template-columns:1fr 1fr; gap:12px}
.label{display:block; font-size:.9rem; margin-bottom:.35rem; color:#7b6b57}
input,select{width:100%; padding:.65rem .75rem; border:1px solid var(--line); border-radius:12px; background:#fff}

/* 以下（カレンダー〜確認ダイアログ）は既存コードそのまま維持 */

/* Layout */
.reserve .grid{display:grid; grid-template-columns:1fr; gap:22px; margin:22px 0 60px}
.panel{background:#fff; border:1px solid var(--line); border-radius:16px; padding:18px}
.step{font-size:1.05rem; margin:0 0 .6rem}
.block{margin:18px 0}
.two{display:grid; grid-template-columns:1fr 1fr; gap:12px}
.label{display:block; font-size:.9rem; margin-bottom:.35rem; color:#7b6b57}
input,select{width:100%; padding:.65rem .75rem; border:1px solid var(--line); border-radius:12px; background:#fff}

/* Calendar */
.calendar{border:1px solid var(--line); border-radius:14px; overflow:hidden}
.cal-head{display:flex; align-items:center; justify-content:space-between; padding:.4rem .6rem; border-bottom:1px solid var(--line); background:#fff}
.cal-prev,.cal-next{width:34px; height:34px; border-radius:9px; border:1px solid var(--line); background:#fff; cursor:pointer}
.cal-ym{font-weight:800}
.cal-grid{display:grid; grid-template-columns:repeat(7,1fr)}
.dow{padding:.6rem .2rem; text-align:center; font-size:.85rem; color:#7b6b57; background:#faf7f3; border-bottom:1px solid var(--line)}
.day{padding:1rem .2rem; text-align:center; border-bottom:1px solid var(--line); border-right:1px solid var(--line); min-height:60px; position:relative; cursor:pointer; background:#fff}
.day:nth-child(7n){border-right:0}
.day.is-today::after{content:"今日"; position:absolute; top:6px; left:6px; font-size:.7rem; color:#9a8f81}
.day.is-picked{outline:2px solid var(--accent); outline-offset:-2px; background:color-mix(in srgb, var(--accent) 22%, #fff)}
.day[aria-disabled="true"]{color:#b7ab9d; background:#faf7f3; cursor:not-allowed}
.badges{display:flex; gap:4px; justify-content:center; margin-top:.35rem}
.badge{display:inline-block; width:.6rem; height:.6rem; border-radius:50%}
.b-closed{background:#c8b6b6}.b-lunch{background:#7ec8a9}
.legend{padding:.5rem; font-size:.82rem; color:#7b6b57}
.calendar button.is-disabled{ opacity: .35; pointer-events: none;}


/* Times */
.times{display:flex; flex-wrap:wrap; gap:8px}
.time{padding:.55rem .75rem; border:1px solid var(--line); border-radius:10px; background:#fff; cursor:pointer}
.time.is-picked{background:var(--accent); color:var(--accent-ink); border-color:transparent; font-weight:700}
.time[aria-disabled="true"]{opacity:.45; cursor:not-allowed}
.time.is-disabled {opacity: 0.4;pointer-events: none;}
.day.is-disabled,
.time.is-disabled,
label.is-disabled {
  opacity: .4;
  pointer-events: none;
}


/* Kids ages */
.kids-ages{display:grid; grid-template-columns:repeat(4,1fr); gap:8px}
.kids-ages .item{display:flex; gap:6px; align-items:center}
.kids-ages .item input{width:100%}

/* Courses */
.course-cards{display:grid; grid-template-columns:repeat(2,1fr); gap:12px}
.course{display:grid; grid-template-columns:96px 1fr; gap:12px; border:1px solid var(--line); border-radius:12px; padding:10px; cursor:pointer; background:#fff}
.course:hover{box-shadow:0 8px 22px rgba(0,0,0,.06)}
.course input{display:none}
.course img{width:96px; height:72px; object-fit:cover; border-radius:10px}
.course .course-body strong{font-weight:800}
.course:has(input:checked){outline:2px solid var(--accent); outline-offset:2px}
.seat-only{grid-template-columns:72px 1fr}
.seat-only .seat-icon{width:72px; height:72px; border-radius:12px; display:grid; place-items:center; border:1px dashed var(--line); color:#7b6b57}

/* Summary */
.summary h3{margin:.2rem 0 1rem}
.dl{display:grid; gap:10px}
.dl>div{display:flex; gap:10px}
.dl dt{min-width:4em; color:#7b6b57}
.sns{display:flex; gap:10px; margin-top:12px}
.sns-btn{flex:1; text-align:center; padding:.6rem .8rem; border-radius:10px; text-decoration:none; color:#fff}
.sns-btn.ig{background:#d63384}.sns-btn.ln{background:#06c755}
.summary.inline{margin-top:8px}

/* Dialogs */
.confirm {
  border: 0;
  padding: 0;
  background: transparent;
}
.confirm::backdrop {
  background: rgba(0, 0, 0, .45);
}

.confirm-body {
  background: linear-gradient(135deg, #fdf7ef 0%, #fffaf5 50%, #f7eee4 100%);
  backdrop-filter: blur(10px);
  border: 1px solid var(--line);
  border-radius: 20px;
  padding: 22px 20px 20px;
  max-width: 520px;
  margin: auto;
  box-shadow: 0 18px 40px rgba(70, 48, 24, 0.18);
  text-align: center;
}

/* 完了ダイアログ専用 */
.confirm-done .confirm-title {
  margin: 0.4rem 0 0.4rem;
  font-size: 1.15rem;
  letter-spacing: 0.06em;
}

.confirm-done .confirm-sub {
  margin: 0 0 0.8rem;
  font-size: 0.9rem;
  color: #7b6b57;
  line-height: 1.7;
}

/* チェックアイコン */
.confirm-icon {
  width: 56px;
  height: 56px;
  margin: 0 auto 10px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: radial-gradient(circle at 30% 0, #ffe9c7, #f1cfa0);
  color: #5b4023;
  font-size: 1.5rem;
  font-weight: 700;
  box-shadow: 0 10px 22px rgba(125, 92, 57, 0.35);
}

/* 予約番号ボックス */
.done-res-box {
  margin: 8px auto 14px;
  padding: 10px 12px;
  border-radius: 14px;
  background: #f6eee4;
  border: 1px solid #e0d1bc;
}

.done-res-label {
  margin: 0 0 2px;
  font-size: 0.75rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #8a745b;
}

.done-res-no {
  margin: 0;
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  color: #3b2b1a;
}

.done-res-note {
  margin: 4px 0 0;
  font-size: 0.78rem;
  color: #8a7a65;
}

/* SNSボタン横並び */
.done-sns {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 6px;
  flex-wrap: wrap;
}

.done-sns .sns-btn {
  min-width: 150px;
}

/* 閉じるボタン */
.done-close {
  margin-top: 14px;
}

/* ==============================
   コースカードのレスポンシブ最適化
   ============================== */
@media (max-width: 768px) {
  .course-cards {
    grid-template-columns: 1fr; /* 1列表示に */
    gap: 16px;                  /* カード間の余白を少し広げる */
  }

  .course {
    grid-template-columns: 100px 1fr; /* 左の画像をやや大きく */
    padding: 14px;
    border-radius: 14px;
  }

  .course img {
    width: 100px;
    height: 80px;
  }

  .course .course-body {
    font-size: 0.95rem; /* 全体の文字を少し大きく */
    line-height: 1.7;
  }

  .course .course-body strong {
    font-size: 1rem;
  }
}

/* ===== Header (Tailwindなし / index風) ===== */
:root{
  --paper:#f7f3e9;
  --gold:#c5a059;
  --dark:#1a1a1a;
  --border:rgba(120,120,120,.18);
}

body{
  /* 固定ヘッダー分の押し下げ（reserveページの重なり防止） */
  padding-top: 92px;
}
@media (max-width: 1024px){
  body{ padding-top: 86px; }
}

.main-header{
  position: fixed;
  top: 0; left: 0;
  width: 100%;
  z-index: 100;
  padding: 24px 5%;
  background: var(--paper);
  border-bottom: 1px solid var(--border);
  box-shadow: 0 2px 10px rgba(0,0,0,.04);
  transition: padding .7s, background-color .7s, box-shadow .7s;
}
.main-header.compact{
  padding-top: 12px;
  padding-bottom: 12px;
  background: rgba(247,243,233,.95);
  box-shadow: 0 6px 18px rgba(0,0,0,.08);
}

.main-header__inner{
  max-width: 1280px;
  margin: 0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 16px;
}

.main-header__logo{
  font-size: 22px;
  font-weight: 700;
  letter-spacing: .2em;
  text-decoration:none;
  color: var(--dark);
  position: relative;
  z-index: 110;
}

/* PC nav */
.main-nav{
  display:flex;
  align-items:center;
  gap: 40px;
}
.main-nav__link{
  font-size: 12px;
  letter-spacing: .18em;
  text-decoration:none;
  color: var(--dark);
  transition: color .25s;
}
.main-nav__link:hover{ color: var(--gold); }

.main-nav__cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 14px 32px;
  background: var(--dark);
  color:#fff;
  text-decoration:none;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .3em;
  transition: background-color .25s;
}
.main-nav__cta:hover{ background: var(--gold); }

/* Language PC */
.lang-pc{ position: relative; }
.lang-pc__btn{
  font-size: 10px;
  border: 1px solid rgba(0,0,0,.18);
  background: transparent;
  padding: 6px 12px;
  border-radius: 999px;
  display:flex;
  align-items:center;
  gap: 6px;
  cursor:pointer;
}
.lang-pc__btn:hover{ background: rgba(0,0,0,.03); }

.lang-pc__menu{
  position:absolute;
  top: calc(100% + 8px);
  right: 0;
  width: 140px;
  background:#fff;
  border: 1px solid rgba(0,0,0,.08);
  box-shadow: 0 18px 40px rgba(0,0,0,.12);
  padding: 8px 0;
  opacity:0;
  visibility:hidden;
  transform: translateY(10px);
  transition: .35s;
}
.lang-pc:hover .lang-pc__menu{
  opacity:1; visibility:visible; transform: translateY(0);
}
.lang-pc__menu .lang-item{
  width:100%;
  background: transparent;
  border:0;
  text-align:left;
  font-size: 10px;
  padding: 10px 14px;
  cursor:pointer;
}
.lang-pc__menu .lang-item:hover{
  background: rgba(0,0,0,.03);
  color: var(--gold);
}

/* Mobile controls */
.lang-sp{ display:none; position:relative; z-index:110; }
.mobile-toggle{
  display:none;
  border:0;
  background: transparent;
  padding: 8px;
  cursor:pointer;
  position: relative;
  z-index: 110;
}

.hamburger{ display:flex; flex-direction:column; gap: 6px; }
.hamburger__line{
  width: 24px;
  height: 2px;
  background: var(--dark);
  display:block;
  transition: transform .25s, opacity .25s;
}

/* Drawer */
.mobile-drawer{
  position: fixed;
  inset: 0;
  background: var(--paper);
  z-index: 105;
  transform: translateX(100%);
  transition: transform .5s;
  overflow-y:auto;
}
.mobile-drawer.is-open{ transform: translateX(0); }

.mobile-drawer__inner{
  padding: 120px 40px 80px;
}
.mobile-drawer__block{
  border-bottom: 1px solid rgba(0,0,0,.12);
  padding-bottom: 40px;
}
.mobile-drawer__list{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap: 26px; }
.mobile-drawer__row{ display:flex; align-items:center; gap: 18px; }
.mobile-drawer__home{
  font-size: 42px;
  font-weight: 800;
  letter-spacing: -.02em;
  text-decoration:none;
  color: var(--dark);
}
.mobile-drawer__sns{ display:flex; align-items:center; gap: 14px; opacity:.8; }
.mobile-drawer__sns img{ display:block; }

.mobile-drawer__link{
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-size: 22px;
  font-weight: 700;
  letter-spacing: .12em;
  text-decoration:none;
  color: var(--dark);
}
.mobile-drawer__link span{ color: var(--gold); font-size: 12px; }

.mobile-drawer__cta{ padding-top: 24px; }
.mobile-drawer__ctaBtn{
  display:block;
  width:100%;
  background: var(--dark);
  color:#fff;
  text-decoration:none;
  text-align:center;
  padding: 18px 16px;
  font-weight: 800;
  letter-spacing: .4em;
  transition: background-color .25s;
}
.mobile-drawer__ctaBtn:hover{ background: var(--gold); }

/* Mobile Language menu */
.lang-sp__btn{
  font-size: 10px;
  border: 1px solid rgba(0,0,0,.18);
  background: #fff;
  padding: 6px 12px;
  border-radius: 999px;
  display:flex;
  align-items:center;
  gap: 6px;
  cursor:pointer;
}
.lang-sp__menu{
  position:absolute;
  top: calc(100% + 8px);
  left: 0;
  width: 180px;
  background:#fff;
  border: 1px solid rgba(0,0,0,.08);
  box-shadow: 0 18px 40px rgba(0,0,0,.12);
  padding: 8px 0;
  display:none;
}
.lang-sp__menu.is-open{ display:block; }
.lang-sp__menu .lang-item{
  width:100%;
  background: transparent;
  border:0;
  text-align:left;
  font-size: 10px;
  padding: 10px 14px;
  cursor:pointer;
}
.lang-sp__menu .lang-item:hover{
  background: rgba(0,0,0,.03);
  color: var(--gold);
}

/* breakpoint */
@media (max-width: 1024px){
  .main-nav{ display:none; }
  .lang-sp{ display:block; }
  .mobile-toggle{ display:block; }
  .mobile-drawer__inner{ padding-left: 32px; padding-right: 32px; }
}

/* ===== Font (indexと完全一致) ===== */
body{
  font-family:
    "Noto Sans JP",
    -apple-system,
    BlinkMacSystemFont,
    "Hiragino Kaku Gothic ProN",
    "Hiragino Sans",
    "Yu Gothic",
    "Meiryo",
    sans-serif;

  font-weight: 400;
  letter-spacing: 0.04em;
  color: #1a1a1a;
}

.notice{
  margin: 10px 0;
  font-size: 12px;
  line-height: 1.6;
  color: #7b6b57;
}
.notice-strong{
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(255,255,255,.65);
  border: 1px solid rgba(231,223,213,.9);
}
/* ===== Calendar badges improve ===== */
.cal-grid .day {
  position: relative;
}

/* バッジを“文字あり”にする（今は丸だけっぽいので） */
.cal-grid .day .badges {
  position: absolute;
  left: 8px;
  bottom: 6px;
  display: flex;
  gap: 6px;
  align-items: center;
  pointer-events: none;
}

.cal-grid .day .badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 18px;
  min-width: 18px;
  padding: 0 6px;
  border-radius: 999px;
  font-size: 11px;
  line-height: 1;
  font-weight: 600;
  border: 1px solid rgba(0,0,0,.18);
  background: rgba(255,255,255,.92);
  color: rgba(0,0,0,.78);
}

/* 休 */
.cal-grid .day .badge.b-closed::after { content: "休"; }
.cal-grid .day.is-disabled .badge.b-closed {
  background: rgba(240,240,240,.95);
  color: rgba(0,0,0,.45);
}

/* 昼のみ */
.cal-grid .day .badge.b-lunch::after { content: "昼"; }

/* 夜のみ（reserve.jsで b-night を出す前提） */
.cal-grid .day .badge.b-night::after { content: "夜"; }

/* overrideがある日を枠で示す（JSで class 付与する） */
.cal-grid .day.is-override {
  outline: 2px solid rgba(0,0,0,.45);
  outline-offset: -2px;
  border-radius: 10px; /* 角丸に合わせて調整 */
}

/* overrideの角マーク（より気づきやすい） */
.cal-grid .day.is-override::before {
  content: "";
  position: absolute;
  top: 6px;
  left: 6px;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: rgba(0,0,0,.55);
  opacity: .55;
}

/* 休みの日はセル全体も“休”感 */
.cal-grid .day.is-disabled {
  opacity: .55;
}
/* ==============================
   iPhone / Mobile fix (Modal + Card form)
   ============================== */

/* iOS Safari: フォーム入力で勝手にズーム→レイアウトが揺れるのを防ぐ */
@media (max-width: 640px) {
  input, select, textarea {
    font-size: 16px; /* 重要: iOSの自動ズーム抑止 */
  }

  /* カード入力の2列が窮屈なので1列に落とす */
  .two {
    grid-template-columns: 1fr;
  }
}

/* dialog（確認モーダル）を「画面中央固定」にして、ぐにゃぐにゃを止める */
.confirm[open]{
  position: fixed;
  inset: 0;
  margin: 0;
  padding: 16px;
  display: grid;
  place-items: center;
  width: 100%;
  max-width: none;
  background: transparent;
}

/* モーダル本体：高さ上限 + 中身スクロールで“切れ”を防ぐ */
.confirm-body{
  width: min(92vw, 520px);
  max-height: calc(100svh - 32px); /* iOSのアドレスバー変動に強い */
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  padding-bottom: max(20px, env(safe-area-inset-bottom));
}

/* 古いiOS対策（svh未対応の保険） */
@supports not (height: 100svh) {
  .confirm-body{ max-height: calc(100vh - 32px); }
}
/* ==============================
   Confirm Modal Typography tuning
   ============================== */

/* タイトルは少しだけ締める */
.confirm-body h3{
  font-size: 20px;
  letter-spacing: .03em;
  margin-bottom: 16px;
}

/* 項目全体の余白を少し詰める */
.confirm-grid{
  row-gap: 10px;
}

/* 左側ラベル */
.confirm-grid dt{
  font-size: 13px;
  color: #8b7d6b;
  letter-spacing: .05em;
}

/* 右側値 */
.confirm-grid dd{
  font-size: 15px;
  line-height: 1.6;
}

/* 長文（キャンセル説明）を少しコンパクトに */
.confirm-body .note,
.confirm-body .cancel-text{
  font-size: 13px;
  line-height: 1.6;
  color: #6f6252;
}

/* ボタン余白調整 */
.confirm-actions{
  margin-top: 20px;
}

/* =========================================================
   Meat multi picker (ランチ席のみ 任意)
========================================================= */
.meatPick{
  margin-top:14px;
}
.meatPick-label{
  font-size:13px;
  color:#6f6252;
  margin:10px 0 8px;
}
.meatPick-note{
  font-size:12px;
  color:#8a7a68;
  margin-top:8px;
}

.meatMulti{
  border:1px solid rgba(120,100,80,.22);
  border-radius:12px;
  background:#fff;
  overflow:hidden;
}
.meatMulti-summary{
  list-style:none;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:12px 14px;
  cursor:pointer;
}
.meatMulti-summary::-webkit-details-marker{ display:none; }
.meatMulti-summaryText{
  font-size:14px;
  color:#3e3324;
  line-height:1.4;
}
.meatMulti-caret{ opacity:.75; }

.meatMulti-panel{
  padding:12px 14px 14px;
  border-top:1px dashed rgba(120,100,80,.22);
}

.meatRows{ display:grid; gap:10px; }

.meatRow{
  display:grid;
  /* iOS Safari で <select> がタップ不能になる重なりを防ぐため、列幅を固定 */
  grid-template-columns: 1fr 96px 40px;
  gap:10px;
  align-items:center;
}

/* Gridアイテムがはみ出して重なるのを防ぐ */
.meatRow > *{ min-width:0; }

.meatSel,
.meatQty{
  width:100%;
  padding:10px 12px;
  border:1px solid rgba(120,100,80,.25);
  border-radius:12px;
  background:#fff;
  font-size:14px;
}

.meatQty{ width:96px; text-align:center; }

.meatDelBtn{
  width:40px;
  height:40px;
  border-radius:12px;
  border:1px solid rgba(120,100,80,.25);
  background:#fff;
  font-size:18px;
  line-height:1;
}

.meatAddBtn{
  width:100%;
  margin-top:12px;
  padding:12px 14px;
  border-radius:12px;
  border:1px dashed rgba(120,100,80,.35);
  background:rgba(255,255,255,.75);
  font-size:14px;
}

@media (max-width:480px){
  .meatRow{ grid-template-columns: 1fr 96px 40px; }
  .meatQty{ width:96px; }
}
.done-phone-label{
  margin-top: 14px;
  font-size: 12px;
  color: #8b7b67;
}

.done-phone-no{
  margin-top: 4px;
}

.done-phone-no a{
  display: inline-block;
  font-size: 20px;
  font-weight: 700;
  color: #3e3324;
  text-decoration: none;
}

.done-phone-no a:hover{
  opacity: .8;
}