html, body {
  font-family: "MS UI Gothic", "ＭＳ Ｐゴシック", "Osaka", "Hiragino Sans", sans-serif;
  font-size: 12px;
  background: #008080;
  margin: 0;
  padding: 0;
}

body {
  padding: 12px;
  min-height: 100vh;
  box-sizing: border-box;
}

.window {
  max-width: 720px;
  margin: 0 auto;
}

.window-body {
  font-family: "MS UI Gothic", "ＭＳ Ｐゴシック", "Osaka", "Hiragino Sans", sans-serif;
}

table {
  border-collapse: collapse;
  font-family: "MS UI Gothic", "ＭＳ Ｐゴシック", "Osaka", "Hiragino Sans", sans-serif;
  font-size: 12px;
  width: 100%;
  table-layout: auto;
}

table th, table td {
  border: 1px solid #808080;
  padding: 2px 6px;
  vertical-align: top;
  text-align: left;
  white-space: normal;
  word-break: break-word;
  overflow-wrap: anywhere;
}

table th {
  background: #c0c0c0;
}

.field-row {
  margin: 6px 0;
}

.field-row label {
  display: inline-block;
  width: 110px;
}

.field-row input[type="text"],
.field-row input[type="number"],
.field-row textarea,
.field-row select {
  font-family: "MS UI Gothic", "ＭＳ Ｐゴシック", "Osaka", "Hiragino Sans", sans-serif;
  font-size: 12px;
  width: calc(100% - 120px);
  max-width: 360px;
}

.field-row textarea {
  height: 60px;
  vertical-align: top;
}

.button-row {
  margin-top: 12px;
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.menu-buttons {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: center;
  padding: 24px 0;
}

.menu-buttons button {
  width: 140px;
  height: 80px;
  font-size: 14px;
}

.suggest-list {
  margin-top: 8px;
  max-height: 360px;
  overflow-y: auto;
  border: 1px solid #808080;
  background: #fff;
}

.suggest-item {
  padding: 4px 8px;
  border-bottom: 1px solid #c0c0c0;
  cursor: pointer;
}

.suggest-item:hover {
  background: #000080;
  color: #fff;
}

.muted {
  color: #555;
}

.error {
  color: #8b0000;
}

#reader {
  width: 100%;
  max-width: 360px;
}

.qr-area {
  text-align: center;
  padding: 12px;
}

.qr-area canvas {
  border: 1px solid #000;
  background: #fff;
}

.warn {
  background: #ffffc0;
  border: 1px solid #808080;
  padding: 6px 8px;
  margin: 8px 0;
}

.title-bar-text {
  font-family: "MS UI Gothic", "ＭＳ Ｐゴシック", "Osaka", "Hiragino Sans", sans-serif !important;
}

.cover-thumb {
  max-width: 40px;
  max-height: 56px;
  display: block;
  vertical-align: middle;
}

/* シリーズ統合の元リスト: テーブル表示。他の入力欄と幅を合わせる。
   行クリックで checkbox トグル(行全体がタップ領域)。
   98.cssのチェックボックス隠しスタイルを上書きしてネイティブ表示に。 */
/* 統合元/先のコントロールラッパ。select/input/tableが縦に並ぶ */
.merge-ctrl-wrap {
  flex: 1 1 auto;
  min-width: 0;
  max-width: 360px;
}
.merge-ctrl-wrap > select,
.merge-ctrl-wrap > input[type="text"] {
  width: 100%;
  max-width: none;
}
/* ラッパが縦長になるのでラベルを上揃えに */
.field-row.merge-row {
  align-items: flex-start;
}
.field-row.merge-row > label {
  padding-top: 3px;
}

.merge-from-wrap {
  width: 100%;
  max-height: 240px;
  overflow-y: auto;
  border: 1px solid #808080;
  background: #fff;
}
#mergeFromTable {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
}
#mergeFromTable th,
#mergeFromTable td {
  border: 1px solid #c0c0c0;
  padding: 2px 6px;
  text-align: left;
}
#mergeFromTable thead th {
  position: sticky;
  top: 0;
  background: #c0c0c0;
}
#mergeFromTable tbody tr {
  cursor: pointer;
}
#mergeFromTable tbody tr:hover {
  background: #e6e6e6;
}
/* checkboxは98.cssの隠しinput+label:before方式をそのまま使う(他箇所と統一感)。
   labelは空でよく、:beforeで描画される視覚チェックがcell先頭に来る。 */
#mergeFromTable td:first-child,
#mergeFromTable th:first-child {
  text-align: left;
  width: 28px;
  padding-left: 6px;
}
#mergeFromTable td:first-child label {
  display: inline-block;
  width: 13px;
  height: 13px;
  vertical-align: middle;
}
#mergeFromTable td:last-child,
#mergeFromTable th:last-child {
  text-align: right;
  width: 48px;
}
@media (max-width: 600px) {
  .merge-from-wrap {
    max-width: none;
    width: auto;
  }
  .merge-ctrl-wrap {
    max-width: none;
  }
}

.date-pick-wrap {
  position: relative;
  display: inline-block;
  vertical-align: middle;
}
.date-pick-wrap > button {
  pointer-events: none;
}
.date-pick-wrap > input[type="date"] {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  min-width: 32px;
  opacity: 0;
  cursor: pointer;
  border: 0;
  padding: 0;
  margin: 0;
  background: transparent;
  font-size: 16px;
  box-shadow: none;
}

/* スマホ・タブレット縦向け: ラベルを上、入力を下、行ごと整えてガタつき抑制 */
@media (max-width: 600px) {
  body {
    padding: 6px;
  }

  .field-row {
    flex-wrap: wrap;
    align-items: center;
  }
  /* ラベルは独立行に */
  .field-row > label {
    flex: 1 0 100%;
    width: auto;
    margin-bottom: 2px;
  }
  /* ラベル直後の要素は行頭なので左マージン消す */
  .field-row > label + * {
    margin-left: 0;
  }
  /* テキスト系は伸びる、numberは元の幅尊重 */
  .field-row > input[type="text"],
  .field-row > input[type="email"],
  .field-row > input[type="password"],
  .field-row > input[type="search"],
  .field-row > input[type="tel"],
  .field-row > input[type="url"],
  .field-row > textarea,
  .field-row > select {
    flex: 1 1 auto;
    min-width: 0;
    width: auto;
    max-width: none;
  }
  /* iOSの自動ズーム回避と可読性確保のため入力フォントは16pxに */
  .field-row input,
  .field-row textarea,
  .field-row select {
    font-size: 16px;
  }

  .menu-buttons button {
    width: 45%;
    height: 70px;
    font-size: 14px;
  }

  /* 表セルは横幅を圧縮 */
  table { font-size: 12px; }
  table th, table td { padding: 1px 4px; }

  /* タップ領域の確保 */
  .date-pick-wrap > button {
    min-width: 40px;
    min-height: 28px;
  }
}
