/* Play Radio – Grila de Programe: public display. */
.prs-schedule {
	--prs-minute-px: 1px;
	--prs-canvas-height: 1440px;
	--prs-ink: #f6f6f6;
	--prs-muted: #b8bbc0;
	--prs-surface: #171717;
	--prs-surface-elevated: #202020;
	--prs-line: rgba(255, 255, 255, .12);
	--prs-line-strong: rgba(255, 255, 255, .18);
	--prs-accent: #ff7900;
	--prs-shadow: 0 16px 46px rgba(0, 0, 0, .24);
	position: relative;
	box-sizing: border-box;
	margin: 0 auto 40px;
	border: 1px solid var(--prs-line-strong);
	border-radius: 16px;
	background: var(--prs-surface);
	box-shadow: var(--prs-shadow);
	color: var(--prs-ink);
	overflow: hidden;
}

:root[data-play-theme="light"] .prs-schedule {
	--prs-ink: #16181b;
	--prs-muted: #5e646b;
	--prs-surface: #ffffff;
	--prs-surface-elevated: #f6f7f8;
	--prs-line: rgba(20, 25, 31, .12);
	--prs-line-strong: rgba(20, 25, 31, .19);
	--prs-shadow: 0 14px 34px rgba(10, 20, 32, .10);
}

.prs-schedule *,
.prs-schedule *::before,
.prs-schedule *::after {
	box-sizing: border-box;
}

.prs-schedule__topbar {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	padding: 14px 30px;
	border-bottom: 1px solid var(--prs-line);
}

.prs-schedule__now {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	flex: 0 0 auto;
	padding: 9px 12px;
	border: 1px solid rgba(255, 121, 0, .45);
	border: 1px solid color-mix(in srgb, var(--prs-accent) 45%, transparent);
	border-radius: 999px;
	background: rgba(255, 121, 0, .12);
	background: color-mix(in srgb, var(--prs-accent) 12%, transparent);
	color: var(--prs-ink);
	font-size: 12px;
	font-weight: 800;
}

.prs-schedule__live-dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: var(--prs-accent);
	box-shadow: 0 0 0 5px rgba(255, 121, 0, .18);
	box-shadow: 0 0 0 5px color-mix(in srgb, var(--prs-accent) 18%, transparent);
}

.prs-schedule__special-week {
	display: flex;
	align-items: center;
	gap: 8px;
	margin: 0;
	padding: 11px 30px;
	border-bottom: 1px solid var(--prs-line);
	background: color-mix(in srgb, var(--prs-accent) 8%, transparent);
	color: var(--prs-ink);
	font-size: 12px;
	font-weight: 800;
	line-height: 1.35;
}

.prs-schedule__special-week-dot {
	width: 8px;
	height: 8px;
	flex: 0 0 auto;
	border-radius: 50%;
	background: var(--prs-accent);
	box-shadow: 0 0 0 4px color-mix(in srgb, var(--prs-accent) 18%, transparent);
}

.prs-schedule__day-tabs {
	display: none;
	gap: 8px;
	padding: 13px 14px;
	border-bottom: 1px solid var(--prs-line);
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}

.prs-schedule__day-tab {
	flex: 0 0 auto;
	border: 1px solid var(--prs-line-strong);
	border-radius: 999px;
	background: transparent;
	color: var(--prs-muted);
	font: inherit;
	font-size: 12px;
	font-weight: 800;
	line-height: 1;
	padding: 9px 11px;
	cursor: pointer;
}

.prs-schedule__day-tab.is-selected,
.prs-schedule__day-tab:hover,
.prs-schedule__day-tab:focus-visible {
	border-color: var(--prs-accent);
	background: var(--prs-accent);
	color: #101010;
	outline: none;
}

.prs-schedule__viewport {
	/* The 24-hour programme grid determines the natural document height. This
	 * prevents a second vertical scrollbar inside the schedule card. */
	overflow-x: auto;
	overflow-y: hidden;
	max-height: none;
	overscroll-behavior-x: contain;
}

.prs-schedule__grid {
	display: grid;
	grid-template-columns: 66px minmax(760px, 1fr);
	min-width: 826px;
}

.prs-schedule__time-column {
	position: relative;
	z-index: 3;
	background: var(--prs-surface-elevated);
	border-right: 1px solid var(--prs-line-strong);
}

.prs-schedule__corner,
.prs-schedule__day-heading {
	height: 46px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-bottom: 1px solid var(--prs-line-strong);
	color: var(--prs-muted);
	font-size: 11px;
	font-weight: 900;
	letter-spacing: .06em;
	text-transform: uppercase;
}

.prs-schedule__time-canvas,
.prs-schedule__day-canvas {
	position: relative;
	height: var(--prs-canvas-height);
}

.prs-schedule__time-label {
	position: absolute;
	top: calc(var(--prs-minute) * var(--prs-minute-px));
	left: 0;
	width: 100%;
	transform: translateY(-50%);
	padding-right: 10px;
	color: var(--prs-muted);
	font-size: 10px;
	font-variant-numeric: tabular-nums;
	font-weight: 800;
	line-height: 1;
	text-align: right;
}

.prs-schedule__time-label:first-child {
	transform: none;
	top: 5px;
}

.prs-schedule__time-label:last-child {
	transform: translateY(-100%);
	top: calc(var(--prs-canvas-height) - 5px);
}

.prs-schedule__days {
	display: grid;
	grid-template-columns: repeat(7, minmax(105px, 1fr));
	min-width: 0;
}

.prs-schedule__day {
	min-width: 0;
	border-right: 1px solid var(--prs-line);
}

.prs-schedule__day:last-child {
	border-right: 0;
}

.prs-schedule__day.is-current-day .prs-schedule__day-heading {
	background: rgba(255, 121, 0, .12);
	background: color-mix(in srgb, var(--prs-accent) 12%, var(--prs-surface-elevated));
	color: var(--prs-ink);
}

.prs-schedule__day-canvas {
	background: linear-gradient(to bottom, color-mix(in srgb, var(--prs-surface-elevated) 42%, transparent), transparent 240px);
}

.prs-schedule__hour-line {
	position: absolute;
	z-index: 0;
	top: calc(var(--prs-minute) * var(--prs-minute-px));
	left: 0;
	right: 0;
	border-top: 1px solid var(--prs-line);
	pointer-events: none;
}

.prs-schedule__hour-line:nth-child(odd) {
	border-color: color-mix(in srgb, var(--prs-line-strong) 62%, transparent);
}

.prs-schedule__slot {
	position: absolute;
	z-index: 1;
	top: calc(var(--prs-slot-start) * var(--prs-minute-px) + 2px);
	left: 4px;
	right: 4px;
	height: max(28px, calc((var(--prs-slot-end) - var(--prs-slot-start)) * var(--prs-minute-px) - 4px));
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	justify-content: center;
	gap: 4px;
	margin: 0;
	padding: 8px 9px;
	border: 1px solid var(--prs-slot-color);
	border: 1px solid color-mix(in srgb, var(--prs-slot-color) 78%, #ffffff 22%);
	border-radius: 10px;
	background: var(--prs-slot-color);
	background: color-mix(in srgb, var(--prs-slot-color) 73%, #151515 27%);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, .17), 0 8px 20px rgba(0, 0, 0, .16);
	color: #fff;
	font: inherit;
	text-align: left;
	cursor: pointer;
	overflow: hidden;
	transition: transform .16s ease, box-shadow .16s ease, filter .16s ease;
}

:root[data-play-theme="light"] .prs-schedule__slot {
	background: var(--prs-slot-color);
	background: color-mix(in srgb, var(--prs-slot-color) 77%, #ffffff 23%);
	color: #101010;
	box-shadow: inset 0 1px 0 rgba(255,255,255,.45), 0 8px 18px rgba(20,25,31,.10);
}

.prs-schedule__slot:hover,
.prs-schedule__slot:focus-visible {
	z-index: 4;
	transform: translateY(-2px) scale(1.015);
	box-shadow: 0 0 0 2px var(--prs-slot-color), 0 13px 24px rgba(0, 0, 0, .24);
	box-shadow: 0 0 0 2px color-mix(in srgb, var(--prs-slot-color) 92%, #fff 8%), 0 13px 24px color-mix(in srgb, var(--prs-slot-color) 24%, transparent);
	filter: saturate(1.12) brightness(1.06);
	outline: none;
}

.prs-schedule__slot.is-on-air {
	z-index: 3;
	box-shadow: 0 0 0 2px #fff, 0 0 0 5px var(--prs-slot-color), 0 12px 28px rgba(0, 0, 0, .24);
	box-shadow: 0 0 0 2px #fff, 0 0 0 5px var(--prs-slot-color), 0 12px 28px color-mix(in srgb, var(--prs-slot-color) 44%, transparent);
}

.prs-schedule__slot-time {
	display: block;
	font-size: 10px;
	font-variant-numeric: tabular-nums;
	font-weight: 900;
	line-height: 1;
	opacity: .82;
}

.prs-schedule__slot-title {
	display: -webkit-box;
	overflow: hidden;
	font-size: 13px;
	font-weight: 900;
	letter-spacing: -.01em;
	line-height: 1.14;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 3;
}

.prs-schedule__slot-rule {
	display: inline-flex;
	max-width: 100%;
	padding: 3px 5px;
	border: 1px solid rgba(255,255,255,.42);
	border-radius: 999px;
	background: rgba(0,0,0,.16);
	color: currentColor;
	font-size: 9px;
	font-weight: 900;
	letter-spacing: .03em;
	line-height: 1;
	white-space: nowrap;
}

:root[data-play-theme="light"] .prs-schedule__slot-rule {
	border-color: rgba(0,0,0,.22);
	background: rgba(255,255,255,.36);
}

.prs-schedule__slot.is-monthly {
	border-width: 2px;
	background-image: linear-gradient(135deg, rgba(255,255,255,.13) 0, rgba(255,255,255,.13) 12%, transparent 12%, transparent 24%, rgba(255,255,255,.06) 24%, rgba(255,255,255,.06) 36%, transparent 36%, transparent 48%, rgba(255,255,255,.03) 48%, rgba(255,255,255,.03) 60%, transparent 60%);
}

.prs-schedule__slot-live {
	margin-top: 2px;
	padding: 3px 5px;
	border-radius: 4px;
	background: rgba(255,255,255,.91);
	color: #111;
	font-size: 9px;
	font-weight: 900;
	letter-spacing: .07em;
	line-height: 1;
}

.prs-schedule__slot.is-compact {
	height: max(8px, calc((var(--prs-slot-end) - var(--prs-slot-start)) * var(--prs-minute-px) - 2px));
	min-height: 0;
	justify-content: center;
	padding: 1px 5px;
	border-radius: 4px;
}

.prs-schedule__slot.is-compact .prs-schedule__slot-title,
.prs-schedule__slot.is-compact .prs-schedule__slot-rule,
.prs-schedule__slot.is-compact .prs-schedule__slot-live {
	display: none;
}

.prs-schedule__slot.is-compact .prs-schedule__slot-time {
	display: none;
}

.prs-schedule__now-line {
	position: absolute;
	z-index: 5;
	top: calc(var(--prs-now-minute) * var(--prs-minute-px));
	left: 0;
	right: 0;
	border-top: 2px solid #ff3e4d;
	pointer-events: none;
}

.prs-schedule__now-line span {
	position: absolute;
	top: -9px;
	right: 5px;
	padding: 3px 5px;
	border-radius: 4px;
	background: #ff3e4d;
	color: #fff;
	font-size: 9px;
	font-weight: 900;
	letter-spacing: .06em;
	line-height: 1;
}

.prs-schedule__empty {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	padding: 34px;
	color: var(--prs-muted);
	text-align: center;
}

.prs-schedule__empty .dashicons {
	color: var(--prs-accent);
}

.prs-schedule__modal[hidden] {
	display: none;
}

.prs-schedule__modal {
	position: fixed;
	z-index: 99999;
	inset: 0;
	display: grid;
	place-items: center;
	padding: 18px;
}

.prs-schedule__modal-backdrop {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, .68);
	-webkit-backdrop-filter: blur(4px);
	backdrop-filter: blur(4px);
}

.prs-schedule__modal-dialog {
	position: relative;
	z-index: 1;
	width: min(460px, 100%);
	padding: 26px;
	border: 1px solid var(--prs-line-strong);
	border-radius: 16px;
	background: var(--prs-surface);
	box-shadow: 0 22px 70px rgba(0,0,0,.42);
	color: var(--prs-ink);
}

.prs-schedule__modal-close {
	position: absolute;
	top: 10px;
	right: 12px;
	width: 34px;
	height: 34px;
	border: 1px solid var(--prs-line-strong);
	border-radius: 50%;
	background: transparent;
	color: var(--prs-ink);
	font-size: 23px;
	line-height: 1;
	cursor: pointer;
}

.prs-schedule__modal-close:hover,
.prs-schedule__modal-close:focus-visible {
	border-color: var(--prs-accent);
	color: var(--prs-accent);
	outline: none;
}

.prs-schedule__modal-time {
	margin: 0 42px 8px 0;
	color: var(--prs-accent);
	font-size: 12px;
	font-weight: 900;
}

.prs-schedule__modal-dialog h3 {
	margin: 0 34px 11px 0;
	color: var(--prs-ink);
	font-size: 26px;
	line-height: 1.1;
}

.prs-schedule__modal-dialog p:not(.prs-schedule__modal-time) {
	margin: 0;
	color: var(--prs-muted);
	line-height: 1.6;
}

.prs-schedule__modal-link[hidden] {
	display: none !important;
}

.prs-schedule__modal-link {
	display: inline-flex;
	margin-top: 18px;
	padding: 10px 13px;
	border-radius: 8px;
	background: var(--prs-accent);
	color: #121212 !important;
	font-size: 13px;
	font-weight: 900;
	text-decoration: none;
}

.prs-schedule__modal-link:hover,
.prs-schedule__modal-link:focus-visible {
	filter: brightness(1.1);
	outline: 2px solid var(--prs-ink);
	outline-offset: 2px;
}

@media (max-width: 900px) {
	.prs-schedule__topbar {
		padding: 13px 20px;
	}

}

@media (max-width: 680px) {
	.prs-schedule {
		border-radius: 13px;
	}

	.prs-schedule__topbar {
		align-items: center;
		justify-content: flex-end;
		padding: 12px 18px;
	}

	.prs-schedule__special-week {
		padding: 10px 18px;
		font-size: 11px;
	}

	.prs-schedule__day-tabs {
		display: flex;
	}


	.prs-schedule__grid {
		grid-template-columns: 56px minmax(0, 1fr);
		min-width: 0;
	}

	.prs-schedule__days {
		display: block;
	}

	.prs-schedule__day {
		display: none;
		border-right: 0;
	}

	.prs-schedule__day.is-mobile-visible {
		display: block;
	}

	.prs-schedule__corner,
	.prs-schedule__day-heading {
		height: 42px;
	}

	.prs-schedule__slot {
		left: 6px;
		right: 6px;
		padding: 8px 10px;
	}

	.prs-schedule__slot-title {
		font-size: 14px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.prs-schedule *,
	.prs-schedule *::before,
	.prs-schedule *::after {
		transition-duration: .01ms !important;
		scroll-behavior: auto !important;
	}
}
