/**
 * Aratice Title Marquee — bandeau horizontal défilant
 *
 * Le JS duplique les items pour que le track contienne 2 sets identiques,
 * chacun ≥ la largeur du container. L'animation translateX(0 → -50%) fait
 * que le set 2 prend exactement la place du set 1 → boucle seamless infinie.
 */

.aratice-title-marquee {
    position: relative;
    width: 100%;
    overflow: hidden;
    background: #163C79;
    color: #fff;
    padding: 18px 0;
}

.aratice-title-marquee__track {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    width: max-content;
    will-change: transform;
}

/* L'animation n'est appliquée qu'après que le JS a dupliqué les items —
   évite un flash de défilement avec un track trop court. */
.aratice-title-marquee__track.is-animated {
    animation: araticeMarqueeLeft 30s linear infinite;
}

.aratice-title-marquee__track--right.is-animated {
    animation-name: araticeMarqueeRight;
}

.aratice-title-marquee--pause-hover:hover .aratice-title-marquee__track {
    animation-play-state: paused;
}

.aratice-title-marquee__item {
    flex-shrink: 0;
    display: inline-block;
    margin: 0 30px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    white-space: nowrap;
}

.aratice-title-marquee__sep {
    flex-shrink: 0;
    display: inline-block;
    opacity: 0.7;
    user-select: none;
}

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

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