/* ========================================
   NEWS & MEDIA LAYOUTS — v1.2.0
======================================== */

/* Breaking News Ticker Bar */
.dss-news-ticker{position:absolute;left:0;width:100%;z-index:12;display:flex;overflow:hidden;background:rgba(200,0,0,.95);color:#fff;font-size:13px;font-weight:700;height:36px;align-items:center}
.dss-ticker-bottom{bottom:0}
.dss-ticker-top{top:0}
.dss-ticker-label{display:flex;align-items:center;gap:6px;padding:0 16px;background:#cc0000;white-space:nowrap;height:100%;letter-spacing:2px;text-transform:uppercase;font-size:11px;z-index:1;box-shadow:4px 0 8px rgba(0,0,0,.3)}
.dss-ticker-live-dot{width:8px;height:8px;background:#fff;border-radius:50%;animation:livePulse 1s infinite}
@keyframes livePulse{0%,100%{opacity:1}50%{opacity:.3}}
.dss-ticker-track{flex:1;overflow:hidden;position:relative;height:100%;display:flex;align-items:center}
.dss-ticker-content{display:flex;gap:20px;white-space:nowrap;animation:tickerScroll var(--dss-ticker-duration,30s) linear infinite;padding-left:100%}
@keyframes tickerScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.dss-ticker-item{letter-spacing:.5px}
.dss-ticker-sep{opacity:.4;font-size:8px}
.dss-news-ticker:hover .dss-ticker-content{animation-play-state:paused}

/* News Channel Lower Third */
.dss-lower-third{position:absolute;bottom:60px;left:0;width:100%;z-index:9;padding:0 40px;opacity:0;transform:translateY(20px)}
.dss-slide.active .dss-lower-third{animation:fadeInUp .6s .4s ease-out forwards}
.dss-lt-channel{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.dss-lt-logo{height:28px;width:auto;object-fit:contain}
.dss-lt-name{font-size:11px;font-weight:800;letter-spacing:3px;text-transform:uppercase;color:var(--dss-accent);background:rgba(0,0,0,.6);padding:4px 12px;border-radius:3px}
.dss-lt-headline{background:linear-gradient(135deg,rgba(0,0,0,.85),rgba(0,0,0,.7));backdrop-filter:blur(10px);border-left:4px solid var(--dss-accent);padding:16px 24px;border-radius:0 8px 8px 0;max-width:700px}
.dss-lt-category{display:inline-block;font-size:10px;font-weight:800;letter-spacing:3px;text-transform:uppercase;color:var(--dss-accent);margin-bottom:6px}
.dss-lt-title{font-size:22px;font-weight:800;color:#fff;line-height:1.2;margin:0}
.dss-lt-desc{font-size:13px;color:rgba(255,255,255,.7);margin:6px 0 0;line-height:1.4}

/* Live TV Overlay */
.dss-live-overlay{position:absolute;top:20px;left:20px;z-index:11;display:flex;align-items:center;gap:12px}

/* Live Overlay Horizontal Position */
.dss-live-pos-left{left:20px;right:auto}
.dss-live-pos-center{left:50%;right:auto;transform:translateX(-50%)}
.dss-live-pos-right{left:auto;right:20px}

/* Live Overlay Vertical Position */
.dss-live-vpos-top{top:20px;bottom:auto}
.dss-live-vpos-bottom{top:auto;bottom:20px}

.dss-live-badge{display:flex;align-items:center;gap:6px;background:#cc0000;color:#fff;padding:6px 14px;border-radius:4px;font-size:12px;font-weight:900;letter-spacing:3px;text-transform:uppercase;animation:liveBadgePulse 2s infinite}
@keyframes liveBadgePulse{0%,100%{box-shadow:0 0 0 0 rgba(204,0,0,.6)}50%{box-shadow:0 0 0 8px rgba(204,0,0,0)}}
.dss-live-dot{width:8px;height:8px;background:#fff;border-radius:50%;animation:livePulse 1s infinite}
.dss-live-logo{height:32px;width:auto;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5))}
.dss-rtl .dss-live-overlay{left:auto;right:20px}
.dss-rtl .dss-live-pos-right{right:auto;left:20px}

/* ========================================
   3D LOGO ANIMATIONS
======================================== */

/* Spin 3D — continuous Y-axis rotation */
.dss-logo-anim-spin{animation:logoSpin3D 4s linear infinite;transform-style:preserve-3d}
@keyframes logoSpin3D{
    0%{transform:perspective(600px) rotateY(0deg)}
    100%{transform:perspective(600px) rotateY(360deg)}
}

/* Pulse — scale in/out heartbeat */
.dss-logo-anim-pulse{animation:logoPulse 2s ease-in-out infinite}
@keyframes logoPulse{
    0%,100%{transform:scale(1)}
    50%{transform:scale(1.15)}
}

/* Bounce — vertical hop */
.dss-logo-anim-bounce{animation:logoBounce 2s ease infinite}
@keyframes logoBounce{
    0%,20%,50%,80%,100%{transform:translateY(0)}
    40%{transform:translateY(-12px)}
    60%{transform:translateY(-6px)}
}

/* Flip 3D — X-axis rotation */
.dss-logo-anim-flip{animation:logoFlip3D 3s ease-in-out infinite;transform-style:preserve-3d}
@keyframes logoFlip3D{
    0%{transform:perspective(600px) rotateX(0deg)}
    50%{transform:perspective(600px) rotateX(180deg)}
    100%{transform:perspective(600px) rotateX(360deg)}
}

/* Swing — pendulum rock */
.dss-logo-anim-swing{animation:logoSwing 2s ease-in-out infinite;transform-origin:top center}
@keyframes logoSwing{
    0%,100%{transform:rotate(0deg)}
    20%{transform:rotate(12deg)}
    40%{transform:rotate(-10deg)}
    60%{transform:rotate(6deg)}
    80%{transform:rotate(-4deg)}
}

/* Glow — glowing halo effect */
.dss-logo-anim-glow{animation:logoGlow 2s ease-in-out infinite}
@keyframes logoGlow{
    0%,100%{filter:drop-shadow(0 0 4px rgba(255,255,255,.2))}
    50%{filter:drop-shadow(0 0 18px rgba(255,255,255,.6)) drop-shadow(0 0 40px rgba(255,68,68,.3))}
}

/* ========================================
   3D CUBE LOGO
======================================== */
.dss-logo-cube-scene{display:inline-block;flex-shrink:0}
.dss-logo-cube{position:relative;transform-style:preserve-3d;animation:logoCubeRotate 8s linear infinite}
@keyframes logoCubeRotate{
    0%{transform:rotateX(-15deg) rotateY(0deg)}
    25%{transform:rotateX(15deg) rotateY(90deg)}
    50%{transform:rotateX(-15deg) rotateY(180deg)}
    75%{transform:rotateX(15deg) rotateY(270deg)}
    100%{transform:rotateX(-15deg) rotateY(360deg)}
}
.dss-cube-face{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;backface-visibility:visible;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:4px;box-shadow:inset 0 0 20px rgba(255,255,255,.03)}
.dss-cube-face img{object-fit:contain;filter:drop-shadow(0 2px 8px rgba(0,0,0,.4))}

/* Lower-Third Logo Position */
.dss-lt-pos-center .dss-lt-channel{justify-content:center}
.dss-lt-pos-right .dss-lt-channel{justify-content:flex-end}

/* Reduced motion — disable all logo animations */
@media(prefers-reduced-motion:reduce){
    .dss-logo-anim-spin,.dss-logo-anim-pulse,.dss-logo-anim-bounce,.dss-logo-anim-flip,.dss-logo-anim-swing,.dss-logo-anim-glow,.dss-logo-cube{animation:none !important}
}

/* Live Clock Overlay */
.dss-clock-overlay{position:absolute;top:20px;right:20px;z-index:11;display:flex;flex-direction:column;align-items:flex-end;gap:2px;padding:8px 14px;background:rgba(0,0,0,.6);backdrop-filter:blur(8px);border-radius:8px;border:1px solid rgba(255,255,255,.1)}
.dss-clock-time{font-size:18px;font-weight:800;color:#fff;font-variant-numeric:tabular-nums;letter-spacing:1px}
.dss-clock-date{font-size:10px;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:2px}
.dss-rtl .dss-clock-overlay{right:auto;left:20px;align-items:flex-start}

/* Weather Widget Overlay */
.dss-weather-overlay{position:absolute;top:20px;right:20px;z-index:11;display:flex;align-items:center;gap:8px;padding:8px 16px;background:rgba(0,0,0,.6);backdrop-filter:blur(8px);border-radius:30px;border:1px solid rgba(255,255,255,.1);color:#fff}
.dss-weather-icon{font-size:22px}
.dss-weather-temp{font-size:18px;font-weight:800;font-variant-numeric:tabular-nums}
.dss-weather-loc{font-size:10px;opacity:.6;text-transform:uppercase;letter-spacing:1px}
/* If both clock and weather, stack them */
.dss-clock-overlay + .dss-weather-overlay,.dss-weather-overlay + .dss-clock-overlay{top:70px}
.dss-rtl .dss-weather-overlay{right:auto;left:20px}

/* Animated Text Ticker (Stock/Scores) */
.dss-text-ticker{position:absolute;top:0;left:0;width:100%;z-index:12;overflow:hidden;background:rgba(0,0,0,.85);height:30px;display:flex;align-items:center;border-bottom:1px solid rgba(255,255,255,.1)}
.dss-text-ticker-track{display:flex;gap:24px;white-space:nowrap;animation:tickerScroll var(--dss-tt-duration,25s) linear infinite}
.dss-tt-item{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:#fff;padding:0 4px}
.dss-tt-label{opacity:.5;font-size:11px;letter-spacing:1px}
.dss-tt-value{font-variant-numeric:tabular-nums}
.dss-tt-up .dss-tt-value,.dss-tt-up .dss-tt-arrow{color:#10b981}
.dss-tt-down .dss-tt-value,.dss-tt-down .dss-tt-arrow{color:#ef4444}
.dss-tt-arrow{font-size:9px}
.dss-text-ticker:hover .dss-text-ticker-track{animation-play-state:paused}

/* Lottie Background Container */
.dss-lottie-bg{position:absolute;top:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none;opacity:.5}
.dss-lottie-bg lottie-player,.dss-lottie-bg dotlottie-player{width:100%;height:100%}

/* ========================================
   RESPONSIVE
======================================== */
@media(max-width:768px){
    .dss-news-ticker{height:28px;font-size:11px}
    .dss-ticker-label{padding:0 10px;font-size:9px}
    .dss-lower-third{bottom:40px;padding:0 16px}
    .dss-lt-title{font-size:16px}
    .dss-lt-headline{padding:10px 16px}
    .dss-live-overlay{top:12px;left:12px}
    .dss-live-badge{font-size:10px;padding:4px 10px}
    .dss-clock-overlay{padding:6px 10px}
    .dss-clock-time{font-size:14px}
    .dss-text-ticker{height:24px}
    .dss-tt-item{font-size:10px}
}
