/* ===== Merchant Schedule — 公開デザインシステム =====
   暖色(オレンジ＋クリーム)が主役、紺は差し色。
   見出しは細め(500-600)・字間広め・上品に。太ポップは禁止。 */

:root{
  --orange:#D85A30;     --orange-d:#bf4a24;   --orange-soft:#f4dcc8;
  --navy:#23314D;       --navy-soft:#41506e;
  --bg:#F7EFE2;         --card:#FFFDF9;       --cream:#FFF6E9;
  --line:#EADCC6;       --line-2:#f0e6d4;
  --ink:#33291d;        --muted:#8c7d68;
  --maru:#2e7d52;       --maru-bg:#e3f3ea;
  --sankaku:#c79100;    --sankaku-bg:#fbf1d4;
  --batsu:#c5573f;      --batsu-bg:#f6e2da;
  --blank:#c9bca6;
  --shadow:0 1px 2px rgba(90,60,20,.05), 0 8px 30px rgba(120,80,30,.07);
  --radius:16px;
  --maxw:880px;
  --font: -apple-system, BlinkMacSystemFont, "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic", "Noto Sans JP", Meiryo, sans-serif;
  --serif: "Hiragino Mincho ProN", "Yu Mincho", "Noto Serif JP", serif;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--font);
  color:var(--ink);
  background:
    radial-gradient(1100px 460px at 82% -8%, #fff3e0 0%, rgba(255,243,224,0) 60%),
    radial-gradient(900px 400px at -5% 8%, #fbe7d2 0%, rgba(251,231,210,0) 55%),
    var(--bg);
  background-attachment:fixed;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
}

/* ---------- ヘッダ / フッタ ---------- */
.site-head{
  display:flex; align-items:center; justify-content:space-between;
  gap:16px; padding:14px 22px;
  max-width:1100px; margin:0 auto;
}
.brand{display:flex; align-items:center; gap:10px; text-decoration:none; color:var(--navy)}
.brand-mark{display:flex}
.brand-name{font-size:18px; font-weight:600; letter-spacing:.04em}
.brand-name em{font-style:normal; color:var(--orange); font-weight:600}
.head-new{
  text-decoration:none; color:var(--orange-d); font-weight:600; font-size:14px;
  border:1px solid var(--orange-soft); background:var(--card);
  padding:8px 14px; border-radius:999px; transition:.15s;
}
.head-new:hover{background:var(--cream); border-color:var(--orange)}
.site-foot{
  text-align:center; color:var(--muted); font-size:12.5px;
  padding:36px 20px 48px; letter-spacing:.03em;
}
.site-foot span{color:var(--navy); font-weight:600}

.wrap{max-width:var(--maxw); margin:0 auto; padding:10px 18px 20px}

/* ---------- 共通要素 ---------- */
h1,h2,h3{font-weight:500; letter-spacing:.05em; color:var(--navy); line-height:1.5}
.loading{display:flex; justify-content:center; padding:80px 0}
.spinner{width:34px; height:34px; border-radius:50%;
  border:3px solid var(--orange-soft); border-top-color:var(--orange);
  animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

.card{
  background:var(--card); border:1px solid var(--line);
  border-radius:var(--radius); box-shadow:var(--shadow);
  padding:26px 24px; margin:0 0 18px;
}
.card.tight{padding:18px}

label{display:block; font-size:13.5px; color:var(--navy); font-weight:600; margin:0 0 6px; letter-spacing:.02em}
.hint{font-size:12.5px; color:var(--muted); margin:4px 0 0; line-height:1.6}
.field{margin:0 0 18px}

input[type=text], input[type=password], input[type=email], input[type=date],
input[type=time], input[type=datetime-local], textarea, select{
  width:100%; font-family:inherit; font-size:15px; color:var(--ink);
  background:#fff; border:1px solid var(--line);
  border-radius:11px; padding:11px 13px; transition:.15s;
}
textarea{resize:vertical; min-height:80px; line-height:1.7}
input:focus, textarea:focus, select:focus{
  outline:none; border-color:var(--orange); box-shadow:0 0 0 3px var(--orange-soft);
}

.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  font-family:inherit; font-size:15px; font-weight:600; letter-spacing:.03em;
  border:none; border-radius:12px; padding:13px 22px; cursor:pointer;
  background:var(--orange); color:#fff; transition:.15s; box-shadow:0 6px 16px rgba(216,90,48,.22);
}
.btn:hover{background:var(--orange-d); transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn:disabled{opacity:.5; cursor:not-allowed; transform:none}
.btn.lg{padding:15px 30px; font-size:16px; border-radius:14px}
.btn.ghost{background:#fff; color:var(--navy); border:1px solid var(--line); box-shadow:none}
.btn.ghost:hover{background:var(--cream); border-color:var(--orange-soft)}
.btn.navy{background:var(--navy); box-shadow:0 6px 16px rgba(35,49,77,.2)}
.btn.navy:hover{background:var(--navy-soft)}
.btn.danger{background:#fff; color:var(--batsu); border:1px solid #e9ccc2; box-shadow:none}
.btn.danger:hover{background:var(--batsu-bg)}
.btn.sm{padding:8px 14px; font-size:13px; border-radius:10px}
.btn-row{display:flex; gap:10px; flex-wrap:wrap; align-items:center}

.badge{display:inline-flex; align-items:center; gap:5px; font-size:12px; font-weight:600;
  padding:4px 11px; border-radius:999px; letter-spacing:.03em}
.badge.warn{background:var(--batsu-bg); color:var(--batsu)}
.badge.ok{background:var(--maru-bg); color:var(--maru)}
.badge.info{background:var(--cream); color:var(--orange-d); border:1px solid var(--orange-soft)}

/* ---------- 作成LP ---------- */
.hero{ text-align:center; padding:18px 6px 6px }
.hero h1{font-size:27px; margin:0 0 12px; font-weight:500; letter-spacing:.07em; line-height:1.5}
.hero h1 .accent{color:var(--orange); font-weight:600}
.hero p{color:var(--navy-soft); font-size:15px; margin:0 auto; max-width:520px}
.hero .pills{display:flex; gap:8px; justify-content:center; flex-wrap:wrap; margin:16px 0 4px}
.pill{font-size:12.5px; color:var(--navy); background:var(--card); border:1px solid var(--line);
  padding:6px 12px; border-radius:999px}
.pill b{color:var(--orange-d); font-weight:600}

/* 候補日の行 */
.cand-row{display:flex; gap:8px; align-items:center; margin:0 0 9px}
.cand-row .c-date{flex:0 0 auto; width:170px}
.cand-row .c-time{flex:1 1 auto}
.cand-row .c-free{flex:1 1 auto}
.cand-row .c-del{flex:0 0 auto; width:38px; height:42px; border-radius:10px; border:1px solid var(--line);
  background:#fff; color:var(--muted); cursor:pointer; font-size:17px; transition:.15s}
.cand-row .c-del:hover{background:var(--batsu-bg); color:var(--batsu); border-color:#e9ccc2}
@media(max-width:560px){
  .cand-row{flex-wrap:wrap}
  .cand-row .c-date{flex:1 1 auto; width:auto; min-width:0}
  .cand-row .c-time{flex:1 1 100%; width:100%; order:3}
  .cand-row .c-free{flex:1 1 auto; width:auto; min-width:0}
}
.add-link{display:inline-flex; align-items:center; gap:6px; color:var(--orange-d);
  background:none; border:1px dashed var(--orange-soft); border-radius:10px;
  padding:9px 14px; font-size:13.5px; font-weight:600; cursor:pointer; transition:.15s}
.add-link:hover{background:var(--cream)}
.seg{display:flex; gap:6px; margin:2px 0 0}
.seg button{flex:1; padding:7px 8px; border:1px solid var(--line); background:#fff; color:var(--muted);
  border-radius:9px; font-size:12.5px; cursor:pointer; font-weight:600; transition:.15s}
.seg button.on{background:var(--cream); border-color:var(--orange); color:var(--orange-d)}

/* 出欠モード選択カード */
.mode-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:10px}
@media(max-width:560px){.mode-grid{grid-template-columns:1fr}}
.mode-opt{border:1.5px solid var(--line); border-radius:13px; padding:14px 12px; cursor:pointer;
  background:#fff; text-align:center; transition:.15s}
.mode-opt:hover{border-color:var(--orange-soft); background:var(--cream)}
.mode-opt.on{border-color:var(--orange); background:var(--cream); box-shadow:0 0 0 3px var(--orange-soft)}
.mode-opt .syms{font-size:22px; letter-spacing:.12em; margin-bottom:4px}
.mode-opt .syms .m{color:var(--maru)} .mode-opt .syms .s{color:var(--sankaku)}
.mode-opt .syms .b{color:var(--batsu)} .mode-opt .syms .n{color:var(--blank)}
.mode-opt .nm{font-size:12.5px; color:var(--navy); font-weight:600}
.purpose-opt{text-align:left; padding:15px 16px}
.purpose-opt .nm{font-weight:600; display:flex; align-items:center; gap:6px}
.p-desc{font-size:12px; color:var(--muted); line-height:1.6; margin-top:5px; font-weight:500}
.purpose-opt.on .p-desc{color:var(--navy-soft)}

/* テーマカラーのスウォッチ */
.swatch-row{display:flex; gap:9px; flex-wrap:wrap}
.swatch{width:34px; height:34px; border-radius:50%; border:2px solid #fff; cursor:pointer; padding:0;
  box-shadow:0 0 0 1px var(--line); transition:.12s}
.swatch:hover{transform:scale(1.08)}
.swatch.on{box-shadow:0 0 0 2px #fff, 0 0 0 4px var(--navy)}

/* 説明リッチエディタ */
.rich-wrap{border:1px solid var(--line); border-radius:11px; overflow:hidden; background:#fff}
.rich-toolbar{display:flex; align-items:center; gap:8px; padding:7px 9px; background:var(--cream); border-bottom:1px solid var(--line)}
.rich-btn{width:30px; height:28px; border:1px solid var(--line); background:#fff; border-radius:7px; cursor:pointer; font-size:14px; color:var(--navy)}
.rich-btn:hover{background:#fff}
.rich-sep{width:1px; height:18px; background:var(--line)}
.rich-label{font-size:12px; color:var(--muted)}
.rich-colors{display:flex; gap:5px}
.rich-color{width:20px; height:20px; border-radius:50%; border:1px solid rgba(0,0,0,.12); cursor:pointer; padding:0}
.rich-color:hover{transform:scale(1.12)}
.rich-editor{min-height:84px; padding:11px 13px; font-size:15px; line-height:1.7; color:var(--ink); outline:none}
.rich-editor:empty::before{content:attr(data-ph); color:#b8a98f}
.rich-editor:focus{box-shadow:inset 0 0 0 2px var(--orange-soft)}

/* 折りたたみ詳細 */
.disclosure{margin:6px 0 4px}
.disclosure>summary{cursor:pointer; list-style:none; color:var(--orange-d); font-weight:600;
  font-size:14px; padding:10px 0; display:flex; align-items:center; gap:8px}
.disclosure>summary::-webkit-details-marker{display:none}
.disclosure>summary .chev{transition:.2s; color:var(--muted)}
.disclosure[open]>summary .chev{transform:rotate(90deg)}
.disclosure .inner{padding:8px 2px 2px; border-top:1px solid var(--line-2); margin-top:2px}

/* 画像アップロード */
.uploads{display:flex; gap:9px; flex-wrap:wrap; margin:8px 0 0}
.up-thumb{position:relative; width:78px; height:78px; border-radius:10px; overflow:hidden; border:1px solid var(--line)}
.up-thumb img{width:100%; height:100%; object-fit:cover; display:block}
.up-thumb button{position:absolute; top:3px; right:3px; width:20px; height:20px; border-radius:50%;
  border:none; background:rgba(0,0,0,.55); color:#fff; cursor:pointer; font-size:12px; line-height:1}
.up-add{width:78px; height:78px; border-radius:10px; border:1.5px dashed var(--orange-soft);
  background:var(--cream); color:var(--orange-d); cursor:pointer; font-size:24px; display:flex;
  align-items:center; justify-content:center}

/* ---------- 作成完了 ---------- */
.done-urls .url-box{background:var(--cream); border:1px solid var(--orange-soft); border-radius:12px;
  padding:14px 15px; margin:0 0 14px}
.done-urls .url-box .ttl{font-size:12.5px; color:var(--orange-d); font-weight:600; margin-bottom:7px; display:flex; align-items:center; gap:6px}
.done-urls .url-line{display:flex; gap:8px}
.done-urls input{background:#fff; font-size:13px}
.warn-note{font-size:12.5px; color:var(--batsu); background:var(--batsu-bg); border-radius:10px; padding:10px 13px; margin-top:4px}

/* ---------- 参加ページ ---------- */
.ev-title{font-size:24px; margin:0 0 6px; font-weight:500; letter-spacing:.06em}
.ev-desc{color:var(--navy-soft); white-space:pre-wrap; margin:8px 0 0; font-size:14.5px}
.ev-meta{display:flex; gap:8px; flex-wrap:wrap; align-items:center; margin:12px 0 0}

.media-wrap{margin:16px 0 0}
.media-video{position:relative; padding-top:56.25%; border-radius:13px; overflow:hidden; border:1px solid var(--line); background:#000}
.media-video iframe{position:absolute; inset:0; width:100%; height:100%; border:0}
.media-gallery{display:grid; grid-template-columns:repeat(auto-fill,minmax(130px,1fr)); gap:10px; margin-top:12px}
.media-gallery img{width:100%; aspect-ratio:4/3; object-fit:cover; border-radius:11px; border:1px solid var(--line); cursor:zoom-in}

/* 結果グリッド */
.grid-scroll{overflow:auto; border:1px solid var(--line); border-radius:14px; background:var(--card); -webkit-overflow-scrolling:touch}
table.grid{border-collapse:separate; border-spacing:0; width:100%; min-width:max-content}
table.grid th, table.grid td{padding:9px 12px; text-align:center; font-size:14px; white-space:nowrap;
  border-bottom:1px solid var(--line-2); border-right:1px solid var(--line-2)}
table.grid thead th{background:var(--cream); color:var(--navy); font-weight:600; position:sticky; top:0; z-index:3}
table.grid .c-cand{text-align:left; position:sticky; left:0; z-index:2; background:var(--card);
  min-width:150px; max-width:280px; white-space:normal; font-weight:600; color:var(--navy)}
table.grid thead .c-cand{z-index:4; background:var(--cream)}
table.grid .c-cand .sub{display:block; font-size:11.5px; color:var(--muted); font-weight:500; margin-top:1px}
/* 回答者列：全列を均一の固定幅にして崩れを防ぐ */
table.grid th.c-name, table.grid td.c-ans{width:88px; min-width:88px; max-width:88px}
/* ホバー：意味色(○△×)を消さず、先頭列だけ淡く強調 */
table.grid tbody tr:hover .c-cand{background:#fff1dc}
table.grid tbody tr:hover td.c-ans{box-shadow:inset 0 0 0 9999px rgba(216,90,48,.05)}
table.grid .sym{font-size:18px; font-weight:700}
.sym.maru{color:var(--maru)} .sym.sankaku{color:var(--sankaku)} .sym.batsu{color:var(--batsu)} .sym.blank{color:var(--blank)}
td.cell-maru{background:#d3edde} td.cell-sankaku{background:var(--sankaku-bg)} td.cell-batsu{background:var(--batsu-bg)}
table.grid tr.best .c-cand{box-shadow:inset 4px 0 0 var(--orange)}
table.grid tr.best td{background:#fff5e3}
table.grid tr.finalized .c-cand{box-shadow:inset 4px 0 0 var(--maru)}
table.grid tr.finalized td{background:var(--maru-bg)}
.tally-cell{font-size:12px; color:var(--muted); line-height:1.5}
.tally-cell b{font-size:14px}
.tally-cell .tm{color:var(--maru)} .tally-cell .ts{color:var(--sankaku)} .tally-cell .tb{color:var(--batsu)}
table.grid tfoot td{background:#fbf3e6; font-weight:600; position:sticky; bottom:0}
table.grid tfoot .c-cand{background:#fbf3e6}
.c-name{overflow:hidden; text-overflow:ellipsis}
.c-name .lock{font-size:11px; color:var(--muted)}
.row-edit{color:var(--orange-d); cursor:pointer; font-size:12px; text-decoration:underline; background:none; border:none}
.comment-row td{text-align:left; font-size:12px; color:var(--navy-soft); white-space:normal; word-break:break-word; background:#fffdf7}
.comment-row .c-cand{font-size:12px; color:var(--muted)}

/* 出欠確認モード：日程ごと参加者カード */
.attend-list{display:flex; flex-direction:column; gap:12px}
.attend-card{border:1px solid var(--line); border-radius:13px; padding:14px 16px; background:#fff}
.attend-card.top{border-color:var(--orange); background:var(--cream); box-shadow:0 0 0 3px var(--orange-soft)}
.ac-head{display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap}
.ac-date{font-size:15.5px; font-weight:600; color:var(--navy)}
.ac-count{flex:0 0 auto; font-size:13px; font-weight:600; color:var(--muted);
  background:#f1ece2; border-radius:999px; padding:4px 12px}
.ac-count.top{background:var(--orange); color:#fff}
.ac-chips{display:flex; flex-wrap:wrap; gap:7px; margin-top:11px}
.chip{display:inline-flex; align-items:center; gap:4px; font-size:13.5px; color:var(--navy);
  background:var(--maru-bg); border:1px solid #bfe0cc; border-radius:999px; padding:5px 12px}
.chip-lock{font-size:11px; opacity:.7}
.ac-empty{margin-top:9px; font-size:13px; color:var(--muted)}

/* 出欠確認モード：回答者一覧 */
.respondents{margin-top:18px; border-top:1px solid var(--line); padding-top:14px}
.resp-head{font-size:13px; font-weight:600; color:var(--muted); margin-bottom:8px; letter-spacing:.02em}
.resp-item{display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding:9px 2px; border-bottom:1px solid var(--line-2)}
.resp-item:last-child{border-bottom:none}
.ri-main{display:flex; flex-direction:column; gap:2px; min-width:0}
.ri-name{font-size:14px; font-weight:600; color:var(--navy)}
.ri-comment{font-size:12.5px; color:var(--navy-soft); white-space:pre-wrap; word-break:break-word}

.best-note{display:flex; align-items:center; gap:8px; font-size:13.5px; color:var(--navy);
  background:var(--cream); border:1px solid var(--orange-soft); border-radius:11px; padding:11px 14px; margin:0 0 14px}
.best-note b{color:var(--orange-d)}

/* 出欠入力フォーム */
.respond .resp-cands{display:flex; flex-direction:column; gap:8px; margin:10px 0 0}
.resp-cand{display:flex; align-items:center; justify-content:space-between; gap:12px;
  border:1px solid var(--line); border-radius:12px; padding:10px 12px; background:#fff}
.resp-cand .rc-label{font-size:14px; color:var(--navy); font-weight:600}
.resp-cand .rc-label .sub{display:block; font-size:11.5px; color:var(--muted); font-weight:500}
.sym-toggle{display:flex; gap:6px}
.sym-toggle button{width:46px; height:42px; border-radius:11px; border:1.5px solid var(--line); background:#fff;
  font-size:19px; font-weight:600; cursor:pointer; color:var(--blank); transition:.12s}
.sym-toggle button:hover{border-color:var(--orange-soft)}
.sym-toggle button.on.maru{background:var(--maru-bg); border-color:var(--maru); color:var(--maru)}
.sym-toggle button.on.sankaku{background:var(--sankaku-bg); border-color:var(--sankaku); color:var(--sankaku)}
.sym-toggle button.on.batsu{background:var(--batsu-bg); border-color:var(--batsu); color:var(--batsu)}
.bulk{display:flex; gap:6px; align-items:center; margin:4px 0 0; font-size:12px; color:var(--muted)}
.bulk button{font-size:12px; padding:5px 10px; border-radius:8px; border:1px solid var(--line); background:#fff; cursor:pointer; color:var(--navy)}
.bulk button:hover{background:var(--cream)}

.lock-banner{display:flex; gap:10px; align-items:center; background:var(--cream); border:1px solid var(--orange-soft);
  border-radius:11px; padding:11px 14px; font-size:13px; color:var(--navy-soft); margin:0 0 12px}

/* 管理ページ */
.manage-bar{display:flex; gap:10px; flex-wrap:wrap; align-items:center; margin-bottom:8px}
.manage-bar .tag{font-size:12px; color:var(--orange-d); background:var(--cream); border:1px solid var(--orange-soft);
  padding:5px 11px; border-radius:999px; font-weight:600}
.finalize-list{display:flex; flex-direction:column; gap:8px; margin:8px 0 0}
.finalize-list .fl{display:flex; align-items:center; justify-content:space-between; gap:10px;
  border:1px solid var(--line); border-radius:11px; padding:10px 13px; background:#fff}
.finalize-list .fl.on{border-color:var(--maru); background:var(--maru-bg)}
.finalize-list .fl .fl-tally{font-size:12px; color:var(--muted)}

/* トースト */
.toast{position:fixed; left:50%; bottom:26px; transform:translateX(-50%) translateY(20px);
  background:var(--navy); color:#fff; padding:12px 20px; border-radius:12px; font-size:14px;
  box-shadow:0 10px 30px rgba(0,0,0,.2); opacity:0; pointer-events:none; transition:.25s; z-index:100; max-width:90vw}
.toast.show{opacity:1; transform:translateX(-50%) translateY(0)}
.toast.err{background:var(--batsu)}

/* モーダル */
.modal-bg{position:fixed; inset:0; background:rgba(40,28,12,.5); display:flex; align-items:center;
  justify-content:center; padding:18px; z-index:90; opacity:0; animation:fade .2s forwards}
@keyframes fade{to{opacity:1}}
.modal{background:var(--card); border-radius:18px; max-width:440px; width:100%; padding:24px; box-shadow:0 24px 60px rgba(0,0,0,.25); max-height:90vh; overflow:auto}
.modal h3{margin:0 0 14px; font-size:18px}
.modal .lightbox-img{max-width:92vw; max-height:86vh; border-radius:12px}
.modal-bg.light{background:rgba(0,0,0,.82)}

.empty{text-align:center; color:var(--muted); padding:30px 10px; font-size:14px}
