/* =============================================================================
 * 共通コンポーネント
 * =============================================================================
 * - 確認コードマス(FAX耐性)
 * - 状態バッジ(5状態機械のUnicode記号)
 * - 高密度リスト(30-50件)
 * - 予約コード表示(等幅)
 * - 公共通知カード
 * ============================================================================= */

/* ---------------- 確認コードマス ---------------- */
.verification-code {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}

.verification-code .label {
  font-size: var(--fs-xs);
  color: var(--c-ink-sub);
}

.verification-code .boxes {
  display: flex;
  gap: 3px;
  align-items: center;
}

.verification-code .box {
  width: 36px;
  height: 40px;
  border: 2px solid var(--c-ink);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: 22px;
  font-weight: 700;
  background: var(--c-surface);
  text-transform: uppercase;
}

.verification-code .box.empty {
  background: var(--c-bg);
  color: var(--c-ink-faint);
}

.verification-code .box input {
  width: 100%;
  height: 100%;
  border: none;
  text-align: center;
  font-family: var(--font-mono);
  font-size: 22px;
  font-weight: 700;
  background: transparent;
  text-transform: uppercase;
  padding: 0;
  min-height: unset;
  outline: none;
}

.verification-code .separator {
  font-size: 20px;
  color: var(--c-ink-faint);
  padding: 0 4px;
}

.verification-code .checkmarks {
  display: flex;
  gap: 3px;
}
.verification-code .checkmark {
  width: 36px;
  text-align: center;
  font-size: var(--fs-sm);
  color: var(--c-ok);
  cursor: pointer;
  user-select: none;
}
.verification-code .checkmark.unchecked {
  color: var(--c-line);
}

/* ---------------- 予約コード ---------------- */
.reservation-code {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: var(--fs-xl);
  font-weight: 700;
  letter-spacing: 0.1em;
  padding: var(--pad-sm) var(--pad-lg);
  border: 1px solid var(--c-line);
  border-radius: var(--radius-sm);
  background: var(--c-sakura-bg);
  color: var(--c-ink);
}

.reservation-code-label {
  display: block;
  font-size: var(--fs-xs);
  color: var(--c-ink-sub);
  margin-bottom: 2px;
  font-family: var(--font-sans);
  font-weight: 400;
  letter-spacing: normal;
}

/* ---------------- 状態バッジ(Unicode記号のみ) ---------------- */
.status-badge {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-size: var(--fs-sm);
  padding: 1px 6px;
  border: 1px solid var(--c-line);
  border-radius: 2px;
  font-family: var(--font-mono);
  background: var(--c-surface);
}

/* 予約状態 — 桜色系 */
.status-badge[data-status="draft"]     { color: var(--c-ink-faint); }
.status-badge[data-status="pending"]   { color: var(--c-alert); border-color: var(--c-alert); }
.status-badge[data-status="confirmed"] { color: var(--c-info); border-color: var(--c-info); }
.status-badge[data-status="paid"]      { color: var(--c-reina); border-color: var(--c-reina); background: #FFFBEB; }
.status-badge[data-status="ticketed"]  { color: var(--c-minato); border-color: var(--c-minato); background: #EAF4FC; }
.status-badge[data-status="used"]      { color: var(--c-ok); border-color: var(--c-ok); background: #E8F7F3; }
.status-badge[data-status="completed"] { color: var(--c-ok); border-color: var(--c-ok); }
.status-badge[data-status="canceled"]  { color: var(--c-warn); border-color: var(--c-warn); background: #FDEBEA; text-decoration: line-through; }
.status-badge[data-status="expired"]   { color: var(--c-ink-faint); border-color: var(--c-line); }
.status-badge[data-status="handwritten_pending_sync"] {
  color: var(--c-tsumugi); border-color: var(--c-tsumugi); background: #EDF7F5;
}

/* 同期状態 */
.status-badge[data-sync="synced"]       { color: var(--c-ok); border-color: var(--c-ok); }
.status-badge[data-sync="local_only"]   { color: var(--c-tsumugi); border-color: var(--c-tsumugi); }
.status-badge[data-sync="pending_sync"] { color: var(--c-alert); border-color: var(--c-alert); }
.status-badge[data-sync="sync_conflict"]{ color: var(--c-warn); border-color: var(--c-warn); background: #FDEBEA; }
.status-badge[data-sync="reconciled"]   { color: var(--c-suzuna); border-color: var(--c-suzuna); }

/* ---------------- 高密度リスト ---------------- */
.dense-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--fs-sm);
  background: var(--c-surface);
  border: 1px solid var(--c-line);
}

.dense-table thead th {
  background: var(--c-bg);
  padding: var(--pad-xs) var(--pad-md);
  text-align: left;
  font-weight: 600;
  color: var(--c-ink-sub);
  border-bottom: 1px solid var(--c-line);
  font-size: var(--fs-xs);
  white-space: nowrap;
  position: sticky;
  top: 0;
  z-index: 10;
}

.dense-table tbody td {
  padding: 3px var(--pad-md);
  border-bottom: 1px solid var(--c-line-faint);
  white-space: nowrap;
}

.dense-table tbody tr {
  cursor: pointer;
}
.dense-table tbody tr:hover {
  background: var(--c-sakura-bg);
}

.dense-table .num {
  font-family: var(--font-mono);
  color: var(--c-ink-sub);
  text-align: right;
  font-size: var(--fs-xs);
}

.dense-table .code {
  font-family: var(--font-mono);
  font-weight: 600;
  color: var(--c-minato);
}

.dense-table .amount {
  font-family: var(--font-mono);
  text-align: right;
}

.dense-list-meta {
  font-size: var(--fs-xs);
  color: var(--c-ink-sub);
  padding: var(--pad-sm) 0;
  display: flex;
  gap: var(--pad-lg);
  align-items: center;
}

.dense-list-meta .match-reason {
  color: var(--c-ink-faint);
}

.pagination {
  display: inline-flex;
  gap: 2px;
  margin-left: auto;
}
.pagination button {
  min-width: 28px;
  padding: 2px 6px;
  font-size: var(--fs-xs);
  min-height: 24px;
}
.pagination .current {
  background: var(--c-sakura);
  border-color: var(--c-sakura-dark);
  font-weight: 700;
}

/* ---------------- 公共通知カード(G層) ---------------- */
.public-notice {
  display: flex;
  gap: var(--pad-md);
  padding: var(--pad-md);
  background: #FFF8E1;
  border: 1px solid var(--c-alert);
  border-radius: var(--radius-sm);
  font-size: var(--fs-sm);
  margin-bottom: var(--pad-md);
}

.public-notice.emergency {
  background: #FDEBEA;
  border-color: var(--c-warn);
}

.public-notice .severity {
  font-weight: 700;
  color: var(--c-alert);
  flex-shrink: 0;
}
.public-notice.emergency .severity { color: var(--c-warn); }

.public-notice .body {
  flex: 1;
}

.public-notice .meta {
  font-size: var(--fs-xs);
  color: var(--c-ink-sub);
  margin-top: 2px;
}

/* ---------------- セクションカード ---------------- */
.card {
  background: var(--c-surface);
  border: 1px solid var(--c-line);
  border-radius: var(--radius-sm);
  margin-bottom: var(--pad-lg);
}

.card-header {
  padding: var(--pad-md) var(--pad-lg);
  border-bottom: 1px solid var(--c-line-faint);
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-weight: 600;
  font-size: var(--fs-md);
}

.card-header .count {
  color: var(--c-ink-faint);
  font-size: var(--fs-sm);
  font-weight: 400;
}

.card-body {
  padding: var(--pad-md);
}

.card-body.pad-0 { padding: 0; }

/* ---------------- フルールバッジ ---------------- */
.fleur-badge {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-size: var(--fs-xs);
  padding: 1px 6px;
  border-radius: 10px;
  background: var(--c-bg);
  font-family: var(--font-sans);
}

.fleur-badge::before {
  content: "●";
  font-size: 10px;
}

.fleur-badge[data-fleur="sakura"]  { color: var(--c-sakura-dark); }
.fleur-badge[data-fleur="minato"]  { color: var(--c-minato); }
.fleur-badge[data-fleur="tsumugi"] { color: var(--c-tsumugi); }
.fleur-badge[data-fleur="hiyori"]  { color: var(--c-hiyori); }
.fleur-badge[data-fleur="kohaku"]  { color: var(--c-kohaku); }
.fleur-badge[data-fleur="suzuna"]  { color: var(--c-suzuna); }
.fleur-badge[data-fleur="kagari"]  { color: var(--c-kagari); }
.fleur-badge[data-fleur="soyoka"]  { color: var(--c-soyoka); }
.fleur-badge[data-fleur="aoi"]     { color: var(--c-aoi); }
.fleur-badge[data-fleur="shiori"]  { color: var(--c-shiori); }
.fleur-badge[data-fleur="reina"]   { color: var(--c-reina); }
.fleur-badge[data-fleur="yumeno"]  { color: var(--c-yumeno); }

/* ---------------- ユーティリティ ---------------- */
.mt-sm { margin-top: var(--pad-sm); }
.mt-md { margin-top: var(--pad-md); }
.mt-lg { margin-top: var(--pad-lg); }
.mt-xl { margin-top: var(--pad-xl); }

.flex { display: flex; }
.flex-col { flex-direction: column; }
.gap-sm { gap: var(--pad-sm); }
.gap-md { gap: var(--pad-md); }
.gap-lg { gap: var(--pad-lg); }
.flex-1 { flex: 1; }

.text-sub { color: var(--c-ink-sub); }
.text-xs { font-size: var(--fs-xs); }
.text-sm { font-size: var(--fs-sm); }
.mono { font-family: var(--font-mono); }

.kbd {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  background: var(--c-bg);
  border: 1px solid var(--c-line);
  border-bottom-width: 2px;
  padding: 1px 4px;
  border-radius: 2px;
  color: var(--c-ink-sub);
}
