/* ============================================================
   Bandeau « Fil info » défilant (NewsTicker)
   ============================================================ */

#news-ticker {
    background: linear-gradient(to right, #0d1117 0%, #141428 100%);
    color: #e8eaf6;
    overflow: hidden;
    white-space: nowrap;
    height: 2.2rem;
    line-height: 2.2rem;
    font-size: 0.83rem;
    border-bottom: 2px solid #c0392b;
    display: flex;
    align-items: center;
    user-select: none;
    margin-top: -2.2rem;
    position: relative;
    z-index: 1031;
}

#news-ticker.ticker-hidden {
    display: none;
}

.ticker-label {
    flex-shrink: 0;
    background: #c0392b;
    color: #fff;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: 0 0.85rem;
    height: 100%;
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.78rem;
    position: relative;
    z-index: 2;
    box-shadow: 3px 0 6px rgba(0, 0, 0, 0.5);
}

.ticker-track-wrapper {
    flex: 1;
    overflow: hidden;
    height: 100%;
    cursor: default;
    position: relative;
}

/* Fondu de sortie à droite */
.ticker-track-wrapper::after {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    width: 3rem;
    height: 100%;
    background: linear-gradient(to left, #141428, transparent);
    pointer-events: none;
    z-index: 1;
}

.ticker-track {
    display: inline-flex;
    align-items: center;
    height: 100%;
    animation: ticker-scroll 30s linear infinite;
    white-space: nowrap;
}

/* Pause on hover */
#news-ticker:hover .ticker-track {
    animation-play-state: paused;
}

.ticker-date {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    margin-right: 2rem;
    color: #90caf9;
    font-weight: 600;
    font-style: italic;
    letter-spacing: 0.02em;
}

.ticker-item {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    margin-right: 2rem;
}

.ticker-item-sep {
    color: #e74c3c;
    opacity: 0.8;
    margin: 0 1.2rem;
    font-size: 0.55rem;
}

.ticker-item .ticker-cat {
    font-weight: 600;
    color: #e8eaf6;
}

.ticker-item .ticker-val {
    font-weight: 700;
    color: #ffd740;
    margin-left: 0.15rem;
}

.ticker-item .ticker-val-positive {
    font-weight: 700;
    color: #4caf50;
    margin-left: 0.15rem;
}

/* Animation — boucle seamless : on déplace -50% du contenu doublé = 1 copie */
@keyframes ticker-scroll {
    0% {
        transform: translateX(0);
    }

    100% {
        transform: translateX(-50%);
    }
}

/* Respect préférence réduction de mouvement */
@media (prefers-reduced-motion: reduce) {
    .ticker-track {
        animation: none;
        white-space: normal;
    }

    .ticker-item-sep {
        display: none;
    }
}

/* Mobile : hauteur légèrement réduite */
@media (max-width: 576px) {
    #news-ticker {
        font-size: 0.75rem;
        height: 1.9rem;
        line-height: 1.9rem;
    }

    .ticker-label {
        padding: 0 0.5rem;
        font-size: 0.65rem;
    }

    .ticker-track {
        animation-duration: 20s;
    }
}

/* ============================================================
   Items « Échéances » dans le fil info
   ============================================================ */

.ticker-echeance {
    gap: 0.4rem;
}

.ticker-echeance .ticker-val-date {
    font-weight: 700;
    margin-left: 0.1rem;
}

.ticker-echeance .ticker-val-days {
    font-size: 0.72rem;
    font-weight: 700;
    padding: 0.05rem 0.35rem;
    border-radius: 0.25rem;
    margin-left: 0.15rem;
}

/* Danger : date dépassée ou J-2 */
.ticker-echeance-danger .ticker-cat,
.ticker-echeance-danger .ticker-val-date {
    color: #ff6b6b;
}

.ticker-echeance-danger .ticker-val-days {
    background: rgba(220, 53, 69, 0.35);
    color: #ff8787;
}

/* Warning : dans l'horizon paramétré, mais > J-2 */
.ticker-echeance-warning .ticker-cat,
.ticker-echeance-warning .ticker-val-date {
    color: #ffd740;
}

.ticker-echeance-warning .ticker-val-days {
    background: rgba(255, 193, 7, 0.2);
    color: #ffd740;
}

/* ============================================================
   Bouton paramètres (roue) dans le label
   ============================================================ */

.ticker-settings-btn {
    background: none;
    border: none;
    color: rgba(255, 255, 255, 0.55);
    cursor: pointer;
    padding: 0 0 0 0.45rem;
    line-height: 1;
    font-size: 0.82rem;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    transition: color 0.18s, transform 0.3s;
}

.ticker-settings-btn:hover {
    color: #fff;
    transform: rotate(45deg);
}

/* ============================================================
   Items « Budgets » dans le fil info
   ============================================================ */

.ticker-budget .ticker-cat {
    color: #4fc3f7;
}

.ticker-budget .ticker-val {
    color: #69f0ae;
}

/* Budget dépassé */
.ticker-budget-danger .ticker-cat {
    color: #4fc3f7;
}

.ticker-budget-danger .ticker-val {
    color: #ff6b6b;
    font-weight: 700;
    animation: ticker-blink 1.2s ease-in-out infinite;
}

@keyframes ticker-blink {

    0%,
    100% {
        opacity: 1;
    }

    50% {
        opacity: 0.55;
    }
}