/* ke'o ke'o 管理画面 — スタイル（請求管理システムと統一：Noto Sans JP / ネイビー基調 / 左サイドバー） */
:root{
  --ink:#1a1e23; --ink-2:#3b424a; --muted:#5b646e; --line:#d6dae0;
  --blue:#1f3864; --blue-hover:#152844; --teal:#388B8B;
  --red:#c0392b; --red-bg:#fbe3df; --red-row:#fdeeec;
  --green:#1e7a3c; --green-bg:#e2f1e6;
  --panel-bg:#f5f7fa; --card:#fff; --bg:#fff;
  --chip:#e3e8f0; --paid:#e2f1e6; --unpaid:#fbe3df;
  --barbg:#4b5563;
}
*{box-sizing:border-box;margin:0;padding:0;}
html,body{height:100%;}
body{font-family:"Meiryo UI","Meiryo","Segoe UI","Yu Gothic UI","Hiragino Sans",sans-serif;
  background:var(--bg);color:var(--ink);font-size:15px;line-height:1.7;-webkit-font-smoothing:antialiased;font-synthesis:none;}
button{font-family:inherit;cursor:pointer;}
a{color:var(--blue);}
option{color:#000;}

/* ===== ログイン ===== */
.login-wrap{max-width:380px;margin:12vh auto;padding:0 16px;}
.login-card{background:var(--card);border:1px solid #c7cdd6;border-radius:12px;padding:30px 28px;box-shadow:0 1px 3px rgba(31,56,100,.10);}
.login-card h1{font-size:18px;font-weight:600;text-align:center;color:var(--blue);margin:0 0 4px;}
.login-card p{text-align:center;color:var(--muted);font-size:13px;font-weight:600;margin:0 0 20px;}
.login-card label{display:block;font-size:13px;font-weight:500;color:var(--ink-2);margin:12px 0 4px;}
.login-card input{width:100%;padding:10px 12px;border:1px solid #c7cdd6;border-radius:8px;font:inherit;color:#000;}
.login-card input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(31,56,100,.12);}
.login-card button{width:100%;margin-top:18px;padding:11px;border:none;border-radius:8px;background:var(--blue);color:#fff;font-weight:500;font-size:14px;}
.login-card button:hover{background:var(--blue-hover);}
.login-err{color:var(--red);font-size:13px;font-weight:500;margin-top:12px;min-height:1.2em;text-align:center;}

/* ===== アプリシェル（全体は固定・右コンテンツだけ内側スクロール） ===== */
#app{height:100vh;display:flex;flex-direction:column;overflow:hidden;}

/* ===== ヘッダ ===== */
header.bar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;
  padding:12px 24px;background:var(--barbg);box-shadow:0 1px 3px rgba(0,0,0,.12);flex:0 0 auto;z-index:60;}
header.bar h1{font-size:18px;font-weight:600;letter-spacing:.01em;color:#fff;margin:0;}
header.bar .who{color:#dfe3e8;font-size:12.5px;font-weight:400;margin-right:12px;}
header.bar #logout{background:rgba(255,255,255,.14);color:#fff;border:1px solid rgba(255,255,255,.5);border-radius:8px;padding:5px 14px;font-size:12.5px;font-weight:500;}
header.bar #logout:hover{background:rgba(255,255,255,.26);}

/* ===== 左右レイアウト（左サイドバー＋右コンテンツ） ===== */
.layout{display:flex;gap:22px;align-items:stretch;padding:0 32px;flex:1 1 auto;min-height:0;}
.tabs{flex:0 0 190px;width:190px;display:flex;flex-direction:column;gap:2px;
  border-right:1px solid var(--line);padding:16px 10px 16px 0;overflow-y:auto;}
.tabs button{background:transparent;color:#2b3440;border:none;border-left:3px solid transparent;border-radius:0 7px 7px 0;
  padding:11px 14px;font-size:15px;font-weight:600;text-align:left;width:100%;}
.tabs button:hover{background:#f0f3f8;}
.tabs button.active{border-left-color:var(--blue);background:#eef4fc;color:var(--blue);}
.content{flex:1 1 auto;min-width:0;overflow-y:auto;padding-bottom:40px;}
main{max-width:1500px;margin:16px 0 0;}

/* ===== サマリーカード ===== */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;margin:0 0 14px;}
.scard{background:var(--card);border:1px solid #c7cdd6;border-radius:10px;padding:8px 14px;box-shadow:0 1px 3px rgba(31,56,100,.10);
  display:flex;flex-direction:column;justify-content:center;gap:2px;min-height:58px;}
.scard .num{font-size:21px;font-weight:600;line-height:1.15;text-align:right;color:var(--blue);font-variant-numeric:tabular-nums;}
.scard .label{font-size:12px;color:var(--ink-2);font-weight:500;order:-1;}
.scard.need .num{color:var(--red);}
.scard.ok .num{color:var(--green);}

/* ===== ツールバー ===== */
.toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:14px;}
.toolbar select{padding:7px 10px;border:1px solid #c7cdd6;border-radius:7px;font:inherit;background:#fff;color:#000;font-weight:500;font-size:12.5px;}
.toolbar button{background:var(--blue);color:#fff;border:0;border-radius:7px;padding:7px 14px;font-size:12.5px;font-weight:500;}
.toolbar button:hover{background:var(--blue-hover);}
.toolbar .count{margin-left:auto;color:var(--muted);font-size:12.5px;font-weight:500;}

/* ===== 受注カード ===== */
.order{background:var(--card);border:1px solid #c7cdd6;border-radius:10px;margin-bottom:10px;overflow:hidden;box-shadow:0 1px 3px rgba(31,56,100,.08);}
.order-head{display:flex;align-items:center;gap:12px;padding:11px 14px;cursor:pointer;flex-wrap:wrap;}
.order-head .name{font-weight:600;color:var(--ink);}
.order-head .date{color:var(--muted);font-size:12.5px;font-weight:600;}
.chip{font-size:12px;font-weight:500;padding:3px 9px;border-radius:999px;background:var(--chip);color:#3b5a86;}
.chip.line{background:#e2f1e6;color:#1e7a3c;}
.chip.email{background:#e3e8f0;color:#3b5a86;}
.status-sel{padding:5px 8px;border:1px solid #c7cdd6;border-radius:7px;font:inherit;font-size:12px;font-weight:500;background:#fff;color:#000;}
.paid-toggle{display:flex;align-items:center;gap:5px;font-size:12px;font-weight:500;padding:4px 11px;border-radius:999px;border:1px solid var(--line);white-space:nowrap;}
.paid-toggle.paid{background:var(--paid);color:var(--green);border-color:#bfe3cd;}
.paid-toggle.unpaid{background:var(--unpaid);color:var(--red);border-color:#f1cabd;}
.paid-toggle input{width:15px;height:15px;cursor:pointer;}
.due{font-size:12px;color:var(--muted);font-weight:600;}
.due.over{color:var(--red);font-weight:600;}
.spacer{flex:1;}
.caret{color:var(--muted);transition:transform .15s;}
.order.open .caret{transform:rotate(90deg);}
.order-body{display:none;border-top:1px solid var(--line);padding:14px;background:var(--panel-bg);}
.order.open .order-body{display:block;}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px 18px;}
.f{font-size:13px;}
.f .k{color:var(--muted);font-size:12px;font-weight:500;display:block;}
.f .v{color:var(--ink);font-weight:600;white-space:pre-wrap;word-break:break-word;}
.imgs{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px;}
.imgs a{width:84px;height:84px;border-radius:8px;overflow:hidden;border:1px solid var(--line);display:block;}
.imgs img{width:100%;height:100%;object-fit:cover;}

/* ===== 定員カレンダー ===== */
.cap-bar{background:none;border:none;border-radius:0;padding:0 0 14px;margin-bottom:14px;max-width:500px;border-bottom:1px solid var(--line);}
.capcal-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.capcal-nav button{border:1px solid #c7cdd6;background:#fff;border-radius:7px;padding:6px 12px;font-weight:500;color:#000;}
.capcal-nav button:hover{background:#eef4fc;}
.capcal-title{font-weight:600;color:var(--blue);}
.cap-apply{display:flex;gap:10px;flex-wrap:wrap;align-items:center;}
.cap-apply label{font-size:12.5px;color:var(--ink-2);font-weight:500;}
.cap-apply select{margin-left:4px;padding:6px 8px;border:1px solid #c7cdd6;border-radius:7px;font:inherit;background:#fff;color:#000;font-weight:500;}
.cap-apply button{padding:8px 14px;border:0;border-radius:7px;background:var(--blue);color:#fff;font-weight:500;font-size:12.5px;}
.cap-apply button:hover{background:var(--blue-hover);}
.cap-apply button.ghost{background:#fff;color:#000;border:1px solid var(--blue);font-weight:500;}
.cap-apply button.ghost:hover{background:#eef4fc;}
.cap-selcount{font-size:12.5px;color:var(--blue);font-weight:600;}
.cap-hint{font-size:12px;color:var(--muted);font-weight:600;margin:10px 0 0;}
.capcal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;max-width:500px;}
.cap-cell{aspect-ratio:1/1;border-radius:7px;border:1.5px solid var(--line);background:#fff;
  display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;position:relative;}
.cap-cell.empty{background:transparent;border:none;cursor:default;}
.cap-cell .cap-day{font-size:1.1rem;font-weight:600;color:var(--ink);line-height:1.05;}
.cap-cell .cap-info{font-size:.64rem;margin-top:1px;}
.cap-cell .cap-sub{font-size:.56rem;color:var(--muted);line-height:1;}
.cap-cell.c-open{background:var(--green-bg);border-color:#bfe3cd;}
.cap-cell.c-open .cap-info{color:var(--green);font-weight:600;}
.cap-cell.c-closed{background:#eef1f6;color:var(--muted);}
.cap-cell.c-none{background:#fff;}
.cap-cell.c-none .cap-sub{color:#aab3c0;}
.cap-cell.c-sel{outline:3px solid var(--blue);outline-offset:-1px;border-color:var(--blue);}
.cap-dow{text-align:center;font-size:.9rem;color:var(--ink-2);font-weight:600;padding:4px 0;}
.capcal-grid .cap-dow:nth-child(1){color:#c0392b;}
.capcal-grid .cap-dow:nth-child(7){color:#2d5aa6;}
.cap-legend2{display:flex;gap:14px;flex-wrap:wrap;font-size:.76rem;color:var(--muted);font-weight:600;margin-top:12px;}
.cap-legend2 span::before{content:"";display:inline-block;width:12px;height:12px;border-radius:3px;margin-right:5px;vertical-align:-2px;}
.lg2-open::before{background:var(--green-bg);border:1px solid #bfe3cd;}
.lg2-closed::before{background:#eef1f6;border:1px solid var(--line);}
.lg2-none::before{background:#fff;border:1px solid var(--line);}
.lg2-sel::before{background:#fff;outline:2px solid var(--blue);}

/* ===== 受付設定（パネル） ===== */
.cap-add{display:flex;gap:10px;flex-wrap:wrap;align-items:end;background:none;
  border:none;border-radius:0;padding:0 0 16px;margin-bottom:16px;border-bottom:1px solid var(--line);}
.cap-add label{font-size:12.5px;color:var(--ink-2);font-weight:500;display:block;}
.cap-add input,.cap-add select{display:block;padding:8px 10px;border:1px solid #c7cdd6;border-radius:7px;font:inherit;color:#000;margin-top:3px;}
.cap-add button{padding:9px 18px;border:0;border-radius:7px;background:var(--blue);color:#fff;font-weight:500;}
.cap-add button:hover{background:var(--blue-hover);}
.radio-row{display:flex;gap:10px;}

/* ===== オーダー予約設定（統一デザイン） ===== */
.step-title{margin:0 0 12px;}
#view-capacity .cap-hint{font-size:13.5px;}
#view-capacity .capcal-title{font-size:16px;}
#view-capacity .cap-apply label{font-size:14px;}
#view-capacity .cap-apply select{font-size:14px;}
.rcp-card{background:#fff;border:1px solid #e0e5ec;border-radius:12px;padding:20px 22px;max-width:620px;}
.rcp-line{display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-size:15px;}
.rcp-line input[type=date]{padding:8px 10px;border:1px solid #cfd6df;border-radius:8px;font:inherit;color:#000;}
.rcp-label{flex:0 0 76px;font-weight:600;color:var(--ink);}
.rcp-unit{color:var(--muted);font-size:13.5px;}
.rcp-radio{display:inline-flex;align-items:center;gap:8px;font-size:16px;font-weight:600;color:var(--ink);
  border:1.5px solid var(--line);border-radius:10px;padding:10px 22px;cursor:pointer;transition:.12s;}
.rcp-radio:has(input:checked){border-color:var(--blue);background:#eef4fc;color:var(--blue);}
.rcp-radio input{width:18px;height:18px;cursor:pointer;}

/* ===== フォーム編集 / ホームページ編集（共通デザイン） ===== */
.ft-wrap{background:none;border:none;border-radius:0;padding:0;max-width:1300px;margin-bottom:18px;}
.ft-row{display:flex;flex-direction:column;gap:6px;padding:11px 0;border-top:1px solid #eef1f5;}
.ft-row:first-child{border-top:none;padding-top:0;}
.ft-row label{font-size:14px;font-weight:600;color:var(--ink);}
.ft-row label.accent{border-left:3px solid var(--blue);padding-left:9px;}
.ft-row .ft-desc{font-size:12.5px;color:var(--muted);font-weight:400;}
.ft-row input,.ft-row textarea{width:100%;padding:9px 12px;border:1px solid #cfd6df;border-radius:8px;font:inherit;color:#000;background:#fff;transition:border-color .15s,box-shadow .15s;}
.ft-row input:focus,.ft-row textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(31,56,100,.10);}
.ft-row textarea{min-height:120px;resize:vertical;line-height:1.7;}

/* アコーディオン見出し（ホームページ／受付フォーム 共通・大きめ・青線なし） */
/* 見出し帯（ホームページ編集・受付フォーム編集・オーダー予約設定 で共通） */
.hp-h,.step-title{font-size:16px;font-weight:700;color:#2b3440;
  padding:13px 18px;background:#eef1f6;border:1px solid #e0e5ec;border-radius:10px;}
.hp-h{display:flex;align-items:center;justify-content:space-between;cursor:pointer;user-select:none;margin:0;transition:background .15s;}
.hp-h:hover{background:#e5eaf2;}
.sec-caret{font-size:17px;color:#5b6470;transition:transform .2s;margin-left:12px;line-height:1;font-weight:700;}
.ft-wrap.closed .sec-caret{transform:rotate(-90deg);}
.ft-wrap.closed .sec-body{display:none;}
.sec-body{padding:16px 6px 4px;}

/* 横幅を広く */
#view-homepage .hp-cols,#view-formtext .hp-cols{max-width:1400px;}
.sec2{display:flex;gap:32px;align-items:flex-start;flex-wrap:wrap;}
.sec2 .col-l{flex:1 1 460px;min-width:0;}
.sec2 .col-r{flex:0 0 auto;}
@media(max-width:820px){.sec2 .col-l,.sec2 .col-r{flex:1 1 100%;}}
.hpf .ft-row textarea,.sec2 .ft-row textarea{min-height:150px;}
.media2{display:flex;gap:30px;flex-wrap:wrap;}

/* ボタン共通 */
#hp-save,#ft-save,#course-add,#cookie-add,#news-add,#rcp-save{background:var(--blue);color:#fff;border:0;border-radius:8px;padding:11px 26px;font-weight:600;font-size:14px;cursor:pointer;transition:background .15s;}
#hp-save:hover:not(:disabled),#ft-save:hover:not(:disabled),#course-add:hover,#cookie-add:hover,#news-add:hover,#rcp-save:hover{background:var(--blue-hover);}
#hp-save:disabled,#ft-save:disabled{background:#cbd2db;color:#eef1f6;cursor:not-allowed;}

/* 注意書き（1行ごと） */
.notes-rows{display:flex;flex-direction:column;gap:10px;}
.notes-row{display:flex;gap:10px;align-items:center;}
.notes-row input{flex:1 1 auto;padding:9px 12px;border:1px solid #cfd6df;border-radius:8px;font:inherit;color:#000;background:#fff;}
.notes-del{flex:0 0 auto;width:34px;height:34px;background:#fff;color:var(--red);border:1px solid #f1cabd;border-radius:8px;font-size:16px;cursor:pointer;}
.notes-add{background:#fff;color:var(--blue);border:1px solid var(--blue);border-radius:8px;padding:8px 18px;font-weight:600;font-size:13px;align-self:flex-start;margin-top:4px;cursor:pointer;}

/* ドロップ枠（全項目 統一サイズ・左寄せ） */
.dz-wrap{display:flex;flex-direction:column;align-items:flex-start;gap:14px;}
.dz-wrap.side{flex-direction:row;align-items:flex-start;}
.dz{width:240px;min-height:110px;box-sizing:border-box;border:1.6px dashed #b8c0cc;border-radius:10px;
  padding:16px 14px;text-align:center;cursor:pointer;background:#f7f9fb;color:var(--muted);font-size:12.5px;
  display:flex;flex-direction:column;justify-content:center;gap:6px;transition:.15s;}
.dz:hover{border-color:var(--blue);background:#eef4fc;}
.dz.drag{border-color:var(--blue);background:#e2ecfb;color:var(--blue);}
.dz-note{font-size:12px;color:var(--blue);word-break:break-all;}
.dz-prev{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-start;}
.dz-prev:empty{display:none;}

/* サムネイル（画像・動画 共通／削除ボタンは右下） */
.thumb{position:relative;width:150px;border-radius:10px;overflow:hidden;background:#eef1f5;line-height:0;box-shadow:0 1px 3px rgba(0,0,0,.10);}
.thumb.big{width:220px;}
.thumb img,.thumb video{width:100%;height:auto;display:block;}
.thumb-del{position:absolute;right:7px;bottom:7px;width:28px;height:28px;border:none;border-radius:50%;
  background:rgba(20,24,30,.6);color:#fff;font-size:16px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;}
.thumb-del:hover{background:var(--red);}

#news-admin-list .ft-wrap{background:#fff;border:1px solid #e0e5ec;border-radius:12px;padding:18px 20px;margin-bottom:14px;max-width:820px;}
.news-save{background:var(--blue);color:#fff;border:0;border-radius:8px;padding:9px 20px;font-weight:600;font-size:13px;cursor:pointer;}
.news-del{background:#fff;color:var(--red);border:1px solid #f1cabd;border-radius:8px;padding:9px 18px;font-weight:600;font-size:13px;cursor:pointer;}

/* ===== トースト ===== */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--blue);color:#fff;
  padding:11px 20px;border-radius:9px;font-size:13px;font-weight:500;opacity:0;transition:opacity .2s;pointer-events:none;z-index:200;box-shadow:0 6px 20px rgba(0,0,0,.2);}
.toast.show{opacity:1;}
.empty{text-align:center;color:var(--muted);font-weight:600;padding:40px 0;}
.hidden{display:none!important;}

@media (max-width:760px){
  /* スマホは通常スクロールに戻す（アプリシェルを解除） */
  #app{height:auto;overflow:visible;}
  .layout{flex-direction:column;padding:0 14px 40px;overflow:visible;}
  .tabs{flex:0 0 auto;width:auto;flex-direction:row;flex-wrap:wrap;border-right:none;border-bottom:1px solid var(--line);padding:8px 0;overflow:visible;}
  .tabs button{width:auto;border-left:none;border-radius:7px;}
  .tabs button.active{border-left:none;}
  .content{overflow:visible;}
  header.bar{padding:10px 14px;}
}
