/* ============================================
   NEWS TICKER - CSS
   Version: 1.0.0
   ============================================ */

/* ============================================
   CSS VARIABLES (JS-controlled)
   ============================================ */
.news-ticker {
    --ticker-speed: 50px;
    --ticker-duration: 4000ms;
    --ticker-gap: 60px;
    --ticker-height: 50px;
}

/* ============================================
   BASE STYLES
   ============================================ */
.news-ticker {
    position: relative;
    width: 100%;
    font-size: 14px;
    line-height: 1.5;
    overflow: hidden;
}

.news-ticker__wrapper {
    display: flex;
    align-items: stretch;
    overflow: hidden;
    min-height: var(--ticker-height);
}

.news-ticker__label {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 0 20px;
    font-weight: 600;
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    white-space: nowrap;
    flex-shrink: 0;
    position: relative;
    z-index: 2;
}

.news-ticker__label--has-arrow::after {
    content: '';
    position: absolute;
    right: -12px;
    top: 0;
    bottom: 0;
    width: 24px;
    background: inherit;
    clip-path: polygon(0 0, 100% 50%, 0 100%);
}

.news-ticker__label-icon {
    font-family: 'ETmodules' !important;
    speak: none;
    font-style: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-size: 16px;
}

.news-ticker__content {
    flex: 1;
    overflow: hidden;
    position: relative;
    display: flex;
    align-items: center;
    padding: 0 20px;
    min-width: 0;
}

.news-ticker__track {
    display: flex;
    align-items: center;
    gap: var(--ticker-gap);
    white-space: nowrap;
}

/* ============================================
   ITEM STYLES
   ============================================ */
.news-ticker__item {
    display: flex;
    align-items: center;
    gap: 12px;
    transition: opacity 0.3s ease, color 0.3s ease;
    flex-shrink: 0;
}

.news-ticker__category {
    display: inline-flex;
    align-items: center;
    padding: 2px 10px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border-radius: 4px;
    flex-shrink: 0;
}

.news-ticker__tag {
    display: inline-flex;
    align-items: center;
    padding: 2px 8px;
    font-size: 10px;
    font-weight: 500;
    border-radius: 3px;
    flex-shrink: 0;
}

.news-ticker__text {
    font-weight: 500;
}

.news-ticker__date {
    opacity: 0.6;
    font-size: 12px;
    flex-shrink: 0;
}

.news-ticker__separator {
    opacity: 0.5;
    font-size: 12px;
    flex-shrink: 0;
}

/* ============================================
   CONTROLS
   ============================================ */
.news-ticker__controls {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 0 12px;
    flex-shrink: 0;
}

.news-ticker__btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    background: rgba(255, 255, 255, 0.1);
    border: none;
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.2s ease;
}

.news-ticker__btn:active {
    transform: scale(0.95);
}

/* ============================================
   PROGRESS BAR
   ============================================ */
.news-ticker__progress {
    width: 100%;
    height: 3px;
    background: rgba(255, 255, 255, 0.1);
}

.news-ticker__progress-bar {
    height: 100%;
    transition: width 0.3s ease;
    width: 0%;
    background: currentColor;
}

/* ============================================
   SCROLL ANIMATION
   ============================================ */
.news-ticker--scroll .news-ticker__track {
    animation-timing-function: linear;
    animation-iteration-count: infinite;
}

@keyframes ticker-scroll-left {
    0% { transform: translateX(0); }
    100% { transform: translateX(calc(-1 * var(--track-size))); }
}

@keyframes ticker-scroll-right {
    0% { transform: translateX(calc(-1 * var(--track-size))); }
    100% { transform: translateX(0); }
}

/* ============================================
   FADE ANIMATION
   ============================================ */
.news-ticker--fade .news-ticker__track {
    position: relative;
    width: 100%;
}

.news-ticker--fade .news-ticker__item {
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    opacity: 0;
}

.news-ticker--fade .news-ticker__item--active,
.news-ticker--fade .news-ticker__item--fade-in {
    opacity: 1;
    position: relative;
    transform: none;
}

.news-ticker__item--fade-in {
    animation: ticker-fade-in 0.5s ease forwards;
}

.news-ticker__item--fade-out {
    animation: ticker-fade-out 0.5s ease forwards;
    position: absolute !important;
}

@keyframes ticker-fade-in {
    from { opacity: 0; transform: translateY(-50%) scale(0.95); }
    to { opacity: 1; transform: translateY(-50%) scale(1); }
}

@keyframes ticker-fade-out {
    from { opacity: 1; transform: translateY(-50%) scale(1); }
    to { opacity: 0; transform: translateY(-50%) scale(0.95); }
}

/* ============================================
   SLIDE ANIMATION
   ============================================ */
.news-ticker--slide .news-ticker__track {
    position: relative;
    width: 100%;
    height: 100%;
    min-height: 40px;
}

.news-ticker--slide .news-ticker__item {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    opacity: 0;
    pointer-events: none;
}

.news-ticker--slide .news-ticker__item--active {
    opacity: 1;
    pointer-events: auto;
}

.news-ticker__item--slide-in-next { animation: ticker-slide-in-next 0.5s cubic-bezier(0.4, 0, 0.2, 1) forwards; }
.news-ticker__item--slide-out-next { animation: ticker-slide-out-next 0.5s cubic-bezier(0.4, 0, 0.2, 1) forwards; }
.news-ticker__item--slide-in-prev { animation: ticker-slide-in-prev 0.5s cubic-bezier(0.4, 0, 0.2, 1) forwards; }
.news-ticker__item--slide-out-prev { animation: ticker-slide-out-prev 0.5s cubic-bezier(0.4, 0, 0.2, 1) forwards; }

@keyframes ticker-slide-in-next { from { transform: translateX(100%); opacity: 0; } to { transform: translateX(0); opacity: 1; } }
@keyframes ticker-slide-out-next { from { transform: translateX(0); opacity: 1; } to { transform: translateX(-100%); opacity: 0; } }
@keyframes ticker-slide-in-prev { from { transform: translateX(-100%); opacity: 0; } to { transform: translateX(0); opacity: 1; } }
@keyframes ticker-slide-out-prev { from { transform: translateX(0); opacity: 1; } to { transform: translateX(100%); opacity: 0; } }

/* ============================================
   TYPING ANIMATION
   ============================================ */
.news-ticker--typing .news-ticker__track {
    position: relative;
    width: 100%;
}

.news-ticker--typing .news-ticker__item {
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    opacity: 0;
    pointer-events: none;
}

.news-ticker--typing .news-ticker__item--active {
    position: relative;
    transform: none;
    opacity: 1;
    pointer-events: auto;
}

.news-ticker__item--typing .news-ticker__text {
    overflow: hidden;
    white-space: nowrap;
    border-right: 2px solid currentColor;
    animation: ticker-typing 2s steps(40) forwards, ticker-cursor 0.7s step-end infinite;
}

@keyframes ticker-typing { from { width: 0; } to { width: 100%; } }
@keyframes ticker-cursor { 50% { border-color: transparent; } }

/* ============================================
   FLIP ANIMATION
   ============================================ */
.news-ticker--flip .news-ticker__track {
    position: relative;
    width: 100%;
    perspective: 1000px;
}

.news-ticker--flip .news-ticker__item {
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    backface-visibility: hidden;
    opacity: 0;
    pointer-events: none;
}

.news-ticker--flip .news-ticker__item--active {
    position: relative;
    transform: none;
    opacity: 1;
    pointer-events: auto;
}

.news-ticker__item--flip-in { animation: ticker-flip-in 0.6s cubic-bezier(0.4, 0, 0.2, 1) forwards; }
.news-ticker__item--flip-out { animation: ticker-flip-out 0.6s cubic-bezier(0.4, 0, 0.2, 1) forwards; position: absolute !important; }

@keyframes ticker-flip-in { from { transform: translateY(-50%) rotateX(-90deg); opacity: 0; } to { transform: translateY(-50%) rotateX(0); opacity: 1; } }
@keyframes ticker-flip-out { from { transform: translateY(-50%) rotateX(0); opacity: 1; } to { transform: translateY(-50%) rotateX(90deg); opacity: 0; } }

/* ============================================
   ZOOM ANIMATION
   ============================================ */
.news-ticker--zoom .news-ticker__track { position: relative; width: 100%; height: 100%; min-height: 40px; }
.news-ticker--zoom .news-ticker__item { position: absolute; left: 0; top: 0; width: 100%; height: 100%; display: flex; align-items: center; opacity: 0; pointer-events: none; }
.news-ticker--zoom .news-ticker__item--active { opacity: 1; pointer-events: auto; }
.news-ticker__item--zoom-in { animation: ticker-zoom-in 0.6s cubic-bezier(0.34, 1.56, 0.64, 1) forwards; }
.news-ticker__item--zoom-out { animation: ticker-zoom-out 0.4s ease-in forwards; }
@keyframes ticker-zoom-in { from { transform: scale(0); opacity: 0; } to { transform: scale(1); opacity: 1; } }
@keyframes ticker-zoom-out { from { transform: scale(1); opacity: 1; } to { transform: scale(0); opacity: 0; } }

/* ============================================
   BOUNCE ANIMATION
   ============================================ */
.news-ticker--bounce .news-ticker__track { position: relative; width: 100%; height: 100%; min-height: 40px; }
.news-ticker--bounce .news-ticker__item { position: absolute; left: 0; top: 0; width: 100%; height: 100%; display: flex; align-items: center; opacity: 0; pointer-events: none; }
.news-ticker--bounce .news-ticker__item--active { opacity: 1; pointer-events: auto; }
.news-ticker__item--bounce-in { animation: ticker-bounce-in 0.8s cubic-bezier(0.68, -0.55, 0.265, 1.55) forwards; }
.news-ticker__item--bounce-out { animation: ticker-bounce-out 0.4s ease-in forwards; }
@keyframes ticker-bounce-in { 0% { transform: translateY(-100%); opacity: 0; } 50% { transform: translateY(10%); } 70% { transform: translateY(-5%); } 100% { transform: translateY(0); opacity: 1; } }
@keyframes ticker-bounce-out { from { transform: translateY(0); opacity: 1; } to { transform: translateY(100%); opacity: 0; } }

/* ============================================
   ROTATE ANIMATION
   ============================================ */
.news-ticker--rotate .news-ticker__track { position: relative; width: 100%; height: 100%; min-height: 40px; perspective: 1000px; }
.news-ticker--rotate .news-ticker__item { position: absolute; left: 0; top: 0; width: 100%; height: 100%; display: flex; align-items: center; opacity: 0; pointer-events: none; transform-style: preserve-3d; }
.news-ticker--rotate .news-ticker__item--active { opacity: 1; pointer-events: auto; }
.news-ticker__item--rotate-in { animation: ticker-rotate-in 0.7s cubic-bezier(0.4, 0, 0.2, 1) forwards; }
.news-ticker__item--rotate-out { animation: ticker-rotate-out 0.5s ease-in forwards; }
@keyframes ticker-rotate-in { from { transform: rotateY(-180deg) scale(0.5); opacity: 0; } to { transform: rotateY(0) scale(1); opacity: 1; } }
@keyframes ticker-rotate-out { from { transform: rotateY(0) scale(1); opacity: 1; } to { transform: rotateY(180deg) scale(0.5); opacity: 0; } }

/* ============================================
   BLUR ANIMATION
   ============================================ */
.news-ticker--blur .news-ticker__track { position: relative; width: 100%; height: 100%; min-height: 40px; }
.news-ticker--blur .news-ticker__item { position: absolute; left: 0; top: 0; width: 100%; height: 100%; display: flex; align-items: center; opacity: 0; pointer-events: none; }
.news-ticker--blur .news-ticker__item--active { opacity: 1; pointer-events: auto; }
.news-ticker__item--blur-in { animation: ticker-blur-in 0.6s ease-out forwards; }
.news-ticker__item--blur-out { animation: ticker-blur-out 0.4s ease-in forwards; }
@keyframes ticker-blur-in { from { filter: blur(20px); opacity: 0; transform: scale(1.1); } to { filter: blur(0); opacity: 1; transform: scale(1); } }
@keyframes ticker-blur-out { from { filter: blur(0); opacity: 1; transform: scale(1); } to { filter: blur(20px); opacity: 0; transform: scale(0.9); } }

/* ============================================
   WAVE ANIMATION
   ============================================ */
.news-ticker--wave .news-ticker__track { position: relative; width: 100%; height: 100%; min-height: 40px; }
.news-ticker--wave .news-ticker__item { position: absolute; left: 0; top: 0; width: 100%; height: 100%; display: flex; align-items: center; opacity: 0; pointer-events: none; }
.news-ticker--wave .news-ticker__item--active { opacity: 1; pointer-events: auto; }
.news-ticker__item--wave-in { animation: ticker-wave-in 0.8s cubic-bezier(0.175, 0.885, 0.32, 1.275) forwards; }
.news-ticker__item--wave-out { animation: ticker-wave-out 0.5s ease-in forwards; }
@keyframes ticker-wave-in { 0% { transform: translateX(50%) scaleX(0.3); opacity: 0; } 40% { transform: translateX(-5%) scaleX(1.05); } 60% { transform: translateX(3%) scaleX(0.98); } 80% { transform: translateX(-2%) scaleX(1.01); } 100% { transform: translateX(0) scaleX(1); opacity: 1; } }
@keyframes ticker-wave-out { from { transform: translateX(0) scaleX(1); opacity: 1; } to { transform: translateX(-50%) scaleX(0.3); opacity: 0; } }

/* ============================================
   REVEAL ANIMATION
   ============================================ */
.news-ticker--reveal .news-ticker__track { position: relative; width: 100%; height: 100%; min-height: 40px; }
.news-ticker--reveal .news-ticker__item { position: absolute; left: 0; top: 0; width: 100%; height: 100%; display: flex; align-items: center; opacity: 0; pointer-events: none; clip-path: inset(0 100% 0 0); }
.news-ticker--reveal .news-ticker__item--active { opacity: 1; pointer-events: auto; clip-path: inset(0 0 0 0); }
.news-ticker__item--reveal-in { animation: ticker-reveal-in 0.7s cubic-bezier(0.4, 0, 0.2, 1) forwards; }
.news-ticker__item--reveal-out { animation: ticker-reveal-out 0.5s ease-in forwards; }
@keyframes ticker-reveal-in { from { clip-path: inset(0 100% 0 0); opacity: 0; } to { clip-path: inset(0 0 0 0); opacity: 1; } }
@keyframes ticker-reveal-out { from { clip-path: inset(0 0 0 0); opacity: 1; } to { clip-path: inset(0 0 0 100%); opacity: 0; } }

/* ============================================
   GLITCH ANIMATION
   ============================================ */
.news-ticker--glitch .news-ticker__track { position: relative; width: 100%; height: 100%; min-height: 40px; }
.news-ticker--glitch .news-ticker__item { position: absolute; left: 0; top: 0; width: 100%; height: 100%; display: flex; align-items: center; opacity: 0; pointer-events: none; }
.news-ticker--glitch .news-ticker__item--active { opacity: 1; pointer-events: auto; }
.news-ticker__item--glitch-in { animation: ticker-glitch-in 0.6s steps(1) forwards; }
.news-ticker__item--glitch-out { animation: ticker-glitch-out 0.4s steps(1) forwards; }
@keyframes ticker-glitch-in { 0% { opacity: 0; transform: translate(0); filter: hue-rotate(0deg); } 10% { opacity: 1; transform: translate(-5px, 2px); filter: hue-rotate(90deg); } 20% { transform: translate(5px, -2px); filter: hue-rotate(180deg); } 30% { transform: translate(-3px, 1px); filter: hue-rotate(270deg); } 40% { transform: translate(3px, -1px); filter: hue-rotate(0deg); } 50% { transform: translate(-2px, 2px); } 60% { transform: translate(2px, -1px); } 70% { transform: translate(-1px, 1px); } 80% { transform: translate(1px, 0); } 90%, 100% { opacity: 1; transform: translate(0); filter: hue-rotate(0deg); } }
@keyframes ticker-glitch-out { 0% { opacity: 1; transform: translate(0); } 25% { transform: translate(5px, -3px); filter: hue-rotate(90deg); } 50% { transform: translate(-5px, 3px); filter: hue-rotate(180deg); } 75% { transform: translate(3px, -2px); filter: hue-rotate(270deg); } 100% { opacity: 0; transform: translate(0); filter: hue-rotate(0deg); } }

/* ============================================
   SWING ANIMATION
   ============================================ */
.news-ticker--swing .news-ticker__track { position: relative; width: 100%; height: 100%; min-height: 40px; perspective: 1000px; }
.news-ticker--swing .news-ticker__item { position: absolute; left: 0; top: 0; width: 100%; height: 100%; display: flex; align-items: center; opacity: 0; pointer-events: none; transform-origin: top center; }
.news-ticker--swing .news-ticker__item--active { opacity: 1; pointer-events: auto; }
.news-ticker__item--swing-in { animation: ticker-swing-in 0.8s cubic-bezier(0.175, 0.885, 0.32, 1.275) forwards; }
.news-ticker__item--swing-out { animation: ticker-swing-out 0.5s ease-in forwards; }
@keyframes ticker-swing-in { 0% { transform: rotateX(-90deg); opacity: 0; } 40% { transform: rotateX(20deg); } 60% { transform: rotateX(-10deg); } 80% { transform: rotateX(5deg); } 100% { transform: rotateX(0); opacity: 1; } }
@keyframes ticker-swing-out { from { transform: rotateX(0); opacity: 1; } to { transform: rotateX(90deg); opacity: 0; } }

/* ============================================
   CUBE ANIMATION
   ============================================ */
.news-ticker--cube .news-ticker__track { position: relative; width: 100%; height: 100%; min-height: 40px; perspective: 1000px; transform-style: preserve-3d; }
.news-ticker--cube .news-ticker__item { position: absolute; left: 0; top: 0; width: 100%; height: 100%; display: flex; align-items: center; opacity: 0; pointer-events: none; backface-visibility: hidden; }
.news-ticker--cube .news-ticker__item--active { opacity: 1; pointer-events: auto; }
.news-ticker__item--cube-in { animation: ticker-cube-in 0.7s cubic-bezier(0.4, 0, 0.2, 1) forwards; }
.news-ticker__item--cube-out { animation: ticker-cube-out 0.7s cubic-bezier(0.4, 0, 0.2, 1) forwards; }
@keyframes ticker-cube-in { from { transform: translateZ(-100px) rotateY(90deg); opacity: 0; } to { transform: translateZ(0) rotateY(0); opacity: 1; } }
@keyframes ticker-cube-out { from { transform: translateZ(0) rotateY(0); opacity: 1; } to { transform: translateZ(-100px) rotateY(-90deg); opacity: 0; } }

/* ============================================
   NEWSPAPER ANIMATION
   ============================================ */
.news-ticker--newspaper .news-ticker__track { position: relative; width: 100%; height: 100%; min-height: 40px; }
.news-ticker--newspaper .news-ticker__item { position: absolute; left: 0; top: 0; width: 100%; height: 100%; display: flex; align-items: center; opacity: 0; pointer-events: none; }
.news-ticker--newspaper .news-ticker__item--active { opacity: 1; pointer-events: auto; }
.news-ticker__item--newspaper-in { animation: ticker-newspaper-in 0.8s cubic-bezier(0.4, 0, 0.2, 1) forwards; }
.news-ticker__item--newspaper-out { animation: ticker-newspaper-out 0.4s ease-in forwards; }
@keyframes ticker-newspaper-in { from { transform: scale(0) rotate(-720deg); opacity: 0; } to { transform: scale(1) rotate(0); opacity: 1; } }
@keyframes ticker-newspaper-out { from { transform: scale(1) rotate(0); opacity: 1; } to { transform: scale(0) rotate(720deg); opacity: 0; } }

/* ============================================
   DROP ANIMATION
   ============================================ */
.news-ticker--drop .news-ticker__track { position: relative; width: 100%; height: 100%; min-height: 40px; overflow: hidden; }
.news-ticker--drop .news-ticker__item { position: absolute; left: 0; top: 0; width: 100%; height: 100%; display: flex; align-items: center; opacity: 0; pointer-events: none; }
.news-ticker--drop .news-ticker__item--active { opacity: 1; pointer-events: auto; }
.news-ticker__item--drop-in { animation: ticker-drop-in 0.6s cubic-bezier(0.34, 1.56, 0.64, 1) forwards; }
.news-ticker__item--drop-out { animation: ticker-drop-out 0.4s ease-in forwards; }
@keyframes ticker-drop-in { from { transform: translateY(-200%); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
@keyframes ticker-drop-out { from { transform: translateY(0); opacity: 1; } to { transform: translateY(200%); opacity: 0; } }

/* ============================================
   HIDE SEPARATOR IN SINGLE-ITEM MODES
   ============================================ */
.news-ticker:not(.news-ticker--scroll) .news-ticker__separator {
    display: none;
}

/* ============================================
   RESPONSIVE
   ============================================ */
@media (max-width: 768px) {
    .news-ticker { font-size: 13px; }
    .news-ticker__label { padding: 0 14px; font-size: 11px; }
    .news-ticker__label--has-arrow::after { display: none; }
    .news-ticker__content { padding: 0 14px; }
    .news-ticker__controls { padding: 0 8px; }
    .news-ticker__btn { width: 28px; height: 28px; }
}

@media (max-width: 480px) {
    .news-ticker__label-text { display: none; }
    .news-ticker__label { padding: 0 12px; }
}

/* ============================================
   ACCESSIBILITY
   ============================================ */
@media (prefers-reduced-motion: reduce) {
    .news-ticker--scroll .news-ticker__track,
    .news-ticker__item,
    .news-ticker__btn {
        animation: none !important;
        transition: none !important;
    }
}

.news-ticker__btn:focus-visible { outline: 2px solid currentColor; outline-offset: 2px; }
.news-ticker__item:focus-visible { outline: 2px solid currentColor; outline-offset: 2px; }

@media print { .news-ticker { display: none; } }
