.pb-0,
.py-0 {
	padding-bottom: 0 !important;
}
.wrapper {
	position: relative;
	max-width: 1280px;
	padding: 35px 30px;
	margin: 0 auto;
}
.wrapper * {
	box-sizing: border-box;
}
@media only screen and (max-width: 767px) {
	.wrapper {
		padding: 30px 16px;
	}
}
.section {
	position: relative;
	text-align: left;
	z-index: 10;
	width: 100%;
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
}
.section__title {
	position: relative;
	display: inline-block;
	font-size: 215%;
	font-weight: bold;
	padding-right: 25px;
	padding-left: 30px;
	transition: color 0.25s ease, background-image 0.25s ease;
}
.section__title.pad-left {
	padding-left: 30px;
}
.section__title:before {
	position: absolute;
	content: "";
	left: 0;
	top: 10px;
	width: 6px;
	height: calc(100% - 16px);
	background-color: #ff7400;
}
.section__title:after {
	position: absolute;
	content: "";
	right: 0;
	top: 2px;
	width: 13px;
	height: 100%;
	background: url(../images/icon/img_arrow_right.svg) no-repeat center;
	background-size: contain;
	transition: color 0.25s ease, background-image 0.25s ease;
}
.section__title.red-line:before {
	background-color: #990000;
}

.img-fluid {
	max-width: 100%;
	height: auto;
}

/* Schedule Section */
.schedule-banner {
	display: flex;
	flex-direction: row;
	align-items: center;
}
.schedule-banner > * {
	vertical-align: middle;
}
.schedule-banner-title {
	font-size: 24px;
	font-weight: bold;
	background: url(../images/icon/img_pattern-purple.svg) no-repeat center left;
	background-size: auto 80%;
	padding-left: 1.4em;
	white-space: nowrap;
}
.schedule-banner-btns {
	display: flex;
	justify-content: space-evenly;
	width: 100%;
}
.schedule-banner-btn {
	position: relative;
	display: inline-flex;
	flex-wrap: nowrap;
	align-items: center;
	justify-content: space-between;
	width: 30%;
	/* min-width: 200px; */
	max-width: 300px;
	height: 64px;
	margin: 10px;
	border-radius: 6px;
	padding: 6px 12px;
	color: #fff !important;
	background-color: #37272d;
	background-image: url(../images/icon/img_player_bg.svg), linear-gradient(180deg, rgba(255, 255, 255, 0.3) 0%, rgba(255, 255, 255, 0) 100%);
	background-position: center bottom;
	background-repeat: no-repeat;
	background-size: 100%;
	box-shadow: 0 2px 10px 0 rgba(0, 0, 0, 0.3);
}
@media only screen and (max-width: 900px) {
	.schedule-banner {
		align-items: flex-start;
		flex-direction: column;
	}
}
@media only screen and (max-width: 700px) {
	.schedule-banner-btn-left {
		display: none;
	}
	.schedule-banner-btn {
		justify-content: center;
	}
}
.schedule-banner-btn-left {
}
.schedule-banner-btn-right {
}
.schedule-banner-btn__title,
.schedule-banner-btn__content,
.schedule-banner-btn__logo {
	display: block;
}
.schedule-banner-btn__title {
	margin-bottom: 3px;
}
.schedule-banner-btn__content {
	font-size: 80%;
}
.schedule-banner-btn__logo {
	max-width: 100px;
}
.schedule-banner-btn:hover,
.schedule-banner-btn.active {
	color: #fff;
	text-decoration: none;
    background-color: #008b98;
    background: linear-gradient(0deg, rgba(30, 22, 22, 0) 0%, rgba(255, 255, 255, 0.3) 100%), linear-gradient(329.3deg, #008b98 30%, #008b98 100%);
    background-image: url(../images/icon/img_player_bg.svg), linear-gradient(0deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.3) 100%), linear-gradient(329.3deg, #008b98 30%, #008b98 100%);
	background-position: center bottom;
	background-repeat: no-repeat;
	background-size: 100%;
}

/* Table */
.schedule-table {
	/* width: 1240px; */
	font-size: 14px;
	font-weight: bold;
	letter-spacing: 0;
	line-height: 20px;
	overflow-x: auto;

	padding: 20px;

	display: grid;
	grid-template-columns: repeat(7, 168px);
	grid-template-rows: 90px repeat(48, minmax(30px, min-content));
	gap: 0px 10px;
	grid-auto-flow: row;
}
.schedule-table a {
	color: inherit;
	text-decoration: none;
}
.schedule-table > div span {
	display: block;
}

/* General */
.schedule-table > div {
	color: #231f20;
	background-color: #e6ebf1;
	padding: 18px;
}
.schedule-table > .even {
	background-color: #f2f3f7;
}
.schedule-table > .day-header {
	background-color: #d2d8e8 !important;
}
.schedule-table > :not(.day-header) {
	/* background-image: linear-gradient(180deg, rgba(255, 255, 255, 0), rgba(255, 255, 255, 0.5)); */
	border-top: 1px solid #e5e5e5;
}
.schedule-table > .link {
	cursor: pointer;
}
.schedule-table > .link:hover {
	transform: scale(1.06);
	border-radius: 6px !important;
	box-shadow: 0 0 12px;
	z-index: 99;
}
.schedule-table > :not(.day-footer) {
}
.schedule-table > .day-footer {
	/* border: 1px solid #e5e5e5; */
}
.schedule-table > .day-header > :first-child {
	font-size: 24px;
	line-height: 35px;
}
.schedule-table > div > .prog-title {
	font-size: 16px;
	line-height: 24px;
	margin-bottom: 2px;
}
.schedule-table > div span {
	display: block;
	font-size: 12px;
	line-height: 18px;
}
.schedule-table > div > .prog-hosts {
	color: #575757;
	display: flex;
	flex-wrap: wrap;
	gap: 0 0.5em;
}
.schedule-table > div > .prog-hosts span {
	display: inline;
}
.schedule-table > div > .prog-time {
	color: #575757;
	font-size: 14px;
	line-height: 20px;
	margin-top: 2px;
}

/* Today */
.schedule-table > .today {
	background-color: #ffffff !important;
}
.schedule-table > .day-header.today {
	border-radius: 6px 6px 0 0;
}
.schedule-table > .day-footer.today {
	border-radius: 0 0 6px 6px;
}
.schedule-table > .day-header.today > :first-child {
	color: #ef4123;
}
.schedule-table > .day-header.today > :first-child + span::after {
	content: "Today";
	font-size: 12px;
	padding: 2px 6px;
	margin: 0 10px;
	color: #ffffff;
	background-color: #ef4123;
	border-radius: 2px;
}
.schedule-table > .today.active {
	position: relative;
	/* border-color: #3e2f34; */
	border: none;
	background: linear-gradient(180deg, #3e2f34 0%, #6f6367 100%);
}
.schedule-table > .today.active * {
	color: #ffffff;
}
.schedule-table > .today.active::before {
	position: absolute;
	top: 0;
	left: 0;
	width: 50px;
	height: 22px;
	background: url(../images/icon/icon_timetable_live.svg) bottom right no-repeat;
	content: "";
}
.schedule-table > .today.active:hover::before {
	border-radius: 6px 0 0 0;
}
.schedule-table > .today-shadow {
	z-index: -1;
	color: #717171;
	border-radius: 6px;
	box-shadow: 0 0 8px;

	grid-area: 1 / 1 / -1 / span 1;
}

/* Weekend */
.schedule-table > .weekend {
	background-color: #f2e6e6;
}
.schedule-table > .weekend.even {
	background-color: #f7eeef;
}
.schedule-table > .day-header.weekend {
	background-color: #e6d1d0 !important;
}

/* Loading Spinner */
.schedule-table .loading {
	width: 100%;
	height: 200px;
	grid-column: 1 / -1;
	align-content: center;
	text-align: center;
	border: none !important;
	background-color: inherit;
	background-image: none !important;
}
.gg-spinner {
	transform: scale(var(--ggs, 1));
}

.gg-spinner,
.gg-spinner::after,
.gg-spinner::before {
	box-sizing: border-box;
	position: relative;
	display: inline-block;
	width: 20px;
	height: 20px;
}

.gg-spinner::after,
.gg-spinner::before {
	content: "";
	position: absolute;
	border-radius: 100px;
}

.gg-spinner::before {
	animation: spinner 1s cubic-bezier(0.6, 0, 0.4, 1) infinite;
	border: 3px solid transparent;
	border-top-color: currentColor;
}

.gg-spinner::after {
	border: 3px solid;
	opacity: 0.2;
}

@keyframes spinner {
	0% {
		transform: rotate(0deg);
	}
	to {
		transform: rotate(359deg);
	}
}
