@import url("https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@500;600;700&family=Noto+Sans+JP:wght@400;500;700;900&display=swap");

:root {
  color-scheme: light;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

body.settings-body {
  margin: 0;
  min-height: 100dvh;
  background: #f4f5f7;
  color: #1c1c1e;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 14px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

.settings-wrap {
  max-width: 560px;
  margin: 0 auto;
  padding: 20px 16px 48px;
}

.settings-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 20px;
}

.settings-topbar a {
  color: #2f3542;
  text-decoration: none;
  font-size: 12px;
  letter-spacing: 0.06em;
  opacity: 1;
}

.settings-topbar a:hover {
  opacity: 1;
  text-decoration: underline;
}

/* チームカラー適用ラッパー（npb-team-colors.css の変数を継承）。
   ライトモード固定なので面は白く保ち、球団カラーは `--highlight` で強く出す */
.team-skin {
  --panel-bg: #ffffff;
  --team-color: var(--highlight, #245da3);
  --team-color-sub: var(--highlight-sub, var(--accent-sub, #3a83c7));
  --panel-border: color-mix(in srgb, var(--team-color) 42%, #d8dde6);
  --muted: #4b5563;
  --text-strong: #1c1c1e;
  --accent-bar: var(--team-color);
  --field-bg: #ffffff;
  --field-border: #aeb7c4;
  --field-text: #1c1c1e;
  --field-muted: #666f7b;
  --note-bg: color-mix(in srgb, var(--team-color) 8%, #ffffff);
  --note-border: var(--team-color);
}

.team-skin .settings-card {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--team-color) 9%, #fff) 0, #fff 96px),
    var(--panel-bg);
  border: 1px solid var(--panel-border);
  border-top: 8px solid var(--accent-bar);
  border-radius: 14px;
  padding: 20px;
  margin-bottom: 16px;
  box-shadow: 0 6px 20px rgba(20, 20, 30, 0.06);
}

.team-skin h1 {
  margin: 0 0 6px;
  font-size: 20px;
  font-weight: 900;
  letter-spacing: 0.05em;
  color: var(--accent-bar);
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.75);
}

.team-skin .settings-lead {
  margin: 0 0 16px;
  font-size: 12px;
  color: #2f3542;
  letter-spacing: 0.04em;
  line-height: 1.65;
}

.team-skin .settings-lead strong {
  color: #111827;
  font-weight: 900;
  background: color-mix(in srgb, var(--team-color) 16%, #fff);
  padding: 0 3px;
  border-radius: 3px;
  box-shadow: inset 0 -2px 0 color-mix(in srgb, var(--team-color) 45%, transparent);
}

.team-skin .settings-note {
  margin: 0 0 14px;
  padding: 10px 12px;
  border-radius: 8px;
  font-size: 11px;
  line-height: 1.6;
  color: #2f3542;
  background: var(--note-bg);
  border-left: 3px solid var(--note-border);
}

.team-skin .settings-note strong {
  color: #111827;
  font-weight: 900;
  background: color-mix(in srgb, var(--team-color) 16%, #fff);
  padding: 0 3px;
  border-radius: 3px;
  box-shadow: inset 0 -2px 0 color-mix(in srgb, var(--team-color) 45%, transparent);
}

.team-skin .settings-footnotes p {
  margin: 0 0 10px;
}

.team-skin .settings-footnotes p:last-child {
  margin-bottom: 0;
}

.team-skin label.lbl {
  display: block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--muted);
  margin-bottom: 6px;
}

.team-skin select.inp,
.team-skin input.inp {
  width: 100%;
  height: 42px;
  border-radius: 8px;
  border: 1px solid var(--field-border);
  background: var(--field-bg);
  color: var(--field-text);
  font-size: 14px;
  padding: 0 12px;
  margin-bottom: 14px;
  appearance: none;
  -webkit-appearance: none;
}

.team-skin select.inp {
  background-image: linear-gradient(45deg, transparent 50%, #4b5563 50%),
    linear-gradient(135deg, #4b5563 50%, transparent 50%);
  background-position: calc(100% - 18px) 50%, calc(100% - 13px) 50%;
  background-size: 5px 5px, 5px 5px;
  background-repeat: no-repeat;
  padding-right: 32px;
}

.team-skin select.inp optgroup {
  background: #eef2f7;
  color: #111827;
  font-weight: 900;
}

.team-skin select.inp option {
  background: #fff;
  color: #111827;
  font-weight: 600;
}

.team-skin input.inp::placeholder {
  color: var(--field-muted);
}

.team-skin input.inp:focus,
.team-skin select.inp:focus,
.team-skin .inp-sm:focus,
.team-skin .starter-sel:focus {
  outline: none;
  border-color: var(--accent-bar);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent-bar) 25%, transparent);
}

.team-skin .btn-row {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 8px;
}

.team-skin button.btn-primary {
  flex: 1;
  min-width: 120px;
  height: 44px;
  border: none;
  border-radius: 10px;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.08em;
  cursor: pointer;
  background: var(--accent-bar);
  color: #fff;
  box-shadow: 0 2px 6px color-mix(in srgb, var(--accent-bar) 35%, transparent);
}

.team-skin[data-team="tigers"] button.btn-primary,
.team-skin[data-team="fighters"] button.btn-primary {
  color: #111827;
}

.team-skin button.btn-secondary {
  height: 44px;
  padding: 0 18px;
  border-radius: 10px;
  border: 1px solid color-mix(in srgb, var(--accent-bar) 40%, #d1d5db);
  background: #fff;
  color: var(--accent-bar);
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
}

.team-skin button.btn-primary:active,
.team-skin button.btn-secondary:active {
  filter: brightness(0.94);
}

.team-skin a.btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  flex: 1;
  min-width: 140px;
  box-sizing: border-box;
}

.team-skin .section-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 8px;
  margin: 20px 0 10px;
  padding-bottom: 8px;
  border-bottom: 2px solid var(--accent-bar);
}

.team-skin .section-head h2 {
  margin: 0;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 0.14em;
  color: var(--text-strong);
}

.team-skin .section-head span {
  font-size: 11px;
  font-weight: 700;
  color: var(--muted);
  letter-spacing: 0.06em;
}

.team-skin table.roster-grid {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
}

.team-skin table.roster-grid th {
  text-align: left;
  padding: 8px 6px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: #374151;
  border-bottom: 1px solid #cfd6e0;
}

.team-skin table.roster-grid td {
  padding: 4px 4px 4px 0;
  vertical-align: middle;
}

.team-skin table.roster-grid tbody tr.row-pos-P td {
  background: color-mix(in srgb, var(--pos-P) 6%, #fff);
}
.team-skin table.roster-grid tbody tr.row-pos-C td {
  background: color-mix(in srgb, var(--pos-C) 8%, #fff);
}
.team-skin table.roster-grid tbody tr.row-pos-IF td {
  background: color-mix(in srgb, var(--pos-IF) 6%, #fff);
}
.team-skin table.roster-grid tbody tr.row-pos-OF td {
  background: color-mix(in srgb, var(--pos-OF) 6%, #fff);
}
.team-skin table.roster-grid tbody tr.row-pos-DH td {
  background: color-mix(in srgb, var(--pos-DH) 6%, #fff);
}

.team-skin table.roster-grid input.inp-sm,
.team-skin table.roster-grid select.inp-sm {
  width: 100%;
  height: 36px;
  border-radius: 6px;
  border: 1px solid var(--field-border);
  background: var(--field-bg);
  color: var(--field-text);
  font-size: 13px;
  padding: 0 8px;
  margin-bottom: 0;
  appearance: none;
  -webkit-appearance: none;
}

.team-skin table.roster-grid select.inp-sm {
  background-image: linear-gradient(45deg, transparent 50%, #4b5563 50%),
    linear-gradient(135deg, #4b5563 50%, transparent 50%);
  background-position: calc(100% - 14px) 50%, calc(100% - 10px) 50%;
  background-size: 4px 4px, 4px 4px;
  background-repeat: no-repeat;
  padding-right: 24px;
}

.team-skin table.roster-grid .col-no {
  width: 28px;
  text-align: center;
  font-family: "Barlow Condensed", sans-serif;
  font-weight: 700;
  color: #374151;
}

.team-skin table.roster-grid .col-num {
  width: 56px;
}

.team-skin table.roster-grid .col-pos {
  width: 64px;
}

.team-skin .pill {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.08em;
  background: color-mix(in srgb, var(--accent-bar) 12%, #fff);
  color: var(--accent-bar);
  border: 1px solid color-mix(in srgb, var(--accent-bar) 30%, #d1d5db);
}

.lineup-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  align-items: start;
}

@media (max-width: 520px) {
  .lineup-split {
    grid-template-columns: 1fr;
  }
}

.team-skin .mini-title {
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.08em;
  color: var(--text-strong);
  margin: 0 0 8px;
}

.team-skin select.starter-sel {
  width: 100%;
  height: 38px;
  border-radius: 8px;
  border: 1px solid var(--field-border);
  background: var(--field-bg);
  color: var(--field-text);
  font-size: 12px;
  padding: 0 8px;
  margin-bottom: 0;
  appearance: none;
  -webkit-appearance: none;
}

.team-skin .order-label {
  font-family: "Barlow Condensed", sans-serif;
  font-size: 12px;
  font-weight: 700;
  color: #374151;
  margin-bottom: 4px;
  display: flex;
  align-items: center;
  gap: 6px;
}

.settings-msg {
  margin-top: 12px;
  font-size: 12px;
  color: #2e7d32;
  min-height: 1.2em;
  font-weight: 600;
}

.settings-msg.err {
  color: #c62828;
}

/* ==== ポジション色トークン（投/捕/内/外/DH） ==== */
.team-skin {
  --pos-P:  #e74c3c; /* 投手：赤 */
  --pos-C:  #f1a900; /* 捕手：オレンジ */
  --pos-IF: #2e8b57; /* 内野：緑 */
  --pos-OF: #2566c8; /* 外野：青 */
  --pos-DH: #8e44ad; /* DH：紫 */
}

/* ポジション選択肢を色分けするためのフィルタチップ */
.pos-filter {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin: 0 0 8px;
}

.pos-filter button {
  border: 1px solid #d0d2d8;
  background: #fff;
  color: #1f2937;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 11px;
  font-weight: 700;
  padding: 5px 9px;
  border-radius: 999px;
  cursor: pointer;
  letter-spacing: 0.04em;
  transition: background 0.12s, border-color 0.12s, color 0.12s;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.pos-filter button[data-group="P"] { color: var(--pos-P); border-color: color-mix(in srgb, var(--pos-P) 35%, #d0d2d8); }
.pos-filter button[data-group="C"] { color: var(--pos-C); border-color: color-mix(in srgb, var(--pos-C) 35%, #d0d2d8); }
.pos-filter button[data-group="IF"] { color: var(--pos-IF); border-color: color-mix(in srgb, var(--pos-IF) 35%, #d0d2d8); }
.pos-filter button[data-group="OF"] { color: var(--pos-OF); border-color: color-mix(in srgb, var(--pos-OF) 35%, #d0d2d8); }
.pos-filter button[data-group="DH"] { color: var(--pos-DH); border-color: color-mix(in srgb, var(--pos-DH) 35%, #d0d2d8); }

.pos-filter button.is-on { color: #fff; background: #1f2937; border-color: #1f2937; }
.pos-filter button.is-on[data-group="P"] { background: var(--pos-P); border-color: var(--pos-P); }
.pos-filter button.is-on[data-group="C"] { background: var(--pos-C); border-color: var(--pos-C); }
.pos-filter button.is-on[data-group="IF"] { background: var(--pos-IF); border-color: var(--pos-IF); }
.pos-filter button.is-on[data-group="OF"] { background: var(--pos-OF); border-color: var(--pos-OF); }
.pos-filter button.is-on[data-group="DH"] { background: var(--pos-DH); border-color: var(--pos-DH); }
.pos-filter button.is-on[data-group=""] { background: #1c1c1e; border-color: #1c1c1e; color: #fff; }

/* ポジションバッジ（凡例・選択中の表示用） */
.pos-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 22px;
  height: 18px;
  padding: 0 6px;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 800;
  color: #fff;
  background: #6b7280;
  letter-spacing: 0.04em;
}
.pos-badge.is-P  { background: var(--pos-P); }
.pos-badge.is-C  { background: var(--pos-C); }
.pos-badge.is-IF { background: var(--pos-IF); }
.pos-badge.is-OF { background: var(--pos-OF); }
.pos-badge.is-DH { background: var(--pos-DH); }
.pos-badge.is-NA { background: #6b7280; color: #fff; }

/* セレクトの option 自体にも背景色（対応ブラウザのみ） */
select.starter-sel option.opt-pos-P,
select.name-sel option.opt-pos-P  { background: color-mix(in srgb, var(--pos-P) 15%, #fff); }
select.starter-sel option.opt-pos-C,
select.name-sel option.opt-pos-C  { background: color-mix(in srgb, var(--pos-C) 18%, #fff); }
select.starter-sel option.opt-pos-IF,
select.name-sel option.opt-pos-IF { background: color-mix(in srgb, var(--pos-IF) 15%, #fff); }
select.starter-sel option.opt-pos-OF,
select.name-sel option.opt-pos-OF { background: color-mix(in srgb, var(--pos-OF) 15%, #fff); }
select.starter-sel option.opt-pos-DH,
select.name-sel option.opt-pos-DH { background: color-mix(in srgb, var(--pos-DH) 15%, #fff); }

.starter-row {
  margin-bottom: 10px;
}

.starter-row .starter-line {
  display: grid;
  grid-template-rows: 38px 18px;
  row-gap: 3px;
  width: 100%;
  min-width: 0;
}

.starter-row .starter-sel {
  width: 100%;
  min-width: 0;
}

.starter-main-row {
  display: block;
  width: 100%;
  height: 38px;
  min-width: 0;
}

.starter-main-row.with-generic {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 8px;
  align-items: center;
}

.starter-song-inline-select {
  height: 38px !important;
  max-width: 100%;
}

.starter-song-meta {
  height: 18px;
  min-width: 0;
}

.starter-song-meta-select {
  width: 150px;
  max-width: 45%;
  height: 24px;
  padding: 0 6px;
  font-size: 10px;
}

.starter-song-meta-preview {
  min-width: 0;
  height: 18px;
  line-height: 18px;
  display: block;
  font-size: 10px;
  opacity: 0.62;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.starter-row .order-num {
  font-family: "Barlow Condensed", sans-serif;
  font-size: 14px;
  font-weight: 800;
  color: var(--text-strong);
  min-width: 22px;
  text-align: center;
}

/* 凡例 */
.pos-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  font-size: 10px;
  color: #374151;
  margin: 4px 0 12px;
  letter-spacing: 0.04em;
}
.pos-legend .pos-legend-item {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
