/**
 * 2PX Elementor Suite — Text Band Widget
 * Infinite auto-scrolling text ticker. Pure CSS, no JS.
 * BEM methodology.
 */

/* ── Container ─────────────────────────────────────────────────────────────── */
.twopx-tb {
    position: relative;
    box-sizing: border-box;
    overflow: hidden;
    width: 100%;
    background-color: #0a0a0a; /* default dark — overridden by Elementor */
    padding: 14px 0;           /* default — overridden by Elementor */
}

.twopx-tb * {
    box-sizing: border-box;
}

/* ── Edge-fade overlay (::before = left, ::after = right) ───────────────────── */
.twopx-tb--fade::before,
.twopx-tb--fade::after {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    z-index: 2;
    pointer-events: none;
    width: 120px; /* default — overridden by Elementor */
}

.twopx-tb--fade::before {
    left: 0;
    background: linear-gradient(to right, #0a0a0a 0%, transparent 100%);
}

.twopx-tb--fade::after {
    right: 0;
    background: linear-gradient(to left, #0a0a0a 0%, transparent 100%);
}

/* ── Track: clips the scrolling row ─────────────────────────────────────────── */
.twopx-tb__track {
    overflow: hidden;
    width: 100%;
}

/* ── Inner: the flex row that scrolls ──────────────────────────────────────── */
.twopx-tb__inner {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    width: max-content;
    animation-name: twopxTBScroll;
    animation-timing-function: linear;
    animation-iteration-count: infinite;
    animation-duration: 30s;     /* overridden by Elementor speed control */
    will-change: transform;
}

/* ── Direction variants ─────────────────────────────────────────────────────── */
.twopx-tb--rtl .twopx-tb__inner {
    animation-name: twopxTBScrollRTL;
}

/* ── Pause on hover ─────────────────────────────────────────────────────────── */
.twopx-tb--pause-hover .twopx-tb__track:hover .twopx-tb__inner {
    animation-play-state: paused;
}

/* ── Message item ───────────────────────────────────────────────────────────── */
.twopx-tb__item {
    display: inline-flex;
    align-items: center;
    flex-shrink: 0;
    white-space: nowrap;
    color: #ffffff;              /* default — overridden by Elementor */
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 0 32px;             /* default horizontal gap — overridden by Elementor */
    line-height: 1;
}

/* ── Separator ──────────────────────────────────────────────────────────────── */
.twopx-tb__sep {
    display: inline-flex;
    align-items: center;
    flex-shrink: 0;
    color: #ffffff;              /* default — overridden by Elementor */
    font-size: 18px;
    opacity: 0.5;                /* default — overridden by Elementor */
    line-height: 1;
    user-select: none;
}

/* ── Keyframes ──────────────────────────────────────────────────────────────── */

/* Left (default): content moves left, new items enter from the right */
@keyframes twopxTBScroll {
    0%   { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}

/* Right: content moves right, new items enter from the left */
@keyframes twopxTBScrollRTL {
    0%   { transform: translateX(-50%); }
    100% { transform: translateX(0); }
}

/* ── Accessibility: reduce motion ───────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
    .twopx-tb__inner {
        animation: none;
    }
}
