/* NOLA Trip - styles (デモから移植) */
* { box-sizing: border-box; margin: 0; padding: 0; -webkit-tap-highlight-color: transparent; }
:root {
  --bg:#f7f8fa; --card:#fff; --text:#1a1a2e; --muted:#7a7a8c; --border:#e8e8ee; --soft:#fafafa;
  --accent:#3b82f6; --accent-dim:#dbeafe; --green:#16a34a; --green-dim:#dcfce7;
  --red:#ef4444; --red-dim:#fee2e2; --amber:#f59e0b; --amber-dim:#fff7e6;
  --shadow:0 1px 6px rgba(0,0,0,.07); --shadow-lg:0 8px 30px rgba(0,0,0,.16);
  --radius:12px; --radius-sm:8px; --tap:44px;
  --safe-b:env(safe-area-inset-bottom,0); --safe-t:env(safe-area-inset-top,0);
  --appbar-h:96px; --tabbar-h:60px;
  /* category colors */
  --c-conference:#6366f1; --c-meal:#ea580c; --c-cafe:#d97706; --c-sightseeing:#16a34a;
  --c-activity:#0891b2; --c-music:#db2777; --c-shopping:#7c3aed; --c-bar:#b45309; --c-move:#64748b; --c-flight:#475569; --c-free:#94a3b8;
  --c-hnd:#be123c; --c-ord:#1d4ed8;
  /* week grid sizing */
  --day-w:116px; --time-w:38px;
}
html,body { height:100%; }
body {
  background:var(--bg); color:var(--text); overscroll-behavior:none;
  font-family:-apple-system,BlinkMacSystemFont,"Hiragino Kaku Gothic ProN","Yu Gothic",Meiryo,sans-serif;
  font-size:15px; line-height:1.5;
  height:100dvh; display:flex; flex-direction:column; overflow:hidden;
}

/* ===== App bar ===== */
.appbar {
  flex:none; z-index:40; background:var(--card); border-bottom:1px solid var(--border);
  padding:calc(8px + var(--safe-t)) 12px 8px; box-shadow:var(--shadow);
}
.appbar-row { display:flex; align-items:center; gap:8px; }
.app-title { font-size:16px; font-weight:800; letter-spacing:.2px; white-space:nowrap; }
.app-title small { font-weight:600; color:var(--muted); font-size:11px; margin-left:6px; white-space:nowrap; }
.spacer { flex:1; }
.seg { display:inline-flex; background:var(--soft); border:1px solid var(--border); border-radius:99px; padding:3px; }
.seg button { border:0; background:transparent; color:var(--muted); font-weight:700; font-size:13px;
  padding:6px 12px; border-radius:99px; min-height:34px; }
.seg button.on { background:var(--accent); color:#fff; box-shadow:var(--shadow); }
.nav-row { display:flex; align-items:center; gap:8px; margin-top:8px; }
.icon-btn { width:36px; height:36px; border:1px solid var(--border); background:var(--card); border-radius:10px;
  font-size:18px; color:var(--text); display:grid; place-items:center; }
.nav-label { font-weight:800; font-size:15px; }
.today-btn { border:1px solid var(--border); background:var(--card); border-radius:99px; padding:6px 12px;
  font-weight:700; font-size:12px; color:var(--accent); min-height:34px; }
.member-pick { display:flex; align-items:center; gap:6px; margin-top:8px; flex-wrap:wrap; }
.member-pick .lbl { font-size:12px; color:var(--muted); font-weight:700; }
.chip-m { display:inline-flex; align-items:center; gap:6px; border:1px solid var(--border); background:var(--card);
  border-radius:99px; padding:4px 10px 4px 4px; font-size:12px; font-weight:700; }
.chip-m.on { border-color:var(--accent); background:var(--accent-dim); color:#1e3a8a; }
.avatar { width:22px; height:22px; border-radius:50%; color:#fff; font-size:10px; font-weight:800;
  display:grid; place-items:center; flex:none; }
.name-edit { margin-left:auto; border:1px solid var(--border); background:var(--card); border-radius:99px;
  padding:5px 10px; font-size:11px; font-weight:700; color:var(--accent); }
/* new-event form fields */
.field { margin-top:10px; }
.field label { font-size:11px; color:var(--muted); font-weight:700; display:block; margin-bottom:4px; }
.field input, .field select, .field textarea { width:100%; border:1px solid var(--border); border-radius:10px;
  padding:10px 12px; font-size:15px; background:var(--card); color:var(--text); }
.field-row { display:flex; gap:8px; }
.field-row .field { flex:1; }
.kind-pick { display:flex; gap:6px; flex-wrap:wrap; }
.kind-pick button { border:1px solid var(--border); background:var(--card); border-radius:99px;
  padding:6px 11px; font-size:12px; font-weight:700; color:var(--text); }
.kind-pick button.on { color:#fff; border-color:transparent; }

/* ===== Main ===== */
main { flex:1; min-height:0; overflow:hidden; position:relative; }
.section { display:none; height:100%; min-height:0; }
.section.on { display:flex; flex-direction:column; }
#sec-sched.on { gap:0; }
#weekView { flex:1; min-height:0; display:flex; flex-direction:column; }
#dayView { flex:1; min-height:0; overflow:auto; -webkit-overflow-scrolling:touch; }
#sec-check.on { display:block; overflow-y:auto; -webkit-overflow-scrolling:touch; }

/* undated ADA */
.undated { margin:8px 12px 0; flex:none; }
.undated h3 { font-size:12px; color:var(--muted); font-weight:800; margin-bottom:6px; display:flex; align-items:center; gap:6px; }
.undated-scroll { display:flex; gap:8px; overflow-x:auto; padding-bottom:4px; scrollbar-width:none; }
.undated-scroll::-webkit-scrollbar { display:none; }
.ucard { flex:0 0 auto; max-width:230px; background:var(--card); border:1px solid var(--border); border-left:4px solid var(--c-conference);
  border-radius:10px; padding:8px 10px; box-shadow:var(--shadow); }
.ucard .t { font-size:13px; font-weight:800; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ucard .s { font-size:11px; color:var(--muted); margin-top:2px; }
.badge-undated { display:inline-block; background:#eef2ff; color:#4338ca; font-size:10px; font-weight:800;
  border-radius:6px; padding:1px 6px; margin-top:4px; }

/* ===== Week grid ===== */
.week-wrap { position:relative; overflow:auto; flex:1; min-height:0;
  -webkit-overflow-scrolling:touch; margin-top:8px; background:var(--card); border-top:1px solid var(--border); }
.week-head { display:flex; position:sticky; top:0; z-index:20; background:var(--card); box-shadow:0 1px 0 var(--border); width:max-content; }
.corner { width:var(--time-w); flex:0 0 var(--time-w); background:var(--card); border-right:1px solid var(--border);
  position:sticky; left:0; z-index:22; }
.dh { flex:0 0 var(--day-w); width:var(--day-w); text-align:center; padding:6px 2px; border-right:1px solid var(--border); }
.dh .d { font-size:13px; font-weight:800; }
.dh .w { font-size:10px; color:var(--muted); }
.dh.sat .w { color:#2563eb; } .dh.sun .w { color:#dc2626; }
.dh.cur { background:var(--accent-dim); }
.dh .dot { display:inline-block; width:4px; height:4px; border-radius:50%; background:var(--accent); margin-left:2px; vertical-align:middle; }
.week-body { display:flex; position:relative; width:max-content; }
.time-col { width:var(--time-w); flex:0 0 var(--time-w); background:var(--card); border-right:1px solid var(--border);
  position:sticky; left:0; z-index:10; }
.tlabel { height:var(--hour-px,48px); font-size:10px; color:var(--muted); text-align:right; padding:2px 4px 0 0; position:relative; }
.tlabel span { position:relative; top:-6px; }
.day-col { flex:0 0 var(--day-w); width:var(--day-w); position:relative; border-right:1px solid var(--border); }
.hourline { position:absolute; left:0; right:0; height:1px; background:var(--border); }
/* 現在時刻バー（旅行期間中・今日の列のみ） */
.now-line { position:absolute; left:0; right:0; height:2px; background:#ef4444; z-index:6; pointer-events:none; }
.now-line::before { content:""; position:absolute; left:-2px; top:-3px; width:8px; height:8px; border-radius:50%; background:#ef4444; }
.now-mark { position:absolute; right:3px; transform:translateY(-50%); background:#ef4444; color:#fff; font-size:9px; font-weight:800;
  line-height:1; padding:2px 3px; border-radius:4px; z-index:2; pointer-events:none; white-space:nowrap; box-shadow:0 1px 3px rgba(0,0,0,.3); }
.daypart-band { position:absolute; left:3px; right:3px; border:1.5px dashed #c7c9d6; background:repeating-linear-gradient(45deg,rgba(99,102,241,.05),rgba(99,102,241,.05) 6px,transparent 6px,transparent 12px);
  border-radius:7px; padding:3px 5px; overflow:hidden; z-index:3; }
.daypart-band .t { font-size:11px; font-weight:700; color:#4b4d63; line-height:1.15; word-break:break-word; }
.daypart-band .sub { font-size:9px; color:var(--muted); margin-top:1px; }

/* event block */
.ev { position:absolute; left:3px; right:3px; border-radius:7px; padding:3px 5px; color:#fff; overflow:hidden;
  box-shadow:0 1px 3px rgba(0,0,0,.2); touch-action:pan-x pan-y; cursor:pointer; border-left:3px solid rgba(255,255,255,.55); z-index:3; }
.ev .et { font-size:11px; font-weight:700; line-height:1.15; word-break:break-word; }
.ev .es { font-size:9px; opacity:.95; margin-top:1px; }
.ev.option { background-image:repeating-linear-gradient(135deg,rgba(255,255,255,.18),rgba(255,255,255,.18) 5px,transparent 5px,transparent 10px); border:2px dashed rgba(255,255,255,.8); }
.ev .optbadge { position:absolute; top:2px; right:3px; background:rgba(255,255,255,.9); color:#333; font-size:8px; font-weight:900; border-radius:5px; padding:0 4px; }
.ev.ada::after { content:"ADA"; position:absolute; bottom:2px; right:3px; font-size:8px; font-weight:900; background:rgba(255,255,255,.85); color:#4338ca; border-radius:4px; padding:0 3px; }
.ev.dragging { opacity:.92; box-shadow:var(--shadow-lg); z-index:30; transform:scale(1.02); }
.ev.armed { box-shadow:var(--shadow-lg); transform:scale(1.05); z-index:20; opacity:.98; transition:transform .08s ease; }
/* flight block: compact, two-tone (dep region / arr region) */
.ev.flight { color:#fff; border-left:none; }
.fl-half { height:50%; display:flex; align-items:center; gap:3px; padding:0 4px; font-size:9px; font-weight:700; line-height:1; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.fl-half b { font-size:10px; }
.fl-dep { border-radius:6px 6px 0 0; }
.fl-arr { border-radius:0 0 6px 6px; }
.drag-tip { position:absolute; left:3px; top:2px; background:rgba(0,0,0,.7); color:#fff; font-size:10px; font-weight:800; border-radius:5px; padding:1px 5px; z-index:5; }

/* ===== Day view ===== */
.day-list { padding:10px 12px; min-height:50vh; }
.day-empty { text-align:center; color:var(--muted); padding:40px 0; font-size:13px; }
.di { display:flex; gap:10px; background:var(--card); border:1px solid var(--border); border-radius:12px;
  padding:10px; margin-bottom:8px; box-shadow:var(--shadow); border-left:4px solid var(--c-free); touch-action:pan-y; }
.di .time { flex:0 0 52px; text-align:right; }
.di .time .h { font-size:14px; font-weight:800; } .di .time .j { font-size:9px; color:var(--muted); }
.di .body { flex:1; min-width:0; }
.di .title { font-size:14px; font-weight:800; }
.di .sub { font-size:12px; color:var(--muted); margin-top:1px; }
.di .tags { display:flex; gap:5px; margin-top:6px; flex-wrap:wrap; }
.di .parts { display:flex; gap:3px; margin-top:6px; }
.di .parts .avatar { width:20px; height:20px; }
.swipe-hint { text-align:center; color:var(--muted); font-size:11px; padding:6px 0 2px; }

/* tag/badges */
.tag { font-size:10px; font-weight:800; border-radius:6px; padding:2px 7px; }
.tag.kind { color:#fff; }
.tag.cash { background:var(--red-dim); color:#b91c1c; }
.tag.resv { background:var(--amber-dim); color:#92600a; }
.tag.opt { background:#eef2ff; color:#4338ca; }

/* ===== Map ===== */
#mapAll { width:100%; flex:1; min-height:0; position:relative; }
.locate-btn { position:absolute; right:12px; bottom:16px; z-index:1000; width:46px; height:46px; border-radius:50%;
  background:var(--card); color:var(--accent); border:1px solid var(--border); box-shadow:var(--shadow-lg);
  display:flex; align-items:center; justify-content:center; cursor:pointer; padding:0; }
.locate-btn:active { transform:scale(.94); }
.locate-btn.loading { opacity:.55; }
.reset-btn { position:absolute; right:12px; bottom:70px; z-index:1000; width:46px; height:46px; border-radius:50%;
  background:var(--card); color:var(--accent); border:1px solid var(--border); box-shadow:var(--shadow-lg);
  display:flex; align-items:center; justify-content:center; cursor:pointer; padding:0; }
.reset-btn:active { transform:scale(.94); }
.update-banner { position:fixed; left:12px; right:12px; bottom:calc(var(--tabbar-h,60px) + var(--safe-b,0px) + 10px); z-index:4000;
  background:var(--accent); color:#fff; border-radius:12px; box-shadow:var(--shadow-lg);
  display:flex; align-items:center; justify-content:space-between; gap:10px; padding:10px 14px; font-size:13px; font-weight:700; }
.update-banner button { background:#fff; color:var(--accent); border:none; border-radius:8px; padding:7px 14px; font-weight:800; font-size:13px; cursor:pointer; }
.me-dot { width:14px; height:14px; border-radius:50%; background:#3b82f6; border:2px solid #fff;
  box-shadow:0 0 0 1px rgba(37,99,235,.5), 0 1px 4px rgba(0,0,0,.4); }
.map-filter { display:flex; gap:6px; overflow-x:auto; padding:8px 12px; scrollbar-width:none; flex:none; }
.map-filter::-webkit-scrollbar{ display:none; }
.map-legend { display:flex; gap:14px; padding:7px 12px 0; font-size:11px; color:var(--muted); flex:none; flex-wrap:wrap; }
.map-legend span { display:inline-flex; align-items:center; gap:5px; }
.map-legend i { width:13px; height:13px; border-radius:50%; display:inline-block; }
.lg-plan { background:var(--accent); border:2px solid #fff; box-shadow:0 0 0 1px #cbd5e1; }
.lg-cand { background:#fff; border:3px solid var(--amber); }
.lg-other { background:#cbd5e1; width:9px!important; height:9px!important; border:2px solid #fff; }
.fbtn { flex:0 0 auto; border:1px solid var(--border); background:var(--card); border-radius:99px; padding:5px 12px; font-size:12px; font-weight:700; color:var(--muted); }
.fbtn.on { background:var(--accent); color:#fff; border-color:var(--accent); }

/* ===== Suggest (候補地) ===== */
#sec-suggest.on { display:block; overflow-y:auto; -webkit-overflow-scrolling:touch; }
.suggest-wrap { padding:10px 12px; }
.suggest-head { font-size:13px; font-weight:800; color:var(--text); margin-bottom:4px; }
.suggest-sub { font-size:11px; color:var(--muted); margin-bottom:10px; }
.sg-tabbar { display:flex; gap:6px; overflow-x:auto; scrollbar-width:none; padding-bottom:8px; margin-bottom:4px; position:sticky; top:0; background:var(--bg); z-index:5; }
.sg-tabbar::-webkit-scrollbar { display:none; }
.sg-tab { flex:0 0 auto; border:1px solid var(--border); background:var(--card); border-radius:99px; padding:6px 12px; font-size:13px; font-weight:700; color:var(--muted); display:inline-flex; align-items:center; gap:5px; }
.sg-tab.on { background:var(--accent); color:#fff; border-color:var(--accent); }
.sg-cnt { font-size:10px; font-weight:800; background:rgba(0,0,0,.08); border-radius:99px; padding:0 6px; min-width:16px; text-align:center; }
.sg-tab.on .sg-cnt { background:rgba(255,255,255,.3); }
.sg-rec { font-size:12px; font-weight:700; color:#15803d; background:var(--green-dim); border:1px solid #bbf7d0; border-radius:8px; padding:4px 9px; margin-top:7px; display:inline-block; }
.sg-card { background:var(--card); border:1px solid var(--border); border-radius:12px; padding:11px 12px; margin-bottom:9px; box-shadow:var(--shadow); border-left:4px solid var(--c-sightseeing); }
.sg-top { display:flex; align-items:center; gap:8px; }
.sg-name { font-size:15px; font-weight:800; flex:1; }
.sg-in { font-size:10px; font-weight:800; color:#15803d; background:var(--green-dim); border-radius:6px; padding:2px 7px; }
.sg-meta { display:flex; gap:6px; flex-wrap:wrap; margin-top:7px; }
.sg-chip { font-size:11px; font-weight:600; color:var(--muted); background:var(--soft); border:1px solid var(--border); border-radius:7px; padding:2px 8px; }
.sg-memo { font-size:12px; color:#555; margin-top:7px; line-height:1.5; }
/* spot info screen */
.sp-photo { position:relative; height:150px; border-radius:14px; overflow:hidden; margin-top:4px; }
.sp-photo img { width:100%; height:100%; object-fit:cover; display:block; }
.sp-photo-emoji { display:flex; align-items:center; justify-content:center; }
.sp-credit { position:absolute; left:0; right:0; bottom:0; font-size:10px; line-height:1.4; padding:2px 8px; background:rgba(0,0,0,.55); color:#fff; }
.sp-credit a { color:#dbeafe; text-decoration:underline; }
.sp-emoji { font-size:56px; line-height:1; }
.sp-desc { font-size:14px; line-height:1.7; color:var(--text); }
.sp-tips { font-size:13px; line-height:1.6; color:#92600a; background:var(--amber-dim); border:1px solid #fde9c8; border-radius:10px; padding:9px 11px; }
.sg-actions { display:flex; gap:8px; margin-top:10px; }
.sg-actions .btn { flex:1; padding:9px; font-size:13px; }
.day-pick { display:flex; gap:6px; flex-wrap:wrap; }
.dp { flex:1 0 60px; border:1px solid var(--border); background:var(--card); border-radius:10px; padding:8px 4px; font-weight:800; font-size:14px; text-align:center; }
.dp small { display:block; font-weight:600; color:var(--muted); font-size:10px; }
.dp.sat small { color:#2563eb; } .dp.sun small { color:#dc2626; }

/* ===== Checklist ===== */
.check-wrap { padding:10px 12px; }
.check-tabs { display:flex; gap:6px; margin-bottom:10px; }
.check-tabs button { flex:1; border:1px solid var(--border); background:var(--card); border-radius:10px; padding:8px 4px; font-weight:800; font-size:13px; color:var(--muted); }
.check-tabs button.on { background:var(--accent); color:#fff; border-color:var(--accent); }
.add-row { display:flex; gap:8px; margin-bottom:10px; }
.add-row input { flex:1; border:1px solid var(--border); border-radius:10px; padding:10px 12px; font-size:15px; background:var(--card); }
.btn { border:0; border-radius:10px; padding:10px 14px; font-weight:800; font-size:14px; min-height:var(--tap); }
.btn-primary { background:var(--accent); color:#fff; }
.btn-secondary { background:var(--soft); color:var(--text); border:1px solid var(--border); }
.btn-ghost { background:transparent; color:var(--accent); border:1px dashed var(--accent); }
.btn-danger { background:var(--red-dim); color:#b91c1c; border:1px solid #f5b5b5; }
.btn-block { width:100%; }
.bulk { margin-bottom:12px; }
.bulk textarea { width:100%; border:1px solid var(--border); border-radius:10px; padding:10px; font-size:14px; resize:vertical; background:var(--card); }
.item { display:flex; align-items:center; gap:10px; background:var(--card); border:1px solid var(--border);
  border-radius:10px; padding:10px 12px; margin-bottom:6px; box-shadow:var(--shadow); }
.item.done .text { color:var(--muted); text-decoration:line-through; }
.check { width:24px; height:24px; border:2px solid #d1d5db; border-radius:7px; flex:none; display:grid; place-items:center; }
.item.done .check { background:var(--green); border-color:var(--green); color:#fff; }
.item.done .check::after { content:"✓"; font-size:15px; font-weight:900; }
.item .text { flex:1; font-size:15px; }
.item .del { color:var(--muted); font-size:16px; background:transparent; border:0; padding:4px; }
.done-collapse { margin-top:8px; }
.done-collapse summary { font-size:13px; color:var(--muted); font-weight:700; cursor:pointer; padding:6px 0; }
/* souvenir groups + qty */
.souvenir-bar { margin-bottom:10px; }
.sv-tabs { display:flex; gap:6px; overflow-x:auto; scrollbar-width:none; padding-bottom:2px; }
.sv-tabs::-webkit-scrollbar { display:none; }
.sv-tab { flex:0 0 auto; border:1px solid var(--border); background:var(--card); border-radius:99px; padding:6px 14px; font-size:13px; font-weight:700; color:var(--muted); touch-action:none; }
.sv-tab.on { background:var(--accent); color:#fff; border-color:var(--accent); }
.sv-add { flex:0 0 auto; border:1px dashed var(--accent); background:transparent; color:var(--accent); border-radius:99px; padding:6px 12px; font-size:13px; font-weight:700; }
.sv-x { margin-left:6px; opacity:.8; font-weight:900; }
.sv-addbox { display:inline-flex; align-items:center; gap:4px; flex:0 0 auto; }
.sv-addbox input { width:110px; border:1px solid var(--accent); border-radius:99px; padding:6px 10px; font-size:13px; }
.sv-ok { border:0; background:var(--accent); color:#fff; border-radius:99px; padding:6px 12px; font-size:13px; font-weight:700; }
.sv-cancel { border:1px solid var(--border); background:var(--card); color:var(--muted); border-radius:99px; padding:6px 10px; font-size:13px; font-weight:700; }
.sv-hint { font-size:11px; color:var(--muted); margin-top:5px; }
.qty-step { display:flex; align-items:center; gap:3px; flex:none; }
.qty-step button { width:28px; height:28px; border-radius:7px; border:1px solid var(--border); background:var(--soft); font-weight:800; font-size:15px; color:var(--text); }
.qn { min-width:22px; text-align:center; font-weight:800; font-size:14px; }

/* ===== Bottom tab bar ===== */
.tabbar { flex:none; z-index:50; height:calc(var(--tabbar-h) + var(--safe-b));
  padding-bottom:var(--safe-b); background:var(--card); border-top:1px solid var(--border); display:flex; box-shadow:0 -2px 10px rgba(0,0,0,.05); }
.tabbar button { flex:1; border:0; background:transparent; color:var(--muted); font-size:9px; font-weight:700;
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:3px; }
.tabbar button .ic { font-size:19px; }
.tabbar button.on { color:var(--accent); }

/* ===== Modal ===== */
.backdrop { position:fixed; inset:0; z-index:60; background:rgba(0,0,0,.45); display:none; align-items:flex-end; justify-content:center; }
.backdrop.on { display:flex; animation:fade .15s; }
@keyframes fade { from{opacity:0} to{opacity:1} }
.sheet { width:100%; max-width:560px; background:var(--card); border-radius:18px 18px 0 0; max-height:90vh; overflow-y:auto;
  padding:14px 16px calc(20px + var(--safe-b)); animation:slideup .22s cubic-bezier(.2,.8,.2,1); }
@keyframes slideup { from{transform:translateY(100%)} to{transform:translateY(0)} }
.sheet-grip { width:40px; height:4px; background:#d8d8e0; border-radius:99px; margin:0 auto 10px; }
.d-title { font-size:18px; font-weight:900; line-height:1.25; }
.d-time { font-size:14px; font-weight:700; color:var(--accent); margin-top:4px; }
.d-time .jst { color:var(--muted); font-weight:600; font-size:12px; margin-left:6px; }
.d-badges { display:flex; gap:6px; flex-wrap:wrap; margin-top:8px; }
.d-map { width:100%; height:170px; border-radius:12px; margin-top:12px; background:var(--soft); overflow:hidden; }
.d-map-fallback { display:grid; place-items:center; height:100%; color:var(--muted); font-size:12px; text-align:center; padding:10px; }
.d-links { display:flex; gap:8px; margin-top:8px; }
.d-links a { flex:1; text-align:center; text-decoration:none; }
.d-sec { margin-top:14px; }
.d-sec h4 { font-size:12px; color:var(--muted); font-weight:800; margin-bottom:6px; }
.d-memo { font-size:14px; background:var(--soft); border:1px solid var(--border); border-radius:10px; padding:10px; }
.d-info { font-size:13px; }
.d-info div { padding:3px 0; }
.parts-row { display:flex; gap:8px; flex-wrap:wrap; }
.pchip { display:flex; align-items:center; gap:6px; border:1px solid var(--border); border-radius:99px; padding:3px 10px 3px 3px; font-size:12px; font-weight:700; }
.pchip .st { font-size:14px; }
.rsvp-row { display:flex; gap:8px; margin-top:8px; }
.rsvp-row button { flex:1; border:1px solid var(--border); background:var(--card); border-radius:10px; padding:8px; font-weight:800; font-size:13px; }
.rsvp-row button.going.on { background:var(--green-dim); border-color:var(--green); color:#15803d; }
.rsvp-row button.maybe.on { background:var(--amber-dim); border-color:var(--amber); color:#92600a; }
.rsvp-row button.no.on { background:var(--red-dim); border-color:var(--red); color:#b91c1c; }

/* ===== 管理者: 参加状況の代理編集（イベント詳細）===== */
.adm-list { display:flex; flex-direction:column; gap:6px; margin-top:8px; }
.adm-rsvp { display:flex; align-items:center; gap:8px; }
.adm-rsvp .nm { flex:1; font-size:13px; font-weight:700; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.adm-btns { display:flex; gap:4px; flex:none; }
.adm-btns button { min-width:36px; border:1px solid var(--border); background:var(--card); border-radius:8px; padding:5px 6px; font-weight:800; font-size:13px; color:var(--muted); }
.adm-btns button.going.on { background:var(--green-dim); border-color:var(--green); color:#15803d; }
.adm-btns button.no.on { background:var(--red-dim); border-color:var(--red); color:#b91c1c; }
.adm-btns button.none.on { background:var(--soft); border-color:var(--muted); color:var(--text); }
.adm-bulk { display:flex; gap:6px; margin-top:10px; }
.adm-bulk button { flex:1; border:1px solid var(--border); background:var(--card); border-radius:8px; padding:7px; font-weight:700; font-size:12px; color:var(--text); }
.proxy { font-size:10px; background:var(--soft); color:var(--muted); border:1px solid var(--border); border-radius:6px; padding:1px 5px; margin-left:6px; font-weight:700; }

/* ===== 管理者パネル: 利用者一覧 ===== */
.adm-users { display:flex; flex-direction:column; gap:6px; margin-top:6px; }
.adm-user { display:flex; flex-direction:column; gap:6px; border:1px solid var(--border); border-radius:10px; padding:8px; }
.adm-user-head { display:flex; align-items:center; gap:8px; }
.adm-user-head .nm { flex:1; font-size:13px; font-weight:700; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.adm-user-head .uid { font-size:10px; color:var(--muted); font-family:ui-monospace,monospace; }
.adm-user-actions { display:flex; gap:6px; }
.adm-user-actions button { flex:1; border:1px solid var(--border); background:var(--card); border-radius:8px; padding:6px 4px; font-size:11px; font-weight:700; color:var(--text); }
.adm-user-actions button.danger { color:var(--red); border-color:var(--red); }
.adm-user-actions button.adm-grant.on { background:var(--accent-dim); border-color:var(--accent); color:#1e3a8a; }
.adminbadge { font-size:10px; background:var(--accent-dim); color:#1e3a8a; border-radius:6px; padding:1px 5px; margin-left:6px; font-weight:800; }
.adm-user.editing .sv-addbox { flex:1; }
/* ログイン履歴（再ログインで端末の過去IDを選ぶ）*/
.login-hist { display:flex; flex-wrap:wrap; gap:8px; }
.login-hist-btn { display:inline-flex; align-items:center; gap:6px; border:1px solid var(--border); background:var(--card); border-radius:99px; padding:5px 12px 5px 5px; font-size:13px; font-weight:700; color:var(--text); }
/* 🛠 管理タブは管理者(body.admin)のときだけ表示。中身はスクロール可能 */
#tabbar [data-tab="members"] { display:none; }            /* 既定は非表示 */
body.admin #tabbar [data-tab="members"] { display:flex; } /* 管理者のときだけ表示 */
.members-pane { flex:1; overflow-y:auto; -webkit-overflow-scrolling:touch; padding:14px; }
.members-title { font-size:16px; font-weight:800; margin-bottom:4px; }
.d-actions { display:flex; gap:8px; margin-top:16px; }

/* quick menu (long-press) */
.qmenu { position:fixed; z-index:70; background:var(--card); border-radius:14px; box-shadow:var(--shadow-lg); overflow:hidden; display:none; min-width:180px; border:1px solid var(--border); }
.qmenu.on { display:block; animation:fade .12s; }
.qmenu button { display:flex; align-items:center; gap:10px; width:100%; border:0; background:transparent; padding:13px 16px; font-size:15px; font-weight:600; color:var(--text); text-align:left; }
.qmenu button:active { background:var(--soft); }
.qmenu button.danger { color:var(--red); }
.qmenu .sep { height:1px; background:var(--border); }

/* toast */
.toast-stack { position:fixed; left:0; right:0; bottom:calc(var(--tabbar-h) + 12px + var(--safe-b)); z-index:80; display:flex; flex-direction:column; align-items:center; gap:8px; pointer-events:none; }
.toast { background:#1f2330; color:#fff; border-radius:10px; padding:10px 14px; font-size:13px; font-weight:600; box-shadow:var(--shadow-lg); display:flex; gap:12px; align-items:center; pointer-events:auto; max-width:90%; }
.toast button { background:transparent; border:0; color:#7dd3fc; font-weight:800; font-size:13px; }

