* { box-sizing: border-box; }
:root {
  --bg: #0f1115;
  --panel: #171a21;
  --panel-2: #1f2530;
  --text: #e5e7eb;
  --muted: #9aa3b2;
  --primary: #3b82f6;
  --secondary: #64748b;
  --accent: #22c55e;
  --danger: #ef4444;
}
html, body { height: 100%; }
body {
  margin: 0; font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background: var(--bg); color: var(--text);
}
.app-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 16px; background: var(--panel); border-bottom: 1px solid #262b36;
}
.app-logo { width: 280px; height: 200px; display: block; object-fit: contain; }
.loaders { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.flex-break { flex-basis: 100%; height: 0; }
.flex-spacer { flex: 1 1 auto; }
.loaders .btn { min-width: 200px; }
/* Small button variant */
.btn.btn-sm {
  height: 30px;
  padding: 0 10px;
  font-size: 13px;
  min-width: 120px; /* override wide header default */
  border-radius: 6px;
}
.btn {
  background: var(--primary);
  color: white;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 36px; /* uniformiser les hauteurs */
  padding: 0 12px; /* hauteur contrôlée par height */
  line-height: 1; /* éviter le gonflement des labels */
  font-size: 14px; /* harmonise la taille de police */
  font-weight: 600; /* harmonise l'épaisseur */
}
.btn:hover { filter: brightness(1.05); }
.btn-secondary { background: var(--secondary); }
.btn, a.btn, a.btn:link, a.btn:visited { text-decoration: none; color: white; }
.btn-danger { background: var(--danger); color: white; }
.btn-danger { background: var(--danger); color: white; }
.btn-danger:hover { filter: brightness(1.05); }
.btn svg { width: 16px; height: 16px; margin-right: 8px; }
.match-panel { display: flex; gap: 6px; align-items: center; margin-right: 8px; }
.match-input, .match-select { padding: 8px 10px; border-radius: 8px; border: 1px solid #2b3240; background: var(--panel-2); color: var(--text); }
.icon-btn { background: transparent; color: var(--text); border: none; font-size: 18px; cursor: pointer; }
.icon-btn:hover { color: white; }
.yt-form { display: flex; gap: 8px; }
.yt-form input { padding: 8px 10px; border-radius: 8px; border: 1px solid #2b3240; background: var(--panel-2); color: var(--text); min-width: 260px; }

.layout { display: grid; grid-template-columns: 1.4fr 1fr; height: calc(100vh - 64px); }
.left-pane { display: flex; flex-direction: column; border-right: 1px solid #262b36; }
.right-pane { padding: 12px; overflow: auto; }
.players-titlebar { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-bottom: 8px; }
.player-container { position: relative; flex: 1; background: black; display: grid; overflow: hidden; }
.video, .yt-wrapper { position: absolute; inset: 0; width: 100%; height: 100%; transform-origin: center center; will-change: transform; transition: transform 0.12s ease-out; }
.video { background: black; }
.hidden-el { display: none !important; }
.hidden { display: none !important; }
.status-bar { padding: 6px 10px; font-size: 12px; color: var(--muted); background: var(--panel); border-top: 1px solid #262b36; }

.players-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }

/* Zone remplaçants */
.subs-area {
  grid-area: subs;
  display: flex;
  gap: 6px;
  justify-content: space-between;
}
.player-card {
  background: var(--panel); border: 1px solid #262b36; border-radius: 10px; padding: 10px; display: grid; gap: 8px;
  position: relative;
}
.player-head { display: grid; grid-template-columns: 56px 1fr; gap: 10px; align-items: center; }
.player-img { width: 56px; height: 56px; border-radius: 50%; object-fit: cover; background: #0b0d11; border: 1px solid #2b3240; }
.player-name { font-weight: 600; }
.player-name.editable { cursor: text; }
.player-name.editing { outline: 2px dashed var(--primary); border-radius: 4px; padding: 2px 4px; }
.player-actions { display: flex; gap: 8px; }
.small { font-size: 12px; color: var(--muted); position: relative; }
.tag-btn { width: 100%; background: var(--accent); color: #0b0d11; border: none; padding: 8px; border-radius: 8px; cursor: pointer; font-weight: 600; }

/* Croix rouge discrète, toujours visible (sans fond rond) */
.player-remove {
  position: absolute; top: 6px; right: 8px;
  padding: 0; margin: 0; background: transparent; border: none;
  color: #ef4444; font-size: 14px; line-height: 1; font-weight: 900;
  cursor: pointer; opacity: 0.9;
}
.player-remove:hover { opacity: 1; }
.player-remove:focus-visible { outline: 2px solid #ffffff55; border-radius: 4px; }

.modal { position: fixed; inset: 0; background: rgba(0,0,0,0.6); display: grid; place-items: center; z-index: 10000; }
.modal.hidden { display: none; }
.modal-content { width: 680px; max-width: calc(100vw - 24px); background: var(--panel); border: 1px solid #2b3240; border-radius: 12px; overflow: hidden; position: relative; z-index: 10001; }
.modal-header { display: flex; justify-content: space-between; align-items: center; padding: 10px 12px; border-bottom: 1px solid #2b3240; }
.modal-footer { display: flex; justify-content: flex-end; gap: 8px; padding: 10px 12px; border-top: 1px solid #2b3240; }
.events-list { padding: 12px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; max-height: 45vh; overflow: auto; }
.event-item { background: var(--panel-2); border: 1px solid #2b3240; padding: 14px 12px; border-radius: 10px; cursor: pointer; text-align: center; font-weight: 600; letter-spacing: .2px; color: #ffffff; }
.event-item:hover { outline: 2px solid var(--primary); filter: brightness(1.05); }
.event-item.drag-over { outline: 2px dashed var(--accent); }

/* Animation de sélection d'événement */
.event-item.selected { background: var(--primary); color: white; animation: pulse 0.35s ease; }
@keyframes pulse {
  0% { transform: scale(1); }
  50% { transform: scale(1.04); }
  100% { transform: scale(1); }
}

/* Surbrillance temporaire de la carte joueur après tag */
.player-card.highlight { outline: 2px solid var(--accent); animation: flash 0.6s ease; }
/* Drag & drop visuel sur la feuille de match */
.player-card.drag-over { outline: 2px dashed var(--primary); outline-offset: 2px; }
.player-card.dragging { outline: 2px dashed var(--accent); outline-offset: 2px; }
@keyframes flash {
  0% { box-shadow: 0 0 0 0 rgba(34,197,94,0.7); }
  100% { box-shadow: 0 0 0 10px rgba(34,197,94,0); }
}

/* Toast +1 au niveau des stats du joueur */
.plus-one { position: absolute; right: 10px; top: -6px; background: var(--accent); color: #0b0d11; padding: 2px 6px; border-radius: 999px; font-size: 12px; font-weight: 700; opacity: 0; transform: translateY(6px); animation: rise 700ms ease forwards; }
@keyframes rise {
  0% { opacity: 0; transform: translateY(8px); }
  40% { opacity: 1; }
  100% { opacity: 0; transform: translateY(-10px); }
}

@media (min-width: 1400px) {
  .players-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 1100px) {
  .layout { grid-template-columns: 1fr; }
}

/* Sessions modal */
.sessions-list { display: grid; gap: 8px; }
.session-row { display: grid; grid-template-columns: 1fr auto; align-items: center; background: var(--panel-2); border: 1px solid #2b3240; border-radius: 10px; padding: 10px 12px; }
.session-title { font-weight: 600; }
.session-actions { display: flex; gap: 6px; }

/* Rosters modal */
.rosters-toolbar { padding: 10px 12px; display: flex; gap: 8px; align-items: center; border-bottom: 1px solid #2b3240; flex-wrap: wrap; }
.rosters-body { padding: 12px; display: grid; gap: 10px; }
.roster-actions { display: flex; gap: 8px; align-items: center; }
.roster-players { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; max-height: 50vh; overflow: auto; }
.roster-card { background: var(--panel-2); border: 1px solid #2b3240; border-radius: 10px; padding: 10px; display: grid; gap: 8px; position: relative; }
.roster-img { width: 80px; height: 80px; border-radius: 8px; object-fit: cover; background: #0b0d11; border: 1px solid #2b3240; }
.roster-head { display: grid; grid-template-columns: 86px 1fr; gap: 10px; align-items: center; }
.roster-name { font-weight: 600; }
.roster-name.editing { outline: 2px dashed var(--primary); border-radius: 4px; padding: 2px 4px; }
.roster-select { position: absolute; top: 8px; right: 8px; width: 18px; height: 18px; }
