html.tm-html {
  scroll-behavior: smooth;
  scroll-padding-top: var(--navbar-h);
}
.tm-page {
  position: relative;
  background: var(--bg-deep);
  overflow-x: hidden;
}
.tm-snap {
  height: 100dvh;
  min-height: 560px;
  scroll-snap-align: start;
}

/* ============================================================
   NAV VERTICALE
   ============================================================ */
.tm-game-nav {
  position: fixed;
  top: 50%;
  right: clamp(10px, 1.5vw, 22px);
  transform: translateY(-50%);
  z-index: 50;
  display: flex; flex-direction: column;
  gap: 12px; padding: 12px 8px;
  background: rgba(6,18,38,0.6);
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  outline: 1px solid var(--border-md); outline-offset: -1px;
  clip-path: var(--clip-card-alt);
}
.tm-game-nav__btn {
  position: relative;
  display: flex; align-items: center; justify-content: center;
  width: 42px; height: 42px;
  background: rgba(8,20,50,0.7);
  outline: 1px solid var(--border); outline-offset: -1px;
  border: none; cursor: pointer;
  clip-path: var(--clip-icon);
  transition: outline-color var(--tr), background var(--tr);
}
.tm-game-nav__btn:hover,
.tm-game-nav__btn.active {
  outline-color: var(--accent);
  background: rgba(94,170,255,0.18);
}
.tm-game-nav__btn.active { box-shadow: 0 0 14px rgba(94,170,255,0.38); }
.tm-game-nav__icon { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; }
.tm-game-nav__icon img { width: 26px; height: 26px; object-fit: contain; }
.tm-game-nav__icon--orga { color: var(--accent); }
.tm-game-nav__label {
  position: absolute;
  right: calc(100% + 10px); top: 50%;
  transform: translateY(-50%) translateX(-4px);
  white-space: nowrap;
  font-size: 10px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--text);
  background: rgba(4,12,24,0.95);
  -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
  outline: 1px solid var(--border-md); outline-offset: -1px;
  padding: 5px 10px;
  clip-path: var(--clip-tag);
  pointer-events: none; opacity: 0;
  transition: opacity var(--tr), transform var(--tr);
}
.tm-game-nav__btn:hover .tm-game-nav__label { opacity: 1; transform: translateY(-50%) translateX(0); }

@media (max-width: 900px) {
  .tm-game-nav {
    top: auto; right: 50%; bottom: 10px;
    transform: translateX(50%);
    flex-direction: row; gap: 9px; padding: 7px 10px;
  }
  .tm-game-nav__btn { width: 36px; height: 36px; }
  .tm-game-nav__icon img { width: 21px; height: 21px; }
  .tm-game-nav__label { display: none; }
}

/* ============================================================
   GAME SECTION
   ============================================================ */
.tm-game {
  position: relative;
  height: 100dvh; min-height: 560px;
  padding: calc(var(--navbar-h) + clamp(8px,1.2vw,18px)) var(--page-pad) clamp(10px,1.4vw,22px);
  overflow: hidden;
  display: flex; flex-direction: column;
}
.tm-game__inner {
  position: relative; z-index: 2;
  flex: 1;
  display: flex; flex-direction: column;
  min-height: 0;
  overflow: hidden;
}
.tm-game::before {
  content: '';
  position: absolute;
  top: var(--navbar-h); left: var(--page-pad); right: var(--page-pad);
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.16), transparent);
  z-index: 3;
}

/* Header */
.tm-game__header {
  display: flex; align-items: center;
  gap: clamp(10px,1.3vw,18px);
  margin-bottom: clamp(6px,0.9vw,14px);
  flex-shrink: 0;
}
.tm-game__badge {
  width: clamp(36px,3.8vw,50px); height: clamp(36px,3.8vw,50px);
  background: rgba(8,20,50,0.8);
  outline: 1px solid var(--border-hi); outline-offset: -1px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; clip-path: var(--clip-icon);
}
.tm-game__badge img { width: 65%; height: 65%; object-fit: contain; }
.tm-game__head-titles { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.tm-game__eyebrow {
  font-size: clamp(8px,0.7vw,9.5px); font-weight: 700;
  letter-spacing: 0.26em; text-transform: uppercase; color: var(--accent);
}
.tm-game__title {
  font-family: var(--font-display);
  font-size: clamp(34px,4.5vw,64px);
  line-height: 0.9; color: var(--text); letter-spacing: 0.01em;
}
.tm-game__title em { font-style: normal; color: var(--accent); }

/* ============================================================
   LAYOUT 2 colonnes
   ============================================================ */
.tm-game__layout {
  flex: 1;
  display: grid;
  grid-template-columns: 1fr clamp(240px, 24vw, 310px);
  gap: clamp(12px, 1.7vw, 26px);
  align-items: stretch;
  min-height: 0;
  overflow: hidden;
}
.tm-game--right .tm-game__layout {
  grid-template-columns: clamp(240px, 24vw, 310px) 1fr;
}

/* ============================================================
   ROSTER — largeur calculée pour ne jamais déborder
   ============================================================ */
.tm-game__roster {
  display: flex;
  flex-direction: column;
  gap: clamp(4px,0.5vw,7px);
  min-height: 0;
  overflow: hidden;
  /* Largeur plafonnee par la HAUTEUR du viewport
     pour que les cartes (aspect 3/4) ne depassent jamais
     verticalement, meme sur grand ecran */
  width: 100%;
  min-width: 0;
  max-width: min(100%, calc(95vh - 160px));
  margin-right: auto;
}

.tm-roster-subtitle {
  font-size: clamp(7.5px,0.65vw,9px); font-weight: 700;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--text-muted);
  display: flex; align-items: center; gap: 8px;
  flex-shrink: 0; margin: 0;
}
.tm-roster-subtitle::after {
  content: ''; flex: 1; height: 1px;
  background: linear-gradient(90deg, var(--border-md), transparent);
}
.tm-game--bs .tm-roster-subtitle { color: rgba(255,200,80,0.8); }
.tm-game--rl .tm-roster-subtitle { color: rgba(94,155,255,0.8); }

/* ============================================================
   GRILLE — toujours 3 colonnes, joueurs ET managers
   ============================================================ */
/* ============================================================
   ROSTER & CARDS — refonte complete (3 joueurs + 2 managers)
   Disposition différente par section :
   • BS : Cascade diagonale (chaque carte progressivement plus basse)
   • RL : Hero asymétrique (1 grosse carte + 2 petites empilées)
   ============================================================ */

/* ── CARD de base ── */
.tm-card {
  position: relative;
  display: block;
  width: 100%;
  aspect-ratio: 3 / 4;
  overflow: hidden;
  background: #0a1525;
  outline: 1px solid var(--border);
  outline-offset: -1px;
  text-decoration: none;
  cursor: pointer;
  transition: transform 0.35s cubic-bezier(.2,.8,.2,1),
              outline-color var(--tr),
              box-shadow var(--tr);
  will-change: transform;

  /* Octogone aux 4 angles coupés EGAUX */
  --corner: clamp(8px, 0.9vw, 12px);
  clip-path: polygon(
    var(--corner) 0,
    calc(100% - var(--corner)) 0,
    100% var(--corner),
    100% calc(100% - var(--corner)),
    calc(100% - var(--corner)) 100%,
    var(--corner) 100%,
    0 calc(100% - var(--corner)),
    0 var(--corner)
  );
}

/* Photo */
.tm-card__photo {
  position: absolute;
  inset: 0;
  z-index: 1;
}
.tm-card__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
/* Fallback si pas d'image : couleur de fond par jeu */
.tm-game--bs .tm-card { background: #2a0c05; }
.tm-game--rl .tm-card { background: #061638; }
.tm-card--manager     { background: #001f1d; }

/* Overlay sombre en bas pour la lisibilité du nom (38% de la carte) */
.tm-card::after {
  content: '';
  position: absolute;
  inset: 62% 0 0 0;
  z-index: 2;
  background: linear-gradient(to top,
    rgba(2,5,16,0.92) 0%,
    rgba(2,5,16,0.55) 55%,
    transparent 100%
  );
  pointer-events: none;
}

/* Bloc info en bas */
.tm-card__caption {
  position: absolute;
  inset: auto 0 0 0;
  z-index: 3;
  padding: clamp(8px, 1vw, 14px) clamp(9px, 1.1vw, 14px);
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.tm-card__role {
  font-size: clamp(7px, 0.6vw, 9px);
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  line-height: 1;
  color: var(--accent);
}
.tm-game--bs .tm-card:not(.tm-card--manager) .tm-card__role { color: #ffc850; }
.tm-game--rl .tm-card:not(.tm-card--manager) .tm-card__role { color: #5e9bff; }
.tm-card--manager .tm-card__role { color: var(--accent-teal); }

.tm-card__name {
  font-family: var(--font-display);
  font-size: clamp(13px, 1.2vw, 17px);
  color: var(--text);
  line-height: 1.05;
  letter-spacing: 0.01em;
}

.tm-card__handle {
  font-size: clamp(8px, 0.7vw, 10px);
  color: var(--text-muted);
  margin-top: 1px;
  letter-spacing: 0.02em;
}

/* Hover : lift + shadow + outline coloré */
.tm-card:hover {
  outline-color: var(--border-hi);
  box-shadow: 0 14px 32px -10px rgba(0,0,0,0.65);
  z-index: 5;
}
.tm-game--bs .tm-card:not(.tm-card--manager):hover { outline-color: rgba(255,200,80,0.6); }
.tm-game--rl .tm-card:not(.tm-card--manager):hover { outline-color: rgba(94,155,255,0.6); }
.tm-card--manager:hover { outline-color: var(--accent-teal); }

/* ── ROSTER wrapper ── */
.tm-roster {
  display: flex;
  flex-direction: column;
  gap: clamp(10px, 1.2vw, 16px);
  min-width: 0;
  flex: 1;
  overflow: hidden;
}

/* ============================================================
   DISPOSITION BS — Cascade diagonale
   3 cartes joueurs : chacune progressivement plus basse.
   Staff : 2 cartes centrées en pair compact.
   ============================================================ */
.tm-roster--bs .tm-roster__players {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(12px, 1.4vw, 18px);
  align-items: start;
  padding-bottom: clamp(40px, 5vw, 70px); /* place pour la cascade */
}
.tm-roster--bs .tm-roster__players .tm-card:nth-child(1) { transform: translateY(0); }
.tm-roster--bs .tm-roster__players .tm-card:nth-child(2) { transform: translateY(clamp(20px, 2.5vw, 36px)); }
.tm-roster--bs .tm-roster__players .tm-card:nth-child(3) { transform: translateY(clamp(40px, 5vw, 70px)); }

.tm-roster--bs .tm-roster__players .tm-card:nth-child(1):hover { transform: translateY(-6px); }
.tm-roster--bs .tm-roster__players .tm-card:nth-child(2):hover { transform: translateY(calc(clamp(20px, 2.5vw, 36px) - 6px)); }
.tm-roster--bs .tm-roster__players .tm-card:nth-child(3):hover { transform: translateY(calc(clamp(40px, 5vw, 70px) - 6px)); }

.tm-roster--bs .tm-roster__staff {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(12px, 1.4vw, 18px);
  width: min(72%, 100%);
  margin: 0 auto;
}

/* ============================================================
   DISPOSITION RL — Cascade INVERSEE (miroir de BS)
   3 cartes joueurs : chacune progressivement plus haute
   (au lieu de descendre comme BS, elles montent)
   Staff : 2 cartes centrees, miroir de BS
   ============================================================ */
.tm-roster--rl .tm-roster__players {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(12px, 1.4vw, 18px);
  align-items: end;
  padding-top: clamp(40px, 5vw, 70px); /* espace pour la cascade ascendante */
}
/* Inversion : carte 1 en bas, carte 3 en haut (miroir vertical de BS) */
.tm-roster--rl .tm-roster__players .tm-card:nth-child(1) { transform: translateY(0); }
.tm-roster--rl .tm-roster__players .tm-card:nth-child(2) { transform: translateY(calc(-1 * clamp(20px, 2.5vw, 36px))); }
.tm-roster--rl .tm-roster__players .tm-card:nth-child(3) { transform: translateY(calc(-1 * clamp(40px, 5vw, 70px))); }

.tm-roster--rl .tm-roster__players .tm-card:nth-child(1):hover { transform: translateY(-6px); }
.tm-roster--rl .tm-roster__players .tm-card:nth-child(2):hover { transform: translateY(calc(-1 * clamp(20px, 2.5vw, 36px) - 6px)); }
.tm-roster--rl .tm-roster__players .tm-card:nth-child(3):hover { transform: translateY(calc(-1 * clamp(40px, 5vw, 70px) - 6px)); }

.tm-roster--rl .tm-roster__staff {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(12px, 1.4vw, 18px);
  width: min(72%, 100%);
  margin: 0 auto;
}

/* Hover staff RL & BS */
.tm-roster--rl .tm-roster__staff .tm-card:hover { transform: translateY(-4px); }
.tm-roster--bs .tm-roster__staff .tm-card:hover { transform: translateY(-4px); }

/* ============================================================
   SIDEBAR — colonne compacte (largeur reduite)
   ============================================================ */
.tm-game__sidebar {
  display: flex;
  flex-direction: column;
  gap: clamp(8px, 0.9vw, 12px);
  min-height: 0;
  overflow: hidden;
}


/* ============================================================
   INTRO CARD — description du jeu + image 16:9
   Design assorti à Achievement (octogone, bande d'accent, glow)
   ============================================================ */
.tm-intro-card {
  position: relative;
  flex-shrink: 0;
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
  gap: clamp(10px, 1vw, 16px);
  padding: clamp(8px, 0.9vw, 12px);
  background: linear-gradient(150deg, #08111f 0%, #050a14 100%);
  outline: 1px solid rgba(255,255,255,0.10);
  outline-offset: -1px;
  overflow: hidden;

  /* Octogone : miroir d'achievement (haut-droite + bas-gauche) */
  --ic-corner: clamp(12px, 1.3vw, 20px);
  --ic-cut: clamp(8px, 0.8vw, 12px);
  clip-path: polygon(
    0 0,
    calc(100% - var(--ic-corner)) 0,
    100% var(--ic-corner),
    100% 100%,
    var(--ic-cut) 100%,
    0 calc(100% - var(--ic-cut))
  );
}

/* Bande verticale d'accent (côté droit, miroir de Achievement) */
.tm-intro-card::before {
  content: '';
  position: absolute;
  right: 0; top: 0; bottom: 0;
  width: 3px;
  background: linear-gradient(180deg,
    transparent 0%,
    var(--accent) 12%,
    var(--accent) 88%,
    transparent 100%);
  z-index: 3;
  opacity: 0.85;
}

/* Glow ambiant */
.tm-intro-card::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 55% 45% at 100% 0%, rgba(94,170,255,0.10), transparent 65%);
  pointer-events: none;
  z-index: 0;
}

/* Variantes couleur par jeu */
.tm-game--bs .tm-intro-card {
  background: linear-gradient(150deg, #2a0c05 0%, #150402 100%);
  outline-color: rgba(255,200,80,0.22);
}
.tm-game--bs .tm-intro-card::before { background: linear-gradient(180deg, transparent, #ffc850 12%, #ff8a3c 88%, transparent); }
.tm-game--bs .tm-intro-card::after  { background: radial-gradient(ellipse 55% 45% at 100% 0%, rgba(255,200,80,0.13), transparent 65%); }

.tm-game--rl .tm-intro-card {
  background: linear-gradient(150deg, #061638 0%, #050a1c 100%);
  outline-color: rgba(94,155,255,0.22);
}
.tm-game--rl .tm-intro-card::before { background: linear-gradient(180deg, transparent, #5e9bff 12%, #2a5dc8 88%, transparent); }
.tm-game--rl .tm-intro-card::after  { background: radial-gradient(ellipse 55% 45% at 100% 0%, rgba(94,155,255,0.15), transparent 65%); }

/* ── Zone image 16:9 ────────────────────────────────────────── */
.tm-intro-card__media {
  position: relative;
  z-index: 2;
  aspect-ratio: 16 / 9;
  width: 100%;
  overflow: hidden;
  background: rgba(0,0,0,0.45);
  outline: 1px solid rgba(255,255,255,0.08);
  outline-offset: -1px;
  /* Petit clip-path pour casser l'angle haut-droit (cohérent avec la carte) */
  clip-path: polygon(
    0 0,
    calc(100% - 10px) 0,
    100% 10px,
    100% 100%,
    8px 100%,
    0 calc(100% - 8px)
  );
}
.tm-intro-card__media img,
.tm-intro-card__media video {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.6s var(--ease-out, ease-out);
}
.tm-intro-card:hover .tm-intro-card__media img,
.tm-intro-card:hover .tm-intro-card__media video {
  transform: scale(1.04);
}

/* Overlay dégradé sur l'image pour la lisibilité du tag */
.tm-intro-card__media::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, transparent 50%, rgba(0,0,0,0.55) 100%),
    linear-gradient(115deg, transparent 60%, rgba(0,0,0,0.35) 100%);
  pointer-events: none;
}

/* Tag "GAME" sur l'image */
.tm-intro-card__tag {
  position: absolute;
  left: 8px; bottom: 8px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 3px 8px;
  font-family: var(--font-display);
  font-size: clamp(8px, 0.7vw, 10px);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text);
  background: rgba(0,0,0,0.55);
  outline: 1px solid rgba(255,255,255,0.18); outline-offset: -1px;
  clip-path: polygon(5px 0, 100% 0, calc(100% - 5px) 100%, 0 100%);
}
.tm-intro-card__tag::before {
  content: '';
  width: 6px; height: 6px;
  background: var(--accent);
  box-shadow: 0 0 6px var(--accent);
  clip-path: circle(50%);
}
.tm-game--bs .tm-intro-card__tag::before { background: #ffc850; box-shadow: 0 0 6px rgba(255,200,80,0.6); }
.tm-game--rl .tm-intro-card__tag::before { background: #5e9bff; box-shadow: 0 0 6px rgba(94,155,255,0.6); }

/* ── Zone texte ─────────────────────────────────────────────── */
.tm-intro-card__body {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  gap: clamp(4px, 0.5vw, 7px);
  padding: clamp(2px, 0.3vw, 4px) clamp(4px, 0.5vw, 8px) clamp(2px, 0.3vw, 4px) 0;
  min-width: 0;
}
.tm-intro-card__eyebrow {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-display);
  font-size: clamp(8.5px, 0.7vw, 10px);
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--text-muted);
  line-height: 1;
}
.tm-intro-card__eyebrow::before {
  content: '';
  width: 3px; height: clamp(11px, 1.1vw, 14px);
  background: var(--accent);
  border-radius: 2px;
  box-shadow: 0 0 6px var(--accent);
}
.tm-game--bs .tm-intro-card__eyebrow::before { background: #ffc850; box-shadow: 0 0 8px rgba(255,200,80,0.55); }
.tm-game--rl .tm-intro-card__eyebrow::before { background: #5e9bff; box-shadow: 0 0 8px rgba(94,155,255,0.55); }

.tm-intro-card__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(15px, 1.4vw, 20px);
  letter-spacing: 0.04em;
  color: var(--text);
  line-height: 1.05;
}
.tm-intro-card__desc {
  margin: 0;
  font-size: clamp(10px, 0.82vw, 12px);
  line-height: 1.45;
  color: var(--text-muted);
  /* Ellipse propre si jamais ça dépasse */
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Petits "tags meta" optionnels (genre / mode / plateforme) */
.tm-intro-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-top: auto;
  padding-top: clamp(3px, 0.4vw, 5px);
}
.tm-intro-card__chip {
  display: inline-flex;
  align-items: center;
  padding: 2px 7px;
  font-size: clamp(7.5px, 0.6vw, 9px);
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text);
  background: rgba(255,255,255,0.05);
  outline: 1px solid rgba(255,255,255,0.10); outline-offset: -1px;
  clip-path: polygon(4px 0, 100% 0, calc(100% - 4px) 100%, 0 100%);
}
.tm-game--bs .tm-intro-card__chip { background: rgba(255,200,80,0.08); outline-color: rgba(255,200,80,0.22); color: #ffd97a; }
.tm-game--rl .tm-intro-card__chip { background: rgba(94,155,255,0.08); outline-color: rgba(94,155,255,0.22); color: #8fb6ff; }

/* ── Mobile : image en haut, texte en bas ─────────────────────── */
@media (max-width: 700px) {
  .tm-intro-card {
    grid-template-columns: 1fr;
    gap: 7px;
    padding: 6px;
  }
  .tm-intro-card__title { font-size: 13px; }
  .tm-intro-card__desc  { font-size: 10px; -webkit-line-clamp: 3; }
  .tm-intro-card__eyebrow { font-size: 7.5px; }
  .tm-intro-card__chip { font-size: 7.5px; padding: 2px 6px; }
}

/* ============================================================
   ACHIEVEMENT CARD — conteneur principal (hauteur reduite)
   Design original :
   - clip-path octogone asymetrique
   - bande verticale d'accent
   - liste scrollable
   ============================================================ */
.tm-ach-card {
  position: relative;
  flex: 1 1 auto;
  min-height: 0;
  /* Plus de plafond : la carte remplit l'espace restant entre Stats et Network */
  max-height: none;
  display: flex;
  flex-direction: column;
  background: linear-gradient(150deg, #08111f 0%, #050a14 100%);
  outline: 1px solid rgba(255,255,255,0.10);
  outline-offset: -1px;
  overflow: hidden;

  /* Octogone asymetrique : haut-gauche + bas-droite */
  --dc-corner: clamp(14px, 1.4vw, 22px);
  --dc-cut: clamp(8px, 0.8vw, 12px);
  clip-path: polygon(
    var(--dc-corner) 0,
    100% 0,
    100% calc(100% - var(--dc-cut)),
    calc(100% - var(--dc-cut)) 100%,
    0 100%,
    0 var(--dc-cut)
  );
}

/* Bande verticale d'accent */
.tm-ach-card::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: linear-gradient(180deg,
    transparent 0%,
    var(--accent) 12%,
    var(--accent) 88%,
    transparent 100%);
  z-index: 3;
  opacity: 0.85;
}

.tm-ach-card::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 60% 35% at 100% 0%, rgba(94,170,255,0.15), transparent 65%),
    radial-gradient(ellipse 50% 30% at 0% 100%, rgba(94,170,255,0.10), transparent 65%);
  pointer-events: none;
  z-index: 0;
}

.tm-game--bs .tm-ach-card {
  background: linear-gradient(150deg, #2a0c05 0%, #150402 100%);
  outline-color: rgba(255,200,80,0.22);
}
.tm-game--bs .tm-ach-card::before { background: linear-gradient(180deg, transparent, #ffc850 12%, #ff8a3c 88%, transparent); }
.tm-game--bs .tm-ach-card::after {
  background:
    radial-gradient(ellipse 60% 35% at 100% 0%, rgba(255,200,80,0.18), transparent 65%),
    radial-gradient(ellipse 50% 30% at 0% 100%, rgba(232,70,32,0.18), transparent 65%);
}
.tm-game--rl .tm-ach-card {
  background: linear-gradient(150deg, #061638 0%, #050a1c 100%);
  outline-color: rgba(94,155,255,0.22);
}
.tm-game--rl .tm-ach-card::before { background: linear-gradient(180deg, transparent, #5e9bff 12%, #2a5dc8 88%, transparent); }
.tm-game--rl .tm-ach-card::after {
  background:
    radial-gradient(ellipse 60% 35% at 100% 0%, rgba(94,155,255,0.20), transparent 65%),
    radial-gradient(ellipse 50% 30% at 0% 100%, rgba(40,90,200,0.18), transparent 65%);
}

/* HEADER */
.tm-ach-card__head { /* spacing réduit */
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: auto 1fr auto;
  grid-template-rows: auto auto;
  column-gap: clamp(8px, 0.9vw, 12px);
  align-items: center;
  padding: clamp(6px, 0.7vw, 10px) clamp(10px, 1vw, 14px) clamp(5px, 0.6vw, 8px) clamp(10px, 1.1vw, 16px);
  border-bottom: 1px solid rgba(255,255,255,0.06);
  flex-shrink: 0;
}

.tm-ach-card__bar {
  grid-row: 1 / span 2;
  width: 4px;
  height: clamp(28px, 3vw, 40px);
  background: var(--accent);
  border-radius: 2px;
  box-shadow: 0 0 8px var(--accent);
  align-self: center;
}
.tm-game--bs .tm-ach-card__bar { background: #ffc850; box-shadow: 0 0 10px rgba(255,200,80,0.55); }
.tm-game--rl .tm-ach-card__bar { background: #5e9bff; box-shadow: 0 0 10px rgba(94,155,255,0.55); }

.tm-ach-card__eyebrow {
  grid-column: 2;
  grid-row: 1;
  font-size: clamp(7px, 0.55vw, 8.5px);
  font-weight: 700;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--text-muted);
  line-height: 1;
}

.tm-ach-card__title {
  grid-column: 2;
  grid-row: 2;
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(15px, 1.3vw, 19px);
  letter-spacing: 0.04em;
  color: var(--text);
  line-height: 1;
  margin-top: 3px;
}

.tm-ach-card__count {
  grid-row: 1 / span 2;
  align-self: center;
  font-family: var(--font-display);
  font-size: clamp(20px, 1.8vw, 26px);
  color: var(--accent);
  letter-spacing: 0.04em;
  padding: 4px 10px;
  background: rgba(255,255,255,0.04);
  outline: 1px solid rgba(255,255,255,0.10); outline-offset: -1px;
  clip-path: polygon(6px 0, 100% 0, calc(100% - 6px) 100%, 0 100%);
  line-height: 1;
}
.tm-game--bs .tm-ach-card__count { color: #ffc850; outline-color: rgba(255,200,80,0.30); background: rgba(255,200,80,0.08); text-shadow: 0 0 8px rgba(255,200,80,0.4); }
.tm-game--rl .tm-ach-card__count { color: #5e9bff; outline-color: rgba(94,155,255,0.30); background: rgba(94,155,255,0.08); text-shadow: 0 0 8px rgba(94,155,255,0.4); }

/* LIST */
.tm-ach-card__list {
  position: relative;
  z-index: 2;
  flex: 1;
  min-height: 0;
  display: flex;
}

/* Zone scroll */
.tm-ach-scroll {
  flex: 1;
  min-height: 0;
  overflow-y: scroll;
  padding: clamp(4px,0.5vw,7px) clamp(8px,0.8vw,12px);
  display: flex;
  flex-direction: column;
  gap: clamp(5px,0.55vw,7px);
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.tm-ach-scroll::-webkit-scrollbar { display: none; }

/* Scrollbar custom */
.tm-ach-scrollbar {
  width: 16px;
  flex-shrink: 0;
  position: relative;
  background: rgba(0,0,0,0.20);
  border-left: 1px solid rgba(255,255,255,0.06);
}
.tm-game--bs .tm-ach-scrollbar { background: rgba(40,12,4,0.50); border-left-color: rgba(255,200,80,0.18); }
.tm-game--rl .tm-ach-scrollbar { background: rgba(8,18,46,0.50); border-left-color: rgba(94,155,255,0.18); }

.tm-ach-scrollbar__rail {
  position: absolute;
  top: 7px; bottom: 7px;
  left: 50%; transform: translateX(-50%);
  width: 2px;
  background: rgba(255,255,255,0.10);
  border-radius: 2px;
}
.tm-ach-scrollbar__thumb {
  position: absolute;
  left: 50%; transform: translateX(-50%);
  top: 7px;
  width: 12px; height: 12px;
  border-radius: 50%;
  background: rgba(255,255,255,0.30);
  outline: 1.5px solid rgba(255,255,255,0.55); outline-offset: -1px;
  cursor: grab;
  user-select: none; touch-action: none;
  transition: background 0.18s, outline-color 0.18s, transform 0.12s;
  box-shadow: 0 0 5px rgba(0,0,0,0.5);
}
.tm-ach-scrollbar__thumb:hover {
  background: var(--accent);
  outline-color: var(--accent);
  transform: translateX(-50%) scale(1.18);
}
.tm-ach-scrollbar__thumb.dragging {
  cursor: grabbing;
  background: var(--accent);
  outline-color: var(--accent);
  transform: translateX(-50%) scale(1.22);
}
.tm-game--bs .tm-ach-scrollbar__thumb:hover,
.tm-game--bs .tm-ach-scrollbar__thumb.dragging { background: #ffc850; outline-color: #ffc850; }
.tm-game--rl .tm-ach-scrollbar__thumb:hover,
.tm-game--rl .tm-ach-scrollbar__thumb.dragging { background: #5e9bff; outline-color: #5e9bff; }

/* Items achievement */
.tm-ach {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: clamp(12px, 1.3vw, 18px);
  padding: clamp(6px, 0.75vw, 10px) clamp(10px, 1.1vw, 14px);
  background: rgba(2,8,22,0.55);
  outline: 1px solid rgba(255,255,255,0.06); outline-offset: -1px;
  flex-shrink: 0;
  transition: outline-color var(--tr), background var(--tr), transform var(--tr);
  clip-path: polygon(11px 0, 100% 0, 100% 100%, 0 100%, 0 11px);
}
.tm-ach:hover { transform: translateX(2px); }
.tm-game--bs .tm-ach { background: rgba(20,6,2,0.55); }
.tm-game--bs .tm-ach:hover { outline-color: rgba(255,200,80,0.4); background: rgba(40,12,4,0.7); }
.tm-game--rl .tm-ach { background: rgba(4,10,28,0.55); }
.tm-game--rl .tm-ach:hover { outline-color: rgba(94,155,255,0.4); background: rgba(8,18,46,0.7); }

.tm-ach__icon {
  width: clamp(36px, 3vw, 44px); height: clamp(36px, 3vw, 44px);
  background: rgba(255,255,255,0.06);
  outline: 1px solid rgba(255,255,255,0.15); outline-offset: -1px;
  display: flex; align-items: center; justify-content: center;
  color: var(--accent); flex-shrink: 0;
  border-radius: 50%;
}
.tm-ach__icon svg { width: 55%; height: 55%; }
.tm-game--bs .tm-ach__icon { background: rgba(255,200,80,0.12); outline-color: rgba(255,200,80,0.35); color: #ffc850; }
.tm-game--rl .tm-ach__icon { background: rgba(94,155,255,0.12); outline-color: rgba(94,155,255,0.35); color: #5e9bff; }

.tm-ach__body { min-width: 0; display: flex; flex-direction: column; gap: 1px; }
.tm-ach__body strong { font-size: clamp(12px, 1.1vw, 15px); color: var(--text); font-weight: 600; line-height: 1.15; }
.tm-ach__body span { font-size: clamp(11px, 0.9vw, 13px); color: var(--text-muted); line-height: 1.3; }

.tm-ach__year {
  font-family: var(--font-display);
  font-size: clamp(16px, 1.3vw, 19px);
  color: var(--accent); letter-spacing: 0.04em; flex-shrink: 0;
  line-height: 1;
}
.tm-game--bs .tm-ach__year { color: #ffc850; text-shadow: 0 0 6px rgba(255,200,80,0.4); }
.tm-game--rl .tm-ach__year { color: #5e9bff; text-shadow: 0 0 6px rgba(94,155,255,0.4); }

/* ============================================================
   STATS CARD — conteneur separe en dessous d'Achievements
   ============================================================ */
.tm-stats-card {
  position: relative;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  gap: clamp(3px, 0.38vw, 5px);
  padding: clamp(6px, 0.7vw, 10px) clamp(10px, 1vw, 13px) clamp(7px, 0.8vw, 11px);
  background: linear-gradient(150deg, #08111f 0%, #050a14 100%);
  outline: 1px solid rgba(255,255,255,0.10);
  outline-offset: -1px;
  overflow: hidden;

  /* Octogone : miroir de l'achievements (bas-droite + haut-gauche inverses) */
  --sc-corner: clamp(10px, 1vw, 16px);
  --sc-cut: clamp(8px, 0.8vw, 12px);
  clip-path: polygon(
    0 0,
    calc(100% - var(--sc-corner)) 0,
    100% var(--sc-corner),
    100% 100%,
    var(--sc-cut) 100%,
    0 calc(100% - var(--sc-cut))
  );
}

.tm-stats-card::before {
  content: '';
  position: absolute;
  right: 0; top: 0; bottom: 0;
  width: 3px;
  background: linear-gradient(180deg,
    transparent 0%,
    var(--accent) 12%,
    var(--accent) 88%,
    transparent 100%);
  z-index: 1;
  opacity: 0.85;
}
.tm-stats-card::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 50% 40% at 0% 50%, rgba(94,170,255,0.10), transparent 65%);
  pointer-events: none;
  z-index: 0;
}

.tm-game--bs .tm-stats-card {
  background: linear-gradient(150deg, #2a0c05 0%, #150402 100%);
  outline-color: rgba(255,200,80,0.22);
}
.tm-game--bs .tm-stats-card::before { background: linear-gradient(180deg, transparent, #ffc850 12%, #ff8a3c 88%, transparent); }
.tm-game--bs .tm-stats-card::after {
  background: radial-gradient(ellipse 50% 40% at 0% 50%, rgba(255,200,80,0.12), transparent 65%);
}
.tm-game--rl .tm-stats-card {
  background: linear-gradient(150deg, #061638 0%, #050a1c 100%);
  outline-color: rgba(94,155,255,0.22);
}
.tm-game--rl .tm-stats-card::before { background: linear-gradient(180deg, transparent, #5e9bff 12%, #2a5dc8 88%, transparent); }
.tm-game--rl .tm-stats-card::after {
  background: radial-gradient(ellipse 50% 40% at 0% 50%, rgba(94,155,255,0.14), transparent 65%);
}

.tm-stats-card__head {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  gap: clamp(8px, 0.9vw, 12px);
  margin-bottom: clamp(1px, 0.2vw, 2px);
}
.tm-stats-card__bar {
  width: 4px;
  height: clamp(14px, 1.4vw, 18px);
  background: var(--accent);
  border-radius: 2px;
  box-shadow: 0 0 6px var(--accent);
}
.tm-game--bs .tm-stats-card__bar { background: #ffc850; box-shadow: 0 0 8px rgba(255,200,80,0.55); }
.tm-game--rl .tm-stats-card__bar { background: #5e9bff; box-shadow: 0 0 8px rgba(94,155,255,0.55); }

.tm-stats-card__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(11px, 1vw, 14px);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text);
  line-height: 1;
  flex: 1;
}
.tm-stats-card__title::after {
  content: '';
  display: inline-block;
  width: 100%;
}

/* Lignes statistiques (partagees entre stats-card) */
.tm-statline {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: clamp(8px, 0.9vw, 12px);
}

.tm-statline__tag {
  font-size: clamp(7px, 0.55vw, 9px);
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-muted);
  padding: 3px 7px;
  background: rgba(255,255,255,0.05);
  outline: 1px solid rgba(255,255,255,0.08); outline-offset: -1px;
  clip-path: polygon(4px 0, 100% 0, calc(100% - 4px) 100%, 0 100%);
  min-width: clamp(48px, 5vw, 64px);
  text-align: center;
  line-height: 1;
}
.tm-statline--alt .tm-statline__tag {
  background: rgba(255,255,255,0.02);
  color: rgba(255,255,255,0.45);
}
.tm-game--bs .tm-statline__tag { color: rgba(255,200,80,0.85); outline-color: rgba(255,200,80,0.20); background: rgba(255,200,80,0.06); }
.tm-game--rl .tm-statline__tag { color: rgba(94,155,255,0.85); outline-color: rgba(94,155,255,0.20); background: rgba(94,155,255,0.06); }
.tm-game--bs .tm-statline--alt .tm-statline__tag { color: rgba(255,200,80,0.50); background: rgba(255,200,80,0.02); }
.tm-game--rl .tm-statline--alt .tm-statline__tag { color: rgba(94,155,255,0.50); background: rgba(94,155,255,0.02); }

.tm-statline__items {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(2px, 0.3vw, 4px);
}

.tm-statitem {
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 2px;
  padding: clamp(3px, 0.4vw, 5px) 2px;
  background: rgba(0,0,0,0.25);
  outline: 1px solid rgba(255,255,255,0.05); outline-offset: -1px;
  clip-path: polygon(3px 0, 100% 0, calc(100% - 3px) 100%, 0 100%);
}
.tm-game--bs .tm-statitem { background: rgba(28,10,4,0.55); outline-color: rgba(255,200,80,0.10); }
.tm-game--rl .tm-statitem { background: rgba(6,14,38,0.55); outline-color: rgba(94,155,255,0.10); }

.tm-statitem strong {
  font-family: var(--font-display);
  font-size: clamp(12px, 1.1vw, 16px);
  color: var(--accent);
  line-height: 1;
  letter-spacing: 0.02em;
}
.tm-game--bs .tm-statitem strong { color: #ffc850; text-shadow: 0 0 6px rgba(255,200,80,0.30); }
.tm-game--rl .tm-statitem strong { color: #5e9bff; text-shadow: 0 0 6px rgba(94,155,255,0.30); }

.tm-statitem em {
  font-style: normal;
  font-size: clamp(7px, 0.55vw, 8.5px);
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--text-muted);
  line-height: 1;
}


/* ============================================================
   SOCIALS CARD — conteneur reseaux sociaux (3eme container)
   Variation d'octogone : coupes haut-droite + bas-gauche (3eme orientation)
   pour creer un rythme visuel avec achievements (haut-gauche/bas-droite)
   et stats (haut-droite + bas-gauche legers).
   Une ligne par personne : avatar rond + nom/@ + icone reseau.
   ============================================================ */
.tm-socials-card {
  position: relative;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  background: linear-gradient(150deg, #08111f 0%, #050a14 100%);
  outline: 1px solid rgba(255,255,255,0.10);
  outline-offset: -1px;
  overflow: hidden;

  /* Octogone : coupes prononcees en haut-droite et bas-gauche */
  --soc-corner: clamp(12px, 1.2vw, 18px);
  --soc-cut: clamp(8px, 0.8vw, 12px);
  clip-path: polygon(
    0 var(--soc-cut),
    var(--soc-cut) 0,
    calc(100% - var(--soc-corner)) 0,
    100% var(--soc-corner),
    100% 100%,
    var(--soc-corner) 100%,
    0 calc(100% - var(--soc-corner))
  );
}
.tm-socials-card::before {
  content: '';
  position: absolute;
  left: 0; right: 0;
  top: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent 5%, var(--accent) 50%, transparent 95%);
  z-index: 3;
  opacity: 0.6;
}
.tm-socials-card::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 50% 50% at 100% 0%, rgba(94,170,255,0.10), transparent 70%),
    radial-gradient(ellipse 40% 40% at 0% 100%, rgba(94,170,255,0.08), transparent 70%);
  pointer-events: none;
  z-index: 0;
}

.tm-game--bs .tm-socials-card {
  background: linear-gradient(150deg, #2a0c05 0%, #150402 100%);
  outline-color: rgba(255,200,80,0.22);
}
.tm-game--bs .tm-socials-card::before { background: linear-gradient(90deg, transparent 5%, #ffc850 50%, transparent 95%); }
.tm-game--bs .tm-socials-card::after {
  background:
    radial-gradient(ellipse 50% 50% at 100% 0%, rgba(255,200,80,0.14), transparent 70%),
    radial-gradient(ellipse 40% 40% at 0% 100%, rgba(232,70,32,0.14), transparent 70%);
}
.tm-game--rl .tm-socials-card {
  background: linear-gradient(150deg, #061638 0%, #050a1c 100%);
  outline-color: rgba(94,155,255,0.22);
}
.tm-game--rl .tm-socials-card::before { background: linear-gradient(90deg, transparent 5%, #5e9bff 50%, transparent 95%); }
.tm-game--rl .tm-socials-card::after {
  background:
    radial-gradient(ellipse 50% 50% at 100% 0%, rgba(94,155,255,0.16), transparent 70%),
    radial-gradient(ellipse 40% 40% at 0% 100%, rgba(40,90,200,0.14), transparent 70%);
}

/* Header */
.tm-socials-card__head {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  gap: clamp(8px, 0.9vw, 12px);
  padding: clamp(8px, 0.9vw, 12px) clamp(12px, 1.2vw, 16px) clamp(6px, 0.65vw, 9px);
  border-bottom: 1px solid rgba(255,255,255,0.05);
}
.tm-socials-card__bar {
  width: 4px;
  height: clamp(14px, 1.4vw, 18px);
  background: var(--accent);
  border-radius: 2px;
  box-shadow: 0 0 6px var(--accent);
}
.tm-game--bs .tm-socials-card__bar { background: #ffc850; box-shadow: 0 0 8px rgba(255,200,80,0.55); }
.tm-game--rl .tm-socials-card__bar { background: #5e9bff; box-shadow: 0 0 8px rgba(94,155,255,0.55); }
.tm-socials-card__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(11px, 1vw, 14px);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text);
  line-height: 1;
  flex: 1;
}
.tm-socials-card__count {
  font-family: var(--font-display);
  font-size: clamp(12px, 1.1vw, 15px);
  color: var(--accent);
  letter-spacing: 0.04em;
  padding: 2px 7px;
  background: rgba(255,255,255,0.04);
  outline: 1px solid rgba(255,255,255,0.10); outline-offset: -1px;
  clip-path: polygon(4px 0, 100% 0, calc(100% - 4px) 100%, 0 100%);
  line-height: 1;
}
.tm-game--bs .tm-socials-card__count { color: #ffc850; outline-color: rgba(255,200,80,0.30); background: rgba(255,200,80,0.08); }
.tm-game--rl .tm-socials-card__count { color: #5e9bff; outline-color: rgba(94,155,255,0.30); background: rgba(94,155,255,0.08); }

/* Liste */
.tm-socials-card__list {
  list-style: none;
  margin: 0;
  padding: clamp(6px, 0.7vw, 9px) clamp(8px, 0.9vw, 12px) clamp(8px, 0.9vw, 12px);
  display: flex;
  flex-direction: column;
  gap: clamp(4px, 0.45vw, 6px);
  position: relative;
  z-index: 2;
}

/* Une ligne (avatar + info + icone) */
.tm-social {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: clamp(7px, 0.8vw, 10px);
  padding: clamp(4px, 0.5vw, 6px) clamp(7px, 0.8vw, 10px) clamp(4px, 0.5vw, 6px) clamp(5px, 0.55vw, 7px);
  background: rgba(2,8,22,0.5);
  outline: 1px solid rgba(255,255,255,0.05); outline-offset: -1px;
  /* Coin gauche-bas decoupe (signature differente des achievements) */
  clip-path: polygon(0 0, 100% 0, 100% calc(100% - 7px), calc(100% - 7px) 100%, 0 100%);
  transition: outline-color var(--tr), background var(--tr), transform var(--tr);
}
.tm-social:hover {
  transform: translateX(3px);
}
.tm-game--bs .tm-social { background: rgba(20,6,2,0.55); }
.tm-game--bs .tm-social:hover { outline-color: rgba(255,200,80,0.4); background: rgba(40,12,4,0.7); }
.tm-game--rl .tm-social { background: rgba(4,10,28,0.55); }
.tm-game--rl .tm-social:hover { outline-color: rgba(94,155,255,0.4); background: rgba(8,18,46,0.7); }

/* Variante Manager : teal */
.tm-social--mng { /* override par .tm-game--bs / --rl restent prioritaires */
}

/* Avatar rond avec ring colore */
.tm-social__avatar {
  width: clamp(24px, 2.2vw, 30px);
  height: clamp(24px, 2.2vw, 30px);
  border-radius: 50%;
  position: relative;
  background: rgba(255,255,255,0.06);
  outline: 1.5px solid rgba(255,255,255,0.15);
  outline-offset: 1.5px;
  overflow: hidden;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.tm-social__avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
  display: block;
}
.tm-social__avatar::after {
  /* Initiale fallback quand pas d'image */
  content: '?';
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: clamp(11px, 1vw, 14px);
  color: rgba(255,255,255,0.45);
  z-index: -1;
}
.tm-game--bs .tm-social:not(.tm-social--mng) .tm-social__avatar { outline-color: rgba(255,200,80,0.45); background: rgba(255,200,80,0.10); }
.tm-game--rl .tm-social:not(.tm-social--mng) .tm-social__avatar { outline-color: rgba(94,155,255,0.45); background: rgba(94,155,255,0.10); }
.tm-social--mng .tm-social__avatar { outline-color: rgba(56,212,200,0.45); background: rgba(56,212,200,0.10); }

/* Info (nom + handle) */
.tm-social__info {
  display: flex;
  flex-direction: column;
  gap: 0;
  min-width: 0;
}
.tm-social__name {
  font-size: clamp(9.5px, 0.78vw, 11.5px);
  color: var(--text);
  font-weight: 600;
  line-height: 1.15;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.tm-social__handle {
  font-size: clamp(8px, 0.65vw, 9.5px);
  color: var(--text-muted);
  letter-spacing: 0.02em;
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.tm-game--bs .tm-social:not(.tm-social--mng) .tm-social__handle { color: rgba(255,200,80,0.7); }
.tm-game--rl .tm-social:not(.tm-social--mng) .tm-social__handle { color: rgba(94,155,255,0.7); }
.tm-social--mng .tm-social__handle { color: rgba(56,212,200,0.7); }

/* Icone reseau social a droite */
.tm-social__link {
  width: clamp(22px, 2vw, 26px);
  height: clamp(22px, 2vw, 26px);
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,0.04);
  outline: 1px solid rgba(255,255,255,0.10); outline-offset: -1px;
  color: var(--text-muted);
  border-radius: 50%;
  flex-shrink: 0;
  transition: background var(--tr), color var(--tr), outline-color var(--tr), transform var(--tr);
  text-decoration: none;
}
.tm-social__link:hover {
  transform: scale(1.12);
  color: var(--text);
}

/* Couleurs par reseau au hover */
.tm-social__link--x:hover         { background: rgba(255,255,255,0.10); outline-color: rgba(255,255,255,0.45); color: #ffffff; }
.tm-social__link--discord:hover   { background: rgba(88,101,242,0.20);  outline-color: rgba(88,101,242,0.55);  color: #a3aaff; }
.tm-social__link--twitch:hover    { background: rgba(145,71,255,0.18);  outline-color: rgba(145,71,255,0.55);  color: #c79bff; }
.tm-social__link--yt:hover        { background: rgba(255,60,60,0.18);   outline-color: rgba(255,60,60,0.55);   color: #ff8585; }
.tm-social__link--ig:hover        { background: rgba(225,80,150,0.18);  outline-color: rgba(225,80,150,0.55);  color: #ff9bbf; }

/* ============================================================
   BACKGROUNDS DES SECTIONS
   ============================================================ */
.tm-game--bs { background-color: #1a0805; }
.tm-game--bs .tm-game__bg {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(ellipse 75% 60% at 25% 20%, rgba(232,70,32,0.55), transparent 60%),
    radial-gradient(ellipse 70% 55% at 80% 85%, rgba(255,195,70,0.45), transparent 60%),
    linear-gradient(135deg, #4a0e08 0%, #6e1a08 35%, #2a0905 100%);
}
.tm-game--bs .tm-game__title em, .tm-game--bs .tm-game__eyebrow { color: #ffc850; }
.tm-game--bs .tm-game__badge { outline-color: rgba(255,200,80,0.5); background: rgba(40,8,4,0.7); }

.tm-game--rl { background-color: #050a1c; }
.tm-game--rl .tm-game__bg {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(ellipse 75% 60% at 75% 20%, rgba(110,175,255,0.55), transparent 60%),
    radial-gradient(ellipse 70% 55% at 20% 85%, rgba(40,90,200,0.55), transparent 60%),
    linear-gradient(135deg, #051538 0%, #0a2050 35%, #03091e 100%);
}
.tm-game--rl .tm-game__title em, .tm-game--rl .tm-game__eyebrow { color: #5e9bff; }
.tm-game--rl .tm-game__badge { outline-color: rgba(94,155,255,0.5); background: rgba(8,20,50,0.7); }

/* ============================================================
   ORGANISATION
   ============================================================ */
.tm-orga {
  position: relative; height: 100dvh; min-height: 560px;
  padding: calc(var(--navbar-h) + clamp(8px,1.2vw,18px)) var(--page-pad) clamp(10px,1.4vw,22px);
  overflow: hidden; background: #04101e;
  display: flex; flex-direction: column;
}
.tm-orga__bg {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(ellipse 55% 45% at 25% 25%, rgba(94,170,255,0.18), transparent 60%),
    radial-gradient(ellipse 60% 50% at 75% 75%, rgba(56,212,200,0.12), transparent 60%),
    linear-gradient(180deg, #03101e 0%, #061a3e 50%, #030914 100%);
}
.tm-orga::before {
  content: '';
  position: absolute; top: var(--navbar-h); left: var(--page-pad); right: var(--page-pad);
  height: 1px; background: linear-gradient(90deg, transparent, rgba(94,170,255,0.35), transparent);
}
.tm-orga__inner { position: relative; z-index: 2; flex: 1; display: flex; flex-direction: column; min-height: 0; overflow: hidden; }
.tm-orga__header { text-align: center; margin-bottom: clamp(4px,0.6vw,8px); display: flex; flex-direction: column; align-items: center; gap: 3px; flex-shrink: 0; }
.tm-orga__lead { max-width: 480px; margin-top: 2px; font-size: clamp(9px,0.75vw,10.5px); color: var(--text-muted); line-height: 1.5; }
.tm-orga-stats { display: grid; grid-template-columns: repeat(12,1fr); grid-template-rows: minmax(0, 0.48fr) minmax(0, 0.48fr); gap: clamp(5px,0.6vw,8px); flex: 0 1 auto; min-height: 0; max-height: 46%; align-self: center; width: min(960px, 100%); margin: 0 auto; }
.tm-stat-card { position: relative; background: rgba(6,16,40,0.78); -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px); outline: 1px solid var(--border); outline-offset: -1px; overflow: hidden; clip-path: var(--clip-bigcard); transition: outline-color var(--tr); }
.tm-stat-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: linear-gradient(90deg, var(--accent-color, var(--accent)), transparent); opacity: 0.7; }
.tm-stat-card:hover { outline-color: var(--border-hi); }
.tm-stat-card--teams   { grid-column: span 7; grid-row: 1; }
.tm-stat-card--titles  { grid-column: span 5; grid-row: 1; }
.tm-stat-card--members { grid-column: span 5; grid-row: 2; }
.tm-stat-card--wins    { grid-column: span 7; grid-row: 2; }
.tm-stat-card__inner { height: 100%; padding: clamp(5px,0.6vw,8px) clamp(7px,0.8vw,10px); display: grid; grid-template-columns: auto 1fr; grid-template-rows: auto 1fr; grid-template-areas: "icon main" "viz viz"; gap: clamp(3px,0.45vw,6px); align-items: start; }
.tm-stat-card__icon { grid-area: icon; width: clamp(20px,1.6vw,24px); height: clamp(20px,1.6vw,24px); background: color-mix(in srgb, var(--accent-color, var(--accent)) 14%, transparent); outline: 1px solid color-mix(in srgb, var(--accent-color, var(--accent)) 38%, transparent); outline-offset: -1px; display: flex; align-items: center; justify-content: center; color: var(--accent-color, var(--accent)); flex-shrink: 0; clip-path: var(--clip-icon); }
.tm-stat-card__icon svg { width: 60%; height: 60%; }
.tm-stat-card__main { grid-area: main; display: flex; flex-direction: column; gap: 2px; }
.tm-stat-card__n { font-family: var(--font-display); font-size: clamp(16px,1.8vw,24px); line-height: 0.95; color: var(--accent-color, var(--accent)); letter-spacing: 0.02em; text-shadow: 0 0 10px color-mix(in srgb, var(--accent-color, var(--accent)) 45%, transparent); }
.tm-stat-card__l { font-size: clamp(6.5px,0.55vw,8px); font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-muted); }
.tm-stat-card__viz { grid-area: viz; align-self: end; padding-top: clamp(3px,0.4vw,5px); border-top: 1px solid var(--border); display: flex; align-items: center; flex-wrap: wrap; gap: 5px; }
.tm-stat-card__viz small { font-size: clamp(7.5px,0.65vw,9.5px); font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-muted); }
.tm-stat-pills { display: flex; gap: 6px; flex-wrap: wrap; }
.tm-stat-pill { display: inline-flex; align-items: center; gap: 4px; padding: 3px 8px; background: rgba(94,170,255,0.09); outline: 1px solid var(--border-md); outline-offset: -1px; font-size: clamp(8px,0.68vw,9.5px); font-weight: 600; letter-spacing: 0.06em; color: var(--text); clip-path: var(--clip-tag); }
.tm-stat-pill img { width: 12px; height: 12px; object-fit: contain; }
.tm-stat-dots { display: flex; gap: 4px; flex-shrink: 0; }
.tm-stat-dots span { width: 7px; height: 7px; background: var(--accent-color, var(--accent)); clip-path: circle(50%); opacity: 0.85; }
.tm-stat-bars { flex: 1; display: flex; flex-direction: column; gap: 4px; }
.tm-stat-bar { display: grid; grid-template-columns: 22px 1fr 20px; align-items: center; gap: 7px; }
.tm-stat-bar__lbl { font-family: var(--font-display); font-size: clamp(8.5px,0.72vw,10.5px); letter-spacing: 0.08em; color: var(--text-muted); }
.tm-stat-bar__track { height: 4px; background: rgba(94,170,255,0.09); outline: 1px solid var(--border); outline-offset: -1px; position: relative; overflow: hidden; clip-path: var(--clip-tag); }
.tm-stat-bar__track > span { display: block; height: 100%; background: linear-gradient(90deg, var(--accent-color, var(--accent)), color-mix(in srgb, var(--accent-color, var(--accent)) 55%, transparent)); transition: width 0.8s var(--ease-out); }
.tm-stat-bar__val { font-family: var(--font-display); font-size: clamp(10px,0.85vw,12px); color: var(--accent-color, var(--accent)); text-align: right; }
.tm-stat-card__progress { height: 4px; background: rgba(94,170,255,0.07); outline: 1px solid var(--border); outline-offset: -1px; position: relative; overflow: hidden; clip-path: var(--clip-tag); }
.tm-stat-card__progress::before { content: ''; position: absolute; inset: 0; width: var(--p, 0%); background: linear-gradient(90deg, var(--accent-color, var(--accent)), transparent); }

/* ============================================================
   SWIPE HINT
   ============================================================ */
.tm-swipe-hint { display: none; }

/* ============================================================
   TABLETTE (701–1100px)
   ============================================================ */
@media (max-width: 1100px) and (min-width: 701px) {
  /* TABLETTE : roster sur toute la largeur en haut (cartes plus grandes),
     achievement + stats + socials en bas, juste sous les cartes. */
  .tm-game__layout {
    display: grid !important;
    grid-template-columns: 1fr !important;
    grid-template-rows: minmax(0, 1.55fr) minmax(0, 1fr);
    align-items: stretch;
    overflow: hidden;
    gap: clamp(8px, 1.1vw, 14px);
  }
  .tm-game--right .tm-game__layout {
    grid-template-columns: 1fr !important;
  }

  .tm-game__roster {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    margin: 0 auto;
    overflow: hidden;
    flex-shrink: 0;
    align-self: stretch;
  }

  .tm-game__sidebar {
    display: grid;
    grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr) minmax(0, 1fr);
    grid-template-rows: auto 1fr;
    grid-template-areas:
      "intro intro intro"
      "ach   stats   socials";
    gap: clamp(10px, 1.4vw, 16px);
    overflow: hidden;
    min-height: 0;
    align-self: stretch;
  }
  .tm-game__sidebar .tm-intro-card   { grid-area: intro;   flex: none; align-self: stretch; min-width: 0; }
  .tm-game__sidebar .tm-ach-card     { grid-area: ach;     flex: none; max-height: none; height: auto; align-self: stretch; min-height: 0; min-width: 0; }
  .tm-game__sidebar .tm-stats-card   { grid-area: stats;   flex: none; align-self: stretch; min-height: 0; min-width: 0; }
  .tm-game__sidebar .tm-socials-card { grid-area: socials; flex: none; align-self: stretch; min-height: 0; min-width: 0; }

  .tm-card { --corner: 10px; }
}

/* ============================================================
   MOBILE (<700px) — layout net, swipe sans gêne
   ============================================================ */
@media (max-width: 700px) {
  .tm-snap { height: 100dvh; min-height: 100dvh; overflow: hidden; }

  .tm-game,
  .tm-orga {
    height: 100dvh; min-height: 100dvh;
    padding: calc(var(--navbar-h) + 8px) 12px 56px;
    overflow: hidden;
    display: flex; flex-direction: column;
  }

  .tm-game__inner,
  .tm-orga__inner {
    flex: 1; display: flex; flex-direction: column;
    min-height: 0; overflow: hidden;
  }

  /* Header compact */
  .tm-game__header { margin-bottom: 8px; gap: 8px; }
  .tm-game__badge { width: 30px; height: 30px; }
  .tm-game__title { font-size: 20px; line-height: 1; }
  .tm-game__eyebrow { font-size: 7.5px; }

  /* Layout colonne nette */
  .tm-game__layout {
    flex: 1;
    display: flex !important; flex-direction: column;
    gap: 10px;
    min-height: 0; overflow: hidden;
    grid-template-columns: none !important;
    align-items: stretch !important;
  }
  .tm-game--right .tm-game__sidebar { order: 2; }
  .tm-game--right .tm-game__roster  { order: 1; }

  /* Roster mobile : largeur pleine, hauteur auto */
  .tm-game__roster {
    width: 100%; max-width: none; min-width: 0;
    flex-shrink: 0;
    overflow: visible;
    gap: 5px;
  }

  .tm-roster-subtitle { font-size: 7.5px; }
  /* Cartes mobile : aspect-ratio 3/4 INTACT, 4 angles égaux */
  .tm-card {
    --corner: 8px;
  }
  .tm-card__caption { padding: 7px 8px; gap: 1px; }
  .tm-card__role { font-size: 6px; letter-spacing: 0.16em; }
  .tm-card__name { font-size: 10.5px; }
  .tm-card__handle { font-size: 7px; }

  /* Sidebar mobile : meme grille 2x2 que tablette
     - Achievement a gauche (rowspan 2)
     - Stats en haut-droite, Network en bas-droite */
  .tm-game__sidebar {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto 1fr 1fr;
    grid-template-areas:
      "intro intro"
      "ach   stats"
      "ach   socials";
    flex: 1;
    min-height: 0;
    overflow: hidden;
    gap: 6px;
  }
  .tm-game__sidebar .tm-intro-card   { grid-area: intro;   flex: none; align-self: stretch; min-width: 0; }
  .tm-game__sidebar .tm-ach-card     { grid-area: ach;     flex: none; max-height: none; height: auto; align-self: stretch; min-height: 0; }
  .tm-game__sidebar .tm-stats-card   { grid-area: stats;   flex: none; align-self: stretch; min-height: 0; }
  .tm-game__sidebar .tm-socials-card { grid-area: socials; flex: none; align-self: stretch; min-height: 0; }
  .tm-ach-card__head { /* spacing réduit */ padding: 8px 10px 6px 12px; }
  .tm-ach-card__title { font-size: 13px; margin-top: 2px; }
  .tm-ach-card__eyebrow { font-size: 6.5px; }
  .tm-ach-card__count { font-size: 16px; padding: 3px 7px; }
  .tm-ach-card__bar { height: 24px; }

  .tm-ach-scrollbar { width: 14px; }
  .tm-ach-scrollbar__thumb { width: 11px; height: 11px; }

  /* Achievement items : ~1.5x plus grands sur mobile (lisibilite/compacite) */
  .tm-ach { padding: 5px 8px; gap: 7px; }
  .tm-ach__icon { width: 28px; height: 28px; }
  .tm-ach__body strong { font-size: 12.5px; }
  .tm-ach__body span { font-size: 10.5px; }
  .tm-ach__year { font-size: 15px; }

  .tm-stats-card { flex-shrink: 0; padding: 5px 8px 6px; gap: 2px; }
  .tm-stats-card__title { font-size: 11px; letter-spacing: 0.16em; }
  .tm-stats-card__bar { height: 12px; }
  .tm-statline { gap: 6px; }
  .tm-statline__tag { font-size: 6.5px; padding: 2px 5px; min-width: 42px; }
  .tm-statline__items { gap: 2px; }
  .tm-statitem { padding: 3px 1px; }
  .tm-statitem strong { font-size: 11px; }
  .tm-statitem em { font-size: 6.5px; }

  /* Socials mobile compact */
  .tm-socials-card { flex-shrink: 0; }
  .tm-socials-card__head { padding: 6px 10px 4px; }
  .tm-socials-card__title { font-size: 10px; }
  .tm-socials-card__bar { height: 11px; }
  .tm-socials-card__count { font-size: 11px; padding: 2px 5px; }
  .tm-socials-card__list { padding: 5px 8px 7px; gap: 3px; }
  .tm-social { padding: 3px 6px 3px 4px; gap: 6px; }
  .tm-social__avatar { width: 22px; height: 22px; }
  .tm-social__name { font-size: 9.5px; }
  .tm-social__handle { font-size: 8px; }
  .tm-social__link { width: 20px; height: 20px; }

  /* Organisation mobile 2×2 */
  .tm-orga__header { margin-bottom: 8px; }
  .tm-orga__header .tm-game__title { font-size: 20px; }
  .tm-orga__lead { font-size: 9.5px; }
  .tm-orga-stats { grid-template-columns: 1fr 1fr; grid-template-rows: 1fr 1fr; gap: 5px; flex: 1; min-height: 0; }
  .tm-stat-card--teams, .tm-stat-card--titles, .tm-stat-card--members, .tm-stat-card--wins { grid-column: auto; grid-row: auto; }
  .tm-stat-card__inner { padding: 7px 9px; gap: 4px; }
  .tm-stat-card__n { font-size: 22px; }
  .tm-stat-card__l { font-size: 7.5px; }
  .tm-stat-card__icon { width: 24px; height: 24px; }
  .tm-stat-card__viz { padding-top: 6px; }

  /* Nav mobile = bottom bar */
  .tm-game-nav { bottom: 6px; padding: 5px 8px; gap: 5px; }
  .tm-game-nav__btn { width: 34px; height: 34px; }

  /* Swipe hint dots */
  .tm-swipe-hint {
    display: flex;
    position: fixed;
    bottom: 50px; left: 50%;
    transform: translateX(-50%);
    gap: 5px;
    z-index: 60;
    pointer-events: none;
  }
  .tm-swipe-hint span {
    width: 5px; height: 5px;
    border-radius: 50%;
    background: rgba(255,255,255,0.22);
    transition: background 0.3s, transform 0.3s;
  }
  .tm-swipe-hint span.active {
    background: var(--accent);
    transform: scale(1.4);
    box-shadow: 0 0 7px var(--accent);
  }
}

/* ============================================================
   PC (≥1101px) — LAYOUT FINAL
   - Roster GARDE sa taille originale (cards inchangees)
   - La sidebar recupere tout l'espace libre a cote du roster
   - Achievement remplit toute la hauteur disponible (1fr grid)
   - Stats + Network cote a cote en bas, hauteur auto
   ============================================================ */
@media (min-width: 1101px) {
  /* Colonne roster : largeur exactement egale a celle des cards (max-width interne)
     => roster ne s'etend pas dans le vide, cards conservent leur taille naturelle.
     Colonne sidebar : prend tout le reste de la largeur. */
  .tm-game__layout {
    grid-template-columns: minmax(280px, calc(95vh - 160px)) minmax(0, 1fr);
  }
  .tm-game--right .tm-game__layout {
    grid-template-columns: minmax(0, 1fr) minmax(280px, calc(95vh - 160px));
  }

  /* Sidebar interne : grille 2 colonnes, 2 rangees
     - rangee 1 : Achievement plein-largeur, hauteur 1fr (remplit le restant)
     - rangee 2 : Stats | Network cote a cote, hauteur auto */
  .tm-game__sidebar {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto 1fr auto;
    grid-template-areas:
      "intro   intro"
      "ach     ach"
      "stats   socials";
    gap: clamp(10px, 1.2vw, 16px);
    overflow: hidden;
  }
  .tm-game__sidebar .tm-intro-card {
    grid-area: intro;
    flex: none;
    align-self: stretch;
    min-width: 0;
  }
  .tm-game__sidebar .tm-ach-card {
    grid-area: ach;
    flex: none;
    max-height: none;
    height: auto;
    min-height: 0;
  }
  .tm-game__sidebar .tm-stats-card {
    grid-area: stats;
    flex: none;
    align-self: stretch;
    min-width: 0;
  }
  .tm-game__sidebar .tm-socials-card {
    grid-area: socials;
    flex: none;
    align-self: stretch;
    min-width: 0;
  }
}

/* ============================================================
   FALLBACK
   ============================================================ */
@supports not (color: color-mix(in srgb, red 50%, blue)) {
  .tm-stat-card__icon { background: rgba(94,170,255,0.14); outline-color: rgba(94,170,255,0.38); }
  .tm-stat-card__n { text-shadow: 0 0 18px rgba(94,170,255,0.5); }
  .tm-stat-bar__track > span { background: linear-gradient(90deg, var(--accent), rgba(94,170,255,0.6)); }
}

/* ============================================================
   ============================================================
   REDESIGN RESPONSIVE V2 — UNIFIE
   Objectif : sur PC / tablette / mobile, chaque element et carte
   est visible, bien dispose, sans chevauchement.
   ============================================================
   ============================================================ */

/* ---------- Padding lateral fluide (toutes tailles) ---------- */
.team-page,
.tm-game,
.tm-orga {
  --page-pad: clamp(14px, 3vw, 56px);
}

/* ============================================================
   DESKTOP (≥1101px)
   - Roster gauche (largeur bornee par la HAUTEUR pour cards 3/4)
   - Sidebar droite : Ach plein-largeur en haut, Stats|Socials cote a cote
   - Cascade verticale conservee (visuel signature)
   ============================================================ */
@media (min-width: 1101px) {
  .tm-game,
  .tm-orga {
    padding-left: var(--page-pad);
    padding-right: var(--page-pad);
  }

  .tm-game__layout {
    display: grid !important;
    grid-template-columns: minmax(280px, calc(95vh - 180px)) minmax(0, 1fr) !important;
    gap: clamp(20px, 2.4vw, 52px);
    align-items: stretch;
  }
  .tm-game--right .tm-game__layout {
    grid-template-columns: minmax(0, 1fr) minmax(280px, calc(95vh - 180px)) !important;
  }

  .tm-game__sidebar {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto minmax(0, 1fr) auto;
    grid-template-areas:
      "intro intro"
      "ach   ach"
      "stats socials";
    gap: clamp(8px, 1vw, 16px);
    overflow: hidden;
  }
  .tm-game__sidebar .tm-intro-card   { grid-area: intro;   flex: none; align-self: stretch; min-width: 0; }
  .tm-game__sidebar .tm-ach-card     { grid-area: ach;     flex: none; height: auto; max-height: none; min-height: 0; }
  .tm-game__sidebar .tm-stats-card   { grid-area: stats;   flex: none; align-self: stretch; min-width: 0; }
  .tm-game__sidebar .tm-socials-card { grid-area: socials; flex: none; align-self: stretch; min-width: 0; }

  /* Players : 3 cartes (cascade conservee via styles d'origine) */
  .tm-roster__players,
  .tm-roster--bs .tm-roster__players,
  .tm-roster--rl .tm-roster__players {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr);
    gap: clamp(12px, 1.5vw, 26px);
  }

  /* Staff : 2 cartes alignees sur cols 1 et 2 (meme largeur que joueurs) */
  .tm-roster__staff,
  .tm-roster--bs .tm-roster__staff,
  .tm-roster--rl .tm-roster__staff {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr);
    gap: clamp(12px, 1.5vw, 26px);
    width: 100%;
    max-width: none;
    margin: 0;
  }
  .tm-roster__staff > .tm-card:nth-child(1) { grid-column: 1; }
  .tm-roster__staff > .tm-card:nth-child(2) { grid-column: 2; }

  /* Section organisation : gap qui s'ouvre */
  .tm-orga-stats { column-gap: clamp(8px, 1vw, 18px); }
}

/* Tres grand ecran : encore plus d'air */
@media (min-width: 1600px) {
  .team-page,
  .tm-game,
  .tm-orga {
    --page-pad: clamp(36px, 4.2vw, 100px);
  }
  .tm-game__layout  { gap: clamp(28px, 2.8vw, 72px); }
  .tm-game__sidebar { gap: clamp(16px, 1.6vw, 28px); }
  .tm-roster__players,
  .tm-roster--bs .tm-roster__players,
  .tm-roster--rl .tm-roster__players { gap: clamp(18px, 1.8vw, 34px); }
  .tm-roster__staff,
  .tm-roster--bs .tm-roster__staff,
  .tm-roster--rl .tm-roster__staff   { gap: clamp(18px, 1.8vw, 34px); }
}

/* ============================================================
   TABLETTE (701-1100px)
   - Roster en HAUT (centre, largeur bornee pour pas d'overflow)
   - Achievement + Stats + Socials en BAS sur une rangee
   - Cards capees a ~165px (rentre verticalement sur iPad portrait/landscape)
   - Cascade verticale DESACTIVEE
   ============================================================ */
@media (max-width: 1100px) and (min-width: 701px) {
  .tm-game,
  .tm-orga {
    padding-left: var(--page-pad);
    padding-right: var(--page-pad);
  }

  /* Layout : 1 colonne, 2 rangees (roster | sidebar) */
  .tm-game__layout {
    display: grid !important;
    grid-template-columns: 1fr !important;
    grid-template-rows: minmax(0, auto) minmax(0, 1fr);
    gap: clamp(10px, 1.4vw, 18px);
    align-items: stretch;
    overflow: hidden;
  }
  .tm-game--right .tm-game__layout {
    grid-template-columns: 1fr !important;
  }

  /* Roster : largeur bornee, centre horizontalement */
  .tm-game__roster {
    width: 100%;
    max-width: min(100%, 600px);
    margin: 0 auto;
    align-self: stretch;
  }

  /* Joueurs : 3 cartes, taille capee (rentre vertical iPad), gap fluide */
  .tm-roster__players,
  .tm-roster--bs .tm-roster__players,
  .tm-roster--rl .tm-roster__players {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 165px));
    justify-content: center;
    align-items: stretch;
    gap: clamp(10px, 1.6vw, 22px);
    padding: 0;
    width: 100%;
  }

  /* Manager : 2 cartes, MEME largeur que joueurs (3-col grid, cols 1 et 2) */
  .tm-roster__staff,
  .tm-roster--bs .tm-roster__staff,
  .tm-roster--rl .tm-roster__staff {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 165px));
    justify-content: center;
    gap: clamp(10px, 1.6vw, 22px);
    width: 100%;
    max-width: none;
    margin: 0 auto;
  }
  .tm-roster__staff > .tm-card:nth-child(1) { grid-column: 1; }
  .tm-roster__staff > .tm-card:nth-child(2) { grid-column: 2; }

  /* Sidebar : Ach plus large + Stats + Socials sur une rangee */
  .tm-game__sidebar {
    display: grid !important;
    grid-template-columns: minmax(0, 1.5fr) minmax(0, 1fr) minmax(0, 1fr);
    grid-template-rows: auto 1fr;
    grid-template-areas:
      "intro intro intro"
      "ach   stats   socials";
    gap: clamp(10px, 1.4vw, 18px);
    overflow: hidden;
    align-self: stretch;
    min-height: 0;
  }
  .tm-game__sidebar .tm-intro-card   { grid-area: intro;   flex: none; align-self: stretch; min-width: 0; }
  .tm-game__sidebar .tm-ach-card     { grid-area: ach;     flex: none; height: auto; max-height: none; min-height: 0; min-width: 0; }
  .tm-game__sidebar .tm-stats-card   { grid-area: stats;   flex: none; align-self: stretch; min-height: 0; min-width: 0; }
  .tm-game__sidebar .tm-socials-card { grid-area: socials; flex: none; align-self: stretch; min-height: 0; min-width: 0; }

  /* Tue la cascade verticale (translateY) */
  .tm-roster__players .tm-card,
  .tm-roster--bs .tm-roster__players .tm-card,
  .tm-roster--rl .tm-roster__players .tm-card { transform: none !important; }
  .tm-roster__players .tm-card:hover,
  .tm-roster--bs .tm-roster__players .tm-card:hover,
  .tm-roster--rl .tm-roster__players .tm-card:hover { transform: translateY(-4px) !important; }
}

/* ============================================================
   MOBILE (≤700px)
   - Empile : roster en haut, sidebar 2x2 dessous
   - Padding lateral elargi (cartes decollees des bords)
   - Joueurs : 3 cartes capees (105-160px), espace en plus = gap
   - Manager : 2 cartes plus grandes (135-210px), centrees
   - Cascade desactivee
   ============================================================ */
@media (max-width: 700px) {
  .tm-game,
  .tm-orga {
    padding-left: clamp(14px, 5vw, 32px) !important;
    padding-right: clamp(14px, 5vw, 32px) !important;
  }

  /* Layout : flex column (roster puis sidebar) */
  .tm-game__layout {
    display: flex !important;
    flex-direction: column;
    gap: clamp(8px, 2vw, 16px);
    align-items: stretch !important;
  }
  .tm-game--right .tm-game__roster  { order: 1; }
  .tm-game--right .tm-game__sidebar { order: 2; }

  .tm-game__roster {
    width: 100%;
    max-width: none;
    flex-shrink: 0;
    overflow: visible;
    gap: 8px;
  }

  /* JOUEURS : 3 cartes capees, espace en plus = gap (space-between) */
  .tm-roster__players,
  .tm-roster--bs .tm-roster__players,
  .tm-roster--rl .tm-roster__players {
    display: grid !important;
    grid-template-columns: repeat(3, clamp(105px, 30vw, 160px));
    justify-content: space-between;
    align-items: start;
    gap: clamp(7px, 1.8vw, 18px);
    width: 100%;
    padding: 0;
  }
  .tm-roster--rl .tm-roster__players { align-items: end; }

  /* MANAGER : 2 cartes plus grandes, centrees comme groupe */
  .tm-roster__staff,
  .tm-roster--bs .tm-roster__staff,
  .tm-roster--rl .tm-roster__staff {
    display: grid !important;
    grid-template-columns: repeat(2, clamp(135px, 40vw, 200px));
    justify-content: center;
    gap: clamp(12px, 4vw, 32px);
    width: 100%;
    max-width: none;
    margin: 0 auto;
  }
  .tm-roster__staff > .tm-card:nth-child(1),
  .tm-roster__staff > .tm-card:nth-child(2) { grid-column: auto; }

  /* Sidebar : 2x2 (Ach colonne gauche rowspan 2, Stats top-right, Socials bottom-right) */
  .tm-game__sidebar {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto 1fr 1fr;
    grid-template-areas:
      "intro intro"
      "ach   stats"
      "ach   socials";
    flex: 1;
    min-height: 0;
    overflow: hidden;
    gap: 6px;
  }
  .tm-game__sidebar .tm-intro-card   { grid-area: intro;   flex: none; align-self: stretch; min-width: 0; }
  .tm-game__sidebar .tm-ach-card     { grid-area: ach;     flex: none; height: auto; max-height: none; min-height: 0; }
  .tm-game__sidebar .tm-stats-card   { grid-area: stats;   flex: none; align-self: stretch; min-height: 0; }
  .tm-game__sidebar .tm-socials-card { grid-area: socials; flex: none; align-self: stretch; min-height: 0; }

  /* Tue la cascade verticale */
  .tm-roster__players .tm-card,
  .tm-roster--bs .tm-roster__players .tm-card,
  .tm-roster--rl .tm-roster__players .tm-card { transform: none !important; }
  .tm-roster__players .tm-card:hover,
  .tm-roster--bs .tm-roster__players .tm-card:hover,
  .tm-roster--rl .tm-roster__players .tm-card:hover { transform: translateY(-4px) !important; }

  /* Section organisation : 2x2 (deja en place dans le CSS d'origine) */
}

/* ============================================================
   MOBILE PAYSAGE (telephone tourne, hauteur tres faible)
   On compresse encore les espacements pour ne pas overflow
   ============================================================ */
@media (max-width: 900px) and (max-height: 480px) and (orientation: landscape) {
  .tm-game__header { margin-bottom: 4px; }
  .tm-game__layout { gap: 6px; }
  .tm-game__roster { gap: 4px; }
  .tm-roster__players,
  .tm-roster__staff {
    grid-template-columns: repeat(3, minmax(0, 110px));
    gap: 6px;
  }
  .tm-roster__staff { grid-template-columns: repeat(2, minmax(0, 130px)); }
}


/* ============================================================
   FORMAT DES CARTES — préservé sur tablette/mobile
   - aspect-ratio 3/4 GARDÉ (vient de .tm-card de base)
   - photo et caption restent en position absolute
   - ne rien forcer : les cartes héritent du style original
   - juste s'assurer qu'elles ne stretchent pas en flex
   ============================================================ */
@media (max-width: 1100px) {
  .tm-roster__players > .tm-card,
  .tm-roster__staff > .tm-card {
    align-self: center;          /* ne stretch PAS verticalement */
    height: auto;                /* hauteur calculée par aspect-ratio */
    /* PAS de display:flex — on garde block + position relative original */
  }
}

/* ============================================================
   MOBILE — Layout serré : remonte les widgets, libère l'espace
   ============================================================ */
@media (max-width: 700px) {
  /* Layout : roster prend juste sa hauteur, sidebar prend le reste */
  .tm-game__layout {
    flex: 1;
    display: flex !important;
    flex-direction: column;
    gap: 5px;
    min-height: 0;
    overflow: hidden;
    grid-template-columns: none !important;
    align-items: stretch !important;
  }

  /* Roster : hauteur figée selon aspect-ratio des cartes (compact) */
  .tm-game__roster {
    flex: 0 0 auto !important;
    flex-shrink: 0 !important;
    flex-grow: 0 !important;
  }

  /* Sidebar : prend TOUT l'espace restant, contenu serré */
  .tm-game__sidebar {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    align-self: stretch !important;
  }

  /* Intro card mobile : ULTRA compacte (image+texte côte à côte, pas empilés) */
  .tm-game__sidebar .tm-intro-card {
    max-height: 88px;
    grid-template-columns: minmax(0, 1.15fr) minmax(0, 1fr) !important;
    gap: 6px;
    padding: 5px;
  }
  .tm-intro-card__media {
    aspect-ratio: 16 / 9;
    max-height: 78px;
  }
  .tm-intro-card__title { font-size: 12px; line-height: 1; }
  .tm-intro-card__desc {
    font-size: 9px;
    -webkit-line-clamp: 2;
    line-height: 1.3;
  }
  .tm-intro-card__eyebrow { font-size: 7px; letter-spacing: 0.18em; }
  .tm-intro-card__chip { font-size: 6.5px; padding: 1px 5px; letter-spacing: 0.06em; }
  .tm-intro-card__body { gap: 2px; padding: 0; }
  .tm-intro-card__meta { gap: 3px; padding-top: 2px; }
  .tm-intro-card__tag { font-size: 6.5px; padding: 2px 5px; left: 4px; bottom: 4px; }

  /* Mode très petit écran (paysage / petit phone) : encore plus compact */
  @media (max-height: 720px) {
    .tm-game__sidebar .tm-intro-card { max-height: 72px; }
    .tm-intro-card__media { max-height: 62px; }
    .tm-intro-card__desc { -webkit-line-clamp: 1; }
    .tm-intro-card__meta { display: none; }
    .tm-intro-card__title { font-size: 11px; }
  }
}
