/* ==========================================================================
   UniFoot app (app.unifoot.fr) — design system Unipros
   Tokens canoniques (source : skill unipros-app-stack). Shell sidebar dark.
   ========================================================================== */
:root {
  --brand-cyan:    #00CCFF;
  --brand-magenta: #FF4DE1;

  --neutral-0:   #FFFFFF;
  --neutral-50:  #F9FAFB;
  --neutral-100: #F3F4F6;
  --neutral-200: #E5E7EB;
  --neutral-300: #D1D5DB;
  --neutral-400: #9CA3AF;
  --neutral-500: #6B7280;
  --neutral-700: #374151;
  --neutral-900: #111827;
  --neutral-950: #060E1E;

  --blue-50:  #F0F7FF;
  --blue-500: #2F7FFD;
  --blue-600: #1B62D9;
  --blue-700: #1348B6;
  --red-500:  #DB3D4B;
  --green-500:#00B06B;
  --orange-500:#DB621F;
  --violet-500:#5E2BFF;

  --fg-1: var(--neutral-900);
  --fg-2: var(--neutral-500);
  --fg-3: var(--neutral-400);
  --bg-1: var(--neutral-0);
  --bg-2: var(--neutral-50);
  --bg-3: var(--neutral-100);
  --border-1: var(--neutral-200);
  --accent: var(--blue-500);

  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 16px;
  --radius-pill: 999px;

  /* Extension Unifoot — namespace --jeu-* (cf. design system) */
  --jeu-dark:      #060E1E;
  --jeu-dark-2:    #0D1B2E;
  --jeu-green:     #00E676;
  --jeu-green-dk:  #00B248;
  --jeu-gold:      #F5A623;
  --jeu-silver:    #A8B2C1;
  --jeu-bronze:    #C97B3A;
  --jeu-correct:  var(--green-500);
  --jeu-exact:    var(--jeu-gold);
  --jeu-wrong:    var(--red-500);
  --jeu-pending:  var(--neutral-500);

  --shadow-xs: 0 1px 2px -1px rgba(65,70,81,.16);
  --shadow-sm: 0 1px 4px -2px rgba(65,70,81,.16);
  --shadow-md: 0 4px 12px -4px rgba(65,70,81,.12), 0 1px 4px -2px rgba(65,70,81,.16);

  --font: "Poppins", system-ui, -apple-system, sans-serif;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; height: 100%; }
body {
  background: var(--jeu-dark);
  font: 400 14px/24px var(--font);
  color: #fff;
  -webkit-font-smoothing: antialiased;
}
h1 { font: 400 16px/24px var(--font); margin: 0; }
p  { margin: 0; font: 400 14px/22px var(--font); color: rgba(255,255,255,.55); }
.hidden { display: none !important; }

/* ── Shell (dark) ────────────────────────────────────────────────────── */
.shell {
  display: grid; grid-template-columns: 240px 1fr; min-height: 100vh;
  background:
    radial-gradient(64% 46% at 50% 122%, rgba(0,230,118,.10), transparent 62%),
    radial-gradient(42% 52% at 6% -6%, rgba(98,168,255,.16), transparent 60%),
    radial-gradient(42% 52% at 94% -6%, rgba(168,85,247,.12), transparent 60%),
    radial-gradient(120% 70% at 85% -10%, #16314f 0%, transparent 55%),
    linear-gradient(170deg, #091226 0%, #0b1830 58%, #0c1c2e 100%);
}

/* ── Sidebar (dark — charte Unifoot) ─────────────────────────────────── */
.sidebar {
  background: linear-gradient(180deg, #0e1a2c 0%, #0a1322 100%);
  border-right: 1px solid rgba(255,255,255,.05);
  display: flex; flex-direction: column; gap: 2px;
  padding: 20px 14px;
  position: sticky; top: 0; height: 100vh; overflow-y: auto;
}
.sidebar .brand {
  display: flex; align-items: center;
  padding: 4px 6px 20px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  margin-bottom: 12px;
}
.brand-logo { height: 30px; width: auto; display: block; }
.nav-item {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 12px; border: none; background: transparent;
  color: rgba(255,255,255,.66); font: 500 13.5px/1 var(--font);
  border-radius: 10px; cursor: pointer; text-align: left; width: 100%;
  position: relative; transition: .15s;
}
.nav-item:hover { background: rgba(255,255,255,.05); color: #fff; }
.nav-item.active {
  background: rgba(0,230,118,.10); color: #fff;
  box-shadow: inset 0 0 0 1px rgba(0,230,118,.16);
}
.nav-item.active::before {
  content: ""; position: absolute; left: 0; top: 8px; bottom: 8px;
  width: 3px; border-radius: 3px; background: var(--jeu-green);
  box-shadow: 0 0 14px 1px var(--jeu-green);
}
.nav-item.active svg { color: var(--jeu-green); }
.nav-item svg { width: 20px; height: 20px; flex: none; }

/* ── Contenu ─────────────────────────────────────────────────────────── */
.content {
  padding: 24px 32px 40px; display: flex; flex-direction: column; gap: 24px;
  position: relative; z-index: 1; color: #fff; min-width: 0;
}
.panel { display: flex; flex-direction: column; gap: 24px; }
.page-head { display: flex; align-items: center; justify-content: space-between; min-height: 32px; }

/* ── Card (dark) ─────────────────────────────────────────────────────── */
.card {
  background: linear-gradient(180deg, #111f33, #0d1828);
  border: 1px solid rgba(255,255,255,.09);
  border-radius: var(--radius-lg); padding: 18px;
  box-shadow: 0 12px 34px rgba(0,0,0,.34);
  color: #fff; position: relative; overflow: hidden;
}

/* ── Boutons ─────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  height: 40px; padding: 0 16px; border-radius: var(--radius-md);
  font: 500 12px/1 var(--font); cursor: pointer; border: 1px solid transparent;
}
.btn.primary   { background: var(--blue-500); color: #fff; }
.btn.primary:hover { background: var(--blue-600); }
.btn.secondary { background: var(--bg-1); color: var(--fg-1); border-color: var(--border-1); box-shadow: var(--shadow-sm); }
.btn.secondary:hover { background: var(--bg-2); }
.btn.danger    { background: var(--red-500); color: #fff; }
.btn:disabled  { opacity: .5; cursor: not-allowed; }

/* ============================================================
   Surface anonyme (non connecté)
   ============================================================ */
.anon-stage {
  min-height: 100vh; display: grid; place-items: center;
  padding: 24px; position: relative; overflow: hidden;
  background: radial-gradient(80% 60% at 50% -10%, #1a2d4d 0%, #0b1730 45%, #070f20 100%);
}
/* projecteurs animés */
.anon-beam {
  position: absolute; top: -18%; width: 300px; height: 560px; pointer-events: none; z-index: 0; filter: blur(6px);
  background: conic-gradient(from 180deg at 50% 0, transparent 43%, rgba(150,200,255,.16) 50%, transparent 57%);
}
.anon-beam.l { left: 8%; transform: rotate(12deg); }
.anon-beam.r { right: 8%; transform: rotate(-12deg); }
@media (prefers-reduced-motion: no-preference) {
  .anon-beam.l { animation: anonSweepL 7s ease-in-out infinite; }
  .anon-beam.r { animation: anonSweepR 7s ease-in-out infinite; }
  @keyframes anonSweepL { 0%,100% { transform: rotate(9deg);  opacity: .7; } 50% { transform: rotate(15deg);  opacity: 1; } }
  @keyframes anonSweepR { 0%,100% { transform: rotate(-9deg); opacity: 1; }  50% { transform: rotate(-15deg); opacity: .7; } }
}
/* arc de pelouse */
.anon-pitch {
  position: absolute; bottom: -180px; left: 50%; transform: translateX(-50%);
  width: 680px; height: 340px; border-radius: 50%; z-index: 0;
  border: 1.5px solid rgba(0,230,118,.16); box-shadow: 0 0 80px rgba(0,230,118,.12) inset;
}
.anon-card {
  position: relative; z-index: 2; width: 440px; max-width: 100%; border-radius: var(--radius-xl, 20px);
  background: linear-gradient(180deg, rgba(20,33,54,.92), rgba(11,22,42,.96));
  border: 1px solid rgba(255,255,255,.1);
  box-shadow: 0 30px 70px rgba(0,0,0,.55), 0 0 0 1px rgba(0,230,118,.06), 0 16px 50px -10px rgba(0,230,118,.28);
  padding: 36px 38px 28px; display: flex; flex-direction: column; align-items: center; text-align: center;
  overflow: hidden; backdrop-filter: blur(8px); color: #fff;
}
/* liseré néon haut */
.anon-card::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, transparent, var(--jeu-green) 30%, #22D3EE 70%, transparent);
}
/* halo de coin */
.anon-card::after {
  content: ""; position: absolute; top: -60px; right: -60px; width: 200px; height: 200px; border-radius: 50%;
  background: radial-gradient(circle, rgba(0,230,118,.2), transparent 70%); pointer-events: none;
}
.anon-badge {
  display: inline-flex; align-items: center; gap: 8px; position: relative; z-index: 1;
  background: rgba(0,230,118,.13); color: var(--jeu-green); border: 1px solid rgba(0,230,118,.32);
  border-radius: var(--radius-pill, 999px); padding: 6px 13px; margin-bottom: 20px;
  font: 600 10px/1 var(--font); text-transform: uppercase; letter-spacing: .14em;
}
.anon-badge .dot {
  width: 6px; height: 6px; border-radius: 50%; background: var(--jeu-green);
  box-shadow: 0 0 0 0 rgba(0,230,118,.6); animation: anonPulse 2s infinite;
}
@keyframes anonPulse {
  0%   { box-shadow: 0 0 0 0 rgba(0,230,118,.6); }
  70%  { box-shadow: 0 0 0 8px rgba(0,230,118,0); }
  100% { box-shadow: 0 0 0 0 rgba(0,230,118,0); }
}
.anon-logo { height: 38px; width: auto; display: block; margin-bottom: 20px; position: relative; z-index: 1; }
.anon-stage h1 {
  font: 800 24px/1.25 var(--font); margin: 0 0 10px; letter-spacing: -.01em; color: #fff;
  position: relative; z-index: 1;
}
.anon-lead {
  font: 400 13.5px/1.6 var(--font); color: rgba(255,255,255,.62);
  margin: 0 0 22px; max-width: 330px; position: relative; z-index: 1;
}
/* teaser stats */
.anon-stats {
  display: flex; align-items: stretch; width: 100%; position: relative; z-index: 1;
  background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.09);
  border-radius: var(--radius-md); padding: 12px 0; margin-bottom: 22px;
}
.anon-stats .ls { flex: 1; display: flex; flex-direction: column; gap: 3px; }
.anon-stats .ls + .ls { border-left: 1px solid rgba(255,255,255,.1); }
.anon-stats .ls b { font: 800 17px/1 var(--font); color: #fff; }
.anon-stats .ls b.g { color: var(--jeu-green); text-shadow: 0 0 14px rgba(0,230,118,.5); }
.anon-stats .ls small { font: 600 9px/1.2 var(--font); text-transform: uppercase; letter-spacing: .06em; color: rgba(255,255,255,.5); }
.anon-cta {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  width: 100%; height: 54px; border-radius: var(--radius-md); position: relative; z-index: 1;
  background: linear-gradient(115deg, var(--jeu-green), #19c8ff); color: #04121f; border: 0; text-decoration: none;
  font: 800 13px/1 var(--font); letter-spacing: .02em; box-shadow: 0 12px 30px -6px rgba(0,230,118,.6); transition: .15s;
}
.anon-cta:hover { filter: brightness(1.08); transform: translateY(-1px); box-shadow: 0 16px 36px -6px rgba(0,230,118,.7); }
.anon-cta:active { transform: translateY(0); }
.anon-sep {
  display: flex; align-items: center; gap: 14px; width: 100%; margin: 22px 0 16px;
  position: relative; z-index: 1; color: rgba(255,255,255,.4);
}
.anon-sep::before, .anon-sep::after { content: ""; flex: 1; height: 1px; background: rgba(255,255,255,.12); }
.anon-sep span { font: 600 10px/1 var(--font); text-transform: uppercase; letter-spacing: .12em; }
.anon-join { font: 400 13px/1.5 var(--font); color: rgba(255,255,255,.6); position: relative; z-index: 1; margin: 0; }
.anon-join a { color: var(--jeu-green); font-weight: 600; }
.anon-foot {
  margin-top: 22px; padding-top: 16px; width: 100%; position: relative; z-index: 1;
  border-top: 1px solid rgba(255,255,255,.1);
  font: 400 11px/1.5 var(--font); color: rgba(255,255,255,.4); text-align: center;
}

/* ============================================================
   Topbar + sidebar foot — charte Unifoot
   ============================================================ */
.topbar { display: flex; align-items: center; gap: 18px; padding-bottom: 4px; min-height: 64px; }
.topbar .burger {
  display: none; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.14);
  border-radius: 10px; width: 40px; height: 40px;
  align-items: center; justify-content: center; cursor: pointer; color: #fff;
}
.topbar .greet h1 { font: 700 27px/1.1 var(--font); margin: 0; color: #fff; text-shadow: 0 2px 22px rgba(0,230,118,.28); }
.topbar .greet p  { font: 400 14px/1 var(--font); color: rgba(255,255,255,.6); margin: 6px 0 0; }
.topbar .spacer { flex: 1; }

/* Chip "rangscore" : 2 cellules côte à côte (rang + score) */
.topbar-rank {
  display: flex; background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.13);
  border-radius: var(--radius-lg); overflow: hidden; flex: none;
  align-self: stretch; min-height: 64px; /* hauteur uniforme avec bandeau + cloche */
}
.topbar-rank .rs { padding: 11px 20px; display: flex; flex-direction: column; justify-content: center; }
.topbar-rank .rs + .rs { border-left: 1px solid rgba(255,255,255,.1); }
.topbar-rank .rs small {
  display: block; font: 600 9px/1 var(--font); letter-spacing: .08em;
  text-transform: uppercase; color: rgba(255,255,255,.5); margin-bottom: 7px;
}
.topbar-rank .rs b { font: 800 24px/1 var(--font); color: #fff; display: block; }
.topbar-rank .rs.rk b { color: #62a8ff; }
.topbar-rank .rs.sc b { color: var(--jeu-green); text-shadow: 0 0 16px rgba(0,230,118,.5); }
.topbar-rank .rs.sc b small {
  font: 700 13px/1 var(--font); color: rgba(255,255,255,.5); margin-left: 3px;
  text-transform: lowercase; letter-spacing: 0; text-shadow: none;
}

.sidebar-foot { margin-top: auto; padding-top: 12px; border-top: 1px solid rgba(255,255,255,.08); display: flex; flex-direction: column; gap: 4px; }
.sidebar-foot .me { display: flex; align-items: center; gap: 12px; padding: 8px 8px; color: #fff; }
.me-av {
  width: 36px; height: 36px; border-radius: 50%; flex: none;
  display: grid; place-items: center; font: 700 13px/1 var(--font);
  background: linear-gradient(135deg, var(--brand-cyan), var(--brand-magenta));
}
.me-info b { font: 600 13px/1.2 var(--font); color: #fff; display: block; }
.me-info small { color: rgba(255,255,255,.5); font-size: 11px; }

/* ============================================================
   Dashboard — Match du jour + dcards (charte Unifoot)
   ============================================================ */
.dash-grid { display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(0, .78fr) minmax(0, .7fr); gap: 20px; align-items: stretch; }
.dash-col-main { display: flex; flex-direction: column; gap: 20px; min-width: 0; }
@media (max-width: 1100px) { .dash-grid { grid-template-columns: 1fr 1fr; } .dash-grid .dash-col-main { grid-column: 1 / -1; } }
@media (max-width: 760px)  { .dash-grid { grid-template-columns: 1fr; } .dash-grid .dash-col-main { grid-column: auto; } }

/* ── Défi du moment (SPEC-JEU-013 — dark) ── */
.defi {
  display: flex; align-items: center; gap: 20px;
  background: linear-gradient(180deg, #111f33, #0d1828);
  border: 1px solid rgba(255,255,255,.09);
  border-radius: var(--radius-lg); padding: 18px 22px;
  box-shadow: 0 12px 34px rgba(0,0,0,.34); color: #fff;
}
.defi-l { flex: 1; min-width: 0; }
.defi-head { display: flex; align-items: center; gap: 8px; font: 700 11px/1 var(--font); letter-spacing: .1em; text-transform: uppercase; color: #fff; }
.defi-head svg { color: var(--jeu-green); flex: none; }
.defi-l p { font: 500 13.5px/1.5 var(--font); color: rgba(255,255,255,.6); margin: 10px 0 12px; max-width: 320px; }
.defi-bar { height: 8px; border-radius: var(--radius-pill); background: rgba(255,255,255,.1); overflow: hidden; }
.defi-bar i { display: block; height: 100%; background: linear-gradient(90deg, var(--jeu-green-dk), var(--jeu-green)); box-shadow: 0 0 12px rgba(0,230,118,.6); transition: width .4s; }
.defi-r { flex: none; text-align: center; display: flex; flex-direction: column; align-items: center; gap: 6px; }
.defi-prog { font: 600 12px/1 var(--font); color: rgba(255,255,255,.6); }
.defi-pts { font: 800 20px/1 var(--font); color: var(--jeu-green); text-shadow: 0 0 16px rgba(0,230,118,.45); }
.defi.done { border-color: rgba(0,230,118,.35); }
.defi.done .defi-l p { color: var(--jeu-green); }

/* ── Mes exploits (SPEC-JEU-007 §6 — dark) ── */
.sec-lbl { display: flex; align-items: center; justify-content: space-between; margin: 4px 0 -4px; }
.sec-lbl h3 { display: flex; align-items: center; gap: 9px; font: 700 16px/1 var(--font); letter-spacing: .01em; color: #fff; margin: 0; }
.sec-lbl h3 svg { color: var(--jeu-green); }
.sec-lbl a { font: 600 13px/1 var(--font); color: var(--jeu-green); }

.exploits { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.exploit {
  position: relative; overflow: hidden;
  background: linear-gradient(180deg, #111f33, #0d1828);
  border: 1px solid rgba(255,255,255,.09); border-radius: var(--radius-lg);
  padding: 18px 20px; box-shadow: 0 12px 34px rgba(0,0,0,.34); color: #fff;
}
/* Liseré néon en haut — identique à la carte d'inscription (.anon-card). */
.exploit::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, transparent, var(--jeu-green) 30%, #22D3EE 70%, transparent);
}
.exploit .ex-top { display: flex; align-items: center; gap: 11px; margin-bottom: 14px; }
.ex-ring { width: 46px; height: 46px; border-radius: 50%; display: grid; place-items: center; flex: none; border: 2px solid; }
.ex-ring.flame  { border-color: rgba(255,122,26,.45); color: #ff7a1a; background: rgba(255,122,26,.1); }
.ex-ring.target { border-color: rgba(0,230,118,.45);  color: var(--jeu-green); background: rgba(0,230,118,.1); }
.ex-ring.bolt   { border-color: rgba(98,168,255,.45); color: #62a8ff; background: rgba(98,168,255,.1); }
.ex-ring.star   { border-color: rgba(168,85,247,.45); color: #b97cff; background: rgba(168,85,247,.1); }
.exploit .ex-lbl { font: 600 10px/1.3 var(--font); letter-spacing: .07em; text-transform: uppercase; color: rgba(255,255,255,.55); }
.exploit .ex-v { font: 800 30px/1 var(--font); color: #fff; }
.exploit .ex-v small { font: 600 13px/1 var(--font); color: rgba(255,255,255,.4); margin-left: 4px; }
.exploit .ex-sub { font: 500 12px/1 var(--font); color: rgba(255,255,255,.5); margin-top: 7px; }
@media (max-width: 880px) { .exploits { grid-template-columns: 1fr 1fr; } }
@media (max-width: 460px) { .exploits { grid-template-columns: 1fr; } }

/* ── Prochains matchs (strip — dark) ── */
.sec-lbl .next-all { font: 600 12px/1 var(--font); color: var(--jeu-green); text-decoration: none; }
.nx-strip { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.nx-card {
  display: flex; align-items: center; gap: 12px;
  background: linear-gradient(180deg, #111f33, #0d1828);
  border: 1px solid rgba(255,255,255,.09); border-radius: var(--radius-md);
  padding: 14px 16px; transition: .15s; cursor: pointer; color: #fff;
}
.nx-card:hover { border-color: rgba(0,230,118,.3); box-shadow: 0 8px 24px rgba(0,0,0,.3); }
.nx-card .nx-l { flex: 1; min-width: 0; }
.nx-date { font: 600 10px/1 var(--font); letter-spacing: .04em; text-transform: uppercase; color: rgba(255,255,255,.5); margin-bottom: 9px; }
.nx-mt { display: flex; align-items: center; gap: 7px; }
.nx-mt .flag { width: 24px; height: 24px; border-width: 1.5px; }
.nx-mt .cc { font: 700 12px/1 var(--font); color: #fff; }
.nx-mt .x { font: 600 10px/1 var(--font); color: rgba(255,255,255,.4); margin: 0 1px; }
.nx-card .nx-lock { width: 32px; height: 32px; border-radius: 9px; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.12); display: grid; place-items: center; color: rgba(255,255,255,.5); flex: none; }
.nx-card .nx-edit { width: 32px; height: 32px; border-radius: 9px; background: rgba(0,230,118,.16); border: 1px solid rgba(0,230,118,.34); display: grid; place-items: center; color: var(--jeu-green); flex: none; }
.nx-card:hover .nx-edit { background: var(--jeu-green); color: var(--jeu-dark); }
@media (max-width: 900px) { .nx-strip { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .nx-strip { grid-template-columns: 1fr; } }

/* ── Match du jour : carte sombre avec fond stade + overlay ── */
.mdj {
  position: relative; border-radius: var(--radius-lg); overflow: hidden;
  border: 1px solid var(--border-1);
  padding: 22px 24px 24px; color: #fff;
  isolation: isolate; background: #0c1626; min-height: 360px;
  display: flex; flex-direction: column;
}
.mdj .mdj-bg {
  position: absolute; inset: 0; z-index: -2;
  background-image: url(/assets/unifoot-header.png);
  background-size: cover; background-position: center 35%;
}
.mdj::after {
  content: ""; position: absolute; inset: 0; z-index: -1;
  background: linear-gradient(180deg,
    rgba(6,14,28,.62) 0%, rgba(6,14,28,.42) 32%,
    rgba(6,14,28,.72) 72%, rgba(6,14,28,.92) 100%);
}
.mdj-head {
  display: flex; align-items: center; justify-content: center; gap: 9px;
  font: 700 13px/1 var(--font); letter-spacing: .12em; text-transform: uppercase;
}
.mdj-head svg { color: var(--jeu-gold); }
.mdj-grp { text-align: center; font: 500 12px/1 var(--font); color: rgba(255,255,255,.68); margin-top: 9px; }
.mdj-teams {
  display: grid; grid-template-columns: 1fr auto 1fr;
  align-items: center; gap: 8px; margin: 22px 0;
}
.mdj-teams .t { display: flex; flex-direction: column; align-items: center; gap: 11px; }
.mdj-teams .flag { width: 72px; height: 72px; border-width: 3px; box-shadow: 0 8px 24px rgba(0,0,0,.4); }
.mdj-teams .t b { font: 800 16px/1 var(--font); letter-spacing: .04em; text-shadow: 0 2px 10px rgba(0,0,0,.5); }
.mdj-teams .vs { font: 800 22px/1 var(--font); color: rgba(255,255,255,.55); }
.mdj-prono {
  background: rgba(8,16,30,.5); backdrop-filter: blur(6px);
  border: 1px solid rgba(255,255,255,.14); border-radius: var(--radius-md);
  padding: 14px 18px; display: flex; align-items: center; justify-content: space-between;
}
.mdj-prono .pl { font: 600 10px/1 var(--font); letter-spacing: .1em; text-transform: uppercase; color: rgba(255,255,255,.6); }
.mdj-prono .pv { display: flex; align-items: center; gap: 14px; }
.mdj-prono .pv b { font: 800 30px/1 var(--font); letter-spacing: .06em; }
.mdj-prono .edit {
  width: 38px; height: 38px; border-radius: 10px;
  background: rgba(0,230,118,.16); border: 1px solid rgba(0,230,118,.34);
  color: var(--jeu-green); display: grid; place-items: center; cursor: pointer; transition: .15s;
}
.mdj-prono .edit:hover { background: var(--jeu-green); color: var(--jeu-dark); }
/* SPEC-JEU-012 Type A — ligne buteurs sur la carte Match du jour */
.mdj-scorers {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  margin-top: 10px; padding: 11px 18px;
  background: rgba(8,16,30,.35); border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--radius-md);
}
.mdj-scorers .pl { font: 600 10px/1 var(--font); letter-spacing: .1em; text-transform: uppercase; color: rgba(255,255,255,.6); white-space: nowrap; }
.mdj-scorers .sv { display: flex; gap: 8px; flex-wrap: wrap; justify-content: flex-end; }
.sc-chip { display: inline-flex; align-items: center; gap: 6px; font: 600 12px/1 var(--font); color: #fff;
  background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.12); border-radius: 999px; padding: 5px 10px; }
.sc-chip .flag { width: 16px; height: 16px; }
.sc-chip.muted { color: rgba(255,255,255,.4); }

/* SPEC-JEU-012 Types B/C — widget pronostics globaux (dashboard).
   Harmonisé avec la carte « Défi du moment » (.defi). */
/* Rangée : Défi du moment + pronostics globaux sur la même ligne (repli si étroit). */
.defi-row { grid-column: 1 / -1; display: flex; flex-wrap: wrap; gap: 16px; align-items: stretch; }
.defi-row > .defi { flex: 1 1 300px; }
.defi-row > .dash-globals { flex: 1.5 1 340px; margin-top: 0; }
.defi-row > .defi.hidden { display: none; } /* si pas de défi actif, les globaux prennent la ligne */

/* SPEC-JEU-007 — barre « Ma position » épinglée en haut du classement */
.lead-me {
  width: 100%;
  display: flex; align-items: center; gap: 14px; margin: 0 0 14px;
  padding: 12px 16px; border: 1px solid rgba(0,230,118,.45); border-radius: var(--radius-md);
  /* Fond OPAQUE (base sombre solide sous le dégradé vert) pour ne pas laisser
     transparaître les lignes du classement au scroll. */
  background: linear-gradient(120deg, rgba(0,230,118,.2), rgba(34,211,238,.12)), #0b1830;
  box-shadow: 0 12px 30px -8px rgba(0,0,0,.6), 0 0 0 1px rgba(0,230,118,.15); color: #fff; cursor: pointer; text-align: left;
}
.lead-me:hover { filter: brightness(1.06); }
.lead-me .lm-rank { font: 800 18px/1 var(--font); color: var(--jeu-green); min-width: 42px; }
.lead-me .lm-id { flex: 1; min-width: 0; display: flex; align-items: center; gap: 10px; font: 600 14px/1 var(--font); }
.lead-me .lm-id .av { width: 30px; height: 30px; border-radius: 50%; display: grid; place-items: center; font: 700 11px/1 var(--font); color: #04121f; flex: none; }
.lead-me .lm-id em { font-style: normal; color: var(--jeu-green); font-size: 12px; }
.lead-me .lm-x { color: rgba(255,255,255,.6); font: 600 12px/1 var(--font); white-space: nowrap; }
.lead-me .lm-pts { font: 800 16px/1 var(--font); color: #fff; white-space: nowrap; }

/* SPEC-JEU-007 §8 — tendance de rang dans le classement */
.trend { font: 700 12px/1 var(--font); white-space: nowrap; }
.trend.up   { color: var(--jeu-green); }
.trend.down { color: var(--jeu-wrong); }
.trend.flat,
.trend.new  { color: rgba(255,255,255,.35); }

.dash-globals { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 14px; }
.dg-card {
  display: flex; align-items: center; gap: 16px;
  background: linear-gradient(180deg, #111f33, #0d1828);
  border: 1px solid rgba(255,255,255,.09);
  border-radius: var(--radius-lg); padding: 18px 20px;
  box-shadow: 0 12px 34px rgba(0,0,0,.34);
}
.dg-ico { width: 44px; height: 44px; border-radius: 12px; display: grid; place-items: center; flex: none; font-size: 20px; }
.dg-ico.ts { background: rgba(245,166,35,.18); }
.dg-ico.bp { background: rgba(98,168,255,.18); }
.dg-ico.ch { background: rgba(0,230,118,.18); }
.dg-body { display: flex; flex-direction: column; gap: 7px; min-width: 0; }
.dg-lbl { font: 700 11px/1 var(--font); color: rgba(255,255,255,.6); text-transform: uppercase; letter-spacing: .1em; }
.dg-lbl em { font-style: normal; color: var(--jeu-green); margin-left: 4px; }
.dg-val { font: 700 16px/1.2 var(--font); color: #fff; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.dg-cta { background: rgba(0,230,118,.16); border: 1px solid rgba(0,230,118,.34); color: var(--jeu-green);
  font: 700 12px/1 var(--font); padding: 7px 14px; border-radius: 999px; cursor: pointer; }
.dg-cta:hover { background: var(--jeu-green); color: var(--jeu-dark); }
.dg-edit { background: none; border: 0; color: rgba(255,255,255,.5); font: 500 11px/1 var(--font); text-decoration: underline; cursor: pointer; padding: 0; }
.dg-none { color: rgba(255,255,255,.45); font-weight: 500; }
.dg-res.ok { color: var(--jeu-green); font-size: 12px; }
.dg-res.ko { color: var(--jeu-wrong); font-size: 12px; }
@media (max-width: 560px) { .dash-globals { grid-template-columns: 1fr; } }

.mdj-lock { text-align: center; margin: 16px 0; }
.mdj-lock small {
  display: block; font: 600 10px/1 var(--font); letter-spacing: .1em;
  text-transform: uppercase; color: rgba(255,255,255,.6); margin-bottom: 8px;
}
.mdj-lock span {
  font: 800 26px/1 var(--font); color: var(--jeu-green);
  text-shadow: 0 0 20px rgba(0,230,118,.6); font-variant-numeric: tabular-nums;
}
.mdj-empty { color: rgba(255,255,255,.7); text-align: center; padding: 40px 0; }
.mdj-loading { color: rgba(255,255,255,.5); text-align: center; padding: 60px 0; }

/* Identique au CTA du formulaire d'inscription (.anon-cta). */
.btn-full {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  width: 100%; height: 54px; margin-top: auto; border: 0; cursor: pointer;
  background: linear-gradient(115deg, var(--jeu-green), #19c8ff);
  color: #04121f; font: 800 13px/1 var(--font); letter-spacing: .02em;
  border-radius: var(--radius-md); box-shadow: 0 12px 30px -6px rgba(0,230,118,.6);
  transition: .15s;
}
.btn-full:hover { filter: brightness(1.08); transform: translateY(-1px); box-shadow: 0 16px 36px -6px rgba(0,230,118,.7); }
.btn-full:active { transform: translateY(0); }

/* ── Dcards (cartes du dashboard — thème dark) ── */
.dcard {
  background: linear-gradient(180deg, #111f33, #0d1828);
  border: 1px solid rgba(255,255,255,.09);
  border-radius: var(--radius-lg); padding: 20px;
  display: flex; flex-direction: column;
  box-shadow: 0 12px 34px rgba(0,0,0,.34);
  color: #fff;
}
.dcard-h {
  display: flex; align-items: center; gap: 9px;
  font: 700 12px/1 var(--font); letter-spacing: .1em;
  text-transform: uppercase; margin-bottom: 16px;
  color: rgba(255,255,255,.85);
}
.dcard-h svg { color: var(--jeu-green); }
.dcard-h .trophy { color: var(--jeu-gold); }

.live-list { display: flex; flex-direction: column; gap: 4px; flex: 1; }
.live-row {
  display: flex; align-items: center; gap: 12px;
  padding: 9px 10px; border-radius: 10px;
}
.live-row .pos { width: 18px; font: 700 13px/1 var(--font); color: rgba(255,255,255,.4); text-align: center; }
.live-row.r1 .pos { color: var(--jeu-gold); }
.live-row.r2 .pos { color: var(--jeu-silver); }
.live-row.r3 .pos { color: var(--jeu-bronze); }
.live-row .av { width: 30px; height: 30px; border-radius: 50%; display: grid; place-items: center; font: 700 11px/1 var(--font); color: #fff; flex: none; }
.live-row .who { flex: 1; font: 600 13.5px/1.2 var(--font); min-width: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; color: #fff; }
.live-row .pts { font: 700 13.5px/1 var(--font); color: #fff; }
.live-row .pts small { color: rgba(255,255,255,.45); font-weight: 500; }
.live-row.me { background: rgba(0,230,118,.12); box-shadow: inset 0 0 0 1px rgba(0,230,118,.28); }
.live-row.me .who { color: var(--jeu-green); }

.btn-ghost-d {
  margin-top: 14px; width: 100%; height: 42px;
  border-radius: var(--radius-md); background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.13); color: #fff;
  font: 700 11px/1 var(--font); letter-spacing: .08em; cursor: pointer;
  transition: .15s;
}
.btn-ghost-d:hover { background: rgba(255,255,255,.1); border-color: rgba(255,255,255,.2); }

/* ── Objectif communauté (dcard objc — dark) ── */
.objc-num { font: 800 44px/1 var(--font); margin-top: 2px; color: #fff; }
.objc-num .g { color: var(--jeu-green); text-shadow: 0 0 22px rgba(0,230,118,.5); }
.objc-num small { font: 600 18px/1 var(--font); color: rgba(255,255,255,.4); }
.objc-sub { font: 500 13px/1 var(--font); color: rgba(255,255,255,.55); margin-top: 6px; }
.objc-bar {
  height: 9px; border-radius: var(--radius-pill);
  background: rgba(255,255,255,.1); overflow: hidden; margin: 16px 0 12px;
}
.objc-bar i { display: block; height: 100%; background: linear-gradient(90deg, var(--jeu-green-dk), var(--jeu-green)); box-shadow: 0 0 16px rgba(0,230,118,.7); transition: width .4s; }
.objc p { font: 500 12.5px/1.5 var(--font); color: rgba(255,255,255,.6); margin: 0 0 18px; }
.objc p b { color: #fff; }

.reward-lbl { font: 700 9px/1 var(--font); letter-spacing: .12em; text-transform: uppercase; color: rgba(255,255,255,.4); margin-bottom: 9px; }
.reward {
  display: flex; align-items: center; gap: 13px;
  background: linear-gradient(120deg, rgba(245,166,35,.14), rgba(245,166,35,.04));
  border: 1px solid rgba(245,166,35,.32); border-radius: var(--radius-md); padding: 13px 15px;
}
.reward .rw-ico { width: 40px; height: 40px; border-radius: 11px; display: grid; place-items: center; flex: none; background: linear-gradient(150deg, var(--jeu-gold), #d98a14); color: #fff; }
.reward .rw-img { width: 56px; height: 56px; border-radius: 12px; object-fit: cover; flex: none; }
.reward .rw-t { flex: 1; line-height: 1.3; }
.reward .rw-t b { font: 700 13.5px/1.2 var(--font); color: #fff; }
.reward .rw-t small { display: block; font: 500 11.5px/1 var(--font); color: rgba(255,255,255,.6); }
.reward .rw-lock { color: rgba(255,255,255,.4); flex: none; }

/* ── Bandeau motivation (topbar) ── */
.topbanner {
  display: flex; align-items: center; gap: 13px;
  background: rgba(255,255,255,.05); border: 1px solid rgba(255,122,26,.3);
  border-radius: var(--radius-lg); padding: 0 16px 0 14px; min-height: 64px;
  align-self: stretch; /* hauteur uniforme avec rang + cloche */
  cursor: pointer; transition: .15s; min-width: 240px; color: #fff;
}
.topbanner:hover { border-color: rgba(255,122,26,.55); box-shadow: 0 0 20px rgba(255,122,26,.12); }
.topbanner .tb-ico { width: 38px; height: 38px; border-radius: 11px; display: grid; place-items: center; flex: none; background: rgba(255,122,26,.16); }
.topbanner .tb-t { flex: 1; line-height: 1.3; text-align: left; }
.topbanner .tb-t b { font: 700 14px/1.3 var(--font); color: #fff; }
.topbanner .tb-t b span { color: var(--jeu-green); }
.topbanner .tb-t small { display: block; font: 400 12px/1.3 var(--font); color: rgba(255,255,255,.55); }
.topbanner .tb-arr { color: rgba(255,255,255,.4); flex: none; }

/* ── Cloche notifications ── */
.bell {
  width: 48px; align-self: stretch; min-height: 64px; border-radius: var(--radius-lg);
  background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.13);
  display: grid; place-items: center; color: rgba(255,255,255,.75); position: relative;
  flex: none; cursor: pointer; transition: .15s;
}
.bell:hover { background: rgba(255,255,255,.1); color: #fff; }
.bell::after { content: ""; position: absolute; top: 11px; right: 12px; width: 7px; height: 7px; border-radius: 50%; background: var(--jeu-wrong); border: 2px solid var(--jeu-dark-2); }

/* ── Delta rang (topbar) ── */
.topbar-rank .delta { display: flex; align-items: center; gap: 4px; font: 600 10.5px/1 var(--font); color: var(--jeu-green); margin-top: 8px; }
.topbar-rank .delta svg { width: 12px; height: 12px; }

/* ============================================================
   Pronostics + Matchs — tabs et listes
   ============================================================ */
.tabs {
  display: flex; gap: 4px; padding: 4px;
  background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.12);
  border-radius: 999px; width: fit-content;
}
.tab {
  background: transparent; border: 0; padding: 8px 16px; border-radius: 999px;
  font: 500 12px/1 var(--font); color: rgba(255,255,255,.6); cursor: pointer;
}
.tab:hover { color: #fff; }
.tab.active { background: var(--jeu-green); color: var(--jeu-dark); }
.empty { color: rgba(255,255,255,.5); text-align: center; padding: 32px 0; font-size: 13px; }

.pred-list {
  display: flex; flex-direction: column; gap: 10px;
  background: linear-gradient(180deg, #111f33, #0d1828);
  border: 1px solid rgba(255,255,255,.09);
  border-radius: var(--radius-lg); overflow: hidden;
  box-shadow: 0 12px 34px rgba(0,0,0,.34);
}
.pl-row {
  display: grid; grid-template-columns: 110px 1fr 140px 150px; gap: 16px; align-items: center;
  padding: 16px 20px; border-bottom: 1px solid rgba(255,255,255,.07);
}
.pl-row:last-child { border-bottom: 0; }
.pl-row:hover { background: rgba(255,255,255,.04); }
.pl-row .date { font: 700 13px/1.3 var(--font); color: #fff; }
.pl-row .date small { display: block; color: rgba(255,255,255,.5); font: 500 11px/1.3 var(--font); margin-top: 4px; }
.pl-row .match { display: flex; align-items: center; gap: 12px; min-width: 0; }
.pl-row .match .t { font: 600 14px/1 var(--font); color: #fff; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.pl-row .match .vsd { color: rgba(255,255,255,.4); font: 700 11px/1 var(--font); padding: 0 4px; }
.pl-row .pred { font: 600 10px/1 var(--font); color: rgba(255,255,255,.5); letter-spacing: .06em; text-transform: uppercase; }
.pl-row .pred b { display: block; color: #fff; font: 800 18px/1.2 var(--font); margin-top: 6px; letter-spacing: .04em; text-transform: none; }
.pl-row .status { text-align: right; font: 500 11px/1.4 var(--font); color: rgba(255,255,255,.55); }
.badge-res {
  display: inline-flex; align-items: center; gap: 5px; padding: 6px 12px;
  border-radius: var(--radius-pill); font: 700 11px/1 var(--font);
}
.badge-res.exact  { background: rgba(245,166,35,.18); color: #B17E10; }
.badge-res.spread { background: rgba(0,176,107,.15); color: var(--green-500); }
.badge-res.win    { background: rgba(0,176,107,.15); color: var(--green-500); }
.badge-res.miss   { background: rgba(219,61,75,.15); color: var(--red-500); }
.lock-soon    { color: var(--orange-500); font-weight: 700; }
.lock-pending { color: var(--fg-3); }

/* ============================================================
   Classement (tableau — charte Unifoot)
   ============================================================ */
.lead-tbl { width: 100%; border-collapse: collapse; }
.lead-tbl th {
  font: 600 10px/1 var(--font); text-transform: uppercase; letter-spacing: .08em;
  color: rgba(255,255,255,.55); text-align: left; padding: 13px 20px;
  background: rgba(255,255,255,.04); border-bottom: 1px solid rgba(255,255,255,.1);
}
.lead-tbl td {
  padding: 13px 20px; border-bottom: 1px solid rgba(255,255,255,.07);
  font: 500 14px/1 var(--font); color: #fff;
}
.lead-tbl tr:last-child td { border-bottom: 0; }
.lead-tbl tbody tr:hover td { background: rgba(255,255,255,.04); }
.lead-tbl .rk { font: 800 14px/1 var(--font); color: rgba(255,255,255,.4); width: 44px; }
.lead-tbl tr.gold .rk    { color: var(--jeu-gold); text-shadow: 0 0 14px rgba(255,193,7,.7); }
.lead-tbl tr.silver .rk  { color: #cfd6e2; }
.lead-tbl tr.bronze .rk  { color: var(--jeu-bronze); }
.lead-tbl tr.gold td, .lead-tbl tr.silver td, .lead-tbl tr.bronze td { background: rgba(255,255,255,.03); }
.lead-tbl .uc { display: flex; align-items: center; gap: 12px; }
.lead-tbl .uc .av {
  width: 34px; height: 34px; border-radius: 50%; display: grid; place-items: center;
  color: #fff; font: 700 12px/1 var(--font); flex: none;
}
.lead-tbl .pts-c { font: 800 14px/1 var(--font); text-align: right; color: #fff; }
.lead-tbl tr.me td { background: rgba(0,230,118,.12); }
.lead-tbl tr.me:hover td { background: rgba(0,230,118,.18); }
.lead-tbl tr.me .me-tag { color: var(--jeu-green); font-weight: 700; margin-left: 4px; }
.lead-tbl tr.lead-gap td { text-align: center; color: rgba(255,255,255,.3); letter-spacing: 4px; padding: 4px 0; font-size: 16px; background: transparent; }
.lead-tbl tr.lead-gap:hover td { background: transparent; }

/* ============================================================
   Matchs — grille de cards
   ============================================================ */
.mgrid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 16px; }
.mcard {
  background: linear-gradient(180deg, #111f33, #0d1828);
  border: 1px solid rgba(255,255,255,.09); border-radius: var(--radius-lg);
  padding: 18px; display: flex; flex-direction: column; gap: 14px;
  transition: box-shadow .15s, border-color .15s;
  box-shadow: 0 12px 34px rgba(0,0,0,.34); color: #fff;
}
.mcard:hover { border-color: rgba(0,230,118,.3); box-shadow: 0 16px 40px rgba(0,230,118,.16), 0 12px 34px rgba(0,0,0,.4); }
.mcard.live { border-color: rgba(219,61,75,.45); }
.mcard.locked { opacity: .85; }
.mcard.finished { opacity: .9; }
.mc-top { display: flex; align-items: center; justify-content: space-between; }
.tag {
  display: inline-flex; align-items: center; gap: 6px; padding: 5px 11px; border-radius: var(--radius-pill);
  font: 700 11px/1 var(--font);
}
.tag::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.tag.soon     { background: rgba(98,168,255,.18); color: #7db4ff; }
.tag.locked   { background: rgba(255,255,255,.08); color: rgba(255,255,255,.7); }
.tag.live     { background: rgba(219,61,75,.18); color: #ff7779; }
.tag.live::before { animation: pulse 1s infinite; }
.tag.finished { background: rgba(0,230,118,.16); color: var(--jeu-green); }
@keyframes pulse { 0%,100% { opacity: 1; } 50% { opacity: .35; } }

.mc-teams { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.mc-teams .t { display: flex; align-items: center; gap: 8px; flex: 1; min-width: 0; }
.mc-teams .t.away { justify-content: flex-end; }
.mc-teams .t b { font: 700 14px/1.1 var(--font); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; color: #fff; }
.mc-teams .vs { font: 700 13px/1 var(--font); color: rgba(255,255,255,.4); padding: 0 4px; }
.mc-score { display: flex; align-items: center; justify-content: center; gap: 14px; font: 800 30px/1 var(--font); color: #fff; }
.mc-score.live { color: #ff7779; }
.mc-info { font: 500 12px/1.4 var(--font); color: rgba(255,255,255,.6); }
.mc-info small { display: block; color: rgba(255,255,255,.45); font-size: 11px; margin-top: 2px; }
.mc-actions { display: flex; justify-content: space-between; align-items: center; gap: 8px; }
/* Bouton actif : même dégradé que le CTA d'inscription (.anon-cta). */
.btn-mini { height: 32px; padding: 0 16px; border-radius: 999px; background: linear-gradient(115deg, var(--jeu-green), #19c8ff); color: var(--jeu-dark); border: 0; font: 700 11px/1 var(--font); cursor: pointer; box-shadow: 0 8px 20px -6px rgba(0,230,118,.5); transition: .15s; }
.btn-mini:hover { filter: brightness(1.08); transform: translateY(-1px); }
.btn-mini:active { transform: translateY(0); }
.btn-mini.ghost { background: rgba(255,255,255,.06); color: rgba(255,255,255,.7); border: 1px solid rgba(255,255,255,.14); box-shadow: none; }

/* ============================================================
   Drapeaux (CSS pures)
   ============================================================ */
.flag { display: block; width: 22px; height: 22px; border-radius: 50%; flex: none; overflow: hidden; position: relative; border: 0; background-position: center; background-size: cover; }
.flag.fr { background: linear-gradient(90deg,#0055A4 33.33%,#fff 33.33% 66.66%,#EF4135 66.66%); }
.flag.es { background: linear-gradient(180deg,#AA151B 25%,#F1BF00 25% 75%,#AA151B 75%); }
.flag.ar { background: linear-gradient(180deg,#74ACDF 33.33%,#fff 33.33% 66.66%,#74ACDF 66.66%); }
.flag.pt { background: linear-gradient(90deg,#046A38 42%,#DA291C 42%); }
.flag.us { background: repeating-linear-gradient(180deg,#B22234 0 14.2%,#fff 14.2% 28.4%); }
.flag.us::before { content: ""; position: absolute; top: 0; left: 0; width: 42%; height: 54%; background: #3C3B6E; }
.flag.br { background: #009C3B; }
.flag.br::before { content: ""; position: absolute; inset: 0; margin: auto; width: 62%; height: 62%; background: #FFDF00; transform: rotate(45deg); }
.flag.br::after { content: ""; position: absolute; inset: 0; margin: auto; width: 30%; height: 30%; border-radius: 50%; background: #002776; }
.flag.uy { background: repeating-linear-gradient(180deg,#fff 0 11.1%,#7AB2E1 11.1% 22.2%); }
.flag.uy::before { content: ""; position: absolute; top: 0; left: 0; width: 44%; height: 55%; background: #fff; }
.flag.en { background: #fff; }
.flag.en::before { content: ""; position: absolute; left: 42%; top: 0; width: 16%; height: 100%; background: #CF142B; }
.flag.en::after { content: ""; position: absolute; top: 42%; left: 0; width: 100%; height: 16%; background: #CF142B; }
.flag.de { background: linear-gradient(180deg,#000 33.3%,#DD0000 33.3% 66.6%,#FFCE00 66.6%); }
.flag.it { background: linear-gradient(90deg,#008C45 33.3%,#fff 33.3% 66.6%,#CD212A 66.6%); }
.flag.nl { background: linear-gradient(180deg,#AE1C28 33.3%,#fff 33.3% 66.6%,#21468B 66.6%); }
.flag.be { background: linear-gradient(90deg,#000 33.3%,#FDDA24 33.3% 66.6%,#EF3340 66.6%); }
.flag.large { width: 36px; height: 36px; }
.flag.xl    { width: 52px; height: 52px; }

/* ============================================================
   Modal pronostic
   ============================================================ */
.modal-scrim {
  position: fixed; inset: 0; background: rgba(6,14,30,.65); z-index: 1000;
  display: flex; align-items: center; justify-content: center; padding: 24px;
  backdrop-filter: blur(4px);
}
.modal {
  background: linear-gradient(180deg, #14233a, #0d1828);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 20px; padding: 28px; max-width: 460px; width: 100%;
  position: relative; box-shadow: 0 24px 60px rgba(0,0,0,.5);
  color: #fff;
}
.modal-x { position: absolute; top: 14px; right: 14px; width: 32px; height: 32px; border-radius: 50%; background: rgba(255,255,255,.08); border: 0; cursor: pointer; font-size: 18px; color: rgba(255,255,255,.7); display: grid; place-items: center; }
.modal-x:hover { background: rgba(255,255,255,.16); color: #fff; }
.modal-eyebrow { font: 600 11px/1 var(--font); color: rgba(255,255,255,.5); letter-spacing: .08em; text-transform: uppercase; display: block; margin-bottom: 14px; text-align: center; }
.modal-teams { display: flex; align-items: center; justify-content: center; gap: 14px; margin-bottom: 8px; }
.modal-teams .mt-side { display: flex; align-items: center; gap: 8px; flex: 1; min-width: 0; }
.modal-teams .mt-side:last-child { justify-content: flex-end; }
.modal-teams b { font: 700 16px/1 var(--font); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; color: #fff; }
.modal-teams .mt-v { color: rgba(255,255,255,.4); font: 700 14px/1 var(--font); }
.modal-meta { text-align: center; font: 500 12px/1 var(--font); color: rgba(255,255,255,.55); margin-bottom: 24px; }

.score-row { display: flex; align-items: center; justify-content: center; gap: 18px; margin: 24px 0; }
.stepper { display: flex; flex-direction: column; align-items: center; gap: 8px; }
.sc { font: 800 48px/1 var(--font); color: #fff; width: 78px; text-align: center; }
.sbtns { display: flex; gap: 6px; }
.stp { width: 36px; height: 36px; border-radius: 10px; border: 1px solid rgba(255,255,255,.14); background: rgba(255,255,255,.06); font: 700 16px/1 var(--font); color: #fff; cursor: pointer; }
.stp:hover { background: rgba(0,230,118,.16); border-color: rgba(0,230,118,.34); color: var(--jeu-green); }
.score-dash { font: 700 32px/1 var(--font); color: rgba(255,255,255,.3); }

.pred-info { display: flex; gap: 10px; margin-bottom: 18px; }
.pi { flex: 1; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.1); border-radius: var(--radius-md); padding: 10px 14px; text-align: center; }
.pi small { display: block; font: 500 11px/1 var(--font); color: rgba(255,255,255,.5); margin-bottom: 4px; }
.pi b { font: 700 16px/1 var(--font); color: #fff; }
.pi.gold { background: rgba(245,166,35,.14); border-color: rgba(245,166,35,.3); }
.pi.gold b { color: #ffcf4d; }

.modal .modal-save, .modal-save {
  width: 100%; height: 48px; border-radius: 999px;
  background: linear-gradient(115deg, var(--jeu-green), #16c98f);
  color: var(--jeu-dark); border: 0;
  font: 800 13px/1 var(--font); letter-spacing: .06em; text-transform: uppercase;
  box-shadow: 0 10px 30px -6px rgba(0,230,118,.6);
  cursor: pointer;
}
.modal .modal-save:hover { filter: brightness(1.07); }
.modal-err { color: #ff7779; font-size: 12px; text-align: center; margin-top: 10px; }

/* ── SPEC-JEU-012 — Buteurs (modale) ───────────────────────────────── */
.scorers { margin: 4px 0 16px; border-top: 1px solid rgba(255,255,255,.1); padding-top: 14px; }
.scorers-head { margin-bottom: 10px; }
.scorers-head .modal-eyebrow em { color: var(--jeu-green); font-style: normal; font-weight: 700; margin-left: 6px; }
.scorers-cols { display: flex; gap: 14px; }
.scorers-col { flex: 1; min-width: 0; max-height: 300px; overflow-y: auto; padding-right: 4px; }
.sc-team { font: 700 12px/1 var(--font); color: rgba(255,255,255,.55); text-transform: uppercase; letter-spacing: .04em; margin-bottom: 8px; }
.sc-opt { display: flex; align-items: center; gap: 8px; padding: 7px 6px; border-radius: 8px; cursor: pointer; }
.sc-opt:hover { background: rgba(255,255,255,.05); }
.sc-opt input { accent-color: var(--jeu-green); flex: none; }
.sc-opt span { font: 500 13px/1.2 var(--font); color: #fff; }
.sc-opt span em { color: rgba(255,255,255,.4); font-style: normal; font-size: 11px; margin-left: 4px; }
.sc-opt.none span { color: rgba(255,255,255,.55); }
.sc-result { font: 700 13px/1.3 var(--font); padding: 6px 0; }
.sc-result.ok { color: var(--jeu-green); }
.sc-result.ko { color: #ff7779; }
.sc-result.none { color: rgba(255,255,255,.5); }
.sc-scored { font: 500 12px/1.4 var(--font); color: rgba(255,255,255,.7); }

/* ── SPEC-JEU-012 — Pronostics globaux (panel Pronostics) ──────────── */
.global-preds { margin-bottom: 16px; }
.gp-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.gp-head h3 { font: 700 16px/1 var(--font); color: #fff; margin: 0; }
.gp-lock { font: 600 12px/1 var(--font); color: rgba(255,255,255,.55); }
.gp-lock.locked { color: var(--jeu-gold); }
.gp-grid { display: flex; gap: 14px; flex-wrap: wrap; }
.gp-q { flex: 1; min-width: 200px; }
.gp-q label { display: block; font: 600 13px/1 var(--font); color: #fff; margin-bottom: 6px; }
.gp-q label em { color: var(--jeu-green); font-style: normal; font-weight: 700; margin-left: 4px; }
.gp-q select {
  width: 100%; height: 42px; padding: 0 12px; border-radius: 10px;
  background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.14);
  color: #fff; font: 500 13px/1 var(--font); cursor: pointer;
}
.gp-q select:disabled { opacity: .6; cursor: not-allowed; }
.gp-q select.gp-country { margin-bottom: 8px; }
.gp-result { display: block; margin-top: 6px; font: 700 12px/1.3 var(--font); min-height: 14px; }
.gp-result.ok { color: var(--jeu-green); }
.gp-result.ko { color: #ff7779; }
.gp-sublock { display: block; margin-top: 6px; font: 600 11px/1.3 var(--font); color: rgba(255,255,255,.5); }
.gp-sublock.locked { color: var(--jeu-gold); }
.gp-q-champion label { color: var(--jeu-gold); }
.gp-q-champion label em { color: var(--jeu-gold); }
@media (max-width: 520px) { .scorers-cols, .gp-grid { flex-direction: column; } }

/* ============================================================
   Règlement (panel — dark)
   ============================================================ */
.reg-card h2 { font: 700 22px/1.3 var(--font); margin: 0 0 6px; color: #fff; }
.reg-card h3 { font: 600 15px/1.3 var(--font); margin: 22px 0 6px; color: #fff; }
.reg-card p { font: 400 14px/1.5 var(--font); color: rgba(255,255,255,.85); margin-bottom: 8px; max-width: 720px; }
.reg-card .reg-version { color: rgba(255,255,255,.5); font-size: 12px; margin-bottom: 14px; }
.reg-card a { color: var(--jeu-green); }
.reg-tbl { border-collapse: collapse; margin: 8px 0 12px; }
.reg-tbl th, .reg-tbl td { padding: 8px 16px; border: 1px solid rgba(255,255,255,.1); font-size: 13px; text-align: left; color: #fff; }
.reg-tbl th { background: rgba(255,255,255,.04); font-weight: 600; color: rgba(255,255,255,.7); }

/* Règlement chargé depuis /api/reglement (HTML par défaut : h1/h2/.sub/table.reg).
   Mise en forme alignée sur la page publique SSR. */
.reg-doc h1 { font: 800 24px/1.2 var(--font); margin: 0 0 6px; color: #fff; }
.reg-doc h2 { font: 600 15px/1.3 var(--font); margin: 22px 0 6px; color: #fff; }
.reg-doc h3 { font: 600 15px/1.3 var(--font); margin: 22px 0 6px; color: #fff; }
.reg-doc p { font: 400 14px/1.5 var(--font); color: rgba(255,255,255,.85); margin: 0 0 8px; max-width: 720px; }
.reg-doc .sub, .reg-doc .reg-version { color: rgba(255,255,255,.5); font-size: 12px; margin: 0 0 14px; }
.reg-doc a { color: var(--jeu-green); }
.reg-doc table.reg, .reg-doc .reg-tbl { border-collapse: collapse; margin: 8px 0 12px; }
.reg-doc table.reg th, .reg-doc table.reg td,
.reg-doc .reg-tbl th, .reg-doc .reg-tbl td { padding: 8px 16px; border: 1px solid rgba(255,255,255,.1); font-size: 13px; text-align: left; color: #fff; }
.reg-doc table.reg th, .reg-doc .reg-tbl th { background: rgba(255,255,255,.04); font-weight: 600; color: rgba(255,255,255,.7); }

/* ============================================================
   Lots (panel — dark)
   ============================================================ */
.lots-cols { display: grid; grid-template-columns: 1fr 320px; gap: 22px; align-items: start; }
.lot-list { display: flex; flex-direction: column; gap: 14px; }
.lot-item {
  display: grid; grid-template-columns: auto 64px 1fr auto; gap: 16px; align-items: center;
  background: linear-gradient(180deg, #111f33, #0d1828); border: 1px solid rgba(255,255,255,.09);
  border-radius: var(--radius-lg); padding: 14px 18px; box-shadow: 0 12px 34px rgba(0,0,0,.34); color: #fff;
}
.lot-item .medal {
  width: 44px; height: 44px; border-radius: 12px; flex: none; color: #fff;
  display: flex; align-items: center; justify-content: center;
  font: 800 18px/1 var(--font); white-space: nowrap; line-height: 1;
}
.lot-item .medal sup { font: 700 9px/1 var(--font); margin-left: 1px; vertical-align: top; position: relative; top: 1px; }
.lot-item .medal.g1 { background: linear-gradient(150deg, var(--jeu-gold), #c97f12); }
.lot-item .medal.g2 { background: linear-gradient(150deg, var(--jeu-silver), #7d8696); }
.lot-item .medal.g3 { background: linear-gradient(150deg, var(--jeu-bronze), #9a5a26); }
.lot-item .lotimg { width: 64px; height: 64px; object-fit: cover; border-radius: 10px; background: rgba(255,255,255,.05); }
.lot-item .li-t { font: 700 15px/1.3 var(--font); color: #fff; }
.lot-item .li-s { font: 500 12px/1.4 var(--font); color: rgba(255,255,255,.55); margin-top: 3px; }
.lot-item .li-p { font: 800 16px/1 var(--font); white-space: nowrap; color: var(--jeu-green); }
.callout {
  position: relative; overflow: hidden;
  display: flex; gap: 12px; background: rgba(98,168,255,.1); border: 1px solid rgba(98,168,255,.28);
  border-radius: var(--radius-lg); padding: 16px 18px;
}
/* Voile + cadenas tant que l'objectif (500 inscrits) n'est pas atteint. */
.callout-veil {
  position: absolute; inset: 0; display: none; align-items: center; justify-content: center; gap: 10px;
  background: rgba(8,16,30,.72); backdrop-filter: blur(3px); -webkit-backdrop-filter: blur(3px);
  color: #fff; font: 700 13px/1.3 var(--font); text-align: center; padding: 0 16px;
}
.callout-veil svg { color: rgba(255,255,255,.85); flex: none; }
.callout.locked .callout-veil { display: flex; }
.callout.locked { transition: filter .4s, opacity .4s; }
.callout .ci { color: #7db4ff; flex: none; }
.callout .callout-img { width: 72px; height: 72px; object-fit: cover; border-radius: 12px; flex: none; align-self: center; background: rgba(255,255,255,.05); }
.callout b { font: 700 13px/1.4 var(--font); color: #fff; }
.callout p { font: 400 12.5px/1.5 var(--font); color: rgba(255,255,255,.6); margin: 4px 0 0; }
.obj-side {
  background: linear-gradient(180deg, #111f33, #0d1828); border: 1px solid rgba(255,255,255,.09);
  border-radius: var(--radius-lg); padding: 22px; box-shadow: 0 12px 34px rgba(0,0,0,.34); color: #fff;
}
.obj-side .eyebrow { color: rgba(255,255,255,.5); }
.obj-side .big { font: 800 40px/1 var(--font); margin: 12px 0 2px; }
.obj-side .big .g { color: var(--jeu-green); text-shadow: 0 0 22px rgba(0,230,118,.5); }
.obj-side .big small { font: 500 16px/1 var(--font); color: rgba(255,255,255,.4); margin-left: 4px; }
.bar-l { height: 10px; border-radius: var(--radius-pill); background: rgba(255,255,255,.1); overflow: hidden; margin: 16px 0; width: 100%; }
.bar-l i { display: block; height: 100%; background: linear-gradient(90deg, var(--jeu-green-dk), var(--jeu-green)); box-shadow: 0 0 14px rgba(0,230,118,.6); transition: width .4s; }
@media (max-width: 860px) { .lots-cols { grid-template-columns: 1fr; } }
@media (max-width: 520px) {
  .lot-item { grid-template-columns: auto 1fr auto; }
  .lot-item .lotimg { display: none; }
}

/* ============================================================
   Toast
   ============================================================ */
.toast {
  position: fixed; bottom: 20px; left: 50%; transform: translateX(-50%);
  background: var(--neutral-900); color: #fff; padding: 12px 18px; border-radius: 12px;
  box-shadow: 0 12px 32px rgba(0,0,0,.3); font: 500 13px/1.3 var(--font);
  z-index: 1100; max-width: 320px;
}
.toast.error { background: var(--red-500); }

/* ============================================================
   PWA — bottom nav, drawer, prompts (SPEC-JEU-011)
   ============================================================ */
.bottom-nav { display: none; }
.bottom-nav {
  position: fixed; bottom: 0; left: 0; right: 0; height: 64px; z-index: 90;
  background: var(--jeu-dark-2); border-top: 1px solid rgba(255,255,255,.08);
  align-items: stretch; justify-content: space-around;
  padding-bottom: env(safe-area-inset-bottom);
}
.bn-item {
  flex: 1; background: transparent; border: 0; cursor: pointer;
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 4px;
  color: var(--fg-3); padding: 8px 0;
}
.bn-item svg { width: 22px; height: 22px; }
.bn-item .label { font: 500 10px/1 var(--font); }
.bn-item.active { color: var(--jeu-green); }

.drawer-scrim { position: fixed; inset: 0; background: rgba(0,0,0,.5); z-index: 95; display: flex; align-items: flex-end; }
.more-drawer {
  width: 100%; background: var(--jeu-dark-2); border-top-left-radius: 18px; border-top-right-radius: 18px;
  padding: 10px 14px calc(18px + env(safe-area-inset-bottom)); display: flex; flex-direction: column; gap: 4px;
}
.md-handle { width: 40px; height: 4px; border-radius: 2px; background: rgba(255,255,255,.2); margin: 4px auto 12px; }
.md-item {
  display: flex; align-items: center; gap: 12px; width: 100%; text-align: left;
  background: transparent; border: 0; cursor: pointer; color: #fff;
  font: 500 14px/1 var(--font); padding: 14px 12px; border-radius: 10px;
}
.md-item:hover { background: rgba(255,255,255,.05); }
.md-item.danger { color: #ff7779; }

.prompt-scrim { position: fixed; inset: 0; background: rgba(6,14,30,.7); backdrop-filter: blur(4px); z-index: 1200; display: flex; align-items: center; justify-content: center; padding: 24px; }
.prompt-card {
  background: linear-gradient(180deg, #14233a, #0d1828); border: 1px solid rgba(255,255,255,.1);
  border-radius: 18px; padding: 28px; max-width: 380px; width: 100%; text-align: center; color: #fff; position: relative;
}
.prompt-ico { width: 56px; height: 56px; border-radius: 50%; display: grid; place-items: center; margin: 0 auto 14px; background: rgba(0,230,118,.14); color: var(--jeu-green); }
.prompt-card h3 { font: 700 18px/1.3 var(--font); margin: 0 0 8px; }
.prompt-card p { color: rgba(255,255,255,.6); font-size: 13px; margin: 0 0 18px; }
.prompt-card .btn.primary { width: 100%; height: 46px; border-radius: 999px; background: var(--jeu-green); color: var(--jeu-dark); font-weight: 700; border: 0; cursor: pointer; }
.prompt-later { background: transparent; border: 0; color: rgba(255,255,255,.5); cursor: pointer; margin-top: 12px; font: 500 13px/1 var(--font); }
.prompt-card.prefs { text-align: left; }
.pref-row { display: flex; align-items: center; justify-content: space-between; padding: 12px 0; border-bottom: 1px solid rgba(255,255,255,.08); font-size: 14px; }
.pref-row input { width: 20px; height: 20px; accent-color: var(--jeu-green); }
#prefs-status { font-size: 12px; }

/* ============================================================
   Mobile
   ============================================================ */
.scrim-aside { display: none; position: fixed; inset: 0; background: rgba(0,0,0,.4); z-index: 50; }
.scrim-aside.on { display: block; }

@media (max-width: 768px) {
  .shell { grid-template-columns: 1fr; }
  .sidebar {
    position: fixed; top: 0; left: 0; bottom: 0; width: 260px; z-index: 80;
    transform: translateX(-100%); transition: transform .22s;
  }
  .sidebar.open { transform: translateX(0); }
  .topbar .burger { display: inline-flex; }
  .topbar-rank, .topbanner, .bell { display: none; }
  .dash-grid { grid-template-columns: 1fr; }
  .pl-row { grid-template-columns: 1fr; gap: 8px; }
  .pl-row .status { text-align: left; }
  .anon-stage h1 { font-size: 24px; }
  .bottom-nav { display: flex; }
  .content { padding-bottom: calc(80px + env(safe-area-inset-bottom)); }

  /* Classement → lignes compactes (Rang · Avatar+Nom · Points) */
  .panel[data-panel="classement"] .card { padding: 6px 0; }
  .lead-tbl thead { display: none; }
  .lead-tbl, .lead-tbl tbody, .lead-tbl tr, .lead-tbl td { display: block; }
  .lead-tbl tr {
    display: flex; align-items: center; gap: 10px;
    padding: 11px 16px; border-bottom: 1px solid rgba(255,255,255,.07);
  }
  .lead-tbl tr:last-child { border-bottom: 0; }
  .lead-tbl td { padding: 0; border: 0 !important; background: transparent !important; }
  .lead-tbl .rk { width: 24px; flex: none; text-align: center; }
  .lead-tbl td:nth-child(2) { flex: 1; min-width: 0; }           /* Adhérent */
  .lead-tbl td:nth-child(3), .lead-tbl td:nth-child(4) { display: none; } /* Coop + Exacts masqués */
  .lead-tbl .uc { gap: 10px; }
  .lead-tbl .uc .av { width: 30px; height: 30px; }
  .lead-tbl .pts-c { flex: none; font-size: 15px; }
  .lead-tbl .pts-c::after { content: " pts"; font: 500 11px/1 var(--font); color: rgba(255,255,255,.45); }
  .lead-tbl tr.me td:nth-child(2) { color: var(--jeu-green); }
}
@media (min-width: 769px) {
  .bottom-nav, .drawer-scrim { display: none !important; }
}

