/**
 * TV Overlay - Ribbon Style
 * 
 * Bottom-of-screen ticker/ribbon overlay (ESPN, Sky Sports style).
 */

/* ============================================
   Ribbon Container
   ============================================ */
.overlay-ribbon {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: calc(0.75rem * var(--overlay-scale)) calc(1.5rem * var(--overlay-scale));
    background: var(--overlay-bg);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border-top: 1px solid var(--overlay-border);
}

/* Top position variant */
.overlay-ribbon.position-top {
    bottom: auto;
    top: 0;
    border-top: none;
    border-bottom: 1px solid var(--overlay-border);
}

/* ============================================
   Ribbon Inner Layout
   ============================================ */
.ribbon-inner {
    display: flex;
    align-items: center;
    gap: calc(1.5rem * var(--overlay-scale));
    max-width: 1200px;
    width: 100%;
}

/* ============================================
   Sport Badge
   ============================================ */
.ribbon-sport {
    display: flex;
    align-items: center;
    gap: calc(0.5rem * var(--overlay-scale));
    padding: calc(0.375rem * var(--overlay-scale)) calc(0.75rem * var(--overlay-scale));
    background: var(--overlay-accent);
    border-radius: calc(4px * var(--overlay-scale));
    font-size: calc(0.75rem * var(--overlay-scale));
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: white;
    white-space: nowrap;
}

.ribbon-sport i {
    font-size: calc(0.875rem * var(--overlay-scale));
}

/* ============================================
   Score Section
   ============================================ */
.ribbon-score {
    display: flex;
    align-items: center;
    gap: calc(0.25rem * var(--overlay-scale));
    flex: 1;
    justify-content: center;
}

.ribbon-player {
    display: flex;
    align-items: center;
    gap: calc(0.75rem * var(--overlay-scale));
    padding: calc(0.5rem * var(--overlay-scale)) calc(1rem * var(--overlay-scale));
    background: rgba(255, 255, 255, 0.05);
    border-radius: calc(6px * var(--overlay-scale));
    min-width: calc(180px * var(--overlay-scale));
}

.ribbon-player-1 {
    border-left: 3px solid var(--player1-color);
    justify-content: flex-end;
}

.ribbon-player-2 {
    border-right: 3px solid var(--player2-color);
    flex-direction: row-reverse;
}

.ribbon-player-name {
    font-size: calc(0.9375rem * var(--overlay-scale));
    font-weight: 600;
    color: var(--overlay-text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: calc(120px * var(--overlay-scale));
}

.ribbon-player-score {
    font-size: calc(1.5rem * var(--overlay-scale));
    font-weight: 700;
    font-variant-numeric: tabular-nums;
    min-width: calc(2rem * var(--overlay-scale));
    text-align: center;
}

.ribbon-player-1 .ribbon-player-score {
    color: var(--player1-color);
}

.ribbon-player-2 .ribbon-player-score {
    color: var(--player2-color);
}

.ribbon-vs {
    font-size: calc(0.875rem * var(--overlay-scale));
    font-weight: 300;
    color: var(--overlay-text-muted);
    padding: 0 calc(0.75rem * var(--overlay-scale));
}

/* ============================================
   Game Info
   ============================================ */
.ribbon-game-info {
    display: flex;
    align-items: center;
    gap: calc(1rem * var(--overlay-scale));
    padding-left: calc(1rem * var(--overlay-scale));
    border-left: 1px solid var(--overlay-border);
}

.ribbon-game-label {
    font-size: calc(0.75rem * var(--overlay-scale));
    color: var(--overlay-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.ribbon-game-value {
    font-size: calc(1rem * var(--overlay-scale));
    font-weight: 600;
    color: var(--overlay-text);
}

.ribbon-games-won {
    display: flex;
    align-items: center;
    gap: calc(0.5rem * var(--overlay-scale));
}

.ribbon-games-p1,
.ribbon-games-p2 {
    font-size: calc(1.25rem * var(--overlay-scale));
    font-weight: 700;
    font-variant-numeric: tabular-nums;
}

.ribbon-games-p1 {
    color: var(--player1-color);
}

.ribbon-games-p2 {
    color: var(--player2-color);
}

.ribbon-games-separator {
    color: var(--overlay-text-muted);
}

/* ============================================
   Serve Indicator
   ============================================ */
.ribbon-serve {
    display: flex;
    align-items: center;
    gap: calc(0.5rem * var(--overlay-scale));
    padding-left: calc(1rem * var(--overlay-scale));
    border-left: 1px solid var(--overlay-border);
}

.ribbon-serve-dot {
    width: calc(10px * var(--overlay-scale));
    height: calc(10px * var(--overlay-scale));
    background: var(--overlay-accent);
    border-radius: 50%;
    animation: servePulse 1.5s ease-in-out infinite;
}

.ribbon-serve-label {
    font-size: calc(0.75rem * var(--overlay-scale));
    color: var(--overlay-text-muted);
    text-transform: uppercase;
}

.ribbon-serve-player {
    font-size: calc(0.875rem * var(--overlay-scale));
    font-weight: 600;
    color: var(--overlay-text);
}

/* ============================================
   Responsive Scaling
   ============================================ */
@media (max-width: 1200px) {
    .ribbon-inner {
        gap: calc(1rem * var(--overlay-scale));
    }
    
    .ribbon-player {
        min-width: calc(140px * var(--overlay-scale));
    }
}

@media (max-width: 800px) {
    .ribbon-sport span {
        display: none;
    }
    
    .ribbon-game-info {
        flex-direction: column;
        gap: calc(0.25rem * var(--overlay-scale));
        align-items: flex-start;
    }
}
