/* ============================================================
   WP Pronostics — Frontend CSS (pool de pronostics 1/X/2)
   ============================================================ */

/* Polyfill drapeaux : Windows ne dispose pas d'emojis pays dans ses polices
   système (rend « MA » au lieu de 🇲🇦). On charge un sous-ensemble Twemoji
   restreint via unicode-range aux codepoints des drapeaux. */
@font-face {
    font-family: 'Twemoji Country Flags';
    unicode-range: U+1F1E6-1F1FF, U+1F3F4, U+E0062-E0063, U+E0065, U+E0067,
                   U+E006C, U+E006E, U+E0073-E0074, U+E0077, U+E007F;
    font-style: normal;
    font-weight: 400;
    src: url('https://cdn.jsdelivr.net/npm/country-flag-emoji-polyfill@0.1/dist/TwemojiCountryFlags.woff2') format('woff2');
}
/* Version A — claire & éditoriale (défaut). Les couleurs de base sont aussi
   injectées en :root par le customizer ; on garde ici les mêmes valeurs + les
   tokens additionnels (track, ombres, typo titres). */
:root {
    --prono-accent:   #11a14a;
    --prono-accent2:  #2bd07a;
    --prono-success:  #15a34a;
    --prono-danger:   #e11d48;
    --prono-warn:     #f97316;
    --prono-bg:       #f4f6fb;
    --prono-card:     #ffffff;
    --prono-card2:    #f1f4f9;
    --prono-border:   #e6eaf2;
    --prono-text:     #0f172a;
    --prono-muted:    #667085;
    --prono-track:    rgba(15,23,42,.07);
    --prono-radius:   16px;
    --prono-shadow:   0 1px 2px rgba(16,24,40,.04), 0 14px 30px -10px rgba(16,24,40,.14);
    --prono-shadow-sm: 0 1px 2px rgba(16,24,40,.06), 0 4px 14px -6px rgba(16,24,40,.12);
    --prono-font:         'Twemoji Country Flags', 'Montserrat', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
    --prono-font-head:    'Twemoji Country Flags', 'Archivo', 'Montserrat', system-ui, 'Segoe UI', sans-serif;   /* width étendue via font-stretch */
    --prono-font-display: 'Twemoji Country Flags', 'Anton', 'Archivo', 'Montserrat', system-ui, 'Segoe UI', sans-serif; /* gros titres percutants */
}

/* Version B — dark premium (bleu nuit + vert/teal lumineux). Sélecteur plus
   spécifique que :root pour gagner quelle que soit la source du :root. */
html[data-prono-theme="dark"] {
    --prono-accent:   #25d366;
    --prono-accent2:  #14b8a6;
    --prono-success:  #22c55e;
    --prono-danger:   #fb7185;
    --prono-warn:     #fb923c;
    --prono-bg:       #0a1120;
    --prono-card:     #111b2e;
    --prono-card2:    #16223c;
    --prono-border:   #243047;
    --prono-text:     #e8eef9;
    --prono-muted:    #94a8c6;
    --prono-track:    rgba(255,255,255,.08);
    --prono-shadow:   0 1px 2px rgba(0,0,0,.4), 0 20px 44px -14px rgba(0,0,0,.66);
    --prono-shadow-sm: 0 2px 10px rgba(0,0,0,.4);
    --prono-gradient: linear-gradient(135deg, #25d366, #14b8a6);
}

/* ---- Typographie de base appliquée à toute l'app ---- */
.prono-home, .prono-profile, .prono-cal, .prono-leaderboard,
.prono-podium, .prono-match, .prono-modal {
    font-family: var(--prono-font, 'Inter'), system-ui, -apple-system, 'Segoe UI', sans-serif;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}
/* Chiffres alignés (scores, points, classement, compte à rebours). */
.prono-match__score, .prono-lb-points, .prono-lb-rank, .prono-lb-meta,
.prono-podium__points, .prono-stat__val, .prono-cal__dnum,
.prono-countdown__num, .prono-predrow__pts {
    font-variant-numeric: tabular-nums;
    font-feature-settings: "tnum" 1;
}

.prono-empty { color: var(--prono-muted); text-align: center; padding: 32px; }

/* ---- Layout ---- */
.prono-home { max-width: 1080px; margin: 0 auto; padding: 0 16px; }

.prono-hero {
    text-align: center;
    padding: 40px 20px 28px;
}
.prono-hero__title {
    font-family: var(--prono-font-head);
    font-size: clamp(28px, 4.4vw, 44px);
    font-weight: 700;
    letter-spacing: -.02em;
    margin: 0 0 10px;
    background: linear-gradient(135deg, var(--prono-accent), var(--prono-accent2));
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}
.prono-hero__subtitle { color: var(--prono-muted); font-size: 16px; margin: 0; }

/* ---- Titre de page (H1 imprimé par les shortcodes Matchs / Classement) ---- */
.prono-page-title--shortcode {
    font-family: var(--prono-font-head);
    font-size: clamp(26px, 3.6vw, 38px);
    font-weight: 700;
    letter-spacing: -.02em;
    color: var(--prono-text);
    margin: 0 0 22px;
    line-height: 1.15;
}

/* ---- Barre d'authentification ---- */
.prono-auth {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 18px;
}
.prono-auth__user { color: var(--prono-text); font-size: 14px; }
.prono-auth__hint { color: var(--prono-muted); font-size: 14px; }
.prono-auth__btn {
    display: inline-block;
    padding: 8px 18px;
    border-radius: 10px;
    font-size: 14px;
    font-weight: 700;
    text-decoration: none;
    color: #fff;
    background: linear-gradient(135deg, var(--prono-accent), var(--prono-accent2));
    border: 1px solid transparent;
    transition: transform .1s, opacity .15s;
}
.prono-auth__btn:hover { transform: translateY(-1px); opacity: .92; }
.prono-auth__btn--ghost {
    background: transparent;
    color: var(--prono-accent);
    border-color: var(--prono-border);
}
.prono-auth__btn--ghost:hover { border-color: var(--prono-accent); }

.prono-home__grid {
    display: grid;
    grid-template-columns: 1fr 360px;
    gap: 28px;
    align-items: start;
}
.prono-section-title {
    font-size: 18px;
    font-weight: 700;
    color: var(--prono-text);
    margin: 0 0 16px;
}

/* ---- Carte match ---- */
.prono-match {
    background: var(--prono-card);
    border: 1px solid var(--prono-border);
    border-radius: var(--prono-radius);
    box-shadow: var(--prono-shadow);
    overflow: hidden;
    margin-bottom: 20px;
}
.prono-match__top {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    padding: 12px 18px;
    background: var(--prono-card2);
    border-bottom: 1px solid var(--prono-border);
}
.prono-comp-tag {
    background: color-mix(in srgb, var(--prono-accent) 12%, transparent);
    color: var(--prono-accent);
    border: 1px solid color-mix(in srgb, var(--prono-accent) 30%, transparent);
    padding: 2px 10px;
    border-radius: 6px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
}
.prono-match__date { font-size: 12px; color: var(--prono-muted); }
.prono-match__top .prono-badge { margin-left: auto; }

.prono-match__teams {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: 12px;
    padding: 26px 18px;
}
.prono-team {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    text-align: center;
}
.prono-team__logo {
    width: 64px;
    height: 64px;
    object-fit: contain;
    filter: drop-shadow(0 2px 6px rgba(0,0,0,.4));
}
.prono-team__initials {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--prono-accent), var(--prono-accent2));
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    font-weight: 800;
    color: #fff;
    letter-spacing: .04em;
}
.prono-team__name { font-size: 15px; font-weight: 700; color: var(--prono-text); line-height: 1.2; }
.prono-team--winner .prono-team__name { color: var(--prono-success); }
.prono-team--winner .prono-team__logo { filter: drop-shadow(0 0 10px rgba(34,197,94,.5)); }

.prono-match__center { text-align: center; min-width: 70px; }
.prono-match__vs { font-size: 16px; font-weight: 700; color: var(--prono-muted); opacity: .55; letter-spacing: .14em; }
.prono-match__score { font-family: var(--prono-font-head); font-size: 32px; font-weight: 700; color: var(--prono-text); letter-spacing: .02em; }

/* ---- Saisie du score pronostiqué ---- */
.prono-pred { padding: 0 18px 4px; }
.prono-pred__row {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    flex-wrap: wrap;
}
.prono-pred__team {
    font-size: 13px;
    font-weight: 600;
    color: var(--prono-muted);
    max-width: 120px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.prono-pred__team--home { text-align: right; }
.prono-pred__team--away { text-align: left; }
.prono-pred__in {
    width: 60px;
    height: 58px;
    text-align: center;
    font-family: var(--prono-font-head);
    font-size: 28px;
    font-weight: 700;
    color: var(--prono-text);
    background: var(--prono-card2);
    border: 1.5px solid var(--prono-border);
    border-radius: 14px;
    transition: border-color .15s, background .15s, box-shadow .15s;
    -moz-appearance: textfield;
}
.prono-pred__in::-webkit-outer-spin-button,
.prono-pred__in::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.prono-pred__in:focus {
    outline: none;
    border-color: var(--prono-accent);
    background: color-mix(in srgb, var(--prono-accent) 10%, var(--prono-card));
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--prono-accent) 16%, transparent);
}
.prono-pred__in:disabled { opacity: .7; cursor: default; }
.prono-pred__sep { font-size: 22px; font-weight: 800; color: var(--prono-border); }

.prono-pred__submit {
    display: block;
    width: calc(100% - 0px);
    margin: 12px auto 4px;
    padding: 11px 16px;
    border: none;
    border-radius: 10px;
    font-size: 14px;
    font-weight: 700;
    color: #fff;
    background: linear-gradient(135deg, var(--prono-accent), var(--prono-accent2));
    cursor: pointer;
    transition: transform .1s, opacity .15s;
}
.prono-pred__submit:hover { transform: translateY(-1px); opacity: .92; }
.prono-pred__submit:disabled { opacity: .6; cursor: default; transform: none; }
.prono-pred.is-loading { opacity: .6; pointer-events: none; }

/* ---- Répartition 1/X/2 ---- */
.prono-dist {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: 6px 18px 2px;
}
.prono-dist__item {
    display: grid;
    grid-template-columns: 1fr 90px auto;
    align-items: center;
    gap: 10px;
    font-size: 12px;
    color: var(--prono-muted);
}
.prono-dist__sign { font-weight: 800; color: var(--prono-text); }
.prono-dist__lab {
    font-weight: 500;
    color: var(--prono-muted);
    font-size: 11px;
}
.prono-dist__bar {
    height: 6px;
    background: var(--prono-track);
    border-radius: 4px;
    overflow: hidden;
}
.prono-dist__bar > span {
    display: block;
    height: 100%;
    width: 0;
    background: var(--prono-muted);
    opacity: .5;
    transition: width .4s ease;
}
.prono-dist__pct { text-align: right; min-width: 56px; }
.prono-dist__item.is-mine .prono-dist__bar > span { background: var(--prono-accent); opacity: 1; }
.prono-dist__item.is-mine .prono-dist__pct { color: var(--prono-accent); font-weight: 700; }

.prono-vote__msg {
    padding: 8px 18px 16px;
    font-size: 13px;
    color: var(--prono-muted);
    margin: 0;
    min-height: 18px;
}
.prono-vote__msg a { color: var(--prono-accent); text-decoration: none; font-weight: 600; }
.prono-vote__msg a:hover { text-decoration: underline; }

.prono-vote.is-loading { opacity: .6; pointer-events: none; }

/* ---- Liste matchs (shortcode) ---- */
.prono-matches {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
    gap: 20px;
}

/* ---- Classement ---- */
.prono-leaderboard { display: flex; flex-direction: column; gap: 8px; }
/* =====================================================================
   Départements — modal bloquant + onglets classement + battle cards
   ===================================================================== */

/* ---- Modal bloquant : forcer l'user à choisir son département ---- */
body.prono-dept-gate-locked { overflow: hidden; }
.prono-dept-gate {
    position: fixed;
    inset: 0;
    background: rgba(15, 23, 42, .82);
    backdrop-filter: blur(6px);
    z-index: 100000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
}
.prono-dept-gate__box {
    background: var(--prono-card, #fff);
    border-radius: 16px;
    max-width: 440px;
    width: 100%;
    padding: 32px 28px;
    box-shadow: 0 30px 60px -20px rgba(0, 0, 0, .55);
    text-align: center;
}
.prono-dept-gate__title { margin: 0 0 8px; font-family: var(--prono-font-head); font-size: 26px; color: var(--prono-text); }
.prono-dept-gate__lead { color: var(--prono-muted, #64748b); margin: 0 0 22px; }
.prono-dept-gate__form { display: flex; flex-direction: column; gap: 14px; }
.prono-dept-gate__form select {
    width: 100%;
    padding: 12px 14px;
    border: 1px solid var(--prono-border);
    border-radius: 10px;
    font-size: 15px;
    background: #fff;
    color: var(--prono-text);
}
.prono-dept-gate__submit {
    background: linear-gradient(135deg, var(--prono-accent), var(--prono-accent2));
    color: #fff; border: none; padding: 12px 24px; border-radius: 10px;
    font-weight: 700; font-size: 15px; cursor: pointer;
}
.prono-dept-gate__submit:hover { filter: brightness(1.05); }
.prono-dept-gate__msg { font-size: 13px; color: var(--prono-accent); min-height: 18px; }

/* ---- Onglets classement (Tous / Mon dept / Battle) ---- */
.prono-lb-tabs { display: flex; gap: 8px; margin-bottom: 16px; flex-wrap: wrap; }
.prono-lb-tab {
    border: 1px solid var(--prono-border);
    background: var(--prono-card);
    color: var(--prono-text);
    padding: 8px 16px;
    border-radius: 10px;
    font-family: var(--prono-font);
    font-weight: 600;
    font-size: 13px;
    cursor: pointer;
    transition: background .15s, color .15s, border-color .15s;
}
.prono-lb-tab:hover { border-color: var(--prono-accent); }
.prono-lb-tab.is-active {
    background: var(--prono-accent);
    color: #fff;
    border-color: var(--prono-accent);
}

/* ---- Battle des départements : cards ---- */
.prono-battle__lead {
    font-size: 13px;
    color: var(--prono-muted);
    background: color-mix(in srgb, var(--prono-accent) 6%, transparent);
    border-left: 3px solid var(--prono-accent);
    padding: 10px 14px;
    border-radius: 6px;
    margin: 0 0 14px;
}
.prono-battle { display: grid; gap: 12px; }
.prono-battle__card {
    background: var(--prono-card);
    border: 1px solid var(--prono-border);
    border-radius: 12px;
    padding: 16px 18px;
    position: relative;
    overflow: hidden;
    border-left: 6px solid var(--dept-c, var(--prono-accent));
}
.prono-battle__card.is-leader {
    background: linear-gradient(135deg, color-mix(in srgb, var(--dept-c) 18%, var(--prono-card)) 0%, var(--prono-card) 70%);
    box-shadow: 0 10px 24px -10px var(--dept-c);
}
.prono-battle__head { display: flex; align-items: center; gap: 10px; }
.prono-battle__rank { font-size: 22px; }
.prono-battle__name { font-family: var(--prono-font-head); font-size: 19px; font-weight: 700; color: var(--prono-text); }
.prono-battle__metrics {
    display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap;
    margin-top: 6px;
}
.prono-battle__avg { font-size: 18px; color: var(--dept-c); }
.prono-battle__avg strong { font-family: var(--prono-font-head); font-size: 26px; }
.prono-battle__sep { color: var(--prono-muted); }
.prono-battle__total { font-size: 13px; color: var(--prono-muted); }
.prono-battle__sub { font-size: 12px; color: var(--prono-muted); margin-top: 6px; }

/* ---- Pastille dept sur les lignes de classement ---- */
.prono-ptag--dept { font-weight: 700; display: inline-flex; align-items: center; gap: 6px; }
.prono-lb-tag--dept { font-weight: 700; display: inline-flex; align-items: center; gap: 5px; }

/* Icône image du département (logo / badge) — taille inline pilotée par
   l'attribut style="width:Xpx;height:Xpx" injecté par render_icon(). */
.prono-dept-icon {
    display: inline-block;
    object-fit: contain;
    border-radius: 4px;
    vertical-align: middle;
    flex-shrink: 0;
}
.prono-battle__head .prono-dept-icon { border-radius: 6px; }

.prono-lb-row {
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
    gap: 12px;
    background: var(--prono-card);
    border: 1px solid var(--prono-border);
    border-radius: 10px;
    padding: 10px 14px;
    transition: border-color .15s;
}
.prono-lb-row:hover { border-color: var(--prono-accent); }
.prono-lb-rank,
.prono-lb-avatar,
.prono-lb-name,
.prono-lb-points,
.prono-lb-meta { position: relative; z-index: 1; }
.prono-lb-rank { font-size: 16px; font-weight: 800; min-width: 28px; text-align: center; }
.prono-lb-avatar { width: 36px; height: 36px; border-radius: 50%; border: 2px solid var(--prono-border); }
.prono-lb-name { font-weight: 600; color: var(--prono-text); flex: 1; font-size: 14px; }
.prono-lb-points { font-family: var(--prono-font-head); font-weight: 700; font-size: 16px; color: var(--prono-accent); }
.prono-lb-meta { font-size: 11px; color: var(--prono-muted); min-width: 80px; text-align: right; }

/* Habillage léger aux couleurs du pays — voile coloré subtil + petit drapeau
   filigrane à droite, sans surcharger les lignes de la liste. */
.prono-lb-row.is-team-themed {
    background:
        linear-gradient(90deg, color-mix(in srgb, var(--team-c1, var(--prono-card)) 10%, var(--prono-card)) 0%, var(--prono-card) 70%);
    border-color: color-mix(in srgb, var(--team-c1, var(--prono-border)) 40%, var(--prono-border));
}
.prono-lb-flag-bg {
    position: absolute;
    right: -8px;
    top: 50%;
    transform: translateY(-50%) rotate(-8deg);
    font-size: 60px;
    line-height: 1;
    opacity: .14;
    pointer-events: none;
    user-select: none;
    z-index: 0;
    font-family: 'Twemoji Country Flags', 'Montserrat', system-ui, sans-serif;
}

/* ---- Badges ---- */
.prono-badge {
    display: inline-block;
    padding: 3px 9px;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .04em;
}
.prono-badge--en-cours { background: rgba(245,158,11,.12); color: var(--prono-warn); border: 1px solid var(--prono-warn); }
.prono-badge--gagne    { background: rgba(34,197,94,.12);  color: var(--prono-success); border: 1px solid var(--prono-success); }
.prono-badge--annule   { background: rgba(71,85,105,.1);   color: #94a3b8; border: 1px solid #475569; }
.prono-badge--bonus    { background: rgba(245,158,11,.15); color: var(--prono-warn); border: 1px solid var(--prono-warn); }

/* ---- Bouton Bonus ×2 ---- */
.prono-bonus__btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: calc(100% - 36px);
    margin: 0 18px 12px;
    padding: 11px 16px;
    border: 1px dashed var(--prono-warn);
    border-radius: 10px;
    background: transparent;
    color: var(--prono-warn);
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
    transition: background .15s, transform .1s, opacity .15s;
}
.prono-bonus__btn:hover:not(:disabled) { background: rgba(245,158,11,.1); transform: translateY(-1px); }
.prono-bonus__btn:disabled { cursor: default; opacity: .6; }
.prono-bonus__btn.is-active {
    border-style: solid;
    background: rgba(245,158,11,.14);
    box-shadow: 0 0 0 1px var(--prono-warn) inset;
}
.prono-bonus__btn.is-locked { opacity: .8; }
.prono-bonus__x2 {
    font-size: 16px;
    font-weight: 800;
    font-style: italic;
    color: var(--prono-warn);
}
.prono-bonus__btn.is-loading { opacity: .5; pointer-events: none; }

/* ---- Modale Bonus ---- */
.prono-modal {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 16px;
}
.prono-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,.7);
    backdrop-filter: blur(2px);
}
.prono-modal__box {
    position: relative;
    z-index: 1;
    max-width: 380px;
    width: 100%;
    background: var(--prono-card);
    border: 1px solid var(--prono-border);
    border-radius: 16px;
    padding: 26px 24px 24px;
    text-align: center;
    box-shadow: var(--prono-shadow);
    animation: prono-pop .18s ease;
}
@keyframes prono-pop { from { transform: scale(.92); opacity: 0; } to { transform: scale(1); opacity: 1; } }
.prono-modal__close {
    position: absolute;
    top: 10px; right: 12px;
    background: none; border: none;
    color: var(--prono-muted);
    font-size: 24px; line-height: 1;
    cursor: pointer;
}
.prono-modal__icon { font-size: 44px; margin-bottom: 6px; }
.prono-modal__title {
    margin: 0 0 10px;
    font-size: 22px; font-weight: 800;
    letter-spacing: .04em;
    color: var(--prono-warn);
}
.prono-modal__text { color: var(--prono-text); font-size: 14px; line-height: 1.5; margin: 0 0 18px; }
.prono-modal__ok {
    width: 100%;
    padding: 12px;
    border: none; border-radius: 10px;
    background: var(--prono-warn);
    color: #1a1a2e;
    font-size: 15px; font-weight: 800;
    cursor: pointer;
    transition: opacity .15s;
}
.prono-modal__ok:hover { opacity: .9; }

/* ---- Podium top 3 ---- */
.prono-podium {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
    align-items: end;
    margin-bottom: 14px;
}
.prono-podium__spot {
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    background: var(--prono-card);
    border: 1px solid var(--prono-border);
    border-radius: 12px;
    padding: 14px 8px 12px;
    text-align: center;
}
.prono-podium__spot--1 { border-color: #f5c518; box-shadow: 0 0 0 1px #f5c518 inset; padding-top: 20px; }
.prono-podium__spot--2 { border-color: #c0c7d1; }
.prono-podium__spot--3 { border-color: #cd7f32; }
.prono-podium__spot.is-me { outline: 2px solid var(--prono-accent); }
.prono-podium__medal { font-size: 22px; }
.prono-podium__avatar { width: 44px; height: 44px; border-radius: 50%; border: 2px solid var(--prono-border); position: relative; z-index: 1; }
.prono-podium__name {
    font-size: 12px; font-weight: 700; color: var(--prono-text);
    max-width: 100%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
    position: relative; z-index: 1;
}
.prono-podium__points { font-family: var(--prono-font-head); font-size: 15px; font-weight: 700; color: var(--prono-accent); position: relative; z-index: 1; }
.prono-podium__streak { font-size: 11px; color: var(--prono-warn); font-weight: 700; position: relative; z-index: 1; }
.prono-podium__played {
    font-size: 16px;
    font-weight: 700;
    color: var(--prono-muted);
    background: color-mix(in srgb, var(--prono-accent) 12%, transparent);
    border-radius: 10px;
    padding: 2px 10px;
    position: relative;
    z-index: 1;
}

/* ---- Rangée des badges débloqués sur les cartes podium ---- */
.prono-podium__badges {
    display: inline-flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 7px;
    margin-top: 12px;
    position: relative;
    z-index: 2;
}
.prono-podium__badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background: linear-gradient(135deg, #ffffff 0%, #f4f6fb 100%);
    border: 2px solid rgba(255, 255, 255, .9);
    box-shadow: 0 4px 12px -3px rgba(15, 23, 42, .35), inset 0 1px 0 rgba(255, 255, 255, .8);
    font-size: 20px;
    line-height: 1;
    cursor: default;
    transition: transform .18s ease, box-shadow .18s ease;
}
.prono-podium__badge:hover {
    transform: translateY(-3px) scale(1.08);
    box-shadow: 0 8px 18px -4px rgba(15, 23, 42, .55), inset 0 1px 0 rgba(255, 255, 255, .8);
    z-index: 3;
}
.prono-podium__badge img { width: 24px; height: 24px; object-fit: contain; display: block; }
.prono-podium__badge-emoji { font-size: 20px; line-height: 1; }
.prono-podium__badge--more {
    font-family: var(--prono-font-head, var(--prono-font));
    font-size: 13px;
    font-weight: 800;
    color: var(--prono-accent);
    background: linear-gradient(135deg, #fff, color-mix(in srgb, var(--prono-accent) 8%, #fff));
    min-width: 42px;
    width: auto;
    padding: 0 10px;
    border-radius: 18px;
}
/* Sur une carte thématisée (couleurs pays), conserve un contraste fort */
.prono-podium__spot.is-team-themed .prono-podium__badge {
    border-color: rgba(255, 255, 255, .95);
    box-shadow: 0 4px 14px -3px rgba(0, 0, 0, .5), inset 0 1px 0 rgba(255, 255, 255, .9);
}

/* ---- Pastille compacte de badges sur les lignes du classement ---- */
.prono-lb-badges-pill {
    display: inline-block;
    font-weight: 700;
    color: var(--prono-accent);
    cursor: default;
}

/* =====================================================================
   Bannière « Lmadrabkoum éliminé » (😂 OUT)
   Affichée en haut du profil quand le pays favori a été éliminé.
   Animation : entrée en fade + slide + petit shake humoristique de 1.5s,
   puis statique avec glow rouge subtil.
   ===================================================================== */
@keyframes prono-elim-in {
    from { opacity: 0; transform: translateY(-12px) scale(.96); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes prono-elim-shake {
    0%, 100% { transform: translateX(0) rotate(0); }
    15%      { transform: translateX(-4px) rotate(-1deg); }
    30%      { transform: translateX(4px) rotate(1deg); }
    45%      { transform: translateX(-3px) rotate(-.6deg); }
    60%      { transform: translateX(3px) rotate(.6deg); }
    75%      { transform: translateX(-1px) rotate(-.2deg); }
}
@keyframes prono-elim-glow {
    0%, 100% { box-shadow: 0 18px 40px -18px rgba(239, 68, 68, .55), 0 0 0 1px rgba(239, 68, 68, .35); }
    50%      { box-shadow: 0 22px 48px -16px rgba(239, 68, 68, .75), 0 0 0 1px rgba(239, 68, 68, .55); }
}
.prono-elim-banner {
    display: flex;
    align-items: center;
    gap: 18px;
    background: linear-gradient(135deg, #1f1108 0%, #2d0e0e 100%);
    color: #fff;
    border-radius: 16px;
    padding: 18px 22px;
    margin: 0 auto 18px;
    max-width: 860px;
    position: relative;
    overflow: hidden;
    animation:
        prono-elim-in .45s cubic-bezier(.16, 1, .3, 1),
        prono-elim-shake 1.4s ease-in-out .45s,
        prono-elim-glow 3.6s ease-in-out 2s infinite;
}
.prono-elim-banner::after {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(70% 80% at 0% 50%, rgba(239, 68, 68, .25), transparent 60%);
    pointer-events: none;
}
.prono-elim-banner__gif {
    width: 110px;
    height: 110px;
    border-radius: 12px;
    object-fit: cover;
    flex-shrink: 0;
    box-shadow: 0 12px 28px -10px rgba(0, 0, 0, .6);
    position: relative;
    z-index: 1;
}
.prono-elim-banner__emoji {
    font-size: 88px;
    line-height: 1;
    flex-shrink: 0;
    filter: drop-shadow(0 6px 14px rgba(0, 0, 0, .5));
}
.prono-elim-banner__text { flex: 1; position: relative; z-index: 1; }
.prono-elim-banner__title {
    font-family: var(--prono-font-head, sans-serif);
    font-size: clamp(22px, 4vw, 30px);
    margin: 0 0 6px;
    color: #fff;
    text-shadow: 0 2px 6px rgba(0, 0, 0, .35);
}
.prono-elim-banner__sub {
    margin: 0 0 12px;
    font-size: 14px;
    line-height: 1.5;
    color: rgba(255, 255, 255, .9);
}
.prono-elim-banner__cta {
    display: inline-block;
    padding: 9px 18px;
    border: none;
    border-radius: 10px;
    background: #fff;
    color: #1f1108;
    font-weight: 700;
    font-size: 14px;
    cursor: pointer;
    transition: transform .12s ease, box-shadow .12s ease;
}
.prono-elim-banner__cta:hover {
    transform: translateY(-1px);
    box-shadow: 0 8px 18px -6px rgba(0, 0, 0, .35);
}

/* ---- Mini badge « 💀 OUT » sur les cartes classement ---- */
.prono-lb-out {
    display: inline-block;
    margin-left: 8px;
    padding: 1px 8px;
    border-radius: 8px;
    background: linear-gradient(135deg, #b91c1c, #7f1d1d);
    color: #fff;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .05em;
    cursor: default;
    vertical-align: 1px;
}
.prono-podium__out {
    display: inline-block;
    margin-left: 4px;
    font-size: 14px;
    cursor: default;
    filter: drop-shadow(0 2px 4px rgba(0, 0, 0, .35));
}

/* ===== Tooltip custom (CSS pur, sans JS) ===========================
   Tout élément avec class="prono-tt" + attribut data-tt="…" reçoit
   une infobulle stylée au survol. Apparition fluide (fade + slide
   vers le haut), flèche pointant vers l'élément, fond sombre, texte
   blanc. Pas de title=… qui déclencherait la tooltip native moche. */
.prono-tt { position: relative; }
.prono-tt::before,
.prono-tt::after {
    position: absolute;
    bottom: calc(100% + 10px);
    left: 50%;
    pointer-events: none;
    opacity: 0;
    transition: opacity .18s ease, transform .18s cubic-bezier(.16, 1, .3, 1);
    z-index: 1000;
}
.prono-tt::before {
    content: attr(data-tt);
    transform: translate(-50%, 6px);
    background: #0f172a;
    color: #fff;
    font-family: var(--prono-font, sans-serif);
    font-size: 12px;
    font-weight: 600;
    line-height: 1.3;
    letter-spacing: .01em;
    padding: 7px 12px;
    border-radius: 8px;
    white-space: nowrap;
    box-shadow: 0 10px 28px -8px rgba(0, 0, 0, .65), 0 2px 6px rgba(0, 0, 0, .25);
    max-width: 240px;
    text-align: center;
}
/* Flèche pointant vers le bas (vers l'élément). */
.prono-tt::after {
    content: '';
    bottom: calc(100% + 4px);
    transform: translate(-50%, 6px) rotate(45deg);
    width: 8px;
    height: 8px;
    background: #0f172a;
    box-shadow: 2px 2px 6px -2px rgba(0, 0, 0, .35);
}
.prono-tt:hover::before,
.prono-tt:hover::after,
.prono-tt:focus::before,
.prono-tt:focus::after {
    opacity: 1;
    transform: translate(-50%, 0) rotate(0);
}
.prono-tt:hover::after,
.prono-tt:focus::after {
    transform: translate(-50%, 0) rotate(45deg);
}
/* Les conteneurs qui clippent (overflow:hidden pour le filigrane drapeau)
   ouvrent leur overflow quand un tooltip est actif → pas de clipping. */
.prono-podium__spot:has(.prono-tt:hover),
.prono-podium__spot:has(.prono-tt:focus),
.prono-lb-row:has(.prono-tt:hover),
.prono-lb-row:has(.prono-tt:focus) { overflow: visible; }

/* Habillage aux couleurs du pays favori — gradient teinté en fond + emoji
   drapeau en filigrane. Reproduit le pattern de la bannière du profil. */
.prono-podium__spot.is-team-themed {
    color: #fff;
    border-color: color-mix(in srgb, var(--team-c1, var(--prono-border)) 80%, #fff);
    background:
        linear-gradient(180deg, rgba(0,0,0,.08) 0%, rgba(0,0,0,.32) 100%),
        linear-gradient(135deg, var(--team-c1, var(--prono-card)), var(--team-c2, var(--prono-card)));
}
.prono-podium__spot.is-team-themed .prono-podium__name,
.prono-podium__spot.is-team-themed .prono-podium__points { color: #fff; }
.prono-podium__spot.is-team-themed .prono-podium__played {
    color: #fff;
    background: rgba(255,255,255,.22);
}
.prono-podium__spot.is-team-themed .prono-podium__avatar { border-color: rgba(255,255,255,.7); }
.prono-podium__flag-bg {
    position: absolute;
    right: -18px;
    bottom: -20px;
    font-size: 130px;
    line-height: 1;
    opacity: .18;
    pointer-events: none;
    user-select: none;
    transform: rotate(-10deg);
    filter: saturate(1.15);
    z-index: 0;
    font-family: 'Twemoji Country Flags', 'Montserrat', system-ui, sans-serif;
}

.prono-lb-row.is-me { outline: 2px solid var(--prono-accent); }
.prono-lb-streak { font-size: 11px; color: var(--prono-warn); font-weight: 700; margin-left: 6px; }

/* ---- Infos sociales (classement + podium) ---- */
.prono-podium__tags { display: flex; flex-wrap: wrap; gap: 4px; justify-content: center; margin-top: 2px; }
.prono-podium__motto {
    font-size: 10px; font-style: italic; color: var(--prono-muted);
    max-width: 100%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.prono-ptag--sm { font-size: 10px; padding: 2px 7px; }
.prono-lb-social { display: flex; flex-wrap: wrap; align-items: center; gap: 4px 8px; margin-top: 3px; }
.prono-lb-tag {
    font-size: 11px; font-weight: 600; color: var(--prono-muted);
    background: var(--prono-bg, #f1f5f9); border-radius: 10px; padding: 1px 8px;
}
.prono-lb-motto { font-size: 11px; font-style: italic; color: var(--prono-muted); }

/* ---- Calendrier à onglets (page Matchs) ---- */
.prono-cal { margin-top: 8px; position: relative; }
.prono-cal__tabs {
    display: flex;
    gap: 8px;
    overflow-x: auto;
    padding: 6px 2px 12px;
    scroll-snap-type: x proximity;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    /* Scroll horizontal à la molette, scrollbar masquée. */
    scrollbar-width: none;
    -ms-overflow-style: none;
    overscroll-behavior-x: contain;
}
.prono-cal__tabs::-webkit-scrollbar { height: 0; width: 0; display: none; }
/* Dégradés sur les bords pour signaler le défilement possible. */
.prono-cal__tabwrap { position: relative; }
.prono-cal__tabwrap::before,
.prono-cal__tabwrap::after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 12px;
    width: 56px;
    pointer-events: none;
    z-index: 6;
    opacity: 0;
    transition: opacity .15s ease;
}
.prono-cal__tabwrap::before { left: 0;  background: linear-gradient(to right, var(--prono-bg), transparent); }
.prono-cal__tabwrap::after  { right: 0; background: linear-gradient(to left,  var(--prono-bg), transparent); }
.prono-cal__tabwrap.has-prev::before { opacity: 1; }
.prono-cal__tabwrap.has-next::after  { opacity: 1; }

/* Bouton flèche scroll → cliquable, visible quand has-prev/has-next.
   Affordance forte pour signaler aux users qu'il y a plus de jours. */
.prono-cal__nav {
    position: absolute;
    top: 50%;
    transform: translateY(-60%);
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: #fff;
    border: 1px solid var(--prono-border, #e2e8f0);
    box-shadow: 0 2px 8px rgba(15,23,42,.12);
    cursor: pointer;
    z-index: 7;
    display: none;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    font-weight: 700;
    color: #0f172a;
    transition: background .15s ease, transform .1s ease;
    padding: 0;
}
.prono-cal__nav:hover { background: #f8fafc; transform: translateY(-60%) scale(1.05); }
.prono-cal__nav:active { transform: translateY(-60%) scale(.95); }
.prono-cal__nav--prev { left: 0; }
.prono-cal__nav--next { right: 0; }
.prono-cal__tabwrap.has-prev .prono-cal__nav--prev { display: flex; }
.prono-cal__tabwrap.has-next .prono-cal__nav--next { display: flex; }
.prono-cal__tab {
    flex: 0 0 auto;
    scroll-snap-align: center;
    min-width: 62px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
    padding: 10px 12px;
    border: 1px solid var(--prono-border);
    border-radius: 14px;
    background: var(--prono-card);
    color: var(--prono-text);
    box-shadow: var(--prono-shadow-sm);
    cursor: pointer;
    line-height: 1.1;
    transition: transform .12s ease, box-shadow .12s ease, background .12s ease, border-color .12s ease;
}
.prono-cal__tab:hover { transform: translateY(-2px); box-shadow: var(--prono-shadow); }
.prono-cal__tab.is-active {
    background: var(--prono-gradient, linear-gradient(135deg, var(--prono-accent), var(--prono-accent2)));
    border-color: transparent;
    color: #fff;
    box-shadow: 0 8px 20px -6px color-mix(in srgb, var(--prono-accent) 60%, transparent);
}
.prono-cal__dow {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .04em;
    opacity: .7;
}
.prono-cal__tab.is-active .prono-cal__dow { opacity: 1; }
.prono-cal__dnum { font-family: var(--prono-font-head); font-size: 21px; font-weight: 700; }

/* ---- Journée passée : visuel atténué, MAIS reste cliquable et lisible ----
   Réduit l'opacité (sauf si actif/survol) et applique un léger filtre gris
   pour signaler immédiatement « match déjà joué ». */
.prono-cal__tab.is-past:not(.is-active) {
    opacity: .45;
    filter: grayscale(.6);
    background: color-mix(in srgb, var(--prono-bg, #f3f4f6) 80%, var(--prono-border));
    color: var(--prono-muted);
}
.prono-cal__tab.is-past:not(.is-active):hover {
    opacity: .85;
    filter: grayscale(.2);
    transform: translateY(-1px);
}
/* Si l'utilisateur clique sur un jour passé, on garde l'état actif visible
   à fond (pas d'opacité réduite) pour rester clair. */
.prono-cal__tab.is-past.is-active { opacity: 1; filter: none; }

.prono-cal__panel { animation: prono-fade .2s ease; }
.prono-cal__panel[hidden] { display: none; }

/* Panneau d'un jour passé : badge « Journée terminée » à côté de la date,
   et matchs très légèrement atténués pour signaler l'archive (mais 100% lisibles). */
.prono-cal__past-flag {
    display: inline-block;
    margin-left: 10px;
    padding: 3px 10px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--prono-muted);
    background: color-mix(in srgb, var(--prono-muted) 14%, transparent);
    border-radius: 10px;
    vertical-align: middle;
}
.prono-cal__panel.is-past .prono-matches { opacity: .9; }
.prono-cal__head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 10px;
    margin: 14px 2px 12px;
}
.prono-cal__date { font-family: var(--prono-font-head); font-size: 18px; font-weight: 700; color: var(--prono-text); }
.prono-cal__count {
    font-size: 12px;
    font-weight: 600;
    color: var(--prono-accent);
    background: color-mix(in srgb, var(--prono-accent) 12%, transparent);
    padding: 3px 10px;
    border-radius: 10px;
    white-space: nowrap;
}
@keyframes prono-fade { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: none; } }

/* ---- Switcher de thème (clair / sombre) ---- */
.prono-theme-toggle {
    position: fixed;
    right: 18px;
    bottom: 18px;
    z-index: 9998;
    width: 50px;
    height: 50px;
    border-radius: 50%;
    border: 1px solid var(--prono-border);
    background: var(--prono-card);
    box-shadow: var(--prono-shadow);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    line-height: 1;
    transition: transform .15s ease, box-shadow .15s ease;
}
.prono-theme-toggle:hover { transform: translateY(-2px) scale(1.05); }
.prono-theme-toggle:active { transform: scale(.96); }
/* En clair : on propose de passer en sombre → on montre la lune. */
.prono-theme-toggle__moon { display: inline; }
.prono-theme-toggle__sun  { display: none; }
html[data-prono-theme="dark"] .prono-theme-toggle__moon { display: none; }
html[data-prono-theme="dark"] .prono-theme-toggle__sun  { display: inline; }

/* ---- Responsive ---- */
@media (max-width: 880px) {
    .prono-home__grid { grid-template-columns: 1fr; }
}
@media (max-width: 520px) {
    .prono-team__logo, .prono-team__initials { width: 48px; height: 48px; font-size: 13px; }
    .prono-match__teams { padding: 18px 10px; }
    .prono-vote { gap: 6px; }
    .prono-vote__label { font-size: 11px; }
}

/* =====================================================================
   Compte à rebours
   ===================================================================== */
.prono-countdown {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    margin: 18px auto;
    padding: 14px 20px;
    border-radius: var(--prono-radius, 16px);
    background: color-mix(in srgb, var(--prono-accent) 8%, var(--prono-card));
    border: 1px solid color-mix(in srgb, var(--prono-accent) 22%, transparent);
}
.prono-countdown__label {
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--prono-accent);
}
.prono-countdown__clock { display: flex; gap: 10px; }
.prono-countdown__seg {
    display: flex;
    flex-direction: column;
    align-items: center;
    min-width: 48px;
    padding: 8px 6px;
    border-radius: 12px;
    background: var(--prono-card);
    box-shadow: var(--prono-shadow);
}
.prono-countdown__seg b {
    font-family: var(--prono-font-head);
    font-size: clamp(22px, 4vw, 30px);
    font-weight: 700;
    line-height: 1;
    color: var(--prono-text);
    font-variant-numeric: tabular-nums;
}
.prono-countdown__seg i {
    font-style: normal;
    font-size: 11px;
    color: var(--prono-muted, #64748b);
    margin-top: 3px;
}
.prono-countdown__live {
    font-weight: 700;
    color: #ef4444;
}
.prono-countdown.is-live { animation: prono-pulse 1.4s ease-in-out infinite; }
@keyframes prono-pulse { 50% { box-shadow: 0 0 0 4px color-mix(in srgb, #ef4444 18%, transparent); } }
.prono-countdown--compact { flex-direction: row; padding: 8px 12px; margin: 0; }
.prono-countdown--compact .prono-countdown__seg { min-width: 34px; padding: 4px; }
.prono-countdown--compact .prono-countdown__seg b { font-size: 18px; }

/* =====================================================================
   Profil joueur
   ===================================================================== */
.prono-profile { max-width: 860px; margin: 0 auto; }
.prono-profile__banner {
    border-radius: var(--prono-radius, 16px);
    background: linear-gradient(135deg, var(--prono-accent), color-mix(in srgb, var(--prono-accent) 55%, #0ea5e9));
    padding: 28px;
    color: #fff;
    margin-bottom: 18px;
}
/* Bandeau aux couleurs de l'équipe favorite (dégradé du drapeau + filigrane). */
.prono-profile.is-team-themed .prono-profile__banner {
    background:
        linear-gradient(180deg, rgba(0,0,0,.04) 0%, rgba(0,0,0,.34) 100%),
        linear-gradient(135deg, var(--team-c1, var(--prono-accent)), var(--team-c2, var(--prono-accent2, var(--prono-accent))));
    overflow: hidden;
}
.prono-profile__flag {
    position: absolute;
    right: -8px;
    top: 50%;
    transform: translateY(-50%) rotate(-8deg);
    font-size: 190px;
    line-height: 1;
    opacity: .16;
    pointer-events: none;
    user-select: none;
    filter: saturate(1.1);
}
.prono-profile.is-team-themed .prono-profile__id,
.prono-profile.is-team-themed .prono-profile__tags { position: relative; z-index: 1; }

.prono-profile__id { display: flex; align-items: center; gap: 20px; }
.prono-profile__avatar {
    width: 92px; height: 92px;
    border-radius: 50%;
    border: 3px solid rgba(255,255,255,.7);
    object-fit: cover;
    flex-shrink: 0;
}
.prono-profile__name { font-family: var(--prono-font-head); font-size: clamp(24px, 4vw, 34px); margin: 0; color: #fff; }
.prono-profile__motto {
    margin: 4px 0 10px; font-style: italic; opacity: .9;
    max-width: 100%;
    overflow-wrap: anywhere; word-break: break-word;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.prono-profile__tags { display: flex; flex-wrap: wrap; gap: 8px; }
.prono-ptag {
    background: rgba(255,255,255,.18);
    border-radius: 10px;
    padding: 4px 12px;
    font-size: 13px;
    font-weight: 600;
}
.prono-ptag--rank { background: rgba(255,255,255,.28); }

.prono-profile__tabs { display: flex; gap: 8px; margin-bottom: 16px; flex-wrap: wrap; }
.prono-ptab {
    border: 1px solid var(--prono-border);
    background: var(--prono-card);
    color: var(--prono-text);
    padding: 9px 16px;
    border-radius: 10px;
    font-family: var(--prono-font);
    font-weight: 600;
    font-size: 14px;
    cursor: pointer;
    transition: background .15s ease, color .15s ease, border-color .15s ease;
}
.prono-ptab:hover { border-color: var(--prono-accent); }
.prono-ptab.is-active {
    background: var(--prono-accent);
    color: #fff;
    border-color: var(--prono-accent);
}
.prono-ptab__count {
    font-size: 11px;
    opacity: .8;
    margin-left: 2px;
}

/* Grille de stats */
.prono-stats-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
}
.prono-stat {
    background: var(--prono-card);
    border: 1px solid var(--prono-border);
    border-radius: var(--prono-radius, 16px);
    padding: 18px 12px;
    text-align: center;
    box-shadow: var(--prono-shadow);
}
.prono-stat__val {
    display: block;
    font-family: var(--prono-font-head);
    font-size: clamp(22px, 4vw, 30px);
    font-weight: 700;
    color: var(--prono-text);
    line-height: 1;
}
.prono-stat__val sup { font-size: .5em; }
.prono-stat__lab {
    display: block;
    margin-top: 6px;
    font-size: 12px;
    color: var(--prono-muted, #64748b);
    text-transform: uppercase;
    letter-spacing: .04em;
}

/* Liste de pronostics (onglet Mes pronos) */
.prono-predlist { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.prono-predrow {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 12px 14px;
    border-radius: 12px;
    background: var(--prono-card);
    border: 1px solid var(--prono-border);
    border-left: 4px solid var(--prono-border);
}
.prono-predrow.is-win { border-left-color: var(--prono-accent); }
.prono-predrow.is-loss { border-left-color: #ef4444; }
.prono-predrow__match b { font-variant-numeric: tabular-nums; }
.prono-predrow__bonus {
    font-size: 11px; font-weight: 700;
    background: color-mix(in srgb, var(--prono-accent) 16%, transparent);
    color: var(--prono-accent);
    border-radius: 6px; padding: 1px 6px; margin-left: 4px;
}
/* Bonus « Lmaghrib Rab7 » — pastille rouge marocaine. */
.prono-predrow__morocco {
    font-size: 11px; font-weight: 700;
    background: linear-gradient(135deg, #c1272d, #006233);
    color: #fff;
    border-radius: 6px; padding: 1px 8px; margin-left: 4px;
    letter-spacing: .01em;
    box-shadow: 0 2px 6px -2px rgba(193, 39, 45, .55);
}
.prono-predrow.is-morocco-bonus { border-left-color: #c1272d; }
.prono-predrow__right { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.prono-predrow__date { font-size: 12px; color: var(--prono-muted, #64748b); }
.prono-predrow__pts { font-weight: 700; color: var(--prono-accent); }
.prono-predrow.is-loss .prono-predrow__pts { color: var(--prono-muted, #64748b); }
.prono-predrow__pts--pending { color: var(--prono-muted, #64748b); font-size: 13px; }
/* Compte à rebours dans une ligne de pronostic (Mes pronos).
   Plus grand qu'une simple pilule pour rester lisible d'un coup d'œil. */
.prono-predrow .prono-countdown--compact {
    padding: 8px 12px;
    gap: 8px;
    background: color-mix(in srgb, var(--prono-accent) 8%, var(--prono-card));
    border: 1px solid color-mix(in srgb, var(--prono-accent) 20%, transparent);
}
.prono-predrow .prono-countdown--compact .prono-countdown__seg {
    min-width: 38px;
    padding: 4px 6px;
    box-shadow: none;
    background: transparent;
}
.prono-predrow .prono-countdown--compact .prono-countdown__seg b { font-size: 20px; }
.prono-predrow .prono-countdown--compact .prono-countdown__seg i { font-size: 11px; margin-top: 2px; }
.prono-predrow .prono-countdown--compact .prono-countdown__live { font-size: 12px; }
@media (max-width: 560px) {
    .prono-predrow { flex-wrap: wrap; }
    .prono-predrow__right { flex-wrap: wrap; justify-content: flex-end; }
}

/* Badges */
.prono-badges-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    gap: 12px;
}
.prono-badge-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 6px;
    padding: 18px 12px;
    border-radius: var(--prono-radius, 16px);
    background: var(--prono-card);
    border: 1px solid var(--prono-border);
}
.prono-badge-card.is-earned { border-color: color-mix(in srgb, var(--prono-accent) 40%, transparent); }
.prono-badge-card.is-locked { opacity: .55; filter: grayscale(.6); }
.prono-badge-card__icon { font-size: 34px; line-height: 1; }
.prono-badge-card__img { width: 84px; height: 84px; object-fit: contain; display: block; margin: 0 auto; }
.prono-badge-card__title { font-weight: 700; color: var(--prono-text); }
/* Compteur ×N à droite du titre quand le badge est cumulé plusieurs fois. */
.prono-badge-card__count {
    display: inline-block;
    margin-left: 6px;
    font-family: var(--prono-font-head, var(--prono-font));
    font-weight: 800;
    font-size: 13px;
    color: var(--prono-accent);
    background: color-mix(in srgb, var(--prono-accent) 14%, transparent);
    padding: 1px 8px;
    border-radius: 10px;
    line-height: 1.4;
    vertical-align: 1px;
}
.prono-badge-card__desc { font-size: 12px; color: var(--prono-muted, #64748b); }

/* Édition de profil */
.prono-profile__banner { position: relative; }
.prono-profile__edit {
    position: absolute;
    top: 14px; right: 14px;
    z-index: 1;
    background: rgba(255,255,255,.2);
    color: #fff;
    border: 1px solid rgba(255,255,255,.45);
    border-radius: 10px;
    padding: 6px 14px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: background .15s ease;
}
.prono-profile__edit:hover, .prono-profile__edit.is-open { background: rgba(255,255,255,.32); }

/* La modale est masquée par défaut ; ne s'affiche qu'à l'ouverture JS. */
.prono-modal[hidden] { display: none; }
body.prono-modal-open { overflow: hidden; }
.prono-modal__box--edit {
    max-width: 460px;
    text-align: left;
}
.prono-modal__title--edit {
    color: var(--prono-text);
    font-size: 19px;
    text-align: left;
    letter-spacing: 0;
}
.prono-edit {
    display: grid;
    gap: 14px;
    text-align: left;
}
.prono-edit__avatar { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.prono-edit__preview {
    width: 72px; height: 72px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid var(--prono-border);
}
.prono-edit__file {
    background: var(--prono-accent);
    color: #fff;
    border-radius: 10px;
    padding: 8px 16px;
    font-weight: 600;
    font-size: 14px;
    cursor: pointer;
}
.prono-edit__file:hover { filter: brightness(1.05); }
.prono-edit__hint { font-size: 12px; color: var(--prono-muted, #64748b); }
.prono-edit__row {
    display: flex;
    flex-direction: column;
    gap: 5px;
    font-size: 13px;
    font-weight: 600;
    color: var(--prono-text);
}
.prono-edit__row input,
.prono-edit__row select,
.prono-edit__row select option,
.prono-champion__form .prono-edit__select,
.prono-champion__form .prono-edit__select option {
    font-family: var(--prono-font);
}
.prono-edit__row select {
    font-weight: 400;
    padding: 10px 12px;
    border: 1px solid var(--prono-border);
    border-radius: 10px;
    background: var(--prono-bg, #fff);
    color: var(--prono-text);
    font-size: 15px;
}
.prono-edit__row select { appearance: none; -webkit-appearance: none; cursor: pointer;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%2364748b' d='M6 8 0 0h12z'/%3E%3C/svg%3E");
    background-repeat: no-repeat; background-position: right 14px center; padding-right: 36px;
}
.prono-edit__row input:focus,
.prono-edit__row select:focus {
    outline: none;
    border-color: var(--prono-accent);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--prono-accent) 18%, transparent);
}
.prono-edit__actions { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.prono-edit__save {
    background: var(--prono-accent);
    color: #fff;
    border: none;
    border-radius: 10px;
    padding: 10px 22px;
    font-weight: 700;
    cursor: pointer;
}
.prono-edit__save:hover { filter: brightness(1.05); }
.prono-edit__save:disabled { opacity: .6; cursor: default; }
.prono-edit__msg { font-size: 13px; color: var(--prono-accent); }
.prono-edit__msg.is-error { color: #ef4444; }

/* =====================================================================
   Bandeau CTA « Tu n'as pas pronostiqué le prochain match »
   ===================================================================== */
.prono-cta-banner {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 14px 20px;
    margin: 20px 0;
    background: linear-gradient(135deg, #fff7ed, #ffedd5);
    border: 1px solid color-mix(in srgb, var(--prono-warn) 35%, var(--prono-border));
    border-left: 4px solid var(--prono-warn);
    border-radius: var(--prono-radius);
    box-shadow: var(--prono-shadow-sm);
    color: var(--prono-text);
    text-decoration: none;
    transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.prono-cta-banner:hover {
    transform: translateY(-1px);
    box-shadow: 0 6px 20px -6px color-mix(in srgb, var(--prono-warn) 35%, transparent);
    border-color: var(--prono-warn);
}
.prono-cta-banner__icon {
    flex: 0 0 auto;
    font-size: 28px;
    line-height: 1;
    animation: prono-cta-pulse 1.8s ease-in-out infinite;
}
@keyframes prono-cta-pulse {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.18); }
}
.prono-cta-banner__body { flex: 1 1 auto; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.prono-cta-banner__body strong {
    font-size: 15px;
    line-height: 1.3;
    color: #b45309;
}
.prono-cta-banner__sub {
    font-size: 13px;
    color: var(--prono-muted);
}
.prono-cta-banner__arrow {
    flex: 0 0 auto;
    font-size: 22px;
    color: var(--prono-warn);
    font-weight: 700;
    transition: transform .15s ease;
}
.prono-cta-banner:hover .prono-cta-banner__arrow { transform: translateX(4px); }

@media (max-width: 520px) {
    .prono-cta-banner { gap: 12px; padding: 12px 14px; }
    .prono-cta-banner__icon { font-size: 22px; }
    .prono-cta-banner__body strong { font-size: 14px; }
    .prono-cta-banner__sub { font-size: 12px; }
}

@media (prefers-reduced-motion: reduce) {
    .prono-cta-banner__icon { animation: none; }
}

/* =====================================================================
   Toasts de badge débloqué (notification flottante)
   ===================================================================== */
.prono-toasts {
    position: fixed;
    top: max(20px, env(safe-area-inset-top));
    right: max(20px, env(safe-area-inset-right));
    z-index: 99999;
    display: flex;
    flex-direction: column;
    gap: 12px;
    pointer-events: none;
    max-width: 380px;
    width: calc(100vw - 32px);
}
.prono-toast {
    position: relative;
    display: flex;
    gap: 14px;
    padding: 16px 18px 16px 16px;
    background: linear-gradient(135deg, #fff, #fafffd 60%, #f3fff9);
    border: 1px solid color-mix(in srgb, var(--prono-accent) 35%, var(--prono-border));
    border-radius: 16px;
    box-shadow:
        0 20px 50px -20px rgba(17, 161, 74, .35),
        0 4px 14px -4px rgba(16, 24, 40, .12);
    pointer-events: auto;
    overflow: hidden;
    transform: translateX(420px);
    opacity: 0;
    transition: transform .55s cubic-bezier(.22,1.2,.36,1), opacity .35s ease;
}
.prono-toast.is-in {
    transform: translateX(0);
    opacity: 1;
}
.prono-toast.is-out {
    transform: translateX(420px);
    opacity: 0;
    transition: transform .35s ease, opacity .25s ease;
}
.prono-toast__glow {
    position: absolute;
    inset: -2px;
    background: conic-gradient(from 0deg, transparent 0%, color-mix(in srgb, var(--prono-accent) 55%, transparent) 30%, transparent 60%);
    filter: blur(18px);
    opacity: .55;
    pointer-events: none;
    z-index: 0;
    animation: prono-toast-glow 4s linear infinite;
}
@keyframes prono-toast-glow {
    to { transform: rotate(360deg); }
}
.prono-toast > * { position: relative; z-index: 1; }
.prono-toast__icon {
    flex: 0 0 auto;
    width: 56px; height: 56px;
    display: flex; align-items: center; justify-content: center;
    background: linear-gradient(135deg, var(--prono-accent), var(--prono-accent2));
    border-radius: 14px;
    box-shadow: 0 6px 14px -4px color-mix(in srgb, var(--prono-accent) 60%, transparent);
}
.prono-toast__icon-emoji { font-size: 30px; line-height: 1; filter: drop-shadow(0 1px 2px rgba(0,0,0,.18)); }
.prono-toast__icon-img { width: 44px; height: 44px; object-fit: contain; }
.prono-toast__body { flex: 1 1 auto; min-width: 0; padding-right: 18px; }
.prono-toast__kicker {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--prono-accent);
    margin-bottom: 2px;
}
.prono-toast__title {
    font-family: var(--prono-font-head);
    font-stretch: 125%;
    font-weight: 700;
    font-size: 17px;
    color: var(--prono-text);
    line-height: 1.2;
    margin-bottom: 4px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.prono-toast__desc {
    font-size: 13px;
    color: var(--prono-muted);
    line-height: 1.4;
    margin-bottom: 8px;
}
.prono-toast__cta {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 13px;
    font-weight: 700;
    color: var(--prono-accent);
    text-decoration: none;
    transition: color .15s ease, transform .15s ease;
}
.prono-toast__cta:hover { color: color-mix(in srgb, var(--prono-accent) 75%, #000); transform: translateX(2px); }
.prono-toast__close {
    position: absolute;
    top: 8px; right: 10px;
    width: 24px; height: 24px;
    display: flex; align-items: center; justify-content: center;
    background: transparent;
    border: 0;
    color: var(--prono-muted);
    font-size: 22px;
    line-height: 1;
    cursor: pointer;
    border-radius: 6px;
    transition: background .15s ease, color .15s ease;
    z-index: 2;
}
.prono-toast__close:hover { background: var(--prono-card2); color: var(--prono-text); }

@media (max-width: 520px) {
    .prono-toasts {
        top: auto;
        bottom: max(20px, env(safe-area-inset-bottom));
        right: 16px;
        left: 16px;
        max-width: none;
        width: auto;
    }
    .prono-toast { transform: translateY(40px); }
    .prono-toast.is-in { transform: translateY(0); }
    .prono-toast.is-out { transform: translateY(40px); }
}

@media (prefers-reduced-motion: reduce) {
    .prono-toast { transition: opacity .25s ease; transform: none; }
    .prono-toast.is-in,
    .prono-toast.is-out { transform: none; }
    .prono-toast__glow { animation: none; }
}

/* =====================================================================
   Page Règles du jeu
   ===================================================================== */
.prono-rules { display: grid; gap: 18px; grid-template-columns: 1fr; max-width: 920px; margin: 0 auto; }
@media (min-width: 768px) {
    .prono-rules { grid-template-columns: 1fr 1fr; }
    .prono-rules__card--bonus,
    .prono-rules__card--morocco,
    .prono-rules__card--departments,
    .prono-rules__card--callout { grid-column: 1 / -1; }
}
.prono-rules__card {
    background: var(--prono-card);
    border: 1px solid var(--prono-border);
    border-radius: var(--prono-radius);
    box-shadow: var(--prono-shadow-sm);
    padding: 22px 24px;
}
.prono-rules__card--bonus {
    background: linear-gradient(135deg, color-mix(in srgb, var(--prono-warn) 8%, var(--prono-card)), var(--prono-card));
    border-color: color-mix(in srgb, var(--prono-warn) 30%, var(--prono-border));
}
.prono-rules__card--callout {
    background: linear-gradient(135deg, color-mix(in srgb, var(--prono-danger) 6%, var(--prono-card)), var(--prono-card));
    border-color: color-mix(in srgb, var(--prono-danger) 28%, var(--prono-border));
}
/* Bonus Maroc — accent rouge/vert drapeau */
.prono-rules__card--morocco {
    background: linear-gradient(135deg, rgba(193, 39, 45, .06), rgba(0, 98, 51, .06));
    border-color: rgba(193, 39, 45, .35);
}
/* Battle des départements — accent neutre teinté accent2 */
.prono-rules__card--departments {
    background: linear-gradient(135deg, color-mix(in srgb, var(--prono-accent2, var(--prono-accent)) 6%, var(--prono-card)), var(--prono-card));
    border-color: color-mix(in srgb, var(--prono-accent2, var(--prono-accent)) 28%, var(--prono-border));
}
.prono-rules__h {
    font-family: var(--prono-font-head);
    font-stretch: 125%;
    font-size: 19px;
    color: var(--prono-text);
    margin: 0 0 12px;
}
.prono-rules p { color: var(--prono-text); line-height: 1.6; margin: 0 0 10px; }
.prono-rules ul { padding-left: 18px; color: var(--prono-text); line-height: 1.7; margin: 0; }
.prono-rules__scoring { list-style: none; padding: 0; display: grid; gap: 10px; }
.prono-rules__scoring li { display: flex; align-items: center; gap: 12px; padding: 8px 10px; background: var(--prono-card2); border-radius: 10px; }
.prono-rules__pts {
    flex: 0 0 auto;
    display: inline-flex; align-items: center; justify-content: center;
    min-width: 60px;
    font-weight: 800;
    font-family: var(--prono-font-display);
    font-size: 18px;
    padding: 6px 10px;
    border-radius: 10px;
    color: #fff;
}
.prono-rules__pts--3 { background: var(--prono-success); }
.prono-rules__pts--2 { background: var(--prono-accent2); }
.prono-rules__pts--1 { background: var(--prono-warn); }
.prono-rules__pts--0 { background: var(--prono-muted); }

/* =====================================================================
   Sélecteur pays « fancy » — remplace le <select> natif. Le natif reste
   présent (display:none) pour conserver name/value et la soumission.
   ===================================================================== */
.prono-fancy-select { position: relative; display: block; width: 100%; }
.prono-fancy-select > select,
select.prono-fancy-select { display: none !important; }
.prono-fancy-wrapper > .acf-input > select { display: none !important; }
.prono-fancy-select__btn {
    display: flex; align-items: center; gap: 10px;
    width: 100%; box-sizing: border-box;
    padding: 10px 36px 10px 12px;
    border: 1px solid var(--prono-border);
    border-radius: 10px;
    background: var(--prono-card, #fff);
    color: var(--prono-text);
    font: inherit; font-size: 15px;
    text-align: left; cursor: pointer;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%2364748b' d='M6 8 0 0h12z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    transition: border-color .15s ease, box-shadow .15s ease;
}
.prono-fancy-select__btn:hover { border-color: color-mix(in srgb, var(--prono-accent) 50%, var(--prono-border)); }
.prono-fancy-select.is-open .prono-fancy-select__btn,
.prono-fancy-select__btn:focus {
    outline: none;
    border-color: var(--prono-accent);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--prono-accent) 18%, transparent);
}
.prono-fancy-select__placeholder { color: var(--prono-muted); }
.prono-fancy-select__flag {
    width: 24px; height: 18px;
    object-fit: cover;
    border-radius: 3px;
    box-shadow: 0 0 0 1px rgba(0,0,0,.08);
    flex: 0 0 auto;
}
.prono-fancy-select__label { flex: 1 1 auto; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.prono-fancy-select__list {
    position: absolute; top: calc(100% + 6px); left: 0; right: 0;
    max-height: 320px; overflow-y: auto;
    background: var(--prono-card, #fff);
    border: 1px solid var(--prono-border);
    border-radius: 12px;
    box-shadow: var(--prono-shadow, 0 14px 30px -10px rgba(16,24,40,.2));
    padding: 6px;
    z-index: 9999;
    display: none;
}
.prono-fancy-select.is-open .prono-fancy-select__list { display: block; }
.prono-fancy-select__item {
    display: flex; align-items: center; gap: 10px;
    padding: 8px 10px;
    border-radius: 8px;
    cursor: pointer;
    font-size: 14px;
    color: var(--prono-text);
}
.prono-fancy-select__item:hover { background: var(--prono-card2, #f1f4f9); }
.prono-fancy-select__item.is-active {
    background: color-mix(in srgb, var(--prono-accent) 14%, transparent);
    font-weight: 700;
}

/* Pronostic du champion (carte du profil) */
.prono-champion {
    background: linear-gradient(135deg, color-mix(in srgb, var(--prono-accent) 12%, var(--prono-card)), var(--prono-card));
    border: 1px solid color-mix(in srgb, var(--prono-accent) 28%, var(--prono-border));
    border-radius: var(--prono-radius);
    padding: 18px 20px;
    margin-bottom: 18px;
    box-shadow: var(--prono-shadow-sm);
}
.prono-champion__head { display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap; margin-bottom: 12px; }
.prono-champion__title { font-family: var(--prono-font-head); font-stretch: 125%; font-weight: 700; font-size: 18px; color: var(--prono-text); }
.prono-champion__sub { font-size: 13px; color: var(--prono-muted); }
.prono-champion__pick { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin-bottom: 12px; }
.prono-champion__flag { font-size: 38px; line-height: 1; }
.prono-champion__name { font-size: 20px; font-weight: 800; color: var(--prono-text); }
.prono-champion__empty { color: var(--prono-muted); font-size: 14px; }
.prono-champion__badge { font-size: 13px; font-weight: 700; color: var(--prono-success); background: color-mix(in srgb, var(--prono-success) 14%, transparent); padding: 4px 12px; border-radius: 10px; }
.prono-champion__badge--miss { color: var(--prono-danger); background: color-mix(in srgb, var(--prono-danger) 14%, transparent); }
.prono-champion__locked { font-size: 14px; color: var(--prono-muted); margin: 0; }
.prono-champion__form { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.prono-champion__form .prono-edit__select {
    flex: 1 1 220px;
    appearance: none; -webkit-appearance: none; cursor: pointer;
    padding: 10px 36px 10px 12px;
    border: 1px solid var(--prono-border);
    border-radius: 10px;
    background-color: var(--prono-bg, #fff);
    color: var(--prono-text);
    font-size: 15px;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%2364748b' d='M6 8 0 0h12z'/%3E%3C/svg%3E");
    background-repeat: no-repeat; background-position: right 14px center;
}
/* Quand le <select> a été remplacé par le wrapper .prono-fancy-select (JS),
   il devient lui-même flex-item du form : on annule le width:100% par défaut
   pour qu'il partage la ligne avec le bouton « Valider ». */
.prono-champion__form .prono-fancy-select {
    flex: 1 1 220px;
    width: auto;
    min-width: 0;
}
.prono-champion__form .prono-edit__select:focus {
    outline: none;
    border-color: var(--prono-accent);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--prono-accent) 18%, transparent);
}
.prono-champion__save {
    background: var(--prono-accent);
    color: #fff;
    border: none;
    border-radius: 10px;
    padding: 10px 22px;
    font-weight: 700;
    cursor: pointer;
}
.prono-champion__save:hover { filter: brightness(1.05); }
.prono-champion__save:disabled { opacity: .6; cursor: default; }
.prono-champion__msg { font-size: 13px; color: var(--prono-accent); flex-basis: 100%; }
.prono-champion__msg.is-error { color: #ef4444; }
.prono-champion .prono-countdown { margin-top: 12px; flex-direction: row; align-items: center; flex-wrap: wrap; gap: 12px; }
.prono-champion .prono-countdown__clock { gap: 6px; }
.prono-champion .prono-countdown__seg {
    flex-direction: row;
    align-items: baseline;
    gap: 2px;
    min-width: 0;
    padding: 6px 10px;
}
.prono-champion .prono-countdown__seg b { font-size: 18px; }
.prono-champion .prono-countdown__seg i { font-size: 16px; margin-top: 0; text-transform:uppercase; }

@media (max-width: 520px) {
    .prono-stats-grid { grid-template-columns: repeat(2, 1fr); }
    .prono-profile__id { flex-direction: column; text-align: center; }
    .prono-profile__tags { justify-content: center; }
}

/* =====================================================================
   Typographie — overrides placés en fin de fichier pour gagner la cascade
   (Anton pour les gros titres/chiffres, Archivo « expanded » pour les
   titres de section). Doit rester APRÈS toutes les déclarations ci-dessus.
   ===================================================================== */
.prono-page-title--shortcode,
.prono-cal__date,
.prono-pred__in {
    font-family: var(--prono-font-head);
    font-stretch: 125%;
    letter-spacing: .005em;
}
.prono-hero__title,
.prono-profile__name,
.prono-match__score,
.prono-stat__val,
.prono-podium__points,
.prono-lb-points,
.prono-lbc__points,
.prono-cal__dnum,
.prono-countdown__seg b {
    font-family: var(--prono-font-display);
    font-weight: 400;
    letter-spacing: .02em;
}

/* =====================================================================
   Responsive — passe consolidée tablette & mobile
   ===================================================================== */

/* ---- Tablette (≤ 1024px) ---- */
@media (max-width: 1024px) {
    .prono-home__grid { grid-template-columns: 1fr 320px; gap: 22px; }
    .prono-matches { grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 16px; }
}

/* ---- Petite tablette / gros mobile (≤ 768px) ---- */
@media (max-width: 768px) {
    .prono-home__grid { grid-template-columns: 1fr; gap: 20px; }
    .prono-matches { grid-template-columns: 1fr; gap: 16px; }
    .prono-hero { padding: 28px 14px 20px; }
    .prono-match__teams { padding: 22px 14px; }
    .prono-profile__banner { padding: 22px 18px; }
    .prono-profile__edit { position: static; margin-top: 14px; align-self: flex-start; }
    .prono-profile__id { gap: 16px; }
}

/* ---- Mobile (≤ 560px) ---- */
@media (max-width: 560px) {
    .prono-profile__banner { display: flex; flex-direction: column; align-items: center; text-align: center; }
    .prono-profile__edit { align-self: center; }
    .prono-countdown__seg { min-width: 42px; padding: 7px 5px; }
    .prono-countdown__clock { gap: 7px; }
    .prono-lb-row { gap: 9px; padding: 9px 11px; }
    .prono-lb-meta { min-width: 0; font-size: 10px; }
    .prono-podium { gap: 8px;grid-template-columns: repeat(1, 1fr); }
    .prono-badges-grid { grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); gap: 10px; }
    .prono-modal { padding: 12px; align-items: flex-end; }
    .prono-modal__box--edit { max-width: 100%; border-radius: 18px 18px 0 0; padding-bottom: 26px; }
}

/* ---- Très petit mobile (≤ 380px) ---- */
@media (max-width: 380px) {
    .prono-stats-grid { grid-template-columns: 1fr 1fr; gap: 8px; }
    .prono-team__name { font-size: 13px; }
    .prono-pred__in { width: 52px; height: 52px; font-size: 24px; }
    .prono-pred__team { max-width: 84px; }
}

/* =====================================================================
   Classement compact (widget accueil) — lignes empilées, scrollable
   pour absorber la montée en nombre d'utilisateurs.
   ===================================================================== */
.prono-lbc {
    display: flex;
    flex-direction: column;
    gap: 6px;
    max-height: 440px;
    overflow-y: auto;
    padding-right: 4px;
    scrollbar-width: thin;
    scrollbar-color: var(--prono-border) transparent;
}
.prono-lbc::-webkit-scrollbar { width: 6px; }
.prono-lbc::-webkit-scrollbar-thumb { background: var(--prono-border); border-radius: 6px; }
.prono-lbc__row {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 10px;
    background: var(--prono-card2);
    border: 1px solid var(--prono-border);
    border-radius: 12px;
}
.prono-lbc__row.is-me {
    border-color: var(--prono-accent);
    box-shadow: 0 0 0 1px var(--prono-accent) inset;
}
.prono-lbc__rank {
    flex: 0 0 26px;
    text-align: center;
    font-weight: 700;
    font-size: 15px;
    color: var(--prono-muted);
}
.prono-lbc__avatar {
    flex: 0 0 32px;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    object-fit: cover;
}
.prono-lbc__name {
    flex: 1 1 auto;
    min-width: 0;
    display: flex;
    align-items: center;
    gap: 6px;
    font-weight: 600;
    font-size: 14px;
    color: var(--prono-text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.prono-lbc__streak { flex: 0 0 auto; font-size: 12px; }
.prono-lbc__points {
    flex: 0 0 auto;
    font-size: 18px;
    color: var(--prono-accent);
    letter-spacing: .02em;
}
.prono-lbc__points small { font-size: 11px; font-weight: 600; margin-left: 2px; opacity: .8; }
.prono-lbc__all {
    display: block;
    margin-top: 12px;
    text-align: center;
    font-size: 13px;
    font-weight: 600;
    color: var(--prono-accent);
    text-decoration: none;
}
.prono-lbc__all:hover { text-decoration: underline; }

/* =====================================================================
   ACCESSIBILITÉ — filet de focus global
   ---------------------------------------------------------------------
   Beaucoup d'éléments ont `outline: none` pour le rendu visuel propre,
   ce qui CASSE l'accessibilité clavier. On rétablit un focus visible
   uniquement pour la navigation clavier (via :focus-visible, supporté
   tous browsers depuis 2022), tout en préservant le rendu mouse-only.
   ===================================================================== */

/* Reset global : sur ANY focus-visible, on a un ring d'accent visible.
   `:focus-visible` ne se déclenche QUE pour la navigation clavier,
   pas pour les clics — donc impact zéro sur l'UX souris. */
*:focus-visible {
    outline: 2px solid var(--prono-accent, #16a34a) !important;
    outline-offset: 2px;
    border-radius: 4px;
}

/* Pour les inputs/selects/textareas focus-visible : remplace l'outline
   par un box-shadow doux qui respecte les borders arrondis du design. */
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
.prono-fancy-select__btn:focus-visible {
    outline: none !important;
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--prono-accent, #16a34a) 35%, transparent) !important;
    border-color: var(--prono-accent, #16a34a) !important;
}

/* Boutons : ring + slight scale = feedback clair sans casser le rendu */
button:focus-visible,
.prono-auth__btn:focus-visible,
.prono-edit__save:focus-visible,
.prono-champion__save:focus-visible,
.prono-profile__edit:focus-visible,
.prono-ptab:focus-visible,
.prono-cal__tab:focus-visible,
.prono-lb-tab:focus-visible {
    outline: 3px solid var(--prono-accent, #16a34a) !important;
    outline-offset: 3px;
}

/* Cartes / éléments cliquables larges : ring inset pour ne pas déborder */
.prono-match-card:focus-visible,
.prono-podium__spot:focus-visible,
.prono-lb-row:focus-visible {
    outline: none !important;
    box-shadow: inset 0 0 0 3px var(--prono-accent, #16a34a) !important;
}

/* Skip link — déjà géré par WP mais on s'assure qu'il est visible au focus */
.skip-link:focus,
.skip-link:focus-visible {
    position: fixed !important;
    top: 16px;
    left: 16px;
    z-index: 100001;
    background: var(--prono-accent, #16a34a);
    color: #fff !important;
    padding: 10px 18px;
    border-radius: 8px;
    font-weight: 700;
    text-decoration: none;
    box-shadow: 0 10px 30px -8px rgba(0,0,0,.4);
}

/* `prefers-reduced-motion` — désactive les animations pour les users
   avec sensibilité (touche d'accessibilité standard depuis 2020). */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
    /* Garde le shake/glow de la bannière élimination ?
       Non : si user en reduced-motion, on respecte → pas d'anim. */
    .prono-elim-banner { animation: none !important; }
}

/* Contrast renforcé pour les textes de petite taille (12-13px) qui
   doivent passer WCAG AA = ratio ≥ 4.5:1. */
.prono-podium__motto,
.prono-lb-motto,
.prono-podium__played small,
.prono-battle__total,
.prono-battle__sub {
    /* prono-muted = #64748b → ratio ~5.3:1 sur fond blanc, OK. */
    color: var(--prono-muted, #475569);
}

/* Liens : underline obligatoire pour les liens dans le contenu (WCAG 1.4.1)
   sauf les boutons / navigations (déjà identifiables par leur style). */
.prono-rules a,
.prono-elim-banner__sub a,
.prono-auth__hint a {
    text-decoration: underline;
    text-underline-offset: 2px;
}

/* =====================================================================
   Onboarding — shortcode [pronostics_onboarding] (v3 premium accordion)
   Inspiré du design FAQ moderne : cards blanches généreuses, ombre douce,
   "+" qui tourne en "×" à l'ouverture, padding ample, hiérarchie typo claire.
   Couleurs hardcodées (pas de var theme) pour rendu cohérent partout.
   ===================================================================== */
.prono-onboarding--accordion {
    max-width: 760px;
    margin: 0 auto;
    padding: 8px 12px 24px;
    display: flex;
    flex-direction: column;
    gap: 28px;
    color: #1f2937;
}

/* ----- HERO ----- */
.prono-onboarding--accordion .prono-onboarding__hero {
    text-align: center;
    padding: 16px 0 4px;
    background: transparent;
}
.prono-onboarding--accordion .prono-onboarding__greeting {
    margin: 0 0 6px;
    font-size: 14px;
    color: #64748b;
    font-weight: 600;
    letter-spacing: .01em;
}
.prono-onboarding--accordion .prono-onboarding__title {
    margin: 0 0 10px;
    font-size: clamp(26px, 4vw, 36px);
    line-height: 1.15;
    font-weight: 800;
    letter-spacing: -.01em;
    color: #0f172a;
}
.prono-onboarding--accordion .prono-onboarding__subtitle {
    max-width: 560px;
    margin: 0 auto;
    font-size: 16px;
    line-height: 1.55;
    color: #64748b;
}

/* ----- PANELS ----- */
.prono-onboarding__panels {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.prono-onboarding__panel {
    background: #ffffff;
    border-radius: 16px;
    box-shadow: 0 1px 2px rgba(15, 23, 42, .04), 0 4px 16px rgba(15, 23, 42, .05);
    transition: box-shadow .2s ease, transform .2s ease;
    overflow: hidden;
}
.prono-onboarding__panel:hover {
    box-shadow: 0 2px 4px rgba(15, 23, 42, .06), 0 8px 24px rgba(15, 23, 42, .08);
}
.prono-onboarding__panel[open] {
    box-shadow: 0 2px 4px rgba(15, 23, 42, .06), 0 12px 28px rgba(15, 23, 42, .1);
}

/* ----- SUMMARY (header) ----- */
/* Triple règle pour masquer le marker sur tous les navigateurs (Safari, Chrome, Firefox). */
.prono-onboarding__panel-head {
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 22px 26px;
    font-size: 17px;
    font-weight: 700;
    color: #0f172a;
    list-style: none;
    user-select: none;
    position: relative;
    padding-right: 70px;
    transition: padding .2s ease;
}
.prono-onboarding__panel-head::-webkit-details-marker { display: none; }
.prono-onboarding__panel-head::marker { display: none; }

.prono-onboarding__panel-icon {
    font-size: 22px;
    line-height: 1;
    flex-shrink: 0;
}
.prono-onboarding__panel-title {
    flex: 1;
}
.prono-onboarding__panel-meta {
    display: none;
    font-size: 13px;
    font-weight: 500;
    color: #94a3b8;
    background: #f1f5f9;
    padding: 4px 10px;
    border-radius: 999px;
    margin-right: 6px;
}
@media (min-width: 560px) {
    .prono-onboarding__panel-meta { display: inline-flex; }
}

/* "+" qui tourne en "x" : 2 traits dont un vertical */
.prono-onboarding__panel-head::before,
.prono-onboarding__panel-head::after {
    content: "";
    position: absolute;
    right: 28px;
    top: 50%;
    background: #1f2937;
    border-radius: 2px;
    transition: transform .25s ease, background .15s ease;
}
.prono-onboarding__panel-head::before {
    width: 16px;
    height: 2px;
    transform: translateY(-50%);
}
.prono-onboarding__panel-head::after {
    width: 2px;
    height: 16px;
    transform: translate(7px, -50%);
}
.prono-onboarding__panel[open] .prono-onboarding__panel-head::before {
    transform: translateY(-50%) rotate(45deg);
}
.prono-onboarding__panel[open] .prono-onboarding__panel-head::after {
    transform: translate(7px, -50%) rotate(45deg);
}

/* ----- BODY ----- */
.prono-onboarding__panel-body {
    padding: 4px 26px 24px;
    color: #475569;
}
.prono-onboarding__panel-body > *:first-child { margin-top: 4px; }
.prono-onboarding__panel-body > *:last-child  { margin-bottom: 0; }

/* ----- ÉTAPES ----- */
.prono-onboarding__steps-list {
    list-style: none;
    counter-reset: prono-step;
    margin: 8px 0 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 18px;
}
.prono-onboarding__steps-list li {
    counter-increment: prono-step;
    position: relative;
    padding: 4px 0 4px 48px;
}
.prono-onboarding__steps-list li::before {
    content: counter(prono-step);
    position: absolute;
    left: 0;
    top: 2px;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: linear-gradient(135deg, #22c55e 0%, #16a34a 100%);
    color: #fff;
    font-size: 14px;
    font-weight: 800;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 3px 8px rgba(34, 197, 94, .35);
}
.prono-onboarding__steps-list .prono-onboarding__step-title {
    display: block;
    font-size: 15.5px;
    font-weight: 700;
    color: #0f172a;
    margin-bottom: 6px;
}
.prono-onboarding__steps-list .prono-onboarding__step-body {
    margin: 0;
    font-size: 14.5px;
    line-height: 1.6;
    color: #475569;
}

/* ----- MINI-BARÈME ----- */
.prono-onboarding__scoring-list {
    list-style: none;
    margin: 8px 0 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.prono-onboarding__scoring-list li {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 12px 16px;
    background: #f8fafc;
    border-radius: 12px;
    font-size: 14.5px;
    color: #334155;
}
.prono-onboarding__pts {
    flex-shrink: 0;
    min-width: 64px;
    padding: 6px 10px;
    border-radius: 8px;
    text-align: center;
    font-weight: 800;
    color: #fff;
    font-size: 13px;
    letter-spacing: .02em;
}
.prono-onboarding__pts--3 { background: linear-gradient(135deg, #16a34a, #15803d); }
.prono-onboarding__pts--1 { background: linear-gradient(135deg, #f97316, #ea580c); }
.prono-onboarding__pts--0 { background: linear-gradient(135deg, #64748b, #475569); }
.prono-onboarding__rules-link {
    margin: 18px 0 0;
    font-size: 14px;
    text-align: center;
}
.prono-onboarding__rules-link a {
    color: #16a34a;
    font-weight: 600;
    text-decoration: none;
}
.prono-onboarding__rules-link a:hover {
    text-decoration: underline;
}

/* ----- FAQ ----- */
.prono-onboarding__faq-list {
    list-style: none;
    margin: 8px 0 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 18px;
}
.prono-onboarding__faq-list li {
    padding: 14px 16px;
    background: #f8fafc;
    border-radius: 12px;
}
.prono-onboarding__faq-list li strong {
    display: block;
    margin-bottom: 6px;
    font-size: 14.5px;
    font-weight: 700;
    color: #0f172a;
}
.prono-onboarding__faq-list li div {
    font-size: 14px;
    line-height: 1.6;
    color: #475569;
}

/* ----- FOOTER CTA ----- */
.prono-onboarding__footer {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 12px;
    padding: 8px 0 0;
}
.prono-onboarding__btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 22px;
    border-radius: 10px;
    font-weight: 700;
    font-size: 15px;
    text-decoration: none !important;
    transition: transform .15s ease, box-shadow .15s ease;
    border: none;
    cursor: pointer;
}
.prono-onboarding__btn:hover {
    transform: translateY(-1px);
}
.prono-onboarding__btn--primary {
    background: linear-gradient(135deg, #22c55e 0%, #16a34a 100%);
    color: #fff !important;
    box-shadow: 0 4px 12px rgba(34, 197, 94, .3);
}
.prono-onboarding__btn--primary:hover {
    box-shadow: 0 6px 18px rgba(34, 197, 94, .4);
}
.prono-onboarding__btn--secondary {
    background: #fff;
    color: #0f172a !important;
    border: 1px solid #e2e8f0;
    box-shadow: 0 1px 2px rgba(15, 23, 42, .04);
}
.prono-onboarding__btn--secondary:hover {
    border-color: #cbd5e1;
    box-shadow: 0 4px 12px rgba(15, 23, 42, .08);
}

/* ----- DARK MODE compat ----- */
body.theme-dark .prono-onboarding--accordion,
.theme-dark .prono-onboarding--accordion { color: #f1f5f9; }
body.theme-dark .prono-onboarding__title,
.theme-dark .prono-onboarding__title { color: #fff; }
body.theme-dark .prono-onboarding__subtitle,
.theme-dark .prono-onboarding__subtitle,
body.theme-dark .prono-onboarding__greeting,
.theme-dark .prono-onboarding__greeting { color: #94a3b8; }
body.theme-dark .prono-onboarding__panel,
.theme-dark .prono-onboarding__panel {
    background: #1e293b;
    box-shadow: 0 1px 2px rgba(0,0,0,.3), 0 4px 16px rgba(0,0,0,.4);
}
body.theme-dark .prono-onboarding__panel-head,
.theme-dark .prono-onboarding__panel-head { color: #f1f5f9; }
body.theme-dark .prono-onboarding__panel-head::before,
body.theme-dark .prono-onboarding__panel-head::after,
.theme-dark .prono-onboarding__panel-head::before,
.theme-dark .prono-onboarding__panel-head::after { background: #cbd5e1; }
body.theme-dark .prono-onboarding__panel-meta,
.theme-dark .prono-onboarding__panel-meta { background: #334155; color: #94a3b8; }
body.theme-dark .prono-onboarding__panel-body,
.theme-dark .prono-onboarding__panel-body { color: #cbd5e1; }
body.theme-dark .prono-onboarding__steps-list .prono-onboarding__step-title,
.theme-dark .prono-onboarding__steps-list .prono-onboarding__step-title { color: #fff; }
body.theme-dark .prono-onboarding__scoring-list li,
.theme-dark .prono-onboarding__scoring-list li,
body.theme-dark .prono-onboarding__faq-list li,
.theme-dark .prono-onboarding__faq-list li { background: #334155; color: #e2e8f0; }
body.theme-dark .prono-onboarding__faq-list li strong,
.theme-dark .prono-onboarding__faq-list li strong { color: #fff; }
body.theme-dark .prono-onboarding__btn--secondary,
.theme-dark .prono-onboarding__btn--secondary {
    background: #1e293b;
    color: #f1f5f9 !important;
    border-color: #334155;
}


/* =====================================================================
   Classement hebdomadaire (onglet 🏅 Semaine + historique gagnants)
   ===================================================================== */
.prono-lb-view--weekly { padding: 4px 0; }
.prono-weekly__head { text-align: center; margin-bottom: 18px; }
.prono-weekly__title {
    margin: 0 0 4px;
    font-size: 22px;
    font-weight: 800;
    color: var(--prono-text, #0f172a);
}
.prono-weekly__period {
    margin: 0 0 8px;
    font-size: 15px;
    color: var(--prono-text-muted, #64748b);
}
.prono-weekly__lead {
    max-width: 540px;
    margin: 0 auto;
    font-size: 13.5px;
    color: var(--prono-text-muted, #64748b);
    line-height: 1.5;
}

.prono-weekly__list {
    display: flex;
    flex-direction: column;
    gap: 8px;
    max-width: 700px;
    margin: 0 auto;
}
.prono-weekly__row {
    display: grid;
    grid-template-columns: 40px 40px 1fr auto auto;
    align-items: center;
    gap: 12px;
    padding: 10px 14px;
    background: var(--prono-card2, #fff);
    border: 1px solid var(--prono-border, #e2e8f0);
    border-radius: 12px;
    transition: transform .15s ease;
}
.prono-weekly__row:hover { transform: translateY(-1px); }
.prono-weekly__row.is-me {
    border-color: #22c55e;
    background: linear-gradient(90deg, rgba(34,197,94,.08) 0%, var(--prono-card2, #fff) 100%);
}
.prono-weekly__rank {
    font-size: 17px;
    font-weight: 800;
    text-align: center;
    color: var(--prono-text, #0f172a);
}
.prono-weekly__avatar {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    object-fit: cover;
}
.prono-weekly__name {
    font-weight: 700;
    font-size: 14.5px;
    color: var(--prono-text, #0f172a);
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}
.prono-weekly__dept {
    font-size: 11px;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: 6px;
    color: #fff;
}
.prono-weekly__points {
    font-size: 16px;
    font-weight: 800;
    color: #16a34a;
}
.prono-weekly__meta {
    font-size: 12px;
    color: var(--prono-text-muted, #64748b);
    white-space: nowrap;
}

/* Historique */
.prono-weekly__history {
    margin-top: 28px;
    max-width: 700px;
    margin-left: auto;
    margin-right: auto;
}
.prono-weekly__h3 {
    margin: 0 0 12px;
    font-size: 16px;
    color: var(--prono-text, #0f172a);
}
.prono-weekly__history-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.prono-weekly__history-list li {
    display: grid;
    grid-template-columns: auto 32px 1fr auto auto;
    align-items: center;
    gap: 10px;
    padding: 8px 12px;
    background: var(--prono-card, #f8fafc);
    border-radius: 10px;
    font-size: 13.5px;
}
.prono-weekly__crown { font-size: 16px; }
.prono-weekly__hist-avatar {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    object-fit: cover;
}
.prono-weekly__hist-name {
    font-weight: 700;
    color: var(--prono-text, #0f172a);
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
}
.prono-weekly__hist-dept {
    font-size: 10.5px;
    font-weight: 600;
    padding: 1px 6px;
    border-radius: 5px;
    color: #fff;
}
.prono-weekly__hist-period {
    font-size: 12px;
    color: var(--prono-text-muted, #64748b);
    white-space: nowrap;
}
.prono-weekly__hist-pts {
    font-weight: 700;
    color: #16a34a;
    font-size: 13px;
}

/* Toast "Roi de la semaine" (réutilise .prono-toast existant) */
.prono-toast--weekly {
    background: linear-gradient(135deg, #fbbf24 0%, #f59e0b 100%);
    color: #422006;
}
.prono-toast--weekly .prono-toast__icon-emoji { font-size: 32px; }

/* =====================================================================
   Podium hebdomadaire (top 3 visible sur l'onglet Semaine + historique)
   ===================================================================== */
.prono-weekly__podium {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    align-items: end;
    gap: 12px;
    max-width: 720px;
    margin: 0 auto 22px;
    padding: 0 8px;
}
.prono-weekly__spot {
    background: var(--prono-card2, #fff);
    border: 1px solid var(--prono-border, #e2e8f0);
    border-radius: 14px;
    padding: 18px 12px 16px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    position: relative;
    transition: transform .2s ease, box-shadow .2s ease;
}
.prono-weekly__spot:hover { transform: translateY(-2px); box-shadow: 0 6px 18px rgba(15,23,42,.08); }
.prono-weekly__spot--1 {
    border-color: #facc15;
    background: linear-gradient(180deg, rgba(250,204,21,.10) 0%, var(--prono-card2, #fff) 80%);
    padding-top: 26px;
    transform: translateY(-10px);
}
.prono-weekly__spot--2 {
    border-color: #cbd5e1;
    background: linear-gradient(180deg, rgba(203,213,225,.18) 0%, var(--prono-card2, #fff) 80%);
}
.prono-weekly__spot--3 {
    border-color: #fbbf24;
    background: linear-gradient(180deg, rgba(251,191,36,.12) 0%, var(--prono-card2, #fff) 80%);
}
.prono-weekly__spot.is-me { box-shadow: 0 0 0 2px #22c55e inset; }
.prono-weekly__medal {
    position: absolute;
    top: -14px;
    font-size: 30px;
    line-height: 1;
    filter: drop-shadow(0 2px 4px rgba(0,0,0,.18));
}
.prono-weekly__spot-avatar {
    width: 54px;
    height: 54px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid var(--prono-card2, #fff);
}
.prono-weekly__spot-name {
    font-weight: 800;
    font-size: 14.5px;
    color: var(--prono-text, #0f172a);
    text-align: center;
    line-height: 1.2;
}
.prono-weekly__spot-dept {
    font-size: 10.5px;
    font-weight: 600;
    padding: 1px 6px;
    border-radius: 5px;
    color: #fff;
}
.prono-weekly__spot-pts {
    font-size: 16px;
    font-weight: 800;
    color: #16a34a;
}
.prono-weekly__spot-meta {
    font-size: 11px;
    color: var(--prono-text-muted, #64748b);
}

/* Historique podium (3 médaillés par ligne semaine) */
.prono-weekly__hist-week {
    background: var(--prono-card, #f8fafc);
    border-radius: 12px;
    padding: 12px 14px;
    list-style: none;
    margin-bottom: 10px;
}
.prono-weekly__hist-head {
    margin-bottom: 8px;
    font-size: 13px;
    color: var(--prono-text-muted, #64748b);
}
.prono-weekly__hist-period {
    font-weight: 700;
    color: var(--prono-text, #0f172a);
}
.prono-weekly__hist-podium {
    display: grid;
    grid-template-columns: 1fr;
    gap: 6px;
}
@media (min-width: 640px) {
    .prono-weekly__hist-podium { grid-template-columns: repeat(3, 1fr); }
}
.prono-weekly__hist-spot {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 10px;
    background: var(--prono-card2, #fff);
    border-radius: 8px;
    font-size: 13px;
}
.prono-weekly__hist-spot--1 { border-left: 3px solid #facc15; }
.prono-weekly__hist-spot--2 { border-left: 3px solid #cbd5e1; }
.prono-weekly__hist-spot--3 { border-left: 3px solid #fbbf24; }
.prono-weekly__hist-medal { font-size: 16px; }
.prono-weekly__hist-avatar {
    width: 26px;
    height: 26px;
    border-radius: 50%;
    object-fit: cover;
}
.prono-weekly__hist-name {
    font-weight: 700;
    color: var(--prono-text, #0f172a);
}
.prono-weekly__hist-dept {
    font-size: 10px;
    font-weight: 600;
    padding: 1px 5px;
    border-radius: 4px;
    color: #fff;
}
.prono-weekly__hist-pts {
    margin-left: auto;
    font-weight: 700;
    color: #16a34a;
    font-size: 12.5px;
}

/* Toasts argent + bronze (or = .prono-toast--weekly déjà défini) */
.prono-toast--silver {
    background: linear-gradient(135deg, #e2e8f0 0%, #94a3b8 100%);
    color: #1e293b;
}
.prono-toast--silver .prono-toast__icon-emoji { font-size: 32px; }

.prono-toast--bronze {
    background: linear-gradient(135deg, #fed7aa 0%, #c2410c 100%);
    color: #431407;
}
.prono-toast--bronze .prono-toast__icon-emoji { font-size: 32px; }
