/* global vars */
:root {
	--color-announce: steelblue;
	--color-playerName-out: #d7d7d7;
	--color-playerName-in: #e6e8e9;
	--color-score-out: #b6b6b6;
	--color-score-in: #e6e8e9;
	--color-game-out: #6d6d6d;
	--color-game-in: #44484d;
	--color-timer: cornflowerblue;
	}

.liveScoreTable {
	font-size: clamp(2dvw, 2dvw, 3dvw);
	line-height: 1.2em;
	border-collapse: collapse;
	white-space: nowrap;
	}

.liveScoreTable td {
	vertical-align: middle;
	}

.score {
	position: relative;
	overflow: hidden;
	background: linear-gradient(to bottom, var(--color-score-out), var(--color-score-in) 50%, var(--color-score-out));
	font-family: Arial Black, Arial;
	font-weight: 900;
	min-width: 2dvw;
	}

/* overlay for animation */
.score::after {
    content: "";
    position: absolute;
    inset: 0;
    background: var(--color-announce);
    opacity: 0;
    transition: opacity 1s ease-in-out;
    border-radius: inherit;
}

/* class to start animation */
.score.bgFadeInOut::after {
    opacity: 0.4;
}

.logo {
	max-width: 100%;
	max-height: 100%;
	width: auto;
	height: auto;
	display: block;
	margin: auto;
	}

table td:has(.logo) {
    text-align: center;
    vertical-align: middle;
	}

.bottom-element {
	position: fixed;
	bottom: 2.5dvh;
	left: 50%;
	transform: translateX(-50%);
	max-width: 80%;
	z-index: 100;
	}

.hidden {
	visibility: hidden;
	}

.announcement {
	font-size: 1.5dvw;
	font-family: Arial;
	font-weight: bold;
	color: var(--color-announce);
	background: linear-gradient(to right, transparent, var(--color-playerName-out) 20%, var(--color-playerName-out) 80%, transparent);
	padding: 0.5dvw 7dvw;
	}

.tdAnnouncement {
	text-align: center;
	}

.playerName {
	background: linear-gradient(to bottom, var(--color-playerName-out), var(--color-playerName-in) 50%, var(--color-playerName-out));
	text-align: center;
	font-family: Arial;
	font-weight: bolder;
	padding: 0 2dvw;
	}

.noServe {
	background: var(--color-score-out);
	}

.serve {
	background: var(--color-game-out);
	}

.serveA {
	background: linear-gradient(to right, var(--color-game-out), var(--color-score-out));
	}

.serveB {
	background: linear-gradient(to left, var(--color-game-out), var(--color-score-out));
	}

.game {
	color: #ffffff;
	background: linear-gradient(to bottom, var(--color-game-out), var(--color-game-in) 50%, var(--color-game-out));
	text-align: center;
	font-family: Arial;
	font-weight: bolder;
	min-width: 3dvw;
	}

.teams {
	background: linear-gradient(to bottom, var(--color-score-out), var(--color-playerName-in) 50%, var(--color-score-out));
	text-align: center;
	font-family: Arial Black;
	}

.league {
	color: #ffffff;
	background: linear-gradient(to bottom, var(--color-game-out), var(--color-game-in) 50%, var(--color-game-out));
	text-align: left;
	font-family: Arial;
	font-weight: bolder;
	}

.games {
	color: #000000;
	background: linear-gradient(to bottom, #fff, #dcdcdc 50%, #fff);
	text-align: center;
	font-family: Arial;
	font-weight: bolder;
	padding: 0.6dvh 0.4dvw;
	min-width: 3dvw;
	}

.border {
	border-color: silver;
	border-style: solid;
	border-width: 1px;
	}

.left {
	text-align: left;
	padding-left: 0.8dvw !important;
	padding-right: 0.8dvw !important;
	}

.playerColorA {
	--player-color: transparent;
	background: linear-gradient(
		to left,
		var(--player-color),
		var(--player-color) 35%,
		transparent 75%
	);
}

.playerColorB {
	--player-color: transparent;
	background: linear-gradient(
		to right,
		var(--player-color),
		var(--player-color) 35%,
		transparent 75%
	);
}

.video-background {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	overflow: hidden;
	z-index: -1;
	}

.video-background iframe {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 120vw;
	height: 120vh;
	/* transform: translate(-50%, -50%); */
	transform: translate(-50%, -46%) scale(1.02);		/* move video down, to hide original scoreboard */
	pointer-events: none;
	}

/* scoring progress */
.progressParent {
	font-family: Arial;
	font-weight: normal;
	display:flex;
    margin: 0 auto;
	}

.progressParent td {
	vertical-align: middle;
	height: 1.5dvw;
	text-align: center;
	padding: 1px 2px;

/*
	border-width: 1px;
	border-color: wheat;
	border-style: solid;
*/
	}

.progressDot {
	background: transparent;
	border-radius: 500px;
	display: flex;
	height: 100%;
	aspect-ratio: 1/1;
	justify-content: center;
	align-items: center;
	font-size: 0.9dvw;
	}

.progressDotScored {
	background: var(--color-timer);
	box-shadow: 3px 3px 3px rgb(30, 30, 30);
	}

.progressDotWarning {
	border-radius: 500px;
	box-shadow: 3px 3px 3px rgb(30, 30, 30);
	}

.progressDotPenalty {
	background: orangered;
	border-radius: 500px;
	box-shadow: 3px 3px 3px rgb(30, 30, 30);
	}

.progressIcon {
	font-size: 1.5dvw;
	color: var(--color-timer);
	}

.progressNoScore {
	color: white;
	}

.progressText {
	font-size: 0.9dvw;
	font-weight: bold;
	color: white;
	justify-content: start;
	align-items: center;
	display: flex;
	padding: 0;
	margin: 0dvw 0.25dvw 0dvw 0.25dvw;
	max-height: 1.1dvw;
	white-space: nowrap;
	}

table td:has(.progressTextLong) {
	max-width: unset;
	}
