:root {
  --bg: #0b1020;
  --bg2: #131a2e;
  --card: #1a2238;
  --card2: #212b46;
  --line: #2c3962;
  --text: #e8edff;
  --muted: #93a0c4;
  --accent: #ffd24a;
  --accent2: #4a9bff;
  --green: #38d39f;
  --red: #ff6b6b;
  --radius: 14px;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: linear-gradient(180deg, #0a0e1c 0%, #0b1020 100%);
  color: var(--text);
  font-family: -apple-system, BlinkMacSystemFont, "Hiragino Sans", "Segoe UI", sans-serif;
  font-size: 15px;
  line-height: 1.5;
  -webkit-text-size-adjust: 100%;
  padding-bottom: 60px;
}

header {
  position: sticky; top: 0; z-index: 20;
  background: rgba(11,16,32,.92);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--line);
  padding: 10px 14px;
}
.brand { display:flex; align-items:center; justify-content:space-between; gap:10px; max-width: 760px; margin: 0 auto; }
.brand h1 { font-size: 16px; margin: 0; letter-spacing: .5px; }
.brand h1 small { color: var(--muted); font-weight: 400; }
.me-box { display:flex; align-items:center; gap:8px; }
.me-box select {
  background: var(--card2); color: var(--text); border: 1px solid var(--line);
  border-radius: 10px; padding: 6px 8px; font-size: 14px;
}
.me-balance { font-weight: 700; color: var(--accent); white-space: nowrap; }

nav#tabs {
  display:flex; gap:4px; overflow-x:auto; padding: 8px 10px;
  max-width: 760px; margin: 0 auto;
}
nav#tabs button {
  flex: 0 0 auto;
  background: var(--card); color: var(--muted);
  border: 1px solid var(--line); border-radius: 999px;
  padding: 7px 14px; font-size: 14px; cursor: pointer;
}
nav#tabs button.active { background: var(--accent2); color: #051026; border-color: var(--accent2); font-weight: 700; }

main#view { max-width: 760px; margin: 0 auto; padding: 6px 12px 30px; }

.card {
  background: var(--card); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 14px; margin: 12px 0;
}
.card h2 { font-size: 15px; margin: 0 0 10px; }
.section-title { color: var(--muted); font-size: 13px; margin: 18px 2px 6px; letter-spacing:.4px; }

.badge { font-size: 11px; padding: 2px 8px; border-radius: 999px; font-weight: 700; }
.badge.open { background: rgba(56,211,159,.18); color: var(--green); }
.badge.closed { background: rgba(255,107,107,.15); color: var(--red); }
.badge.pending { background: rgba(147,160,196,.15); color: var(--muted); }
.badge.settled { background: rgba(74,155,255,.18); color: var(--accent2); }

/* ランキング */
.rank-row { display:flex; align-items:center; gap:10px; padding: 8px 0; }
.rank-row .pos { width: 26px; font-size: 18px; text-align:center; }
.rank-row .nm { flex: 1; font-weight: 600; }
.rank-row.me .nm { color: var(--accent); }
.rank-row .bal { font-variant-numeric: tabular-nums; font-weight: 700; }
.bar { height: 8px; background: var(--card2); border-radius: 6px; overflow: hidden; margin-top: 4px; }
.bar > i { display:block; height:100%; background: linear-gradient(90deg, var(--accent2), var(--green)); }
.delta { font-size: 12px; }
.delta.up { color: var(--green); }
.delta.down { color: var(--red); }

/* 試合カード */
.match { background: var(--card); border:1px solid var(--line); border-radius: var(--radius); padding: 12px; margin: 10px 0; }
.match .mh { display:flex; align-items:center; justify-content:space-between; gap:8px; color: var(--muted); font-size: 12px; margin-bottom: 8px; }
.team-row { display:flex; align-items:center; gap:10px; padding: 7px 8px; border-radius: 10px; }
.team-row + .team-row { margin-top: 4px; }
.team-row .flag { font-size: 22px; width: 28px; text-align:center; }
.team-row .tn { flex: 1; font-weight: 600; }
.team-row .od { font-variant-numeric: tabular-nums; color: var(--accent); font-weight: 700; min-width: 48px; text-align:right; }
.team-row.win { background: rgba(56,211,159,.12); }
.team-row.win .tn::after { content: " ✓"; color: var(--green); }
.team-row.lose { opacity: .5; }
.vs { text-align:center; color: var(--muted); font-size: 11px; margin: 2px 0; }

.betbox { margin-top: 10px; border-top: 1px dashed var(--line); padding-top: 10px; }
.betbox .amt { display:flex; gap:8px; align-items:center; }
.betbox input[type=number] {
  flex: 1; background: var(--bg2); color: var(--text); border:1px solid var(--line);
  border-radius: 10px; padding: 9px 10px; font-size: 16px; min-width: 0;
}
.bet-btns { display:flex; gap:8px; margin-top: 8px; }
.bet-btns button {
  flex: 1; border:none; border-radius: 10px; padding: 10px 8px; font-size: 13px; font-weight: 700; cursor:pointer;
  background: var(--card2); color: var(--text); border:1px solid var(--line);
}
.bet-btns button:hover { border-color: var(--accent2); }
.bet-btns button .pv { display:block; font-size: 11px; color: var(--green); font-weight: 600; margin-top: 2px; }
.mybets { margin-top: 8px; font-size: 12px; color: var(--muted); }
.mybets .chip { display:inline-block; background: var(--card2); border:1px solid var(--line); border-radius: 999px; padding: 2px 9px; margin: 2px 4px 2px 0; }

/* 優勝当て */
table.tbl { width: 100%; border-collapse: collapse; font-size: 14px; }
table.tbl th, table.tbl td { padding: 8px 6px; border-bottom: 1px solid var(--line); text-align:left; vertical-align: middle; }
table.tbl th { color: var(--muted); font-weight: 600; font-size: 12px; }
table.tbl td.num, table.tbl th.num { text-align:right; font-variant-numeric: tabular-nums; }
table.tbl tr.elim td { opacity: .4; }
table.tbl tr.champ td { background: rgba(255,210,74,.12); }
.mini-bet { display:flex; gap:6px; align-items:center; justify-content:flex-end; }
.mini-bet input { width: 84px; background: var(--bg2); color: var(--text); border:1px solid var(--line); border-radius:8px; padding:6px; font-size:14px; }
.mini-bet button { background: var(--accent2); color:#051026; border:none; border-radius:8px; padding:6px 10px; font-weight:700; cursor:pointer; }

/* 汎用 */
.btn { background: var(--accent2); color:#051026; border:none; border-radius:10px; padding:10px 14px; font-weight:700; cursor:pointer; }
.btn.ghost { background: var(--card2); color: var(--text); border:1px solid var(--line); }
.btn.danger { background: var(--red); color:#2a0808; }
.btn.armed { background: var(--accent); color:#2a1c00; }
.row { display:flex; gap:8px; align-items:center; flex-wrap: wrap; }
.muted { color: var(--muted); }
.right { text-align:right; }
input[type=text], input[type=datetime-local], input[type=password] {
  background: var(--bg2); color: var(--text); border:1px solid var(--line); border-radius:10px; padding:9px 10px; font-size:15px;
}
label.fld { display:block; margin: 8px 0; }
label.fld span { display:block; color: var(--muted); font-size:12px; margin-bottom:4px; }
.hint { color: var(--muted); font-size: 12px; }
.status-won { color: var(--green); font-weight: 700; }
.status-lost { color: var(--red); }
.status-open { color: var(--muted); }

/* トースト */
#toast {
  position: fixed; left: 50%; bottom: 22px; transform: translateX(-50%);
  background: #222c4a; color: var(--text); border:1px solid var(--line);
  padding: 10px 16px; border-radius: 12px; font-size: 14px; max-width: 90%;
  opacity: 0; pointer-events: none; transition: opacity .2s; z-index: 50; text-align:center;
}
#toast.show { opacity: 1; }
#toast.err { border-color: var(--red); background: #3a1f28; }

/* プレイヤー選択画面 */
.chooser h2 { font-size: 18px; }
.chooser-btns { display: flex; flex-direction: column; gap: 10px; margin-top: 12px; }
.btn.big { padding: 16px; font-size: 18px; }
.btn.hsw { padding: 4px 8px; font-size: 12px; }

/* エントリー上限・キャンセル */
.bet-btns button .cap { display: block; font-size: 10px; color: var(--muted); font-weight: 500; margin-top: 2px; }
.bet-btns button:disabled { opacity: .4; cursor: not-allowed; }
.xbtn { background: transparent; border: 1px solid var(--red); color: var(--red); border-radius: 8px; padding: 1px 7px; font-size: 11px; cursor: pointer; margin-left: 4px; }

/* トーナメント表（縦スタック） */
.vbracket { }
.vb-round { color: var(--muted); font-size: 12px; font-weight: 700; letter-spacing: .5px; margin: 14px 2px 6px; padding-bottom: 4px; border-bottom: 1px solid var(--line); }
.vb-round:first-child { margin-top: 2px; }
.vb-match { background: var(--card2); border: 1px solid var(--line); border-radius: 9px; margin: 6px 0; overflow: hidden; }
.vb-match.done { border-color: var(--accent2); }
.vb-tag { font-size: 10px; text-align: center; color: var(--accent); padding: 2px 0; border-bottom: 1px solid var(--line); background: rgba(255,210,74,.06); }
.vb-row { display: flex; align-items: center; gap: 8px; padding: 8px 11px; font-size: 14px; }
.vb-row + .vb-row { border-top: 1px solid var(--line); }
.vb-row .vb-flag { width: 22px; text-align: center; flex: 0 0 auto; font-size: 17px; }
.vb-row .vb-name { flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.vb-row .vb-score { font-variant-numeric: tabular-nums; font-weight: 700; min-width: 22px; text-align: right; }
.vb-row.win { background: rgba(56,211,159,.14); }
.vb-row.win .vb-name { font-weight: 700; }
.vb-row.win .vb-name::after { content: " ✓"; color: var(--green); }
.vb-row.lose { opacity: .5; }
.vb-pk { font-size: 10px; color: var(--muted); margin-left: 3px; font-weight: 500; }
.bw-d { color: var(--green); }
