/* ===== Radio Player ===== */
div.rp-player {
    display: inline-flex !important;
    align-items: center !important;
    gap: 12px !important;
    background: #f4f7f9 !important;
    border-radius: 50px !important;
    padding: 8px 20px 8px 8px !important;
    max-width: 400px;
    width: 100%;
    position: relative !important;
    user-select: none !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
    border: none !important;
    box-shadow: none !important;
    margin: 0 !important;
}

/* Bouton — toutes propriétés forcées contre le thème */
div.rp-player button.rp-play-btn,
div.rp-player button.rp-play-btn:focus,
div.rp-player button.rp-play-btn:hover,
div.rp-player button.rp-play-btn:active {
    -webkit-appearance: none !important;
    appearance: none !important;
    border-radius: 50% !important;
    width: 40px !important;
    height: 40px !important;
    min-width: 40px !important;
    max-width: 40px !important;
    min-height: 40px !important;
    max-height: 40px !important;
    background: #5f6480 !important;
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    margin: 0 !important;
    flex-shrink: 0 !important;
    overflow: hidden !important;
    position: relative !important;
    line-height: 1 !important;
    transition: opacity .15s !important;
}
div.rp-player button.rp-play-btn:hover    { opacity: .85 !important; }
div.rp-player.playing button.rp-play-btn  { background: #949ad7 !important; }

div.rp-player button.rp-play-btn svg {
    width: 18px !important;
    height: 18px !important;
    fill: #fff !important;
    flex-shrink: 0 !important;
    pointer-events: none !important;
}
div.rp-player button.rp-play-btn .rp-icon-play { margin-left: 3px !important; }

/* Spinner chargement */
div.rp-player.loading button.rp-play-btn::after {
    content: '' !important;
    position: absolute !important;
    inset: 0 !important;
    border-radius: 50% !important;
    border: 3px solid rgba(255,255,255,.3) !important;
    border-top-color: #fff !important;
    animation: rp-spin .8s linear infinite !important;
}
div.rp-player.loading button.rp-play-btn svg { opacity: 0 !important; }
@keyframes rp-spin { to { transform: rotate(360deg); } }

/* ── Ticker : défilement CSS pur, permanent ── */
div.rp-player .rp-ticker-wrap {
    overflow: hidden !important;
    flex: 1 !important;
    min-width: 0 !important;
    /* Fondu sur les bords */
    -webkit-mask-image: linear-gradient(to right, transparent 0%, #000 10%, #000 90%, transparent 100%) !important;
    mask-image: linear-gradient(to right, transparent 0%, #000 10%, #000 90%, transparent 100%) !important;
}

div.rp-player .rp-ticker {
    display: flex !important;
    white-space: nowrap !important;
    /* Défilement immédiat, continu, en CSS pur — pas de JS */
    animation: rp-marquee 18s linear infinite !important;
    will-change: transform !important;
}

div.rp-player .rp-song {
    font-size: 13px !important;
    font-weight: 500 !important;
    color: #5f6480 !important;
    white-space: nowrap !important;
    line-height: 1.4 !important;
    padding-right: 60px !important;
}

@keyframes rp-marquee {
    0%   { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}

@media (max-width: 480px) {
    div.rp-player { max-width: 100% !important; }
}
