    [data-lucide] { width: 20px; height: 20px; vertical-align: middle; stroke-width: 2; }
    .icon-sm [data-lucide], .btn-primary [data-lucide], .btn-logout [data-lucide], .btn-theme [data-lucide], .player-pill-actions [data-lucide] { width: 16px; height: 16px; }
    .tab-icon { width: 18px; height: 18px; }
    .logo-ball { color: #2665f9; vertical-align: middle; margin-right: 8px; width: 22px; height: 22px; }
    :root {
      --bg: #f2f3f4; --bg-card: #fdfdfd; --bg-input: #fdfdfd; --border: #d4dbe9;
      --text: #08100C; --text-muted: #5a6f8a; --accent: #2665f9; --accent-hover: #0149f9;
      --success: #00b464; --error: #e74c3c;
      --gold-bg: #FCC86B; --silver-bg: #E5E5E5; --bronze-bg: #DCB38A;
      --grid-pattern: rgba(38, 101, 249, 0.04);
      --chart-grid: rgba(0,0,0,0.06);
      --hover-row: rgba(38,101,249,0.03);
      --my-row: rgba(38,101,249,0.06);
      --my-row-hover: rgba(38,101,249,0.1);
      --shadow: rgba(0,0,0,0.06);
      --shadow-mobile: rgba(0,0,0,0.08);
      --toast-bg: #08100C;
    }
    [data-theme="dark"] {
      --bg: #0f1419; --bg-card: #1a2332; --bg-input: #1e2a3a; --border: #2a3a4e;
      --text: #e1e8f0; --text-muted: #7a8da6; --accent: #4a8cff; --accent-hover: #6ba1ff;
      --success: #2dd4a0; --error: #f87171;
      --gold-bg: #FCC86B; --silver-bg: #c0c0d2; --bronze-bg: #cd9b6a;
      --grid-pattern: rgba(74, 140, 255, 0.03);
      --chart-grid: rgba(255,255,255,0.06);
      --hover-row: rgba(74,140,255,0.05);
      --my-row: rgba(74,140,255,0.1);
      --my-row-hover: rgba(74,140,255,0.16);
      --shadow: rgba(0,0,0,0.2);
      --shadow-mobile: rgba(0,0,0,0.3);
      --toast-bg: #e1e8f0;
    }
    * { margin: 0; padding: 0; box-sizing: border-box; }
    body {
      background: var(--bg);
      font-family: 'Inter', sans-serif; color: var(--text); min-height: 100vh;
      padding-bottom: 0;
      position: relative;
    }
    body::before {
      content: '';
      position: fixed;
      inset: 0;
      background-size: 32px 32px;
      background-image:
        linear-gradient(to right, var(--grid-pattern) 1px, transparent 1px),
        linear-gradient(to bottom, var(--grid-pattern) 1px, transparent 1px);
      z-index: 0;
      pointer-events: none;
    }
    header, main, .sidebar, .tabs-mobile, #weekend-overlay, #password-modal, #toast-container { position: relative; z-index: 1; }

    /* ─── Sidebar (desktop) ──────────────────────────────────────── */
    .sidebar { display: flex; flex-direction: column; justify-content: space-between; position: fixed; top: 0; left: 0; bottom: 0; width: 220px; background: var(--bg-card); border-right: 1px solid var(--border); z-index: 110; padding: 1.25rem 0; overflow-y: auto; }
    .sidebar-top { display: flex; flex-direction: column; gap: 4px; }
    .sidebar-logo { display: flex; align-items: center; gap: 10px; padding: 0 1.25rem 1.25rem; font-size: 1.05rem; font-weight: 700; white-space: nowrap; border-bottom: 1px solid var(--border); margin-bottom: 0.75rem; }
    .sidebar-logo .logo-ball { width: 22px; height: 22px; color: var(--accent); flex-shrink: 0; }
    .sidebar-nav { display: flex; flex-direction: column; gap: 2px; padding: 0 0.75rem; }
    .sidebar-tab { display: flex; align-items: center; gap: 10px; width: 100%; padding: 10px 12px; background: transparent; border: none; border-radius: 8px; color: var(--text-muted); cursor: pointer; font-family: 'Inter', sans-serif; font-size: 0.85rem; font-weight: 500; transition: all 0.15s; text-align: left; white-space: nowrap; }
    .sidebar-tab:hover { background: var(--hover-row); color: var(--text); }
    .sidebar-tab.active { background: rgba(38,101,249,0.08); color: var(--accent); font-weight: 600; }
    [data-theme="dark"] .sidebar-tab.active { background: rgba(74,140,255,0.1); }
    .sidebar-tab .tab-icon { width: 18px; height: 18px; flex-shrink: 0; }
    .sidebar-bottom { display: flex; flex-direction: column; gap: 8px; padding: 0.75rem 1.25rem 0; border-top: 1px solid var(--border); margin-top: auto; }
    .sidebar-user { font-size: 0.72rem; color: var(--text-muted); font-family: 'Space Mono', monospace; word-break: break-all; line-height: 1.4; padding-bottom: 6px; }
    .sidebar-btn { display: flex; align-items: center; gap: 6px; width: 100%; padding: 8px 10px; background: transparent; border: 1px solid var(--border); color: var(--text-muted); cursor: pointer; border-radius: 6px; font-family: 'Space Mono', monospace; font-size: 0.72rem; transition: all 0.15s; }
    .sidebar-btn:hover { border-color: var(--accent); color: var(--accent); }
    .sidebar-actions { display: flex; gap: 6px; }

    /* ─── Header mobile ──────────────────────────────────────────── */
    .header-mobile { display: none; }

    .btn-header { font-family: 'Space Mono', monospace; font-size: 0.72rem; padding: 6px 10px; background: transparent; border: 1px solid var(--border); color: var(--text-muted); cursor: pointer; border-radius: 6px; transition: all 0.15s; display: flex; align-items: center; justify-content: center; gap: 4px; min-width: 34px; min-height: 34px; }
    .btn-header:hover { border-color: var(--accent); color: var(--accent); }
    .btn-logout:hover { border-color: var(--error); color: var(--error); }

    .tabs-mobile { display: none; position: fixed; bottom: 0; left: 0; right: 0; z-index: 100; background: var(--bg-card); border-top: 1px solid var(--border); padding: 6px 0 env(safe-area-inset-bottom, 6px); box-shadow: 0 -2px 12px var(--shadow-mobile); }
    .tabs-mobile-inner { display: flex; justify-content: space-around; }
    .tab-mobile-btn { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 2px; padding: 6px 2px; background: transparent; border: none; cursor: pointer; color: var(--text-muted); font-family: 'Inter', sans-serif; font-size: 0.6rem; font-weight: 500; transition: color 0.15s; -webkit-tap-highlight-color: transparent; min-width: 0; overflow: hidden; }
    .tab-mobile-btn .tab-icon { width: 22px; height: 22px; transition: transform 0.15s; display: flex; align-items: center; justify-content: center; margin: 0 auto; }
    .tab-mobile-btn span:not(.tab-icon) { display: block; }
    .tab-mobile-btn.active { color: var(--accent); }
    .tab-mobile-btn.active .tab-icon { transform: scale(1.1); }

    /* ─── Main content (décalé par la sidebar sur desktop) ────────── */
    main { max-width: 900px; padding: 1.25rem 1.5rem; margin-left: max(220px, calc((100vw - 900px) / 2)); margin-right: auto; }
    .panel { display: none; }
    .panel.visible { display: block; animation: fadeIn 0.18s ease; }
    @keyframes fadeIn { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: translateY(0); } }
    .section { background: var(--bg-card); border: 1px solid var(--border); border-radius: 12px; padding: 1.25rem; margin-bottom: 1rem; }
    .section-title { font-family: 'Space Mono', monospace; font-size: 0.68rem; font-weight: 700; color: var(--accent); text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 1rem; padding-bottom: 0.5rem; border-bottom: 1px solid var(--border); }
    table { width: 100%; border-collapse: collapse; font-size: 0.9rem; }
    th, td { text-align: left; padding: 10px 12px; border-bottom: 1px solid var(--border); }
    th { font-family: 'Space Mono', monospace; font-size: 0.65rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.05em; font-weight: 500; }
    tr:last-child td { border-bottom: none; }
    tr:hover td { background: var(--hover-row); }
    tr.my-row td { background: var(--my-row); }
    tr.my-row:hover td { background: var(--my-row-hover); }
    tr.my-row td:first-child { border-left: 3px solid var(--accent); }
    td:nth-child(2) { font-family: 'Inter', sans-serif; font-weight: 500; }
    .rank { width: 48px; text-align: center; font-family: 'Space Mono', monospace; font-weight: 600; }
    .rank-medal { display: inline-flex; align-items: center; justify-content: center; width: 28px; height: 28px; border-radius: 50%; font-size: 0.85rem; font-weight: 700; }
    .rank.gold .rank-medal { background: var(--gold-bg); color: #1a1a1a; }
    .rank.silver .rank-medal { background: var(--silver-bg); color: #333; }
    .rank.bronze .rank-medal { background: var(--bronze-bg); color: #1a1a1a; }
    .points { font-family: 'Space Mono', monospace; font-weight: 700; color: var(--accent); text-align: right; }
    .stat-card .value { font-family: 'Space Mono', monospace; }
    .points-extra { font-family: 'Space Mono', monospace; font-weight: 400; color: var(--text-muted); text-align: right; }
    .trend { display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:4px;font-size:10px;font-weight:700;flex-shrink:0; }
    .trend-up { background:rgba(0,180,100,0.12);color:#00b464; }
    .trend-down { background:rgba(231,76,60,0.12);color:#e74c3c; }
    .trend-equal { background:transparent;color:var(--border); }
    .form-dot { display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;font-size:0.6rem;font-weight:700;margin:0 1px;font-family:'Space Mono',monospace; }
    .form-dot-good { background:rgba(0,180,100,0.15);color:#00b464; }
    .form-dot-mid { background:rgba(38,101,249,0.1);color:var(--accent); }
    .form-dot-bad { background:rgba(231,76,60,0.12);color:#e74c3c; }
    .skeleton { background: linear-gradient(90deg, var(--border) 25%, #eaecf0 50%, var(--border) 75%); background-size: 200% 100%; animation: shimmer 1.4s infinite; border-radius: 4px; }
    @keyframes shimmer { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }
    .skeleton-row { display: flex; gap: 12px; padding: 12px 0; border-bottom: 1px solid var(--border); align-items: center; }
    .skeleton-circle { width: 28px; height: 28px; border-radius: 50%; flex-shrink: 0; }
    .skeleton-line { height: 14px; border-radius: 4px; }
    #toast-container { position: fixed; bottom: 80px; left: 50%; transform: translateX(-50%); z-index: 9999; display: flex; flex-direction: column; gap: 8px; pointer-events: none; width: max-content; max-width: calc(100vw - 32px); }
    .toast { padding: 10px 16px; border-radius: 8px; font-size: 0.85rem; font-weight: 500; box-shadow: 0 4px 16px var(--shadow-mobile); pointer-events: auto; animation: toastIn 0.2s ease, toastOut 0.3s ease 2.7s forwards; display: flex; align-items: center; gap: 8px; }
    .toast-success { background: var(--toast-bg); color: #fff; }
    [data-theme="dark"] .toast-success { color: #0f1419; }
    .toast-error { background: var(--error); color: #fff; }
    @keyframes toastIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
    @keyframes toastOut { from { opacity: 1; } to { opacity: 0; } }
    .stats-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 10px; }
    .stat-card { background: var(--bg-input); border: 1px solid var(--border); border-radius: 10px; padding: 14px 12px; display: flex; flex-direction: column; gap: 6px; }
    .stat-card .stat-icon { font-size: 20px; }
    .stat-card .label { font-size: 0.68rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.04em; font-family: 'Space Mono', monospace; }
    .stat-card .value { font-family: 'Space Mono', monospace; font-size: 1.05rem; font-weight: 700; }
    .stat-card.best { border-color: rgba(0,180,100,0.3); background: rgba(0,180,100,0.04); }
    .stat-card.best .value { color: var(--success); }
    .stat-card.worst .value { color: var(--text-muted); }
    .last-update { font-size: 0.72rem; color: var(--text-muted); margin-top: 0.75rem; padding-top: 0.5rem; border-top: 1px solid var(--border); }
    .loading { text-align: center; color: var(--text-muted); padding: 2rem; }
    .error-msg { color: var(--error); font-size: 0.9rem; padding: 1rem; }
    .empty { color: var(--text-muted); font-size: 0.875rem; padding: 0.75rem 0; }
    select { background: var(--bg-input); border: 1px solid var(--border); color: var(--text); font-family: 'Inter', sans-serif; font-size: 0.875rem; padding: 8px 12px; border-radius: 8px; margin-bottom: 1rem; cursor: pointer; transition: border-color 0.15s; }
    #select-journee, #select-stats-journee { height: 40px; padding: 0 12px; font-size: 0.875rem; font-family: 'Inter', sans-serif; }
    select:focus { outline: none; border-color: var(--accent); }
    input:focus { outline: none; border-color: var(--accent); }
    input { font-family: 'Space Mono', monospace; }
    input::placeholder { font-family: 'Inter', sans-serif; color: var(--text-muted); }
    .form-row { display: flex; gap: 10px; align-items: flex-end; flex-wrap: wrap; margin-bottom: 12px; }
    .form-row .form-group { flex: 1; min-width: 120px; display: flex; flex-direction: column; gap: 4px; }
    .form-row label { font-size: 0.68rem; color: var(--text-muted); text-transform: uppercase; font-family: 'Space Mono', monospace; letter-spacing: 0.04em; }
    .form-row input, .form-row select { width: 100%; height: 40px; padding: 0 10px; margin: 0; background: var(--bg-input); border: 1px solid var(--border); color: var(--text); border-radius: 8px; font-size: 0.875rem; font-family: 'Space Mono', monospace; transition: border-color 0.15s; }
    .form-row input:focus, .form-row select:focus { border-color: var(--accent); outline: none; }
    .form-row button { height: 40px; padding: 0 16px; background: var(--accent); color: #fdfdfd; border: none; border-radius: 8px; font-weight: 600; cursor: pointer; white-space: nowrap; font-family: 'Inter', sans-serif; font-size: 0.875rem; display: flex; align-items: center; gap: 6px; transition: background 0.15s; }
    .form-row button:hover { background: var(--accent-hover); }
    .form-row button.secondary { background: transparent; border: 1px solid var(--border); color: var(--text-muted); }
    .form-row button.secondary:hover { border-color: var(--accent); color: var(--accent); }
    .admin-success { font-size: 0.8rem; color: var(--success); margin-top: 8px; }
    .btn-primary { height: 40px; padding: 0 16px; background: var(--accent); color: #fff; border: none; border-radius: 8px; font-weight: 600; cursor: pointer; font-family: 'Inter', sans-serif; font-size: 0.875rem; display: inline-flex; align-items: center; gap: 6px; transition: background 0.15s; }
    .btn-primary:hover { background: var(--accent-hover); }
    .player-pills { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px; }
    .player-pill { display: inline-flex; align-items: center; gap: 6px; padding: 6px 10px; background: var(--bg-input); border: 1px solid var(--border); border-radius: 999px; font-size: 0.82rem; font-family: 'Space Mono', monospace; transition: border-color 0.15s; }
    .player-pill:hover { border-color: var(--text-muted); }
    .player-pill-actions { display: flex; gap: 2px; margin-left: 2px; }
    .player-pill-actions button { width: 22px; height: 22px; padding: 0; border: none; border-radius: 50%; background: transparent; color: var(--text-muted); cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all 0.15s; }
    .player-pill-actions button:hover { background: var(--border); color: var(--text); }
    .player-pill-actions button.delete:hover { background: rgba(231,76,60,0.12); color: var(--error); }
    .player-pill-edit { display: inline-flex; align-items: center; gap: 6px; padding: 4px 8px; background: var(--bg-input); border-radius: 999px; border: 1.5px solid var(--accent); }
    .player-pill-edit input { width: 100px; height: 26px; padding: 0 8px; margin: 0; border: none; background: transparent; font-family: 'Space Mono', monospace; font-size: 0.82rem; }
    .player-pill-edit button { padding: 0 8px; height: 26px; font-size: 0.72rem; border-radius: 6px; }
    #admin-scores-players-list { display: grid; grid-template-columns: repeat(2, 1fr); gap: 2px 20px; max-height: 320px; overflow-y: auto; }
    .score-row { display: flex; align-items: center; gap: 8px; padding: 5px 0; border-bottom: 1px solid var(--border); font-size: 0.85rem; }
    .score-row .score-player { flex: 1; font-family: 'Space Mono', monospace; min-width: 0; overflow: hidden; text-overflow: ellipsis; }
    .score-row .score-input { width: 56px; height: 32px; padding: 0 6px; text-align: right; font-family: 'Space Mono', monospace; font-size: 0.85rem; background: var(--bg-input); border: 1px solid var(--border); border-radius: 6px; color: var(--text); flex-shrink: 0; transition: border-color 0.15s; }
    .score-row .score-input:focus { border-color: var(--accent); outline: none; }
    #panel-admin select { font-family: 'Inter', sans-serif; }
    #panel-admin .section-title { font-family: 'Space Mono', monospace; }
    #panel-admin button { font-family: 'Inter', sans-serif; }
    #panel-admin td, #panel-admin .score-player { font-family: 'Inter', sans-serif; }
    #panel-admin .score-input, #panel-admin input[type="number"] { font-family: 'Space Mono', monospace; }
    #panel-admin .player-pill { font-family: 'Inter', sans-serif; }
    .chart-section { margin-top: 0; }
    .chart-wrap { position: relative; height: 280px; margin: 1rem 0; }
    .chart-wrap-ranks { height: 320px; }
    .chart-legend-hint { font-size: 0.72rem; color: var(--text-muted); margin-bottom: 8px; }
    .chart-view-btns { display: flex; gap: 6px; margin-bottom: 10px; flex-wrap: wrap; }
    .chart-view-btn { padding: 4px 12px; border-radius: 999px; border: 1px solid var(--border); background: var(--bg-input); color: var(--text-muted); font-family: 'Space Mono', monospace; font-size: 0.7rem; cursor: pointer; transition: all 0.15s; }
    .chart-view-btn:hover { border-color: var(--accent); color: var(--accent); }
    .chart-view-btn.active { background: var(--accent); border-color: var(--accent); color: #fff; font-weight: 700; }
    .chart-view-custom { display: inline-flex; align-items: center; gap: 6px; padding: 4px 12px; border-radius: 999px; border: 1px solid var(--border); background: var(--bg-input); color: var(--text-muted); font-family: 'Space Mono', monospace; font-size: 0.7rem; }
    .chart-view-custom[hidden] { display: none; }
    .chart-view-custom input { width: 3.2em; padding: 2px 4px; border-radius: 4px; border: 1px solid var(--border); background: var(--bg); color: var(--text); font-family: inherit; font-size: inherit; text-align: center; -moz-appearance: textfield; }
    .chart-view-custom input::-webkit-outer-spin-button,
    .chart-view-custom input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
    .chart-legend { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px; }
    .chart-legend-item { display: inline-flex; align-items: center; gap: 5px; padding: 4px 10px; border-radius: 999px; background: var(--bg-input); border: 1px solid var(--border); font-size: 0.8rem; cursor: pointer; font-family: 'Inter', sans-serif; user-select: none; transition: all 0.15s; }
    .chart-legend-item:hover { border-color: var(--accent); color: var(--accent); }
    .chart-legend-item.focused { border-color: var(--accent); background: rgba(38,101,249,0.08); color: var(--accent); font-weight: 600; }
    .chart-legend-swatch { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }
    .scores-toggle { width:100%;display:flex;align-items:center;justify-content:space-between;padding:0.9rem 1.25rem;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;cursor:pointer;font-family:'Inter',sans-serif;font-size:0.875rem;font-weight:600;color:var(--text);transition:border-color 0.15s;margin-bottom:1rem; }
    .scores-toggle:hover { border-color:var(--accent); }
    .scores-toggle.open { border-radius:12px 12px 0 0;border-bottom-color:transparent;margin-bottom:0; }
    .scores-toggle.open:hover { border-color:var(--accent);border-bottom-color:transparent; }
    .scores-toggle.open:hover + .scores-body.open { border-left-color:var(--accent);border-right-color:var(--accent);border-bottom-color:var(--accent); }
    .scores-toggle .toggle-arrow { font-size:12px;color:var(--text-muted);transition:transform 0.2s; }
    .scores-toggle.open .toggle-arrow { transform:rotate(180deg); }
    .scores-body { display:none;border:1px solid var(--border);border-top:none;border-radius:0 0 12px 12px;padding:1rem;margin-bottom:1rem;background:var(--bg-card); }
    .scores-body.open { display:block; }
    .scores-mini-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px; }
    .scores-day-label { grid-column:1/-1;font-family:'Space Mono',monospace;font-size:0.65rem;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:0.08em;padding:6px 0 2px;border-top:1px solid var(--border);margin-top:4px; }
    .scores-day-label:first-child { border-top:none;margin-top:0; }
    .scores-mini-card { background:var(--bg-input);border:1px solid var(--border);border-radius:8px;padding:10px 12px;display:flex;align-items:center;gap:10px;font-size:0.82rem;min-width:0;overflow:hidden; }
    .scores-mini-card.live { border-color:rgba(0,180,100,0.4);background:rgba(0,180,100,0.04); }
    .scores-mini-teams { display:flex;flex-direction:column;gap:4px;flex:1;min-width:0; }
    .scores-mini-team { display:flex;align-items:center;gap:6px;min-width:0; }
    .scores-mini-name { font-weight:600;font-family:'Inter',sans-serif;font-size:0.75rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }
    .scores-mini-right { display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0; }
    .scores-mini-score { font-family:'Space Mono',monospace;font-weight:700;font-size:0.85rem;color:var(--text);white-space:nowrap;text-align:center; }
    .scores-mini-score.live { color:var(--success); }
    .scores-mini-badge { font-family:'Space Mono',monospace;font-size:0.55rem;font-weight:700;padding:2px 6px;border-radius:4px;white-space:nowrap; }
    .section-hero { background: linear-gradient(135deg, #1a4fcc 0%, #2665f9 60%, #1a55d4 100%); border-color: transparent; box-shadow: 0 4px 24px rgba(38,101,249,0.25); }
    .section-hero .section-title { color: rgba(255,255,255,0.65); border-bottom-color: rgba(255,255,255,0.15); }
    .section-hero table th { color: rgba(255,255,255,0.55); }
    .section-hero table td { color: #fff; border-bottom-color: rgba(255,255,255,0.1); }
    .section-hero table tr:last-child td { border-bottom: none; }
    .section-hero table tr:hover td { background: rgba(255,255,255,0.07); }
    .section-hero table tr.my-row td { background: rgba(255,255,255,0.12); }
    .section-hero table tr.my-row:hover td { background: rgba(255,255,255,0.18); }
    .section-hero table tr.my-row td:first-child { border-left-color: rgba(255,255,255,0.7); }
    .section-hero .points { color: #fff; }
    .section-hero .points-extra { color: rgba(255,255,255,0.5); }
    .section-hero .trend-up { background: rgba(0,255,140,0.15); color: #5dffa8; }
    .section-hero .trend-down { background: rgba(255,100,80,0.2); color: #ff8070; }
    .section-hero .trend-equal { color: rgba(255,255,255,0.2); }
    .section-hero .form-dot-good { background:rgba(0,255,140,0.2);color:#5dffa8; }
    .section-hero .form-dot-mid { background:rgba(255,255,255,0.12);color:rgba(255,255,255,0.7); }
    .section-hero .form-dot-bad { background:rgba(255,100,80,0.2);color:#ff8070; }
    .section-hero .empty { color: rgba(255,255,255,0.5); }
    .section-hero .skeleton { background: linear-gradient(90deg, rgba(255,255,255,0.1) 25%, rgba(255,255,255,0.2) 50%, rgba(255,255,255,0.1) 75%); background-size: 200% 100%; }
    .section-hero .skeleton-row { border-bottom-color: rgba(255,255,255,0.1); }
    @media (max-width: 768px) {
      .sidebar { display: none; }
      .header-mobile { display: flex; align-items: center; justify-content: space-between; background: var(--bg-card); position: sticky; top: 0; z-index: 100; box-shadow: 0 1px 3px var(--shadow); border-bottom: 1px solid var(--border); padding: 0 1rem; min-height: 56px; }
      .header-mobile h1 { font-size: 1rem; font-weight: 700; white-space: nowrap; flex-shrink: 0; }
      .header-right { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
      .scores-mini-grid { grid-template-columns: 1fr 1fr; }
      .scores-mini-card { padding: 8px 10px; gap: 6px; }
      .scores-mini-name { font-size: 0.68rem; }
      .scores-mini-score { font-size: 0.78rem; }
      body { padding-bottom: 80px; }
      .tabs-mobile { display: block; }
      main { padding: 1rem; margin-left: 0 !important; }
      .section { padding: 1rem; }
      #classement-content, #journee-content, #stats-content { overflow-x: auto; -webkit-overflow-scrolling: touch; }
      table { font-size: 0.82rem; min-width: 260px; }
      th, td { padding: 8px 8px; }
      .chart-wrap { height: 220px; }
      .chart-wrap-ranks { height: 260px; }
      .stats-grid { grid-template-columns: 1fr 1fr; }
      #admin-scores-players-list { grid-template-columns: 1fr; }
      .player-pill { font-size: 0.78rem; }
      #toast-container { bottom: 90px; }
    }
    @media (max-width: 480px) {
      .rank { width: 36px; }
      .rank-medal { width: 24px; height: 24px; font-size: 0.75rem; }
      .stats-grid { grid-template-columns: 1fr 1fr; }
      .form-row button { width: 100%; justify-content: center; }
      .podium { gap: 6px; }
      .podium-card { padding: 10px 8px 8px; }
      .podium-rank { font-size: 1.2rem; }
      .podium-1 { min-height: 100px; }
      .podium-2 { min-height: 88px; }
      .podium-3 { min-height: 78px; }
      .scores-mini-grid { grid-template-columns: 1fr 1fr; }
      .scores-mini-card { padding: 6px 8px; gap: 5px; }
      .scores-mini-name { font-size: 0.62rem; }
      .scores-mini-score { font-size: 0.72rem; }
      .scores-mini-team img { width: 16px; height: 16px; }
    }
    /* ─── Admin collapsible sections ─────────────────────────────── */
    .section-collapsible .section-title { cursor: pointer; display: flex; align-items: center; justify-content: space-between; user-select: none; }
    .section-collapsible .section-title:hover { color: var(--accent-hover); }
    .section-collapsible .section-title .collapse-arrow { transition: transform 0.2s; font-size: 0.7rem; color: var(--text-muted); }
    .section-collapsible .section-title.open .collapse-arrow { transform: rotate(180deg); }
    .section-collapsible .section-body { display: none; padding-top: 0.75rem; }
    .section-collapsible .section-body.open { display: block; }

    /* ─── Admin quick action ──────────────────────────────────────── */
    .admin-quick-action { display: flex; align-items: center; gap: 10px; padding: 12px 16px; background: linear-gradient(135deg, rgba(38,101,249,0.06), rgba(38,101,249,0.02)); border: 1px solid rgba(38,101,249,0.15); border-radius: 10px; margin-bottom: 1rem; cursor: pointer; transition: all 0.15s; }
    .admin-quick-action:hover { border-color: var(--accent); background: rgba(38,101,249,0.08); }
    .admin-quick-action .quick-label { font-family: 'Inter', sans-serif; font-size: 0.85rem; font-weight: 600; color: var(--accent); }
    .admin-quick-action .quick-hint { font-family: 'Space Mono', monospace; font-size: 0.68rem; color: var(--text-muted); }

    /* ─── Points bar (détail journée) ─────────────────────────────── */
    .points-bar-wrap { display: flex; align-items: center; gap: 10px; }
    .points-bar-name { flex-shrink: 0; width: 130px; font-weight: 600; font-size: 0.85rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; display: flex; align-items: center; }
    .points-bar-track { flex: 1; height: 28px; background: var(--bg); border-radius: 6px; position: relative; overflow: hidden; }
    .points-bar-fill { height: 100%; border-radius: 6px; display: flex; align-items: center; justify-content: flex-end; padding-right: 8px; font-family: 'Space Mono', monospace; font-size: 0.75rem; font-weight: 700; color: #fff; transition: width 0.5s ease; min-width: 40px; }
    .points-bar-fill.above { background: linear-gradient(90deg, var(--accent), #5b8af9); }
    .points-bar-fill.below { background: linear-gradient(90deg, var(--text-muted), #8a9bb5); }
    .points-bar-fill.best { background: linear-gradient(90deg, var(--success), #2dd4a0); }
    .points-bar-avg-line { position: absolute; top: 0; bottom: 0; width: 2px; background: var(--error); opacity: 0.6; z-index: 1; }
    .points-bar-avg-label { position: absolute; top: -16px; font-size: 0.6rem; color: var(--error); font-family: 'Space Mono', monospace; transform: translateX(-50%); white-space: nowrap; }
    .points-bar-row { padding: 6px 0; border-bottom: 1px solid var(--border); animation: rowSlideIn 0.25s ease both; }
    .points-bar-row:last-child { border-bottom: none; }
    .points-bar-row.my-row { background: rgba(38,101,249,0.04); }
    .points-bar-row.my-row .points-bar-name { color: var(--accent); }
    @media (max-width: 768px) {
      .points-bar-name { width: 90px; font-size: 0.75rem; }
      .points-bar-fill { font-size: 0.68rem; padding-right: 5px; }
    }

    /* ─── Matchday nav ──────────────────────────────────────────────── */
    .matchday-nav { display: flex; align-items: center; gap: 8px; margin-bottom: 1rem; }
    .matchday-nav select { margin-bottom: 0; flex: 1; max-width: 220px; }
    .matchday-nav-btn { width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; background: var(--bg-input); border: 1px solid var(--border); border-radius: 8px; cursor: pointer; color: var(--text-muted); transition: all 0.15s; flex-shrink: 0; }
    .matchday-nav-btn:hover { border-color: var(--accent); color: var(--accent); }
    .matchday-nav-btn:disabled { opacity: 0.3; cursor: default; }
    .matchday-nav-btn:disabled:hover { border-color: var(--border); color: var(--text-muted); }

    /* ─── Podium ─────────────────────────────────────────────────────── */
    .podium { display: flex; align-items: flex-end; justify-content: center; gap: 12px; margin-bottom: 1.25rem; padding: 0.5rem 0 0; }
    .podium-card { display: flex; flex-direction: column; align-items: center; gap: 6px; padding: 16px 14px 14px; border-radius: 12px; flex: 1; max-width: 160px; position: relative; transition: transform 0.2s; }
    .podium-card:hover { transform: translateY(-2px); }
    .podium-rank { font-family: 'Space Mono', monospace; font-size: 1.5rem; font-weight: 700; line-height: 1; }
    .podium-name { font-family: 'Inter', sans-serif; font-size: 0.82rem; font-weight: 600; text-align: center; word-break: break-word; }
    .podium-pts { font-family: 'Space Mono', monospace; font-size: 0.9rem; font-weight: 700; }
    .podium-last { font-family: 'Space Mono', monospace; font-size: 0.65rem; opacity: 0.6; }
    .podium-1 { background: linear-gradient(135deg, rgba(252,200,107,0.25), rgba(252,200,107,0.08)); border: 1.5px solid rgba(252,200,107,0.5); order: 2; min-height: 140px; }
    .podium-1 .podium-rank { color: #FCC86B; }
    .podium-2 { background: linear-gradient(135deg, rgba(192,192,210,0.2), rgba(192,192,210,0.06)); border: 1.5px solid rgba(192,192,210,0.4); order: 1; min-height: 120px; }
    .podium-2 .podium-rank { color: #C0C0D2; }
    .podium-3 { background: linear-gradient(135deg, rgba(205,127,50,0.2), rgba(205,127,50,0.06)); border: 1.5px solid rgba(205,127,50,0.35); order: 3; min-height: 105px; }
    .podium-3 .podium-rank { color: #CD7F32; }
    .section-hero .podium-card { border-color: rgba(255,255,255,0.15); }
    .section-hero .podium-1 { background: rgba(252,200,107,0.12); border-color: rgba(252,200,107,0.35); }
    .section-hero .podium-2 { background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,0.18); }
    .section-hero .podium-3 { background: rgba(205,127,50,0.1); border-color: rgba(205,127,50,0.25); }
    .section-hero .podium-name { color: #fff; }
    .section-hero .podium-pts { color: rgba(255,255,255,0.9); }

    /* ─── MVP banner ──────────────────────────────────────────────────── */
    .mvp-banner { display: flex; align-items: center; gap: 10px; padding: 10px 14px; border-radius: 10px; margin-bottom: 1rem; font-size: 0.82rem; }
    .section-hero .mvp-banner { background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.1); color: #fff; }
    .mvp-banner .mvp-icon { font-size: 1.2rem; }
    .mvp-banner .mvp-name { font-weight: 700; }
    .mvp-banner .mvp-pts { font-family: 'Space Mono', monospace; font-weight: 700; margin-left: auto; white-space: nowrap; }
    .section-hero .mvp-banner .mvp-pts { color: #FCC86B; }

    /* ─── Stagger animation ───────────────────────────────────────────── */
    @keyframes rowSlideIn { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: translateY(0); } }
    .stagger-row { animation: rowSlideIn 0.25s ease both; }

    /* ─── Mobile : hide secondary columns ─────────────────────────────── */
    .col-form, .col-played, .col-avg { white-space: nowrap; }
    @media (max-width: 768px) {
      .col-form, .col-played, .col-avg { display: none; }
      .podium { gap: 8px; }
      .podium-card { max-width: 120px; padding: 12px 10px 10px; }
      .podium-1 { min-height: 115px; }
      .podium-2 { min-height: 100px; }
      .podium-3 { min-height: 90px; }
      .podium-name { font-size: 0.75rem; }
      .podium-pts { font-size: 0.78rem; }
      .podium-last { font-size: 0.6rem; }
      .mvp-banner { font-size: 0.75rem; gap: 8px; padding: 8px 12px; flex-wrap: wrap; }
      .mvp-banner .mvp-pts { margin-left: 0; }
      #totp-qr { max-width: 200px; }
      #totp-codes-list { grid-template-columns: repeat(2, 1fr) !important; }
    }

    /* ─── Dark mode: skeleton shimmer ────────────────────────────── */
    [data-theme="dark"] .skeleton { background: linear-gradient(90deg, var(--border) 25%, #2a3a4e 50%, var(--border) 75%); background-size: 200% 100%; }
    [data-theme="dark"] .points-bar-row.my-row { background: rgba(74,140,255,0.06); }
    [data-theme="dark"] .chart-legend-item.focused { background: rgba(74,140,255,0.12); }
    [data-theme="dark"] .admin-quick-action { background: linear-gradient(135deg, rgba(74,140,255,0.08), rgba(74,140,255,0.03)); border-color: rgba(74,140,255,0.2); }
    [data-theme="dark"] .admin-quick-action:hover { background: rgba(74,140,255,0.1); }
    [data-theme="dark"] .stat-card.best { border-color: rgba(45,212,160,0.3); background: rgba(45,212,160,0.06); }
    [data-theme="dark"] .trend-up { background: rgba(45,212,160,0.15); color: #2dd4a0; }
    [data-theme="dark"] .trend-down { background: rgba(248,113,113,0.15); color: #f87171; }
    [data-theme="dark"] .form-dot-good { background: rgba(45,212,160,0.18); color: #2dd4a0; }
    [data-theme="dark"] .form-dot-bad { background: rgba(248,113,113,0.15); color: #f87171; }
    [data-theme="dark"] .player-pill-actions button.delete:hover { background: rgba(248,113,113,0.15); color: var(--error); }
    [data-theme="dark"] .scores-mini-card.live { border-color: rgba(45,212,160,0.4); background: rgba(45,212,160,0.06); }

    /* ─── Theme toggle button ────────────────────────────────────── */

    @keyframes wk-pulse { 0%,100%{opacity:1} 50%{opacity:0.3} }
    .wk-live-dot { animation: wk-pulse 1.2s ease-in-out infinite; }
