/* Sports week calendar — index-page-final .week-banner */
.cn-sports-week-calendar.week-banner {
	background: #111827;
	padding: 0;
	overflow: hidden;
	display: grid;
	grid-template-columns: auto 1fr;
	margin-bottom: 0;
	width: 100%;
	max-width: 100%;
	--cn-swcal-date: #b4bcc8;
	--cn-swcal-meta: #9ca3af;
}

.cn-sports-week-calendar .week-label {
	background: #0f172a;
	padding: 20px 24px;
	border-right: 1px solid rgba(255, 255, 255, 0.08);
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.cn-sports-week-calendar .week-eyebrow {
	font-family: "DM Mono", "Courier New", monospace;
	font-size: 9px;
	color: #4ade80;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	margin-bottom: 4px;
}

.cn-sports-week-calendar .week-title {
	font-family: "Playfair Display", Georgia, serif;
	font-size: 16px;
	color: #fff;
	white-space: nowrap;
	margin: 0;
}

.cn-sports-week-calendar .week-cells {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
}

.cn-sports-week-calendar .week-cell {
	padding: 14px 16px;
	border-right: 1px solid rgba(255, 255, 255, 0.06);
	min-width: 0;
}

.cn-sports-week-calendar .week-cell:last-child {
	border-right: none;
}

.cn-sports-week-calendar .week-date {
	font-family: "DM Mono", "Courier New", monospace;
	font-size: 9px;
	color: var(--cn-swcal-date, #b4bcc8);
	letter-spacing: 0.06em;
	text-transform: uppercase;
	margin-bottom: 7px;
}

.cn-sports-week-calendar .week-event {
	font-size: 12px;
	font-weight: 500;
	color: #e5e7eb;
	margin-bottom: 3px;
	line-height: 1.3;
}

.cn-sports-week-calendar .week-sport {
	font-family: "DM Mono", "Courier New", monospace;
	font-size: 10px;
	color: var(--cn-swcal-meta, #9ca3af);
}

.cn-sports-week-calendar .cal-dot {
	width: 6px;
	height: 6px;
	border-radius: 50%;
	display: inline-block;
	margin-right: 5px;
	vertical-align: middle;
	flex-shrink: 0;
}

.cn-sports-week-calendar .dot-soccer {
	background: #2563eb;
}

.cn-sports-week-calendar .dot-f1 {
	background: #dc2626;
}

.cn-sports-week-calendar .dot-bball {
	background: #f97316;
}

.cn-sports-week-calendar .dot-horse {
	background: #16a34a;
}

.cn-sports-week-calendar .dot-tennis {
	background: #a855f7;
}

.cn-sports-week-calendar .dot-other {
	background: #9ca3af;
}

.cn-sports-week-calendar .week-event {
	display: flex;
	align-items: flex-start;
	gap: 0;
}

.cn-sports-week-calendar .week-empty {
	padding: 14px 16px;
	color: var(--cn-swcal-meta, #9ca3af);
	font-family: "DM Mono", "Courier New", monospace;
	font-size: 10px;
}

/* Continuous marquee when many fixtures in the week */
.cn-sports-week-calendar.week-banner--marquee {
	align-items: stretch;
}

.cn-sports-week-calendar .week-cells--marquee {
	display: block;
	min-width: 0;
	overflow: hidden;
}

.cn-sports-week-calendar .week-cells__viewport {
	overflow: hidden;
	width: 100%;
}

.cn-sports-week-calendar .week-cells__track {
	display: flex;
	width: max-content;
	animation: cn-sports-week-marquee var(--cn-sports-marquee-duration, 60s) linear infinite;
	will-change: transform;
}

.cn-sports-week-calendar .week-cells__viewport:hover .week-cells__track {
	animation-play-state: paused;
}

@keyframes cn-sports-week-marquee {
	0% {
		transform: translateX(0);
	}

	100% {
		transform: translateX(-50%);
	}
}

.cn-sports-week-calendar .week-cells--marquee .week-cell {
	flex: 0 0 auto;
	min-width: 168px;
	max-width: 220px;
	border-right: 1px solid rgba(255, 255, 255, 0.06);
}

.cn-sports-week-calendar .week-cells--marquee .week-cell:last-child {
	border-right: 1px solid rgba(255, 255, 255, 0.06);
}

@media (prefers-reduced-motion: reduce) {
	.cn-sports-week-calendar .week-cells__track {
		animation: none;
		flex-wrap: wrap;
		width: 100%;
	}

	.cn-sports-week-calendar .week-cells--marquee .week-cell {
		flex: 1 1 160px;
		max-width: none;
	}
}

@media (max-width: 900px) {
	.cn-sports-week-calendar.week-banner {
		grid-template-columns: 1fr;
	}

	.cn-sports-week-calendar .week-label {
		border-right: 0;
		border-bottom: 1px solid rgba(255, 255, 255, 0.08);
		padding: 16px 18px;
	}

	.cn-sports-week-calendar:not(.week-banner--marquee) .week-cells {
		display: flex;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		scrollbar-width: none;
	}

	.cn-sports-week-calendar:not(.week-banner--marquee) .week-cells::-webkit-scrollbar {
		display: none;
	}

	.cn-sports-week-calendar:not(.week-banner--marquee) .week-cell {
		flex: 0 0 min(72vw, 220px);
		border-right: 1px solid rgba(255, 255, 255, 0.06);
	}

	.cn-sports-week-calendar:not(.week-banner--marquee) .week-cell:last-child {
		border-right: none;
	}

	.cn-sports-week-calendar.week-banner--marquee .week-cells--marquee .week-cell {
		min-width: min(72vw, 200px);
	}
}

@media (max-width: 600px) {
	.cn-sports-week-calendar .week-title {
		white-space: normal;
		font-size: 15px;
	}
}
