/* ═══════════════════════════════════════════════════
   EMULATION.CSS — Système de points · PhysEdBoard
   ═══════════════════════════════════════════════════ */

/* ── Design tokens ── */
:root {
  --bg:         #061428;
  --panel:      #0d2040;
  --border:     #1a3a60;
  --border-hi: rgba(255, 255, 255, 0.08);
  --accent:     #ffd43b;
  --red:        #ff3c3c;
  --text:       rgba(255,255,255,0.88);
  --dim:        rgba(255,255,255,0.45);
  --dim2:       rgba(255,255,255,0.20);
  --card-r:     20px;
  --gap:        14px;
  --pad:        20px;
  --topbar-h:   60px;   /* height reserved for bottom topbar */
  --topbar-b:   20px;
  --topbar-r:   20px;
  --topbar-fs:  12px;
  --topbar-pad: 9px 20px;
}

@media (max-width: 899px) {
  :root {
    --card-r:    16px;
    --gap:       10px;
    --pad:       14px;
    --topbar-b:  14px;
    --topbar-r:  14px;
    --topbar-fs: 10px;
  }
}

@media (max-width: 599px) {
  :root {
    --card-r:     12px;
    --gap:        8px;
    --pad:        10px;
    --topbar-b:   10px;
    --topbar-r:   10px;
    --topbar-fs:  9px;
    --topbar-pad: 7px 12px;
  }
}

/* ═══════════════════════════════════════════════════
   RESET
   ═══════════════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { height: 100%; touch-action: manipulation; }

/*
  body scrolls on portrait tablets where cards need
  more vertical space than the viewport offers.
  On landscape / desktop it will still be overflow:hidden
  because the JS fits everything in the viewport.
*/
body {
  background: var(--bg);
  color: var(--text);
  font-family: 'Barlow Condensed', sans-serif;
  min-height: 100dvh;
  overflow-x: hidden;
  overflow-y: auto;
}

/* Grid texture */
body::before {
  content: '';
  position: fixed; inset: 0; pointer-events: none; z-index: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.04) 1px, transparent 1px);
  background-size: 40px 40px;
}

/* Vignette */
body::after {
  content: '';
  position: fixed; inset: 0; pointer-events: none; z-index: 0;
  background: radial-gradient(ellipse 80% 70% at 50% 50%,
    transparent 30%, rgba(4,8,16,0.92) 100%);
}

/* ═══════════════════════════════════════════════════
   APP SHELL
   ═══════════════════════════════════════════════════ */
.app {
  position: relative; z-index: 1;
  width: 100%;
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
}

.stage {
  flex: 1;
  display: flex;
  flex-direction: column;
}

/*
  Layout wrapper: centres the card grid.
  padding-bottom = topbar height + extra breathing room.
  JS measures this element's inner dimensions to size cards.
*/
.systemePoints-layout {
  position: relative; z-index: 1;
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--pad) var(--pad);
  /* Let content push height on portrait when needed */
  min-height: 0;
}

/* ═══════════════════════════════════════════════════
   TOPBAR
   ═══════════════════════════════════════════════════ */
.systemePoints-topbar {
  position: fixed;
  bottom: var(--topbar-b);
  right:  var(--topbar-r);
  z-index: 90;
  display: flex; align-items: center; gap: 8px;
}

.systemePoints-config-top-btn,
.systemePoints-reset-top-btn {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: var(--topbar-fs); font-weight: 700;
  letter-spacing: 0.25em; text-transform: uppercase;
  padding: var(--topbar-pad); border-radius: 30px;
  cursor: pointer; display: inline-flex; align-items: center; gap: 7px;
  transition: all 0.2s; min-height: 40px;
}
.systemePoints-config-top-btn {
  background: var(--accent); color: #000; border: none;
  box-shadow: 0 4px 18px rgba(255,212,59,0.35);
}
.systemePoints-config-top-btn:hover {
  box-shadow: 0 6px 26px rgba(255,212,59,0.55);
  transform: translateY(-1px);
}
.systemePoints-reset-top-btn {
  background: transparent;
  border: 1px solid rgba(255,60,60,0.25);
  color: rgba(255,80,80,0.5);
}
.systemePoints-reset-top-btn:hover {
  border-color: var(--red); color: var(--red);
  background: rgba(255,60,60,0.07);
}

/* ═══════════════════════════════════════════════════
   SCORE GRID
   Width + grid-template-columns set by JS.
   ═══════════════════════════════════════════════════ */
.systemePoints-grid {
  display: grid;
  gap: var(--gap);
  /* width set by JS to fill available space */
}

/* ═══════════════════════════════════════════════════
   CARD — always a perfect square via aspect-ratio.
   All internals scale with container query units (cqw)
   so they auto-fit whatever card size JS produces.
   ═══════════════════════════════════════════════════ */
.systemePoints-card {
  container-type: inline-size;
  aspect-ratio: 1 / 1;
  width: 100%;
  border-radius: var(--card-r);
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
  background: var(--sp-accent, #1d4ed8);
  cursor: default;
  animation: spCardIn 0.42s cubic-bezier(0.22,1,0.36,1) both;
  box-shadow:
    inset 0  1px 0 rgba(255,255,255,0.26),
    inset 0 -3px 0 rgba(0,0,0,0.32),
    0 1px 0 rgba(0,0,0,0.55),
    0 4px 0 rgba(0,0,0,0.28),
    0 8px 0 rgba(0,0,0,0.12),
    0 18px 42px rgba(0,0,0,0.52);
  transition:
    transform  0.22s cubic-bezier(0.22,1,0.36,1),
    box-shadow 0.22s cubic-bezier(0.22,1,0.36,1);
}
.systemePoints-card:hover {
  transform: translateY(-4px) scale(1.015);
  box-shadow:
    inset 0  1px 0 rgba(255,255,255,0.30),
    inset 0 -3px 0 rgba(0,0,0,0.36),
    0 1px 0 rgba(0,0,0,0.55),
    0 4px 0 rgba(0,0,0,0.28),
    0 8px 0 rgba(0,0,0,0.12),
    0 28px 60px rgba(0,0,0,0.68),
    0 0 0 1px rgba(255,255,255,0.06);
}

/* Gloss */
.systemePoints-card::before {
  content: '';
  position: absolute; inset: 0; border-radius: inherit;
  pointer-events: none; z-index: 1;
  background: linear-gradient(142deg,
    rgba(255,255,255,0.20) 0%,
    rgba(255,255,255,0.06) 32%,
    transparent 58%);
}

/* Grain */
.systemePoints-card::after {
  content: '';
  position: absolute; inset: 0; border-radius: inherit;
  pointer-events: none; z-index: 2;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.72' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.1'/%3E%3C/svg%3E");
  background-size: 160px;
  mix-blend-mode: overlay; opacity: 0.5;
}

/* Vignette overlay */
.sp-vignette {
  position: absolute; inset: 0; border-radius: inherit;
  pointer-events: none; z-index: 1;
  background: radial-gradient(ellipse 90% 80% at 50% 50%,
    transparent 38%, rgba(0,0,0,0.24) 100%);
}

/* ── Score row: fills all space above footer ── */
.systemePoints-score-row {
  flex: 1;
  min-height: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 3cqw;
  padding: 6cqw 4cqw 0;
  position: relative; z-index: 3;
}

/* Score number — 45% of card width */
.systemePoints-score {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(22px, 45cqw, 220px);
  line-height: 0.88;
  letter-spacing: -0.01em;
  color: #fff;
  min-width: 2.2ch;
  text-align: center;
  font-variant-numeric: tabular-nums;
  user-select: none;
  text-shadow:
    0  1px 0 rgba(255,255,255,0.20),
    0 -1px 0 rgba(0,0,0,0.28),
    0  4px 16px rgba(0,0,0,0.45),
    0  8px 32px rgba(0,0,0,0.28);
}
.systemePoints-score.score-bump {
  animation: scoreBump 0.28s cubic-bezier(0.34,1.8,0.64,1);
}

/* +/– buttons — 13% of card width */
.systemePoints-score-btn {
  width:  clamp(26px, 13cqw, 62px);
  height: clamp(26px, 13cqw, 62px);
  background: transparent;
  color: rgba(255,255,255,0.85);
  font-size: clamp(15px, 20cqw, 60px);
  cursor: pointer;
  flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  border: none;
  text-shadow: 
      0 1px 0 rgba(255, 255, 255, 0.20), 
      0 -1px 0 rgba(0, 0, 0, 0.28), 
      0 4px 16px rgba(0, 0, 0, 0.45), 
      0 8px 32px rgba(0, 0, 0, 0.28);
}
.systemePoints-score-btn:hover {
  color: #fff;
  transform: scale(1.13);
}
.systemePoints-score-btn:active { transform: scale(0.88); }

/* ── Footer ── */
.sp-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 3cqw 5cqw 4.5cqw;
  position: relative; z-index: 3;
  gap: 2cqw;
  flex-shrink: 0;
}
.sp-card-footer::before {
  content: '';
  position: absolute; top: 0; left: 8%; right: 8%; height: 1px;
  background: linear-gradient(90deg,
    transparent,
    rgba(255,255,255,0.18) 20%,
    rgba(255,255,255,0.18) 80%,
    transparent);
}

.systemePoints-team-name {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: clamp(9px, 3.8cqw, 20px);
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.78);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  flex: 1;
  text-shadow: 0 1px 4px rgba(0,0,0,0.40);
}

.systemePoints-edit-btn {
  width:  clamp(20px, 7cqw, 30px);
  height: clamp(20px, 7cqw, 30px);
  background: transparent;
  border: none;
  color: rgba(255,255,255,0.55);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-left: auto;
  cursor: pointer;
  font-size: clamp(12px, 5cqw, 16px);
  flex-shrink: 0;
  transition: all 0.14s;
}

.systemePoints-edit-btn:hover {
  border-color: rgba(255,255,255,0.44);
  color: #fff;
}

/* ═══════════════════════════════════════════════════
   COLOR PICKER POPUP
   ═══════════════════════════════════════════════════ */
.sp-color-picker-popup {
  position: absolute; bottom: 46px; right: 10px; z-index: 500;
  background: #0f1f34;
  border: 1px solid rgba(255,255,255,0.10); border-radius: 14px;
  padding: 10px; display: flex; flex-wrap: wrap; gap: 6px; width: 160px;
  box-shadow: 0 20px 54px rgba(0,0,0,0.82), 0 0 0 1px rgba(255,255,255,0.04);
  animation: popupIn 0.15s cubic-bezier(0.34,1.4,0.64,1);
}
.sp-swatch {
  width: 28px; height: 28px;
  border-radius: 8px; border: 2px solid transparent; cursor: pointer;
  transition: transform 0.12s, border-color 0.12s, box-shadow 0.12s;
}
.sp-swatch:hover { transform: scale(1.20); box-shadow: 0 4px 14px rgba(0,0,0,0.5); }
.sp-swatch.active { border-color: #fff; box-shadow: 0 0 0 1px rgba(255,255,255,0.35); }

/* ═══════════════════════════════════════════════════
   MODALS
   ═══════════════════════════════════════════════════ */
.systemePoints-overlay,
.systemePoints-reset-overlay {
  display: none; position: fixed; inset: 0; z-index: 400;
  background: rgba(4,8,16,0.88);
  align-items: center; justify-content: center;
  backdrop-filter: blur(14px);
}
.systemePoints-overlay.visible,
.systemePoints-reset-overlay.visible { display: flex; }

.systemePoints-modal {
  background: #08182e;
  border: 1px solid rgba(255,255,255,0.08); border-radius: 22px;
  width: min(550px, 90vw); max-height: 90vh;
  display: flex; flex-direction: column; overflow: hidden;
  box-shadow: 0 40px 80px rgba(0,0,0,0.88), 0 0 0 1px rgba(255,255,255,0.04);
  animation: modalIn 0.22s cubic-bezier(0.34,1.4,0.64,1);
}
.systemePoints-header {
  display: flex; align-items: center; gap: 10px;
  padding: 20px 18px 20px;  flex-shrink: 0;
  background-color: rgba(255, 255, 255, 0.02);
  border-bottom: 1px solid var(--border-hi);
}
.systemePoints-title {
  flex: 1;
  font-size: clamp(12px, 2vw, 15px);
  font-weight: 700;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--text);
  display: flex;
  align-items: center;
  gap: 8px;
}
.systemePoints-title i { font-size: clamp(12px, 2vw, 15px); color: var(--accent); opacity: 0.8; }
.systemePoints-close {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 11px; font-weight: 700; letter-spacing: 0.12em;
  background: transparent; border: 1px solid var(--border); border-radius: 6px;
  color: var(--dim2); padding: 4px 10px; cursor: pointer;
  transition: all 0.15s; min-height: 30px;
}
.systemePoints-close:hover { border-color: var(--red); color: var(--red); }

.systemePoints-body {
  flex: 1; overflow-y: auto;
  display: flex; flex-direction: column;
}
.systemePoints-label {
  font-size: clamp(12px, 2vw, 15px); font-weight: 700;
  letter-spacing: 0.25em; text-transform: uppercase; color: var(--text);
}
.systemePoints-footer {
  display: flex; gap: 8px; justify-content: flex-end;
  padding: 0px 18px 10px; flex-shrink: 0;
}
.systemePoints-btn-secondary {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: clamp(12px, 2vw, 15px); font-weight: 700; letter-spacing: 0.12em;
  background: transparent; border: 1px solid var(--border); border-radius: 6px;
  color: var(--dim2); padding: 10px 18px; cursor: pointer; text-transform: uppercase;
  transition: all 0.15s; min-height: 40px;
}
.systemePoints-btn-secondary:hover { border-color: var(--red); color: var(--red); }

.systemePoints-btn-next {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: clamp(12px, 2vw, 15px); font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase;
  padding: 10px 22px; border-radius: 8px; cursor: pointer;
  background: var(--accent); color: #000; border: none;
  transition: filter 0.15s, transform 0.15s; min-height: 40px;
}
.systemePoints-btn-next:hover { filter: brightness(1.1); transform: translateY(-1px); }

/* ── Count row ── */
.systemePoints-count-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 15px 18px 5px; 
}
.systemePoints-count-select {
  font-family: 'Bebas Neue', sans-serif; font-size: 26px;
  background: var(--bg); border: 1px solid var(--border); border-radius: 8px;
  color: var(--text); padding: 4px 14px; outline: none; cursor: pointer;
  transition: border-color 0.15s;
}
.systemePoints-count-select:focus { border-color: var(--accent); }

/* ── Team list in modal ── */
#systemePointsTeamList {
  display: grid; grid-template-columns: 1fr 1fr; gap: 0 16px; padding: 10px 18px;
}
.sp-team-row {
  display: flex; align-items: center; gap: 16px;
  padding: 9px 0; border-bottom: 1px solid rgba(255,255,255,0.06); min-width: 0;
}
#systemePointsTeamList .sp-team-row:nth-last-child(-n+2) { border-bottom: none; }

.sp-team-num {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: clamp(12px, 2vw, 15px); font-weight: 700; letter-spacing: 0.25em; text-transform: uppercase;
  color: var(--text); min-width: 80px;
}
.sp-color-select-wrap { display: flex; align-items: center; gap: 10px; flex: 1; min-width: 0; }
.sp-color-preview {
  width: 28px; height: 28px; border-radius: 6px;
  border: 2px solid rgba(255,255,255,0.20); flex-shrink: 0;
}
.sp-color-select {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: clamp(12px, 2vw, 15px); font-weight: 600; letter-spacing: 0.08em;
  background: var(--bg); border: 1px solid var(--border); border-radius: 6px;
  color: var(--text); padding: 8px 6px; cursor: pointer; outline: none;
  width: 100%; transition: border-color 0.15s;
}
.sp-color-select:focus { border-color: var(--accent); }

.setup-divider { height: 1px; background: var(--border-hi); margin: 10px 0; }

/* No spinners */
input[type="number"] { -moz-appearance: textfield; appearance: textfield; }
input[type="number"]::-webkit-outer-spin-button,
input[type="number"]::-webkit-inner-spin-button { -webkit-appearance: none; }

/* Scrollbar */
::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.10); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: rgba(255,255,255,0.20); }

/* ═══════════════════════════════════════════════════
   KEYFRAMES
   ═══════════════════════════════════════════════════ */
@keyframes spCardIn {
  from { opacity: 0; transform: scale(0.86) translateY(20px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}
@keyframes scoreBump {
  0%   { transform: scale(1); }
  45%  { transform: scale(1.20); }
  72%  { transform: scale(0.96); }
  100% { transform: scale(1); }
}
@keyframes popupIn {
  from { opacity: 0; transform: scale(0.88) translateY(6px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}
@keyframes modalIn {
  from { opacity: 0; transform: scale(0.95) translateY(8px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}