/* ============================================================
   IVANN 57 — Leaderboard global (saisons mensuelles)
   Sentinel : LB_V1
   ============================================================ */
/* LB_V1 */

.ivann-lb {
    background: linear-gradient(135deg, #312e81 0%, #0a0e14 100%);
    color: #f8fafc;
    border-radius: 14px;
    padding: 28px;
    margin: 32px 0;
    border: 1px solid #6366f1;
    font-family: 'JetBrains Mono', 'Consolas', monospace;
}

.ivann-lb__head {
    display: flex; justify-content: space-between; align-items: center;
    flex-wrap: wrap; gap: 12px;
    margin-bottom: 24px;
    padding-bottom: 16px;
    border-bottom: 1px solid rgba(99, 102, 241, 0.3);
}
.ivann-lb__title {
    margin: 0; font-size: 26px; font-weight: 900;
    background: linear-gradient(90deg, #fbbf24, #c084fc);
    -webkit-background-clip: text; background-clip: text; color: transparent;
    text-transform: uppercase; letter-spacing: 4px;
}
.ivann-lb__season {
    display: flex; flex-direction: column; align-items: flex-end;
    gap: 4px;
}
.ivann-lb__season-id {
    font-size: 16px; font-weight: 800;
    color: #c4b5fd;
    letter-spacing: 2px;
}
.ivann-lb__season-end {
    font-size: 11px; color: #94a3b8;
    text-transform: uppercase; letter-spacing: 1.5px;
}
.ivann-lb__season-end strong { color: #fde047; }

/* Podium top 3 */
.ivann-lb__podium {
    display: grid;
    grid-template-columns: 1fr 1.2fr 1fr;
    gap: 12px;
    margin-bottom: 24px;
    align-items: end;
}
.ivann-lb__podium-step {
    background: linear-gradient(135deg, var(--bg-from, #1e293b), #0f172a);
    border: 2px solid var(--border, #94a3b8);
    border-radius: 12px;
    padding: 14px 12px;
    text-align: center;
}
.ivann-lb__podium-step--1 {
    --bg-from: #422006;
    --border: #fbbf24;
    box-shadow: 0 0 30px rgba(251, 191, 36, 0.35);
    transform: translateY(-12px);
}
.ivann-lb__podium-step--2 {
    --bg-from: #18181b;
    --border: #d4d4d8;
}
.ivann-lb__podium-step--3 {
    --bg-from: #431407;
    --border: #f97316;
}
.ivann-lb__podium-rank {
    font: 900 32px/1 monospace;
    margin-bottom: 4px;
}
.ivann-lb__podium-step--1 .ivann-lb__podium-rank { color: #fbbf24; }
.ivann-lb__podium-step--2 .ivann-lb__podium-rank { color: #d4d4d8; }
.ivann-lb__podium-step--3 .ivann-lb__podium-rank { color: #f97316; }
.ivann-lb__podium-name {
    font-size: 13px; font-weight: 700;
    margin: 8px 0 4px;
    color: #f8fafc;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.ivann-lb__podium-elo {
    font: 900 22px/1 monospace;
    color: #fde047;
    font-variant-numeric: tabular-nums;
}
.ivann-lb__podium-wl {
    font-size: 10px; color: #94a3b8;
    margin-top: 4px;
    text-transform: uppercase; letter-spacing: 1px;
}

/* Ma carte */
.ivann-lb__me {
    background: linear-gradient(135deg, #1e3a8a 0%, #0c0a1d 100%);
    border: 2px solid #3b82f6;
    border-radius: 12px;
    padding: 18px 22px;
    margin-bottom: 24px;
    display: flex; justify-content: space-between; align-items: center;
    flex-wrap: wrap; gap: 14px;
}
.ivann-lb__me-rank {
    font: 900 36px/1 monospace;
    color: #fde047;
    min-width: 60px;
    text-align: center;
}
.ivann-lb__me-rank small { font-size: 14px; opacity: 0.6; display: block; }
.ivann-lb__me-info {
    flex: 1; min-width: 0;
}
.ivann-lb__me-label {
    font-size: 11px; color: #94a3b8;
    text-transform: uppercase; letter-spacing: 1.5px;
    margin-bottom: 4px;
}
.ivann-lb__me-name {
    font-size: 18px; font-weight: 800;
    color: #f8fafc;
}
.ivann-lb__me-stats {
    display: flex; gap: 18px;
    font-size: 12px;
    flex-wrap: wrap;
}
.ivann-lb__me-stat strong {
    display: block;
    font-size: 22px;
    color: #67e8f9;
    font-variant-numeric: tabular-nums;
}
.ivann-lb__me-stat-label {
    font-size: 10px; color: #94a3b8;
    text-transform: uppercase; letter-spacing: 1px;
}

/* Liste rangs 4-100 */
.ivann-lb__list {
    background: rgba(0,0,0,0.3);
    border-radius: 10px;
    padding: 8px;
}
.ivann-lb__row {
    display: grid;
    grid-template-columns: 50px 1fr 80px 100px 80px;
    gap: 12px;
    align-items: center;
    padding: 10px 14px;
    border-bottom: 1px dashed rgba(148,163,184,0.1);
    font-size: 13px;
    transition: background 150ms;
}
.ivann-lb__row:last-child { border-bottom: none; }
.ivann-lb__row:hover { background: rgba(255,255,255,0.03); }
.ivann-lb__row--me {
    background: rgba(251, 191, 36, 0.08);
    border-left: 3px solid #fbbf24;
}
.ivann-lb__row-rank {
    font: 800 14px/1 monospace;
    color: #94a3b8;
    text-align: center;
    font-variant-numeric: tabular-nums;
}
.ivann-lb__row-rank--top { color: #c4b5fd; }
.ivann-lb__row-name {
    font-weight: 600;
    color: #f8fafc;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    min-width: 0;
}
.ivann-lb__row-elo {
    font: 800 14px/1 monospace;
    color: #fde047;
    text-align: right;
    font-variant-numeric: tabular-nums;
}
.ivann-lb__row-wl {
    font-size: 11px; color: #94a3b8;
    text-align: right;
    font-variant-numeric: tabular-nums;
}
.ivann-lb__row-pct {
    font: 700 12px/1 monospace;
    color: #4ade80;
    text-align: right;
}
.ivann-lb__row-pct.is-low { color: #f43f5e; }

/* Rewards section */
.ivann-lb__rewards {
    background: rgba(0,0,0,0.3);
    border-radius: 10px;
    padding: 16px;
    margin-top: 24px;
}
.ivann-lb__rewards-title {
    font-size: 11px; color: #fde047;
    text-transform: uppercase; letter-spacing: 1.5px;
    margin: 0 0 12px;
}
.ivann-lb__rewards-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 10px;
}
.ivann-lb__reward {
    background: rgba(255,255,255,0.03);
    border-left: 3px solid var(--rew-color, #94a3b8);
    border-radius: 4px;
    padding: 10px 14px;
    font-size: 12px;
}
.ivann-lb__reward-rank {
    font-weight: 800;
    color: var(--rew-color, #94a3b8);
    font-size: 13px;
}
.ivann-lb__reward--apex   { --rew-color: #c084fc; }
.ivann-lb__reward--top10  { --rew-color: #fbbf24; }
.ivann-lb__reward--top100 { --rew-color: #67e8f9; }
.ivann-lb__reward--all    { --rew-color: #4ade80; }

/* Archives */
.ivann-lb__archives {
    margin-top: 24px;
}
.ivann-lb__archives-title {
    font-size: 11px; color: #94a3b8;
    text-transform: uppercase; letter-spacing: 1.5px;
    margin-bottom: 12px;
}
.ivann-lb__archive-row {
    display: flex; justify-content: space-between; align-items: center;
    padding: 10px 14px;
    background: rgba(0,0,0,0.3);
    border-radius: 6px;
    margin-bottom: 6px;
    font-size: 12px;
}
.ivann-lb__archive-season {
    font-weight: 800;
    color: #c4b5fd;
}
.ivann-lb__archive-top {
    color: #fde047;
    font-weight: 700;
}

.ivann-lb__empty {
    text-align: center;
    padding: 40px 16px;
    color: #94a3b8;
}
.ivann-lb__empty-icon { font-size: 48px; margin-bottom: 8px; opacity: 0.4; }

/* Panneau "comment grimper" (affiche quand le classement est vide) */
.ivann-lb__rankinfo {
    margin: 8px auto 0; max-width: 620px;
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 14px; padding: 22px 24px;
}
.ivann-lb__rankinfo-title {
    font: 800 13px/1 monospace; letter-spacing: 1.5px;
    text-transform: uppercase; color: #c4b5fd; margin: 0 0 10px;
    text-align: center;
}
.ivann-lb__rankinfo-text {
    font-size: 13px; color: #9aa1ba; line-height: 1.6;
    text-align: center; margin: 0 0 18px;
}
.ivann-lb__rankinfo-tiers { display: flex; flex-direction: column; gap: 8px; }
.ivann-lb__rankinfo-tier {
    display: flex; align-items: center; gap: 10px;
    padding: 9px 14px; border-radius: 9px;
    background: rgba(255,255,255,0.025);
    border-left: 3px solid var(--t, #94a3b8);
}
.ivann-lb__rankinfo-dot {
    width: 9px; height: 9px; border-radius: 50%;
    background: var(--t, #94a3b8); box-shadow: 0 0 8px var(--t, #94a3b8);
}
.ivann-lb__rankinfo-name { flex: 1; font-weight: 700; font-size: 13px; color: #e8eaf3; }
.ivann-lb__rankinfo-elo {
    font: 800 12px/1 monospace; color: var(--t, #94a3b8);
}

@media (max-width: 720px) {
    .ivann-lb__row { grid-template-columns: 40px 1fr 70px; }
    .ivann-lb__row-wl, .ivann-lb__row-pct { display: none; }
    .ivann-lb__podium { grid-template-columns: 1fr; }
    .ivann-lb__podium-step--1 { transform: none; }
}
