/* RESTO-PAAN PWA — RestoTheme 準拠のスタイル */
:root{
  --blue:#1A2E5C; --blueDeep:#0F1F40; --blueSoft:#F5F7FB; --blueTint:#E8ECF5;
  --ink:#4A4A4A; --inkDeep:#2B2B2B;           /* 旧goldを黒墨に */
  --bg:#FAFAFA; --bgSoft:#F0F0F0; --surface:#FFFFFF;
  --border:#D4D4D4; --borderSubtle:#E5E5E5;
  --text:#1A1A1A; --textMute:#4A4A4A; --textSoft:#707070; --textFaint:#B0B0B0;
  --danger:#C8102E; --warning:#8B6F1A; --live:#1B7A3D;
  --radius-s:10px; --radius-m:14px; --radius-l:18px;
  --tabbar-h:64px;
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html,body{height:100%;}
body{
  background:var(--bg); color:var(--text);
  font-family:-apple-system,"Hiragino Sans","Noto Sans JP",system-ui,sans-serif;
  font-size:16px; line-height:1.5; overscroll-behavior-y:none;
}
button{font-family:inherit;cursor:pointer;}
input,textarea,select{font-family:inherit;font-size:16px;}
.hidden{display:none !important;}

/* レイアウト */
#app{min-height:100%;}
.screen{max-width:560px;margin:0 auto;padding:0 16px calc(var(--tabbar-h) + 24px);}
.screen.no-tabbar{padding-bottom:24px;}
.appbar{position:sticky;top:0;z-index:20;background:rgba(250,250,250,.92);backdrop-filter:blur(10px);
  display:flex;align-items:center;gap:8px;padding:12px 16px;max-width:560px;margin:0 auto;border-bottom:1px solid var(--borderSubtle);}
.appbar .title{font-size:17px;font-weight:700;flex:1;text-align:center;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.appbar .iconbtn{width:36px;height:36px;border:none;background:none;color:var(--blue);display:flex;align-items:center;justify-content:center;border-radius:50%;}
.appbar .tbtn{border:none;background:none;color:var(--blue);font-size:15px;font-weight:600;padding:6px 4px;}
.appbar .appbar-pill{flex:none;border:1px solid var(--borderSubtle);border-radius:999px;padding:5px 11px;font-size:12px;font-weight:700;color:var(--blue);background:var(--surface);white-space:nowrap;}
.h1{font-size:30px;font-weight:800;margin:14px 2px 4px;}
.eyebrow{font-size:14px;font-weight:500;color:var(--textMute);margin:20px 2px 8px;}
.muted{color:var(--textSoft);}
.center{text-align:center;color:var(--textSoft);padding:48px 16px;}

/* アイコン */
.icon{width:22px;height:22px;display:inline-block;vertical-align:middle;flex:none;}

/* カード */
.card{background:var(--surface);border:1px solid var(--borderSubtle);border-radius:var(--radius-m);padding:16px;margin-bottom:10px;}
.row-card{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--borderSubtle);
  border-radius:var(--radius-m);padding:14px 16px;margin-bottom:10px;width:100%;text-align:left;color:inherit;}
.row-card .chev{margin-left:auto;color:var(--textFaint);}
.tile{width:44px;height:44px;border-radius:10px;background:var(--blueTint);display:flex;align-items:center;justify-content:center;color:var(--blue);flex:none;}

/* ボタン */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:var(--radius-m);
  font-size:16px;font-weight:600;padding:0 18px;height:52px;width:100%;}
.btn-primary{background:var(--blue);color:#fff;}
.btn-primary:disabled{background:#9aa6c2;}
.btn-soft{background:var(--blueSoft);color:var(--blue);border:1px solid rgba(26,46,92,.25);}
.btn-danger-soft{background:rgba(200,16,46,.08);color:var(--danger);border:1px solid rgba(200,16,46,.25);}
.btn-ghost{background:none;color:var(--blue);}
.btn-sm{height:40px;font-size:14px;padding:0 14px;width:auto;}

/* 入力 */
.field{width:100%;border:1px solid var(--border);border-radius:var(--radius-m);padding:13px 14px;background:var(--surface);}
.field:focus{outline:none;border-color:var(--blue);}
.label{font-size:13px;color:var(--textMute);margin:14px 2px 6px;font-weight:600;}
textarea.field{min-height:84px;resize:vertical;line-height:1.6;}

/* バッジ・ピル */
.pill{font-size:12px;color:var(--textMute);background:var(--bgSoft);border-radius:999px;padding:3px 10px;}
.badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;padding:3px 8px;border-radius:999px;}
.badge.live{color:var(--live);background:rgba(27,122,61,.12);}
.badge.muted{color:var(--textSoft);background:var(--bgSoft);}
.badge.translating{color:var(--warning);background:rgba(139,111,26,.12);}  /* 翻訳中 amber */
.badge.failed{color:var(--danger);background:rgba(200,16,46,.10);}        /* 翻訳失敗 red */
.badge.pending{color:var(--warning);background:rgba(139,111,26,.12);}   /* 翻訳作業中 amber */
.badge.ready{color:#7A5E12;background:rgba(122,94,18,.14);}            /* 翻訳済み・未掲載 濃い金 (薄い金は読みにくい) */
.badge.untranslated{color:#7A808A;background:rgba(122,128,138,.12);}    /* 翻訳未実施 slate */
.dot{width:7px;height:7px;border-radius:50%;display:inline-block;}
.dot.live{background:var(--live);}
.dot.muted{background:var(--textFaint);}
.blink{animation:blink 1s ease-in-out infinite;}
@keyframes blink{50%{opacity:.25;}}

/* メニュー詳細の料理行 */
.dish{padding:14px 2px;border-bottom:1px solid var(--borderSubtle);}
.dish:last-child{border-bottom:none;}
.dish .dtop{display:flex;gap:10px;align-items:baseline;}
.dish .dname{font-size:16px;font-weight:600;flex:1;}
.dish .dprice{font-size:15px;font-weight:700;color:var(--inkDeep);white-space:nowrap;}
.dish .ddesc{font-size:13px;color:var(--textSoft);margin-top:4px;}
.dish .dthumb{width:72px;height:54px;border-radius:10px;object-fit:cover;border:1px solid var(--border);float:left;margin-right:10px;}
.dish .dalg{font-size:11px;font-weight:600;color:var(--warning);margin-top:5px;}

/* 掲載バナー */
.banner{display:flex;gap:10px;align-items:flex-start;border-radius:var(--radius-l);padding:16px;margin:8px 0 4px;}
.banner.live{background:rgba(27,122,61,.10);border:1px solid rgba(27,122,61,.3);}
.banner.live .ttl{color:var(--live);font-weight:700;}
.banner .sub{font-size:13px;color:var(--textMute);margin-top:2px;}

/* 下部タブバー */
.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:30;background:rgba(255,255,255,.96);backdrop-filter:blur(10px);
  border-top:1px solid var(--borderSubtle);padding-bottom:env(safe-area-inset-bottom);}
.tabbar-in{max-width:560px;margin:0 auto;display:flex;align-items:flex-end;justify-content:space-around;height:var(--tabbar-h);}
.tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;border:none;background:none;color:var(--textFaint);font-size:11px;font-weight:600;padding:8px 0;}
.tab.active{color:var(--blue);}
.tab.cta{flex:1;}
.tab.cta .cta-c{width:50px;height:50px;border-radius:50%;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;margin-bottom:-6px;box-shadow:0 4px 12px rgba(26,46,92,.35);}

/* シート / モーダル */
.sheet-bg{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:50;display:flex;align-items:center;justify-content:center;padding:20px;}
.sheet{background:var(--surface);border-radius:18px;width:100%;max-width:560px;margin:0 auto;padding:18px 16px;max-height:90vh;overflow:auto;}
.sheet h3{font-size:17px;font-weight:700;margin-bottom:12px;}
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:60;display:flex;align-items:center;justify-content:center;padding:24px;}
.modal{background:var(--surface);border-radius:var(--radius-l);width:100%;max-width:420px;padding:20px;}

/* トースト */
.toast{position:fixed;left:50%;bottom:calc(var(--tabbar-h) + 20px);transform:translateX(-50%);z-index:80;
  background:var(--inkDeep);color:#fff;padding:12px 18px;border-radius:999px;font-size:14px;font-weight:600;
  box-shadow:0 6px 20px rgba(0,0,0,.25);opacity:0;transition:opacity .25s, transform .25s;pointer-events:none;}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
.toast.success{background:var(--live);}   /* 翻訳完了トースト=緑 */

/* スピナー */
.spinner{width:22px;height:22px;border:2.5px solid var(--blueTint);border-top-color:var(--blue);border-radius:50%;animation:spin .8s linear infinite;display:inline-block;vertical-align:middle;}
.spinner.white{border-color:rgba(255,255,255,.4);border-top-color:#fff;}
@keyframes spin{to{transform:rotate(360deg);}}
.loading-full{display:flex;align-items:center;justify-content:center;min-height:60vh;}

/* ログイン */
.auth-top{position:sticky;top:0;z-index:20;background:rgba(250,250,250,.92);backdrop-filter:blur(10px);
  display:flex;align-items:center;justify-content:space-between;gap:8px;padding:12px 16px;border-bottom:1px solid var(--borderSubtle);}
.auth-top .mark{display:flex;align-items:center;gap:8px;color:var(--blue);font-weight:800;font-size:15px;letter-spacing:.5px;text-decoration:none;}
.auth-top .mark img{width:26px;height:26px;display:block;}
.auth-top .to-top{display:inline-flex;align-items:center;gap:5px;color:var(--blue);font-size:13px;font-weight:600;text-decoration:none;padding:6px 4px;}
.auth{max-width:420px;margin:0 auto;padding:24px 24px 48px;display:flex;flex-direction:column;}
.auth .ios-note{text-align:center;font-size:12px;color:var(--textSoft);margin-top:18px;}
/* 新規登録CTAカード (iOS 踏襲) */
.signup-cta{display:flex;align-items:center;gap:14px;width:100%;text-align:left;background:var(--blue);border:none;border-radius:var(--radius-l);padding:18px 18px;color:#fff;cursor:pointer;margin-bottom:18px;}
.signup-cta .sc-ic{flex:none;width:40px;height:40px;border-radius:12px;background:rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;}
.signup-cta .sc-ic .icon{width:22px;height:22px;}
.signup-cta .sc-t{flex:1;min-width:0;}
.signup-cta .sc-h{display:block;font-weight:700;font-size:17px;}
.signup-cta .sc-s{display:block;font-size:12.5px;color:rgba(255,255,255,.82);margin-top:2px;}
/* できることカード */
.feat-card{background:var(--blueSoft);border-radius:var(--radius-l);padding:18px 18px 14px;margin-bottom:22px;}
.feat-card .fc-title{font-size:17px;font-weight:700;color:var(--inkDeep);}
.feat-card .fc-byline{font-size:12.5px;color:var(--textSoft);margin:2px 0 12px;}
.feat-card .fc-row{display:flex;align-items:center;gap:12px;padding:6px 0;font-size:13.5px;font-weight:500;color:var(--text);}
.feat-card .fc-row .icon{width:20px;height:20px;flex:none;color:var(--blue);}
.feat-card .fc-foot{margin-top:12px;padding-top:10px;border-top:1px solid var(--blueTint);font-size:12.5px;font-weight:600;color:var(--blue);line-height:1.6;}
/* パスワード表示トグル */
.pw-wrap{position:relative;}
.pw-eye{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:34px;height:34px;border:none;background:none;display:flex;align-items:center;justify-content:center;color:var(--textFaint);cursor:pointer;}
.pw-eye.on{color:var(--blue);}
.err{color:var(--danger);font-size:13px;margin-top:10px;}

/* 閲覧の下部バー (店員/会計/食事制限) — pvRoot のflex列で常時最下部に固定表示 */
.pv-bottombar{flex:none;background:var(--surface);border-top:1px solid var(--borderSubtle);padding:10px 12px calc(10px + env(safe-area-inset-bottom));}
.pv-bb-in{display:flex;gap:8px;max-width:560px;margin:0 auto;}
.pv-bottombar .pv-bb{flex:1;height:46px;font-size:13px;padding:0 6px;gap:5px;}
.pv-bottombar .pv-bb .icon{width:17px;height:17px;}
.pv-bottombar .pv-bb.pv-bb-on{background:var(--blue);color:#fff;}
/* 価格の概算換算 */
.dish .dconv{display:block;font-size:11px;color:var(--textFaint);margin-top:1px;}
/* 目次 (Contents) */
.toc-row{display:flex;align-items:center;gap:10px;width:100%;text-align:left;background:none;border:none;color:inherit;padding:12px 0;border-bottom:1px solid var(--borderSubtle);}
.toc-row:last-child{border-bottom:none;}
/* フローティング「注文を店員に見せる」バー */
.pv-orderbar{flex:none;display:flex;align-items:center;justify-content:space-between;gap:12px;width:calc(100% - 24px);margin:0 12px 8px;border:none;border-radius:14px;background:var(--blue);color:#fff;padding:14px 18px;font-size:15px;box-shadow:0 6px 18px rgba(26,46,92,.3);}
.pv-orderbar .icon{width:18px;height:18px;}
.pv-orderbar .ob-count{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 6px;border-radius:999px;background:rgba(255,255,255,.25);font-size:13px;font-weight:700;}
.pv-orderbar .ob-total{font-weight:800;white-space:nowrap;}
/* お会計 / 注文票 */
.ck-item2{display:flex;align-items:flex-start;gap:12px;padding:11px 0;border-bottom:1px solid var(--borderSubtle);}
.ck-item2:last-child{border-bottom:none;}
.ck-item2 .ck-q{flex:none;color:var(--blue);font-weight:700;font-size:15px;min-width:30px;}
.ck-item2 .ck-nm{flex:1;min-width:0;}
.ck-item2 .ck-nm .o{display:block;font-weight:600;font-size:15px;}
.ck-item2 .ck-nm .t{display:block;font-size:12px;color:var(--textSoft);margin-top:1px;}
.ck-item2 .ck-p{flex:none;font-weight:600;font-size:14px;white-space:nowrap;}
.ck-sum{background:var(--blueSoft);border-radius:var(--radius-m);padding:12px 14px;margin-top:14px;}
.ck-note{background:var(--bgSoft);border-radius:var(--radius-m);padding:12px 14px;margin-top:12px;font-size:12px;color:var(--textMute);line-height:1.6;}
/* 閲覧の料理行: 左に名前/原文/説明、 右に価格+数量ステッパー(縦積み) */
.dish.dish-row{display:flex;gap:12px;align-items:flex-start;}
.dish.dish-row .dmain{flex:1;min-width:0;}
.dish.dish-row .dname{display:block;}
.dish.dish-row .dorig{margin-top:1px;}
.dish.dish-row .ddesc{margin-top:5px;}
.dish .dright{flex:none;display:flex;flex-direction:column;align-items:flex-end;gap:8px;}
.dish .dstepper{display:inline-flex;align-items:center;gap:1px;border:1px solid var(--border);border-radius:999px;overflow:hidden;}
.dish .dstepper.on{border-color:var(--blue);}
.dish .dstepper button{border:none;background:none;width:28px;height:26px;font-size:15px;color:var(--blue);line-height:1;padding:0;}
.dish .dstepper .q{min-width:22px;text-align:center;font-weight:700;font-size:13px;}
/* 閲覧プレビューはヘッダー・本文とも全幅を使う (中央寄せの余白を作らない) */
/* flex列の子に margin:0 auto があると内容幅に縮んで中央寄せになるため、 全幅に上書き */
#pvRoot .appbar{max-width:none;width:100%;margin:0;}
#pvRoot .screen{max-width:none;width:100%;margin:0;}
/* 料理画像の拡大 */
.img-zoom{position:fixed;inset:0;z-index:90;background:rgba(0,0,0,.85);display:flex;align-items:center;justify-content:center;padding:20px;cursor:zoom-out;}
.img-zoom img{max-width:100%;max-height:100%;border-radius:12px;}
/* 店員フレーズ */
.phrase-card{display:flex;align-items:center;gap:10px;width:100%;text-align:left;background:var(--surface);border:1px solid var(--borderSubtle);border-radius:var(--radius-m);padding:11px 14px;margin-bottom:8px;color:inherit;}
.phrase-zoom{position:fixed;inset:0;z-index:90;background:var(--bg);display:flex;align-items:center;justify-content:center;padding:28px;cursor:pointer;overflow:auto;}
.phrase-zoom .pz-in{display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;}
.phrase-zoom .pz-store{font-size:34px;font-weight:800;line-height:1.4;color:var(--text);}
.phrase-zoom .pz-pron{font-size:14px;color:var(--textSoft);}
.phrase-zoom .pz-client{font-size:15px;color:var(--textMute);margin-top:6px;}

/* 印刷シート: デザインカード */
.print-card{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;gap:5px;background:var(--surface);border:1px solid var(--borderSubtle);border-radius:var(--radius-m);padding:10px 6px;color:inherit;}
.print-card.sel{border-color:var(--blue);box-shadow:0 0 0 1px var(--blue);}
.print-card .pc-prev{display:flex;align-items:center;justify-content:center;width:100%;height:48px;border-radius:6px;font-size:12px;font-weight:700;}
.print-card .pc-name{font-size:13px;font-weight:700;}
.print-card .pc-desc{font-size:10px;color:var(--textSoft);text-align:center;line-height:1.3;}
/* 印刷シート: 言語ボタン */
.print-lang{display:flex;align-items:center;gap:7px;border:1px solid var(--border);border-radius:var(--radius-m);background:var(--surface);height:46px;padding:0 10px;font-size:13px;font-weight:600;color:var(--text);}
.print-lang .pl-check{display:none;flex:none;color:var(--blue);}
.print-lang .pl-check .icon{width:16px;height:16px;}
.print-lang.sel{border-color:var(--blue);background:var(--blueSoft);}
.print-lang.sel .pl-check{display:flex;}

/* メニュー詳細の下部固定アクションバー (外国語を見る / 掲載・解除) */
.fixed-actionbar{position:fixed;left:0;right:0;bottom:0;z-index:30;background:rgba(250,250,250,.96);backdrop-filter:blur(10px);border-top:1px solid var(--borderSubtle);padding:10px 16px calc(10px + env(safe-area-inset-bottom));}
.fab-in{display:flex;gap:10px;max-width:560px;margin:0 auto;}

/* ドラッグ並び替え */
.drag-handle{color:var(--textFaint);}
.dish.dragging{opacity:.6;background:var(--blueSoft);border-radius:10px;}
.edit-list{}

/* ジャンル選択チップ */
.genre-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:2px;}
.gchip{border:1px solid var(--border);border-radius:999px;padding:8px 14px;background:var(--surface);font-size:14px;font-weight:600;color:var(--text);}
.gchip.sel{border-color:var(--blue);background:var(--blueSoft);color:var(--blue);}

/* 新規翻訳の3ステップガイド */
.step-guide{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin:6px 2px 14px;font-size:12px;color:var(--textFaint);}
.step-guide .sg{display:inline-flex;align-items:center;gap:5px;font-weight:600;}
.step-guide .sg b{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;border:1.5px solid var(--textFaint);font-size:11px;}
.step-guide .sg.on{color:var(--blue);}
.step-guide .sg.on b{border-color:var(--blue);background:var(--blue);color:#fff;}
.step-guide .sg-arr{color:var(--textFaint);}

/* 表示設定の選択トグル */
.seg-opt.on{border-color:var(--blue) !important;background:var(--blueSoft) !important;color:var(--blue) !important;}

/* セグメント */
.seg{display:inline-flex;background:var(--bgSoft);border-radius:999px;padding:3px;gap:2px;}
.seg button{border:none;background:none;padding:7px 14px;border-radius:999px;font-size:14px;font-weight:600;color:var(--textMute);}
.seg button.sel{background:var(--surface);color:var(--blue);box-shadow:0 1px 3px rgba(0,0,0,.12);}

/* 言語チップ */
.lchip{color:var(--text);}
.lchip.sel{border-color:var(--blue) !important;background:var(--blueSoft) !important;color:var(--blue) !important;}

/* ステッパー */
.stepper{display:inline-flex;align-items:center;border:1px solid var(--border);border-radius:999px;overflow:hidden;}
.stepper button{border:none;background:none;width:34px;height:32px;font-size:18px;color:var(--blue);}
.stepper .q{min-width:30px;text-align:center;font-weight:700;}

/* リスト分割線 */
.divlist > *{border-bottom:1px solid var(--borderSubtle);}
.divlist > *:last-child{border-bottom:none;}

/* 進捗バー */
.progress{height:8px;background:var(--bgSoft);border-radius:999px;overflow:hidden;}
.progress > i{display:block;height:100%;background:var(--blue);border-radius:999px;transition:width .4s;}

/* ============================================================
   デスクトップ / PC 対応
   iOS は縦長前提だが Web版はオーナーがPCから管理する場合がある。
   560px固定を段階的に緩め、 広い画面で窮屈に見えないようにする。
   ============================================================ */
@media (min-width:768px){
  .screen{max-width:720px;}
  .appbar, .tabbar-in, .sheet{max-width:720px;}
  .h1{font-size:34px;}
  /* PCでは下部固定タブを中央のバー状に */
  .tabbar{border-top:1px solid var(--borderSubtle);}
  /* ホームのスタッツや一覧が広がるように */
}
@media (min-width:1024px){
  .screen{max-width:840px;}
  .appbar, .tabbar-in, .sheet{max-width:840px;}
}
/* マウス環境ではホバーで微フィードバック (タッチには付けない) */
@media (hover:hover) and (pointer:fine){
  .row-card{transition:border-color .15s, background .15s;}
  .row-card:hover{border-color:var(--blue);background:var(--blueSoft);}
  .btn{transition:filter .15s;}
  .btn:hover{filter:brightness(.96);}
}
