/* === Fond identique à minuteur === */
.bg-layer {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
}
.bg-main {
  background:
    radial-gradient(ellipse 130% 70% at 50% 115%, rgba(0,80,200,0.22) 0%, transparent 65%),
    radial-gradient(ellipse 70% 50% at 12% 0%,   rgba(0,50,130,0.16) 0%, transparent 55%),
    radial-gradient(ellipse 70% 50% at 88% 0%,   rgba(0,50,130,0.16) 0%, transparent 55%),
    linear-gradient(180deg, #04101e 0%, var(--bg) 40%, #091e3c 100%);
}
.bg-vignette {
  background: radial-gradient(ellipse 100% 100% at 50% 50%, transparent 35%, rgba(0,0,0,0.52) 100%);
}
.bg-scanlines {
  background-image: repeating-linear-gradient(
    0deg,
    transparent,
    transparent 2px,
    rgba(0,0,0,0.05) 2px,
    rgba(0,0,0,0.05) 4px
  );
  opacity: 0.45;
}

/* ══════════════════════════════════════════════════════
   MATCHSETUP.CSS — PhysEdBoard
   Layout : terrains (gauche) | banc (droite)
   Timer en haut, terrains compacts en dessous
══════════════════════════════════════════════════════ */

:root {
  --bg:         #061428;
  --panel2:     #0a1a30;
  --border:     #1a3a60;
  --accent:     #ffd43b;
  --accent-rgb: 255,212,59;
  --red:        #ff3c3c;
  --text:       #ffffff;
  --text-mid:   rgba(255,255,255,0.65);
  --text-dim:   rgba(255,255,255,0.35);
  --dim:        #3a608a;
  --dim2:       #1a3a60;
  --input-rgb:  4,14,32;
  --tr:         0.2s cubic-bezier(0.4,0,0.2,1);

  --header-h:   64px;
  --bench-w:    0px;
  --bench-show: none;

  --timer-fs:   clamp(64px, 22vh, 180px);
  --field-gap:   clamp(5px, 0.8vw, 12px);
  --field-pad-x: clamp(8px, 1.2vw, 18px);
  --lbl-fs:      clamp(13px, 1.4vw, 18px);
  --btn-fs:  clamp(12px, 1.2vw, 15px);
  --btn-pad: clamp(7px, 0.9vh, 11px) clamp(12px, 1.4vw, 20px);
}

@media (min-width: 768px) {
  :root {
    --bench-w:    clamp(130px, 16vw, 180px);
    --bench-show: flex;
    --timer-fs:   clamp(72px, 22vh, 190px);
    --field-gap:  clamp(8px, 1vw, 16px);
    --lbl-fs:     clamp(14px, 1.5vw, 20px);
  }
}
@media (min-width: 1024px) {
  :root {
    --bench-w:     clamp(160px, 16vw, 220px);
    --timer-fs:    clamp(82px, 22vh, 200px);
    --field-gap:   clamp(10px, 1.1vw, 20px);
    --field-pad-x: clamp(10px, 1.2vw, 22px);
    --btn-fs:      clamp(13px, 1.1vw, 16px);
    --lbl-fs:      clamp(15px, 1.5vw, 22px);
  }
}
@media (min-width: 1280px) {
  :root {
    --bench-w:   clamp(210px, 17vw, 280px);
    --timer-fs:  clamp(92px, 22vh, 210px);
    --field-gap: clamp(12px, 1.2vw, 22px);
    --lbl-fs:    clamp(16px, 1.6vw, 24px);
  }
}
@media (min-width: 1536px) {
  :root {
    --bench-w:   clamp(240px, 16vw, 340px);
    --timer-fs:  clamp(100px, 22vh, 220px);
    --field-gap: clamp(14px, 1.3vw, 26px);
    --lbl-fs:    clamp(17px, 1.6vw, 26px);
  }
}
@media (min-width: 1920px) {
  :root {
    --bench-w:   clamp(270px, 15vw, 380px);
    --timer-fs:  clamp(116px, 24vh, 240px);
    --field-gap: clamp(16px, 1.4vw, 30px);
    --lbl-fs:    clamp(18px, 1.7vw, 28px);
    --btn-fs:    clamp(14px, 1.1vw, 17px);
    --btn-pad:   14px 26px;
  }
}
@media (max-height: 500px) {
  :root {
    --timer-fs:   clamp(44px, 18vh, 72px);
    --field-gap:  5px;
    --bench-w:    0px;
    --bench-show: none;
    --lbl-fs:     clamp(11px, 1.2vw, 15px);
  }
}
@media (max-height: 700px) and (min-width: 768px) {
  :root {
    --timer-fs: clamp(56px, 18vh, 110px);
    --lbl-fs:   clamp(12px, 1.3vw, 17px);
  }
}
@media (hover: none) and (pointer: coarse) {
  .btn             { min-height: 48px; }
  .terrain-nav-btn { min-width: 44px; min-height: 44px; }
}

*,*::before,*::after { box-sizing: border-box; margin: 0; padding: 0; }
html,body { height: 100%; overflow: hidden; touch-action: manipulation; }
body {
  background: var(--bg);
  color: var(--text);
  font-family: 'Barlow Condensed', sans-serif;
  height: 100dvh;
  overflow: hidden;
}

/* ── App ── */
.app {
  position: fixed;
  top: var(--header-h);
  left: 0; right: 0; bottom: 0;
  display: flex;
  flex-direction: row;
  overflow: hidden;
}

/* ── Zone principale ── */
.main-zone {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

/* ── Timer zone ── */
.timer-zone {
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: clamp(3px, 0.5vh, 6px);
  padding: clamp(10px, 1.8vh, 20px) var(--field-pad-x);
  position: relative;
}

.timer-stack {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: clamp(3px, 0.5vh, 6px);
  width: fit-content;
  max-width: 92vw;
}

#time {
  font-family: 'Bebas Neue', cursive;
  font-size: var(--timer-fs);
  line-height: 0.88;
  letter-spacing: 0.04em;
  color: #fff;
  user-select: none;
  transition: color 0.3s;
  text-shadow: 0 2px 0 rgba(0,0,0,0.9), 0 0 40px rgba(255,255,255,0.05);
}
#time.warning {
  color: var(--accent);
  text-shadow: 0 2px 0 rgba(0,0,0,0.8), 0 0 50px rgba(var(--accent-rgb),0.55), 0 0 100px rgba(var(--accent-rgb),0.2);
}
#time.danger {
  color: var(--red);
  text-shadow: 0 2px 0 rgba(0,0,0,0.8), 0 0 50px rgba(255,60,60,0.6);
  animation: pulse 0.45s infinite alternate;
}
#time.done { color: var(--dim); animation: none; text-shadow: none; }

.progress-track {
  width: 100%;
  height: 3px;
  background: rgba(255,255,255,0.1);
  border-radius: 3px;
  flex-shrink: 0;
}
.progress-fill {
  height: 100%;
  background: var(--accent);
  border-radius: 3px;
  transition: width 0.1s linear, background 0.3s;
  box-shadow: 0 0 8px rgba(var(--accent-rgb),0.5);
  position: relative;
}
.progress-fill::after {
  content: '';
  position: absolute;
  right: -3px; top: 50%;
  transform: translateY(-50%);
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 8px var(--accent);
}
.progress-fill.danger { background: var(--red); box-shadow: 0 0 8px rgba(255,60,60,0.6); }
.progress-fill.danger::after { background: var(--red); box-shadow: 0 0 8px var(--red); }

.status-bar {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  font-size: clamp(10px, 1.1vw, 13px);
  font-weight: 700;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--text-dim);
  margin: 5px 0;
}
.status-dot {
  width: 5px; height: 5px; border-radius: 50%;
  background: var(--border); flex-shrink: 0;
  transition: background 0.3s, box-shadow 0.3s;
}
.status-dot.running { background: var(--accent); box-shadow: 0 0 7px var(--accent); animation: blink 1.1s infinite; }
.status-dot.done    { background: var(--red); box-shadow: 0 0 7px var(--red); }

.control-btns {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(6px, 0.8vw, 10px);
  width: 100%;
}

.btn {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: var(--btn-fs); font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  border-radius: 9px; padding: var(--btn-pad);
  cursor: pointer; transition: all 0.15s;
  min-height: 36px;
  display: flex; align-items: center; justify-content: center;
  gap: 7px; white-space: nowrap; border: 1px solid transparent;
}
.btn-main { background: var(--accent); color: #000; box-shadow: 0 3px 14px rgba(var(--accent-rgb),0.3); }
.btn-main:hover            { filter: brightness(1.08); transform: translateY(-1px); }
.btn-main.is-running       { background: var(--dim2); color: var(--text); box-shadow: none; }
.btn-main.is-running:hover { background: #243550; }
.btn-main.is-paused        { background: transparent; color: var(--accent); border-color: rgba(var(--accent-rgb),0.4); }
.btn-main.is-paused:hover  { background: rgba(var(--accent-rgb),0.07); }
.btn-reset { background: transparent; color: rgba(255,255,255,0.3); border-color: rgba(255,255,255,0.1); min-width: clamp(32px,3.5vh,42px); }
.btn-reset:hover { color: var(--red); border-color: rgba(255,60,60,0.4); background: rgba(255,60,60,0.06); }
.btn:active { transform: scale(0.96) !important; }

/* ── Terrains ── */
.terrains-zone {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: clamp(4px, 0.6vh, 8px) var(--field-pad-x) clamp(6px, 1vh, 12px);
  overflow: hidden;
}
.terrains-row {
  flex: 1;
  min-height: 0;
  width: 100%;
  display: flex;
  flex-direction: row;
  align-items: stretch;
  justify-content: center;
  gap: var(--field-gap);
  margin-top: 10px;
}
.terrain-col {
  flex: 1;
  min-width: 0;
  min-height: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: clamp(4px, 0.6vh, 8px);
}
.terrain-col-label {
  font-family: 'Bebas Neue', sans-serif;
  font-size: var(--lbl-fs);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.18);
  flex-shrink: 0;
  align-self: stretch;
  text-align: center;
  white-space: nowrap;
  line-height: 1.1;
  transition: color var(--tr);
}
.terrain-col.active .terrain-col-label { color: rgba(255,212,59,0.75); }
.terrain-slot {
  flex: 1;
  min-height: 0;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.terrain-slot .terrain-field {
  height: 90%;
  width: auto;
  max-width: 100%;
}
.terrain-field {
  display: flex;
  flex-direction: column;
  min-height: 0;
  aspect-ratio: 5 / 8;
  border-radius: clamp(8px, 1vw, 14px);
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: 0 12px 40px rgba(0,0,0,0.55), inset 0 1px 0 rgba(255,255,255,0.05);
  animation: fieldIn 0.38s cubic-bezier(0.34,1.4,0.64,1) both;
}
.terrain-field--empty {
  border-color: rgba(255,255,255,0.04);
  box-shadow: none;
  opacity: 0.3;
}
.terrain-half {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
  background: var(--team-bg, #0c1826);
  min-height: 0;
}
.terrain-half-bg {
  position: absolute; inset: 0;
  background: repeating-linear-gradient(-45deg, rgba(255,255,255,0.018) 0px, rgba(255,255,255,0.018) 1px, transparent 1px, transparent 12px);
  pointer-events: none;
}
.terrain-half-bg::after {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 75% 55% at 25% 25%, rgba(255,255,255,0.07) 0%, transparent 60%);
}
.terrain-half-content {
  position: relative; z-index: 1;
  display: flex; flex-direction: column;
  align-items: center;
  gap: clamp(3px,0.6vh,8px);
  padding: clamp(6px,1.2vh,16px) clamp(6px,1vw,14px);
  text-align: center;
}
.terrain-team-label {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(16px,min(2.6vw,3.6vh),54px);
  line-height: 1;
  letter-spacing: 0.05em;
  text-shadow: 0 2px 10px rgba(0,0,0,0.5);
  color: var(--team-text, rgba(255,255,255,0.25));
}
.terrain-team-sub {
  font-size: clamp(7px,min(0.9vw,1.3vh),13px);
  font-weight: 700;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--team-text, rgba(255,255,255,0.25));
  opacity: 0.4;
}
.terrain-divider {
  flex-shrink: 0;
  height: clamp(22px,3.5vh,38px);
  display: flex;
  align-items: center;
  background: rgba(0,0,0,0.3);
  border-top: 1px solid rgba(255,255,255,0.08);
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.terrain-divider-line { flex: 1; height: 1px; background: rgba(255,255,255,0.12); }
.terrain-divider-vs {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(10px,1.1vw,15px);
  letter-spacing: 0.14em;
  color: rgba(255,255,255,0.55);
  padding: 0 clamp(6px,0.8vw,14px);
}

/* ════════ BANC LATÉRAL ════════ */
.bench-panel {
  display: var(--bench-show);
  flex-direction: column;
  width: var(--bench-w);
  flex-shrink: 0;
  background: var(--panel2);
  border-left: 1px solid rgba(255,255,255,0.07);
  overflow: hidden;
}
.bench-header {
  flex-shrink: 0;
  height: clamp(32px,4.5vh,44px);
  display: flex; align-items: center; gap: 8px;
  padding: 0 clamp(10px,1.4vw,18px);
  border-bottom: 1px solid rgba(255,255,255,0.07);
  font-size: clamp(8px,0.9vw,11px); font-weight: 700;
  letter-spacing: 0.4em; text-transform: uppercase;
  color: rgba(255,255,255,0.22);
}
.bench-header i { font-size: clamp(9px,1vw,12px); opacity: 0.6; }
.bench-footer {
  flex-shrink: 0;
  min-height: clamp(36px, 5vh, 50px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: clamp(4px, 0.6vh, 8px) clamp(6px, 1vw, 12px);
  border-top: 1px solid rgba(255,255,255,0.07);
  gap: 0;
}
.terrain-nav-btn {
  background: transparent;
  border: none;
  color: rgba(255,255,255,0.3);
  width: clamp(26px, 2.8vh, 36px);
  height: clamp(26px, 2.8vh, 36px);
  font-size: clamp(9px, 1vh, 12px);
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: color 0.14s;
  flex-shrink: 0;
  padding: 0;
}
.terrain-nav-btn:hover:not(:disabled) { color: var(--accent); }
.terrain-nav-btn:disabled { opacity: 0.16; cursor: default; }
.bench-round-label {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(12px, 1.4vw, 18px);
  letter-spacing: 0.1em;
  color: rgba(255,255,255,0.35);
  text-align: center;
  flex: 1;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.bench-list {
  flex: 1; min-height: 0;
  overflow-y: auto; overflow-x: hidden;
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,0.08) transparent;
  display: flex; flex-direction: column;
  padding: clamp(6px,1vh,12px) clamp(8px,1.2vw,14px);
  gap: clamp(5px,0.8vh,10px);
}
.bench-list::-webkit-scrollbar { width: 3px; }
.bench-list::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.1); border-radius: 2px; }
.bench-empty {
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 8px; flex: 1;
  opacity: 0.2; text-align: center;
}
.bench-empty i { font-size: clamp(20px,3vw,32px); }
.bench-empty span {
  font-size: clamp(8px,0.9vw,11px); font-weight: 700;
  letter-spacing: 0.3em; text-transform: uppercase;
}
.bench-card {
  flex-shrink: 0;
  display: flex;
  align-items: stretch;
  border-radius: clamp(8px, 1vw, 12px);
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.025);
  animation: benchIn 0.32s cubic-bezier(0.34,1.4,0.64,1) both;
  transition: background var(--tr), border-color var(--tr);
  min-height: clamp(56px, 8vh, 80px);
}
.bench-card:hover {
  background: rgba(255,255,255,0.05);
  border-color: rgba(255,255,255,0.14);
}
.bench-card-color {
  flex-shrink: 0;
  width: clamp(44px, 5.5vw, 64px);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0.92;
}
.bench-card-initial {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(20px, 2.4vw, 32px);
  line-height: 1;
  color: rgba(255,255,255,0.88);
  text-shadow: 0 1px 4px rgba(0,0,0,0.45);
  letter-spacing: 0.04em;
}
.bench-card-info {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 3px;
  padding: clamp(6px, 0.8vh, 10px) clamp(10px, 1.2vw, 16px) clamp(4px, 0.6vh, 8px);
}
.bench-card-name {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(16px, 1.8vw, 26px);
  line-height: 1;
  letter-spacing: 0.04em;
  color: rgba(255,255,255,0.92);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.bench-card-sub {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: clamp(8px, 0.85vw, 10px);
  font-weight: 700;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: rgba(255,212,59,0.55);
}

/* ════════ MOBILE ════════ */
@media (max-width: 599px) {
  .timer-zone  { padding-left: 12px; padding-right: 12px; }
  .timer-stack { width: 100%; max-width: 100%; }
  .terrains-row { flex-direction: column; align-items: center; overflow-y: auto; }
  .terrain-col  { flex: 0 0 auto; width: min(320px,88vw); }
  .terrain-slot { flex: 0 0 auto; height: clamp(130px,30vw,190px); }
}
@media (min-width: 768px) and (max-width: 1279px) {
  .terrains-row        { max-height: 380px; }
  .bench-card          { min-height: clamp(46px, 6vh, 62px); }
  .bench-card-color    { width: clamp(34px, 4.5vw, 46px); }
  .bench-card-initial  { font-size: clamp(16px, 2vw, 22px); }
  .bench-card-name     { font-size: clamp(13px, 1.6vw, 19px); }
  .bench-card-sub      { font-size: clamp(7px, 0.8vw, 9px); }
  .bench-list          { padding: clamp(5px, 0.8vh, 9px) clamp(6px, 0.9vw, 10px); gap: clamp(4px, 0.6vh, 7px); }
  .bench-header        { padding: 0 clamp(7px, 1vw, 12px); font-size: clamp(7px, 0.8vw, 10px); }
  .bench-footer        { padding: clamp(4px, 0.5vh, 7px) clamp(5px, 0.8vw, 10px); }
}

/* ════════ PREP OVERLAY ════════ */
#prepOverlay {
  position: fixed; inset: 0; z-index: 9000;
  display: flex; align-items: center; justify-content: center;
  flex-direction: column; gap: 12px;
  background: radial-gradient(120% 120% at 50% 28%, rgba(var(--accent-rgb),0.18) 0%, rgba(9,30,60,0.94) 44%, rgba(6,20,40,0.98) 100%);
  opacity: 0; pointer-events: none; transition: opacity 0.25s;
}
#prepOverlay.visible { opacity: 1; pointer-events: all; }
#prepNumber { font-family: 'Bebas Neue', sans-serif; font-size: clamp(120px,30vw,320px); line-height: 1; color: #fff; }
#prepLabel  { font-family: 'Barlow Condensed', sans-serif; font-size: clamp(18px,3vw,28px); font-weight: 700; letter-spacing: 0.4em; text-transform: uppercase; color: rgba(255,255,255,0.65); }

/* ════════ MODAL ════════ */
.teams-overlay {
  display: none; position: fixed; inset: 0; z-index: 9999;
  background: rgba(2,8,20,0.88);
  align-items: center; justify-content: center;
  backdrop-filter: blur(12px);
}
.teams-overlay.visible { display: flex; }
.teams-modal {
  background: #07162a;
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 16px;
  width: min(860px, 94vw);
  max-height: 88vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  box-shadow: 0 32px 80px rgba(0,0,0,0.85);
  animation: modalIn 0.2s cubic-bezier(0.34,1.3,0.64,1);
}
.tm-header {
  display: flex; align-items: center;
  padding: 16px 12px;
  border-bottom: 1px solid rgba(255,255,255,0.07);
  flex-shrink: 0;
  gap: 12px;
}
.tm-title {
  flex: 1;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 13px; font-weight: 700;
  letter-spacing: 0.3em; text-transform: uppercase;
  color: rgba(255,255,255,0.5);
  display: flex; align-items: center; gap: 8px;
}
.tm-title i { color: var(--accent); font-size: 12px; }
.tm-close {
  width: 34px; height: 34px;
  background: transparent;
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 8px;
  color: rgba(255,255,255,0.35);
  font-size: 13px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: var(--tr);
}
.tm-close:hover { border-color: var(--red); color: var(--red); background: rgba(255,60,60,0.08); }
.tm-body {
  display: flex;
  flex: 1;
  min-height: 0;
  overflow: hidden;
}
.tm-divider {
  width: 1px;
  background: linear-gradient(
    to bottom,
    transparent 0%,
    rgba(255,212,59,0.15) 20%,
    rgba(255,212,59,0.22) 50%,
    rgba(255,212,59,0.15) 80%,
    transparent 100%
  );
  flex-shrink: 0;
}
.tm-section-label {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 10px; letter-spacing: 0.5em;
  text-transform: uppercase;
  color: rgba(255,212,59,0.4);
  margin-bottom: 4px;
  flex-shrink: 0;
}
.tm-params {
  flex: 0 0 clamp(280px, 52%, 420px);
  display: flex; flex-direction: column;
  padding: 16px 18px;
  gap: 2px;
  overflow-y: auto;
}
.tm-field {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  min-height: 54px;
  border-bottom: 1px solid rgba(255,255,255,0.05);
  flex-shrink: 0;
}
.tm-field:last-child { border-bottom: none; }
.tm-field-info {
  display: flex; flex-direction: column; gap: 2px;
  flex: 1; min-width: 0;
  overflow: hidden;
}
.tm-field-label {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 13px; font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: #fff;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.tm-field-sub {
  font-size: 10px; color: var(--text-dim);
  letter-spacing: 0.03em;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

/* ════════ SPIN INPUTS — pattern standard (s-spin) ════════ */
.tm-params .s-spin {
  position: relative;
  width: 76px;
}
.tm-params .s-spin input {
  font-family: 'Bebas Neue', cursive;
  font-size: 28px;
  line-height: 1;
  height: 44px;
  text-align: center;
  background: rgba(var(--input-rgb),0.88);
  border: 1px solid var(--border);
  border-radius: 10px;
  color: #fff;
  width: 100%;
  outline: none;
  transition: border-color 0.2s, box-shadow 0.2s;
  padding: 6px 32px 6px 4px;
  -moz-appearance: textfield;
  appearance: textfield;
}
.tm-params .s-spin input:focus {
  border-color: rgba(var(--accent-rgb),0.52);
  box-shadow: 0 0 0 3px rgba(var(--accent-rgb),0.08);
}
.tm-params .s-spin input::-webkit-outer-spin-button,
.tm-params .s-spin input::-webkit-inner-spin-button { -webkit-appearance: none; }
.tm-params .spin-btns {
  position: absolute;
  top: 2px; right: 3px; bottom: 2px;
  display: flex; flex-direction: column;
  justify-content: center; gap: 1px;
}
.tm-params .spin-btn {
  background: none; border: none; cursor: pointer;
  color: var(--text-dim); font-size: 13px; padding: 0;
  width: 26px; height: 26px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 5px;
  transition: color 0.14s, background 0.14s;
}
.tm-params .spin-btn:hover {
  color: var(--accent);
  background: rgba(var(--accent-rgb),0.08);
}

/* Duration row — two s-spins side by side */
.tm-duration {
  display: flex; align-items: center; gap: 6px; flex-shrink: 0;
}
.tm-dur-sep {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 24px; color: var(--text-dim); line-height: 1;
}

/* ════════ ÉQUIPES ════════ */
.tm-teams {
  flex: 1; min-width: 0;
  display: flex; flex-direction: column;
  padding: 16px 12px;
  gap: 8px;
}
.tm-teams-list {
  flex: 1; min-height: 0;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,0.1) transparent;
  border-radius: 10px;
  background: rgba(4,14,30,0.5);
}
.tm-teams-list::-webkit-scrollbar { width: 4px; }
.tm-teams-list::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.1); border-radius: 2px; }
.tm-teams-cols { display: grid; grid-template-columns: 1fr 1fr; }
.tm-teams-col  { display: flex; flex-direction: column; min-width: 0; }
.tm-teams-col-divider { display: none; }
.tm-team-row {
  display: flex; align-items: center; gap: 10px;
  min-height: 48px; padding: 0 14px;
  border-bottom: 1px solid rgba(255,255,255,0.04);
  flex-shrink: 0;
}
.tm-team-row:last-child { border-bottom: none; }
.tm-team-num {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 18px; color: rgba(255,255,255,0.2);
  min-width: 24px; text-align: right; flex-shrink: 0;
}
.tm-team-swatch {
  width: 32px; height: 32px;
  border-radius: 8px;
  border: 2px solid transparent;
  flex-shrink: 0; cursor: pointer;
  transition: transform 0.14s, border-color 0.14s, box-shadow 0.14s;
  outline: none; background-clip: padding-box;
}
.tm-team-swatch:hover { transform: scale(1.14); border-color: rgba(255,255,255,0.5); }
.tm-team-swatch:focus-visible { border-color: var(--accent); }
.tm-team-color-label {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 12px; font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: rgba(255,255,255,0.38);
  flex: 1; pointer-events: none; user-select: none;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

/* Color picker */
.tm-color-picker {
  display: flex; flex-direction: column; gap: 6px;
  padding: 10px 12px;
  background: #050f1e;
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 12px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.7);
  animation: pickerIn 0.14s cubic-bezier(0.34,1.5,0.64,1);
  margin: 2px 0 4px 44px;
  max-width: 240px;
  z-index: 9999;
}
.tm-picker-row { display: flex; gap: 6px; }
.tm-picker-swatch {
  width: 30px; height: 30px; border-radius: 7px;
  border: 2px solid transparent; cursor: pointer;
  outline: none; flex-shrink: 0;
  transition: transform 0.12s, border-color 0.12s, filter 0.12s;
}
.tm-picker-swatch:hover:not(:disabled) { transform: scale(1.2); border-color: rgba(255,255,255,0.6); }
.tm-picker-swatch.active  { border-color: #fff; transform: scale(1.1); box-shadow: 0 0 0 2px rgba(255,255,255,0.25); }
.tm-picker-swatch.disabled { filter: brightness(0.22) saturate(0.2); cursor: not-allowed; transform: none !important; }

/* Footer */
.tm-footer {
  display: flex; align-items: center;
  gap: 10px;
  padding: 14px 20px;
  border-top: 1px solid rgba(255,255,255,0.07);
  flex-shrink: 0;
  justify-content: flex-end;
}
.tm-btn-cancel {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 13px; font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase;
  padding: 10px 20px; border-radius: 8px;
  background: transparent;
  border: 1px solid rgba(255,255,255,0.12);
  color: rgba(255,255,255,0.4);
  cursor: pointer; transition: var(--tr);
  min-height: 40px;
}
.tm-btn-cancel:hover { border-color: rgba(255,255,255,0.28); color: rgba(255,255,255,0.7); }
.tm-btn-confirm {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 14px; font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase;
  padding: 10px 28px; border-radius: 8px;
  background: var(--accent); color: #000; border: none;
  cursor: pointer;
  display: flex; align-items: center; gap: 7px;
  transition: var(--tr);
  min-height: 40px;
  box-shadow: 0 3px 14px rgba(var(--accent-rgb),0.35);
}
.tm-btn-confirm:hover { filter: brightness(1.08); transform: translateY(-1px); }
.tm-btn-confirm i { font-size: 12px; }

/* Toggle switch */
.toggle-switch { position: relative; display: inline-flex; align-items: center; cursor: pointer; flex-shrink: 0; }
.toggle-switch input { opacity: 0; width: 0; height: 0; position: absolute; }
.toggle-track {
  width: 46px; height: 26px; border-radius: 26px;
  background: var(--dim2); border: 1px solid rgba(255,255,255,0.2);
  transition: background 0.2s, border-color 0.2s; position: relative;
}
.toggle-track::after {
  content: ''; position: absolute; top: 3px; left: 3px;
  width: 18px; height: 18px; border-radius: 50%;
  background: var(--text-mid);
  transition: transform 0.2s, background 0.2s;
  box-shadow: 0 1px 4px rgba(0,0,0,0.4);
}
.toggle-switch input:checked + .toggle-track { background: var(--accent); border-color: var(--accent); }
.toggle-switch input:checked + .toggle-track::after { transform: translateX(20px); background: #000; }

/* Responsive modal */
@media (max-width: 767px) {
  .teams-modal { width: min(560px, 96vw); max-height: 90vh; }
  .tm-body { flex-direction: column; overflow-y: auto; }
  .tm-divider { width: auto; height: 1px; background: rgba(255,212,59,0.12); margin: 0; }
  .tm-params { flex: 0 0 auto; overflow: visible; border-bottom: none; }
  .tm-teams  { flex: 1; min-height: 200px; }
  .tm-teams-cols { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 599px) {
  .teams-modal { width: 100vw; max-height: 100dvh; border-radius: 0; }
}

/* ════════ ANIMATIONS ════════ */
@keyframes pulse   { from { opacity:1; } to { opacity:0.5; } }
@keyframes blink   { 0%,100% { opacity:1; } 50% { opacity:0.15; } }
@keyframes modalIn { from { opacity:0; transform:scale(0.96) translateY(10px); } to { opacity:1; transform:scale(1) translateY(0); } }
@keyframes fieldIn { from { opacity:0; transform:scale(0.94) translateY(12px); } to { opacity:1; transform:scale(1) translateY(0); } }
@keyframes benchIn { from { opacity:0; transform:translateX(10px); } to { opacity:1; transform:translateX(0); } }
@keyframes pickerIn { from { opacity:0; transform:translateY(-6px) scale(0.95); } to { opacity:1; transform:translateY(0) scale(1); } }
@media (prefers-reduced-motion: reduce) { .terrain-field,.teams-modal,.bench-card { animation:none !important; } }