/**
 * SSCC Events — frontend styles
 * All classes are namespaced with `.sscc-` so they won't leak into the theme.
 */

/* =========================================
 * Brand tokens (CSS variables)
 * ========================================= */
.sscc-events {
	--sscc-brand: #2d3776;
	--sscc-brand-dark: #1f2858;
	--sscc-brand-light: #4650a0;
	--sscc-brand-soft: #eef0fa;
	--sscc-accent: #e4b55d;
	--sscc-accent-dark: #c89a45;
	--sscc-text: #1f2937;
	--sscc-muted: #6b7280;
	--sscc-border: #e5e7eb;
	--sscc-border-strong: #d1d5db;
	--sscc-bg: #ffffff;
	--sscc-bg-soft: #f9fafb;
	--sscc-bg-today: var(--sscc-brand-soft);
	--sscc-today-ring: var(--sscc-brand);
	color: var(--sscc-text);
	font-family: inherit;
}

/* =========================================
 * Legacy grid / list event cards
 * ========================================= */
.sscc-events--grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 24px;
}

.sscc-events--list {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.sscc-events--empty p {
	background: var(--sscc-bg-soft);
	border: 1px dashed var(--sscc-border);
	border-radius: 8px;
	padding: 24px;
	text-align: center;
	color: var(--sscc-muted);
}

.sscc-event-card {
	background: var(--sscc-bg);
	border: 1px solid var(--sscc-border);
	border-radius: 12px;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: box-shadow 0.2s ease, transform 0.2s ease;
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
}

.sscc-event-card:hover {
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
	transform: translateY(-2px);
}

.sscc-event-card.is-featured { border-color: var(--sscc-accent); }
.sscc-event-card__image {
	position: relative;
	display: block;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background: var(--sscc-bg-soft);
}
.sscc-event-card__image img { width: 100%; height: 100%; object-fit: cover; display: block; }
.sscc-event-card__body { padding: 16px; display: flex; flex-direction: column; gap: 10px; flex: 1; }
.sscc-event-card__title { margin: 0; font-size: 1.15rem; line-height: 1.3; }
.sscc-event-card__title a { color: inherit; text-decoration: none; }
.sscc-event-card__title a:hover { color: var(--sscc-brand); }
.sscc-event-card__desc { margin: 0; color: var(--sscc-muted); font-size: 0.95rem; line-height: 1.45; }
.sscc-event-card__actions { margin-top: auto; display: flex; flex-wrap: wrap; gap: 8px; }

.sscc-event-row {
	display: flex;
	gap: 16px;
	background: var(--sscc-bg);
	border: 1px solid var(--sscc-border);
	border-radius: 12px;
	padding: 16px;
	align-items: stretch;
}
.sscc-event-row.is-featured { border-color: var(--sscc-accent); }
.sscc-event-row__image { flex: 0 0 200px; max-width: 200px; display: block; border-radius: 8px; overflow: hidden; background: var(--sscc-bg-soft); }
.sscc-event-row__image img { width: 100%; height: 100%; object-fit: cover; display: block; }
.sscc-event-row__body { display: flex; flex-direction: column; gap: 8px; flex: 1; min-width: 0; }
.sscc-event-row__header { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.sscc-event-row__title { margin: 0; font-size: 1.2rem; }
.sscc-event-row__title a { color: inherit; text-decoration: none; }
.sscc-event-row__title a:hover { color: var(--sscc-brand); }
.sscc-event-row__desc { margin: 0; color: var(--sscc-muted); font-size: 0.95rem; line-height: 1.5; }
.sscc-event-row__actions { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 4px; }

@media (max-width: 640px) {
	.sscc-event-row { flex-direction: column; }
	.sscc-event-row__image { flex: 1; max-width: 100%; aspect-ratio: 16 / 9; }
}

.sscc-event-meta {
	list-style: none; padding: 0; margin: 0;
	display: flex; flex-wrap: wrap; gap: 10px 16px;
	font-size: 0.9rem; color: var(--sscc-muted);
}
.sscc-event-meta__item { display: inline-flex; align-items: center; gap: 6px; }
.sscc-event-meta--single {
	font-size: 1rem; margin: 12px 0 24px; padding: 16px;
	background: var(--sscc-bg-soft); border-radius: 8px; color: var(--sscc-text);
}
.sscc-event-meta--single .sscc-event-meta__item { display: block; margin-bottom: 4px; }

.sscc-badge {
	display: inline-block; padding: 3px 10px; border-radius: 999px;
	font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.04em;
	background: #e5e7eb; color: #374151;
}
.sscc-event-card__image .sscc-badge { position: absolute; top: 10px; left: 10px; }
.sscc-event-card__image .sscc-badge + .sscc-badge { top: 10px; left: auto; right: 10px; }
.sscc-badge--featured { background: var(--sscc-accent); color: #1a1a1a; }
.sscc-badge--sold_out { background: #fff3cd; color: #856404; }
.sscc-badge--cancelled { background: #f8d7da; color: #721c24; }

.sscc-btn {
	display: inline-flex; align-items: center; justify-content: center; gap: 6px;
	padding: 10px 16px; min-height: 42px; border-radius: 8px;
	font-size: 0.9rem; font-weight: 600; text-decoration: none;
	cursor: pointer; border: 1px solid transparent; line-height: 1.2;
	transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease, transform 0.15s ease;
	-webkit-tap-highlight-color: transparent;
}
.sscc-btn:active { transform: translateY(1px); }
.sscc-btn--primary { background: var(--sscc-brand); color: #fff; box-shadow: 0 1px 2px rgba(31, 40, 88, 0.25); }
.sscc-btn--primary:hover { background: var(--sscc-brand-dark); color: #fff; }
.sscc-btn--secondary { background: #fff; color: var(--sscc-text); border-color: var(--sscc-border-strong); }
.sscc-btn--secondary:hover { background: var(--sscc-bg-soft); }
.sscc-btn--facebook { background: #1877f2; color: #fff; }
.sscc-btn--facebook:hover { background: #145dbf; color: #fff; }
.sscc-btn--calendar { background: #fff; color: var(--sscc-brand); border-color: var(--sscc-brand); }
.sscc-btn--calendar:hover { background: var(--sscc-brand); color: #fff; }
.sscc-btn--large { padding: 14px 24px; font-size: 1rem; min-height: 52px; }

/* =========================================
 * Single event page (redesigned)
 * ========================================= */
.sscc-se {
	max-width: 1120px;
	margin: 0 auto;
	padding: 0 0 60px;
}

/* --- Hero with background image --- */
.sscc-se__hero {
	position: relative;
	min-height: 340px;
	background-image: var(--sscc-se-bg);
	background-size: cover;
	background-position: center;
	border-radius: 0 0 24px 24px;
	overflow: hidden;
	margin-bottom: 32px;
	color: #fff;
	isolation: isolate;
}

.sscc-se__hero-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(
		180deg,
		rgba(31, 40, 88, 0.2) 0%,
		rgba(31, 40, 88, 0.6) 60%,
		rgba(31, 40, 88, 0.82) 100%
	);
	z-index: 1;
}

.sscc-se__hero-inner {
	position: relative;
	z-index: 2;
	max-width: 1120px;
	margin: 0 auto;
	padding: 28px 24px 36px;
	min-height: 340px;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	gap: 14px;
}

.sscc-se__hero-title {
	margin: 0;
	font-size: clamp(1.6rem, 3.6vw, 2.3rem);
	font-weight: 700;
	line-height: 1.15;
	color: #fff;
	letter-spacing: -0.01em;
	text-shadow: 0 2px 14px rgba(0, 0, 0, 0.28);
}

.sscc-se__hero-when {
	margin: 0;
	font-size: 1rem;
	color: rgba(255, 255, 255, 0.95);
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	align-items: center;
}

/* --- Plain header (no image) --- */
.sscc-se__header--no-image {
	background: linear-gradient(135deg, var(--sscc-brand) 0%, var(--sscc-brand-dark) 100%);
	color: #fff;
	border-radius: 0 0 24px 24px;
	padding: 40px 24px;
	margin-bottom: 32px;
	max-width: 1120px;
	margin-left: auto;
	margin-right: auto;
	display: flex;
	flex-direction: column;
	gap: 14px;
}

.sscc-se__header--no-image .sscc-se__title {
	margin: 0;
	font-size: clamp(1.6rem, 4vw, 2.3rem);
	font-weight: 800;
	line-height: 1.1;
	color: #fff;
}

/* --- Back link --- */
.sscc-se__back {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	color: rgba(255, 255, 255, 0.9);
	text-decoration: none;
	font-size: 0.9rem;
	font-weight: 600;
	padding: 8px 14px;
	background: rgba(255, 255, 255, 0.12);
	border-radius: 999px;
	align-self: flex-start;
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
	min-height: 36px;
	transition: background 0.15s ease, color 0.15s ease;
}

.sscc-se__back:hover {
	background: rgba(255, 255, 255, 0.22);
	color: #fff;
}

/* --- Badges (hero) --- */
.sscc-se__hero-badges {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}

.sscc-se__badge {
	display: inline-flex;
	align-items: center;
	padding: 4px 12px;
	border-radius: 999px;
	font-size: 0.68rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	background: rgba(255, 255, 255, 0.18);
	color: #fff;
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
	border: 1px solid rgba(255, 255, 255, 0.22);
}

.sscc-se__badge--category {
	background: var(--sscc-color, rgba(255, 255, 255, 0.22));
	color: #fff;
}

.sscc-se__badge--featured {
	background: var(--sscc-accent);
	color: #2b1f00;
}

.sscc-se__badge--sold_out { background: #fff3cd; color: #856404; }
.sscc-se__badge--cancelled { background: #f8d7da; color: #721c24; }

/* --- Layout grid --- */
.sscc-se__layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 340px;
	gap: 40px;
	padding: 0 24px;
}

.sscc-se__content {
	min-width: 0;
}

.sscc-se__lead {
	font-size: 1.15rem;
	line-height: 1.55;
	color: var(--sscc-text);
	font-weight: 500;
	margin: 0 0 24px;
	padding-left: 16px;
	border-left: 4px solid var(--sscc-color, var(--sscc-brand));
}

.sscc-se__body {
	font-size: 1.05rem;
	line-height: 1.7;
	color: var(--sscc-text);
}

.sscc-se__body p { margin: 0 0 1em; }
.sscc-se__body img { max-width: 100%; height: auto; border-radius: 8px; }
.sscc-se__body h2 { font-size: 1.5rem; margin: 1.8em 0 0.5em; line-height: 1.3; }
.sscc-se__body h3 { font-size: 1.2rem; margin: 1.5em 0 0.5em; line-height: 1.3; }
.sscc-se__body ul, .sscc-se__body ol { margin: 0 0 1em 1.2em; }
.sscc-se__body ul li, .sscc-se__body ol li { margin-bottom: 0.3em; }
.sscc-se__body a { color: var(--sscc-brand); text-decoration: underline; }
.sscc-se__body a:hover { color: var(--sscc-brand-dark); }
.sscc-se__body blockquote {
	margin: 1.5em 0;
	padding: 1em 1.2em;
	background: var(--sscc-brand-soft);
	border-left: 4px solid var(--sscc-brand);
	border-radius: 0 8px 8px 0;
	font-style: italic;
	color: var(--sscc-text);
}

.sscc-se__cta-inline {
	margin: 32px 0;
}

/* --- Share section --- */
.sscc-se__share {
	margin-top: 40px;
	padding-top: 24px;
	border-top: 1px solid var(--sscc-border);
}

.sscc-se__share-title {
	margin: 0 0 14px;
	font-size: 0.72rem;
	font-weight: 700;
	color: var(--sscc-muted);
	text-transform: uppercase;
	letter-spacing: 0.16em;
	position: relative;
	padding-bottom: 12px;
}

.sscc-se__share-title::after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	width: 24px;
	height: 1.5px;
	background: var(--sscc-accent);
}

.sscc-se__share-buttons {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.sscc-se__share-buttons .sscc-btn {
	gap: 8px;
}

/* --- Sidebar card --- */
.sscc-se__sidebar {
	position: relative;
}

.sscc-se__card {
	position: sticky;
	top: 24px;
	background: #fff;
	border: 1px solid var(--sscc-border);
	border-top: 2px solid var(--sscc-color, var(--sscc-brand));
	border-radius: 10px;
	padding: 26px 24px 24px;
	box-shadow: 0 2px 8px rgba(17, 24, 39, 0.04);
}

.sscc-se__card-title {
	margin: 0 0 20px;
	font-size: 0.68rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.16em;
	color: var(--sscc-muted);
	position: relative;
	padding-bottom: 14px;
}

.sscc-se__card-title::after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	width: 24px;
	height: 1.5px;
	background: var(--sscc-accent);
}

.sscc-se__facts {
	list-style: none;
	padding: 0;
	margin: 0 0 22px;
	display: flex;
	flex-direction: column;
	gap: 14px;
}

.sscc-se__fact {
	display: flex;
	gap: 12px;
	align-items: flex-start;
}

.sscc-se__fact-icon {
	width: 32px;
	height: 32px;
	flex-shrink: 0;
	border-radius: 6px;
	background: var(--sscc-brand-soft);
	color: var(--sscc-brand);
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.sscc-se__fact > div {
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
}

.sscc-se__fact-label {
	font-size: 0.66rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	color: var(--sscc-muted);
}

.sscc-se__fact-value {
	font-size: 0.92rem;
	font-weight: 500;
	color: var(--sscc-text);
	word-break: break-word;
	letter-spacing: -0.005em;
}

.sscc-se__card-section {
	margin-top: 18px;
	padding-top: 18px;
	border-top: 1px solid var(--sscc-border);
}

.sscc-se__card-subtitle {
	margin: 0 0 10px;
	font-size: 0.78rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--sscc-muted);
}

.sscc-se__card-buttons {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.sscc-btn--block {
	display: flex;
	width: 100%;
}

/* --- Mobile sticky CTA bar --- */
.sscc-se__sticky-cta {
	display: none;
	position: fixed;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 100;
	background: #fff;
	border-top: 1px solid var(--sscc-border);
	box-shadow: 0 -4px 16px rgba(17, 24, 39, 0.08);
	padding: 10px 16px calc(10px + env(safe-area-inset-bottom));
}

.sscc-se__sticky-cta-inner {
	display: flex;
	align-items: center;
	gap: 12px;
	max-width: 1120px;
	margin: 0 auto;
}

.sscc-se__sticky-cta-text {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	line-height: 1.25;
	font-size: 0.85rem;
	color: var(--sscc-muted);
}

.sscc-se__sticky-cta-text strong {
	color: var(--sscc-text);
	font-size: 0.95rem;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.sscc-se__sticky-cta .sscc-btn {
	flex-shrink: 0;
}

/* --- Responsive breakpoints --- */
@media (max-width: 960px) {
	.sscc-se__layout {
		grid-template-columns: 1fr;
		gap: 28px;
	}
	.sscc-se__card { position: static; }
	.sscc-se__sidebar { order: -1; } /* show event details above the description on mobile */
}

@media (max-width: 720px) {
	.sscc-se__hero {
		min-height: 260px;
		border-radius: 0;
	}
	.sscc-se__hero-inner {
		min-height: 260px;
		padding: 20px 16px 24px;
	}
	.sscc-se__header--no-image {
		padding: 28px 16px;
		border-radius: 0;
	}
	.sscc-se__layout {
		padding: 0 16px;
	}
	.sscc-se__card {
		padding: 18px;
	}
	.sscc-se__sticky-cta { display: block; }
	.sscc-se { padding-bottom: 96px; }
	.sscc-se__cta-inline { display: none; } /* the sticky bar replaces it on mobile */
}

@media (max-width: 420px) {
	.sscc-se__hero-title { font-size: 1.5rem; }
	.sscc-se__lead { font-size: 1rem; padding-left: 12px; }
	.sscc-se__body { font-size: 1rem; }
	.sscc-se__share-buttons .sscc-btn {
		flex: 1;
		min-width: calc(50% - 4px);
	}
}

/* =========================================
 * Legacy single-event classes (kept for theme-template back-compat)
 * ========================================= */
.sscc-single-event-wrap { max-width: 840px; margin: 0 auto; padding: 24px 16px 48px; }
.sscc-single-event__image { border-radius: 12px; overflow: hidden; margin-bottom: 20px; aspect-ratio: 16 / 9; background: var(--sscc-bg-soft); }
.sscc-single-event__image img { width: 100%; height: 100%; object-fit: cover; display: block; }
.sscc-single-event__title { margin: 0 0 6px; font-size: 2rem; line-height: 1.15; }
.sscc-single-event__badges { display: flex; gap: 6px; margin-bottom: 16px; flex-wrap: wrap; }
.sscc-single-event__content { font-size: 1.05rem; line-height: 1.6; }
.sscc-single-event__cta { margin: 24px 0; }
.sscc-single-event__actions {
	display: flex; flex-wrap: wrap; gap: 8px;
	margin-top: 32px; padding-top: 20px; border-top: 1px solid var(--sscc-border);
}

/* =========================================
 * Calendar wrapper — refined, elegant
 * ========================================= */
.sscc-cal {
	background: var(--sscc-bg);
	border: 1px solid var(--sscc-border);
	border-radius: 10px;
	overflow: hidden;
}

.sscc-cal__toolbar {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
	gap: 16px;
	padding: 14px 20px;
	background: var(--sscc-bg);
	border-bottom: 1px solid var(--sscc-border);
}

.sscc-cal__toolbar-left {
	display: flex;
	gap: 8px;
	align-items: center;
	justify-content: flex-start;
}

.sscc-cal__toolbar-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 32px;
	padding: 0 12px;
	border: 1px solid var(--sscc-border);
	background: #fff;
	color: var(--sscc-text);
	font-size: 0.82rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	text-decoration: none;
	border-radius: 6px;
	transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
	line-height: 1;
}

.sscc-cal__toolbar-btn:hover {
	background: var(--sscc-bg-soft);
	color: var(--sscc-brand);
	border-color: var(--sscc-border-strong);
}

.sscc-cal__toolbar-btn--today {
	font-weight: 600;
}

.sscc-cal__nav-group {
	display: inline-flex;
	border-radius: 6px;
	overflow: hidden;
	border: 1px solid var(--sscc-border);
}

.sscc-cal__nav-group .sscc-cal__toolbar-btn--nav {
	width: 32px;
	padding: 0;
	font-size: 1rem;
	font-weight: 600;
	border: none;
	border-radius: 0;
	color: var(--sscc-muted);
}

.sscc-cal__nav-group .sscc-cal__toolbar-btn--nav:hover {
	color: var(--sscc-brand);
	background: var(--sscc-bg-soft);
}

.sscc-cal__nav-group .sscc-cal__toolbar-btn--nav + .sscc-cal__toolbar-btn--nav {
	border-left: 1px solid var(--sscc-border);
}

.sscc-cal__range-label {
	margin: 0;
	font-size: 1.05rem;
	font-weight: 600;
	color: var(--sscc-text);
	text-align: center;
	letter-spacing: -0.005em;
}

/* --- View tabs: understated text-with-underline style --- */
.sscc-cal__views {
	display: inline-flex;
	justify-self: end;
	border: 0;
	border-radius: 0;
	overflow: visible;
	gap: 2px;
}

.sscc-cal__view-tab {
	padding: 0 12px;
	height: 32px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 0.78rem;
	font-weight: 600;
	color: var(--sscc-muted);
	text-decoration: none;
	background: transparent;
	border: 0;
	border-bottom: 2px solid transparent;
	border-radius: 0;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	transition: color 0.15s ease, border-color 0.15s ease;
}

.sscc-cal__view-tab:last-child { border-right: none; }

.sscc-cal__view-tab:hover {
	color: var(--sscc-brand);
	background: transparent;
}

.sscc-cal__view-tab.is-active {
	color: var(--sscc-brand);
	background: transparent;
	border-bottom-color: var(--sscc-accent);
}

.sscc-cal__body { background: var(--sscc-bg); }

.sscc-cal--week .sscc-cal__body,
.sscc-cal--day .sscc-cal__body {
	max-height: min(720px, 72vh);
	overflow-y: auto;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	overscroll-behavior: contain;
	scroll-behavior: smooth;
}

/* Thin, subtle scrollbars so users see they can swipe */
.sscc-cal--week .sscc-cal__body::-webkit-scrollbar,
.sscc-cal--day .sscc-cal__body::-webkit-scrollbar {
	width: 8px;
	height: 8px;
}
.sscc-cal--week .sscc-cal__body::-webkit-scrollbar-thumb,
.sscc-cal--day .sscc-cal__body::-webkit-scrollbar-thumb {
	background: #c7cbdd;
	border-radius: 4px;
}
.sscc-cal--week .sscc-cal__body::-webkit-scrollbar-thumb:hover,
.sscc-cal--day .sscc-cal__body::-webkit-scrollbar-thumb:hover {
	background: var(--sscc-brand-light);
}

/* Small screens — stack toolbar */
@media (max-width: 720px) {
	.sscc-cal__toolbar {
		grid-template-columns: 1fr;
		row-gap: 10px;
		padding: 12px;
	}
	.sscc-cal__toolbar-left { justify-content: center; }
	.sscc-cal__range-label { font-size: 1rem; }
	.sscc-cal__views {
		justify-self: center;
		border-top: 1px solid var(--sscc-border);
		padding-top: 8px;
		margin-top: 2px;
		gap: 14px;
	}
	.sscc-cal__view-tab {
		padding: 0 2px;
		font-size: 0.72rem;
	}
	.sscc-cal__toolbar-btn { height: 36px; }
	.sscc-cal__nav-group .sscc-cal__toolbar-btn--nav { width: 36px; }
}

@media (max-width: 400px) {
	.sscc-cal__view-tab { font-size: 0.68rem; }
	.sscc-cal__range-label { font-size: 0.92rem; }
}

/* =========================================
 * Month view
 * ========================================= */
.sscc-month__weekdays {
	display: grid;
	grid-template-columns: repeat(7, 1fr);
	background: #fff;
	border-bottom: 1px solid var(--sscc-border);
}

.sscc-month__weekday {
	padding: 12px 6px;
	text-align: center;
	font-size: 0.68rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.16em;
	color: var(--sscc-muted);
}

.sscc-month__grid {
	display: grid;
	grid-template-columns: repeat(7, 1fr);
	gap: 1px;
	background: var(--sscc-border);
}

.sscc-month__cell {
	background: var(--sscc-bg);
	min-height: 110px;
	padding: 6px;
	display: flex;
	flex-direction: column;
	gap: 4px;
	position: relative;
}

.sscc-month__cell.is-out-month { background: var(--sscc-bg-soft); color: #9ca3af; }
.sscc-month__cell.is-out-month .sscc-month__daynum { color: #9ca3af; }

.sscc-month__cell.is-today { background: var(--sscc-bg-today); }
.sscc-month__cell.is-today .sscc-month__daynum {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--sscc-today-ring);
	color: #fff;
	width: 24px;
	height: 24px;
	border-radius: 50%;
	font-weight: 600;
	font-size: 0.82rem;
}

.sscc-month__cell-header { display: flex; align-items: center; justify-content: flex-end; }
.sscc-month__daynum {
	font-size: 0.85rem;
	font-weight: 500;
	color: var(--sscc-muted);
	padding: 2px 6px;
}

.sscc-month__events {
	list-style: none; padding: 0; margin: 0;
	display: flex; flex-direction: column; gap: 3px;
}

.sscc-month__event { line-height: 1.2; }

.sscc-month__event-link {
	display: flex;
	align-items: center;
	gap: 6px;
	padding: 3px 6px 3px 8px;
	border-radius: 3px;
	text-decoration: none;
	background: transparent;
	color: var(--sscc-text);
	border-left: 2px solid var(--sscc-color);
	transition: background 0.15s ease;
	min-width: 0;
}

.sscc-month__event-link:hover {
	background: color-mix(in srgb, var(--sscc-color) 10%, #ffffff);
	color: var(--sscc-text);
}

.sscc-month__event-time {
	font-size: 0.68rem;
	font-weight: 600;
	white-space: nowrap;
	color: var(--sscc-color);
}

.sscc-month__event-title {
	font-size: 0.74rem;
	font-weight: 500;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	color: var(--sscc-text);
}

.sscc-month__more { position: relative; }
.sscc-month__more-btn {
	background: transparent; border: none; padding: 2px 6px;
	font-size: 0.75rem; font-weight: 600; color: var(--sscc-muted);
	cursor: pointer; border-radius: 4px;
}
.sscc-month__more-btn:hover { background: var(--sscc-bg-soft); color: var(--sscc-text); }

.sscc-cal__popover {
	position: absolute; top: 100%; left: 50%;
	transform: translateX(-50%); z-index: 20;
	background: #fff; border: 1px solid var(--sscc-border);
	border-radius: 10px; box-shadow: 0 12px 32px rgba(31, 40, 88, 0.18);
	padding: 12px; min-width: 220px;
	max-width: min(320px, calc(100vw - 32px));
	max-height: 60vh;
	overflow-y: auto;
}

/* On small screens anchor the popover to the bottom of the screen instead of
 * to the cell, so it always fits and is thumb-reachable. */
@media (max-width: 560px) {
	.sscc-cal__popover {
		position: fixed;
		top: auto;
		bottom: 16px;
		left: 16px;
		right: 16px;
		transform: none;
		max-width: none;
		max-height: 70vh;
		z-index: 200;
		box-shadow: 0 -4px 32px rgba(31, 40, 88, 0.28);
	}
	.sscc-month__more { position: static; }
}
.sscc-cal__popover[hidden] { display: none; }
.sscc-cal__popover-title { margin: 0 0 6px; font-size: 0.9rem; }
.sscc-cal__popover-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 4px; }
.sscc-cal__popover-list li { border-left: 3px solid var(--sscc-color); padding-left: 8px; }
.sscc-cal__popover-list a {
	display: block; padding: 4px 6px; border-radius: 4px;
	text-decoration: none; color: var(--sscc-text); font-size: 0.85rem;
}
.sscc-cal__popover-list a:hover { background: var(--sscc-bg-soft); color: var(--sscc-brand); }

@media (max-width: 720px) {
	.sscc-month__cell { min-height: 84px; padding: 4px; }
	.sscc-month__event-title, .sscc-month__event-time { font-size: 0.72rem; }
	.sscc-month__weekday { font-size: 0.68rem; padding: 8px 2px; }
	.sscc-month__event-link { padding: 5px 6px; min-height: 28px; }
	.sscc-month__more-btn { padding: 4px 8px; min-height: 28px; font-size: 0.78rem; }
}

/* Very narrow screens — hide event titles, keep a colored dot per event.
 * Tapping the cell's "+N more" or an event link still opens the full list. */
@media (max-width: 430px) {
	.sscc-month__event-link {
		padding: 3px 5px;
		gap: 4px;
	}
	.sscc-month__event-time { display: none; }
	.sscc-month__event-title { font-size: 0.68rem; }
}

/* =========================================
 * Week & Day views (time grid)
 * ========================================= */
.sscc-week, .sscc-day {
	--sscc-hour-h: 52px;
	--sscc-day-cols: 7;
	--sscc-gutter-w: 64px;
}

.sscc-day { --sscc-day-cols: 1; }

.sscc-week__head,
.sscc-day__head {
	display: grid;
	grid-template-columns: var(--sscc-gutter-w) repeat(var(--sscc-day-cols), 1fr);
	border-bottom: 1px solid var(--sscc-border);
	background: #fff;
	position: sticky;
	top: 0;
	z-index: 10;
}


.sscc-week__gutter {
	background: #fff;
	border-right: 1px solid var(--sscc-border);
}

.sscc-week__gutter--head { min-height: 60px; }
.sscc-week__gutter--allday {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	padding: 6px 10px;
	font-size: 0.72rem;
	font-weight: 600;
	text-transform: uppercase;
	color: var(--sscc-muted);
	letter-spacing: 0.04em;
}

.sscc-week__day-head {
	padding: 10px 6px;
	text-align: center;
	border-right: 1px solid var(--sscc-border);
	display: flex;
	flex-direction: column;
	gap: 4px;
	align-items: center;
	justify-content: center;
	font-size: 0.82rem;
	color: var(--sscc-muted);
}

.sscc-week__day-head:last-child { border-right: none; }

.sscc-week__day-head.is-today { color: var(--sscc-today-ring); }

.sscc-week__day-name {
	text-transform: uppercase;
	font-weight: 600;
	font-size: 0.72rem;
	letter-spacing: 0.06em;
}

.sscc-week__day-num {
	font-size: 1.4rem;
	font-weight: 700;
	color: var(--sscc-text);
	line-height: 1;
	padding: 4px;
}

.sscc-week__day-num.is-today {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 34px;
	height: 34px;
	border-radius: 50%;
	background: var(--sscc-today-ring);
	color: #fff;
}

.sscc-week__allday-row {
	display: grid;
	grid-template-columns: var(--sscc-gutter-w) repeat(var(--sscc-day-cols), 1fr);
	background: var(--sscc-bg-soft);
	border-bottom: 1px solid var(--sscc-border);
	min-height: 34px;
}

.sscc-week__allday-cell {
	border-right: 1px solid var(--sscc-border);
	padding: 4px 4px;
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.sscc-week__allday-cell:last-child { border-right: none; }

.sscc-week__allday-event {
	font-size: 0.74rem;
	font-weight: 600;
	color: var(--sscc-text);
	background: color-mix(in srgb, var(--sscc-color, var(--sscc-brand)) 14%, #ffffff);
	border-left: 3px solid var(--sscc-color, var(--sscc-brand));
	border-radius: 4px;
	padding: 3px 8px;
	text-decoration: none;
	line-height: 1.2;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	transition: background 0.15s ease;
}

.sscc-week__allday-event:hover {
	color: var(--sscc-text);
	background: color-mix(in srgb, var(--sscc-color, var(--sscc-brand)) 24%, #ffffff);
}

.sscc-week__grid {
	display: grid;
	grid-template-columns: var(--sscc-gutter-w) repeat(var(--sscc-day-cols), 1fr);
	position: relative;
}

.sscc-week__hours {
	border-right: 1px solid var(--sscc-border);
	background: #fff;
	display: flex;
	flex-direction: column;
	position: sticky;
	left: 0;
	z-index: 4;
}

/* Make the head/all-day gutter cells sticky-left too so they align with the
 * hour column during horizontal scroll. */
.sscc-week__head .sscc-week__gutter,
.sscc-week__allday-row .sscc-week__gutter {
	position: sticky;
	left: 0;
	z-index: 12;
	background: #fff;
}

.sscc-week__hour-label {
	height: var(--sscc-hour-h);
	padding: 4px 8px 0 0;
	text-align: right;
	font-size: 0.72rem;
	color: var(--sscc-muted);
	font-weight: 500;
	border-top: 1px solid transparent;
	box-sizing: border-box;
}

.sscc-week__day-col {
	position: relative;
	height: calc(var(--sscc-hour-h) * var(--sscc-rows, 1));
	border-right: 1px solid var(--sscc-border);
	background:
		repeating-linear-gradient(
			to bottom,
			transparent 0,
			transparent calc(var(--sscc-hour-h) - 1px),
			var(--sscc-border) calc(var(--sscc-hour-h) - 1px),
			var(--sscc-border) var(--sscc-hour-h)
		);
}

.sscc-week__day-col:last-child { border-right: none; }

.sscc-week__day-col.is-today { background-color: rgba(37, 99, 235, 0.04); background-blend-mode: multiply; }

.sscc-week__event {
	position: absolute;
	background: color-mix(in srgb, var(--sscc-color, var(--sscc-brand)) 12%, #ffffff);
	color: var(--sscc-text);
	border-radius: 4px;
	border-left: 3px solid var(--sscc-color, var(--sscc-brand));
	padding: 4px 8px;
	text-decoration: none;
	font-size: 0.72rem;
	line-height: 1.2;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	gap: 1px;
	transition: background 0.15s ease, transform 0.15s ease, box-shadow 0.15s ease;
	z-index: 2;
	min-height: 22px;
}

.sscc-week__event:hover {
	background: color-mix(in srgb, var(--sscc-color, var(--sscc-brand)) 22%, #ffffff);
	color: var(--sscc-text);
	z-index: 5;
	box-shadow: 0 2px 8px rgba(45, 55, 118, 0.12);
}

.sscc-week__event-time {
	font-weight: 600;
	font-size: 0.68rem;
	color: var(--sscc-color, var(--sscc-brand));
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	letter-spacing: 0.01em;
}

.sscc-week__event-title {
	font-weight: 600;
	font-size: 0.76rem;
	color: var(--sscc-text);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.sscc-week__event-loc {
	font-size: 0.66rem;
	color: var(--sscc-muted);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.sscc-week__event--cancelled {
	opacity: 0.55;
}

.sscc-week__event--cancelled .sscc-week__event-title {
	text-decoration: line-through;
}

/* color-mix fallback for older browsers */
@supports not (background: color-mix(in srgb, #000 10%, #fff)) {
	.sscc-week__event {
		background: rgba(45, 55, 118, 0.1);
	}
	.sscc-week__event:hover {
		background: rgba(45, 55, 118, 0.18);
	}
}

.sscc-day__empty {
	grid-column: 1 / -1;
	padding: 40px 20px;
	text-align: center;
	color: var(--sscc-muted);
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	pointer-events: none;
}

/* Mobile tweaks for time grid */
@media (max-width: 720px) {
	.sscc-week { --sscc-hour-h: 44px; --sscc-gutter-w: 44px; }
	.sscc-week__day-num { font-size: 1.05rem; }
	.sscc-week__day-num.is-today { width: 28px; height: 28px; }
	.sscc-week__event-title { font-size: 0.72rem; }
	.sscc-week__event-time { font-size: 0.64rem; }
	.sscc-week__event-loc { display: none; }

	/*
	 * On phones the 7-column week view is unreadable if we squeeze it into the
	 * viewport, so we give it a sensible minimum width (7 days * ~90px + gutter)
	 * and let the body scroll horizontally. This matches Google/Apple Calendar.
	 */
	.sscc-week {
		min-width: 680px;
		width: max-content;
	}
	.sscc-week__head,
	.sscc-week__grid,
	.sscc-week__allday-row {
		width: 100%;
	}
	/* Day view single column still fits — no forced min width */
	.sscc-day {
		min-width: auto;
	}
}

@media (max-width: 560px) {
	.sscc-cal--week .sscc-week__day-name { display: none; }
	.sscc-week { min-width: 640px; }
	.sscc-week__day-num { font-size: 0.95rem; padding: 2px; }
}

/* Touch-first: bigger padded event blocks so tapping is easy */
@media (hover: none) and (pointer: coarse) {
	.sscc-week__event {
		min-height: 30px;
		padding: 6px 8px;
	}
	.sscc-week__event:hover { filter: none; }
}

/* =========================================
 * List view
 * ========================================= */
.sscc-list {
	display: flex;
	flex-direction: column;
}

.sscc-list--empty p {
	background: var(--sscc-bg-soft);
	border-radius: 8px;
	padding: 24px;
	text-align: center;
	color: var(--sscc-muted);
	margin: 16px;
}

.sscc-list__day {
	display: grid;
	grid-template-columns: 80px 1fr;
	border-bottom: 1px solid var(--sscc-border);
	padding: 14px 16px;
	gap: 16px;
}

.sscc-list__day:last-child { border-bottom: none; }

.sscc-list__day-head {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: flex-start;
	color: var(--sscc-muted);
	border-right: 1px solid var(--sscc-border);
	padding-right: 12px;
	line-height: 1;
	gap: 4px;
}

.sscc-list__day-dow { font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; }
.sscc-list__day-num { font-size: 1.8rem; font-weight: 800; color: var(--sscc-text); }
.sscc-list__day-month { font-size: 0.75rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em; }

.sscc-list__events { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }

.sscc-list__event-link {
	display: flex;
	gap: 12px;
	align-items: flex-start;
	padding: 8px;
	border-radius: 8px;
	text-decoration: none;
	color: inherit;
	border-left: 3px solid var(--sscc-color);
	background: var(--sscc-bg-soft);
}

.sscc-list__event-link:hover { background: #eef2f7; color: inherit; }

.sscc-list__event-img {
	width: 64px; height: 64px;
	border-radius: 6px;
	object-fit: cover;
	flex-shrink: 0;
}

.sscc-list__event-swatch {
	width: 14px;
	height: 14px;
	margin-top: 6px;
	border-radius: 50%;
	background: var(--sscc-color);
	flex-shrink: 0;
}

.sscc-list__event-body { flex: 1; min-width: 0; }

.sscc-list__event-title { font-weight: 700; font-size: 1rem; color: var(--sscc-text); }

.sscc-list__event-meta { font-size: 0.85rem; color: var(--sscc-muted); display: flex; flex-wrap: wrap; gap: 6px; margin-top: 2px; }

.sscc-list__event-tag {
	background: color-mix(in srgb, var(--sscc-color) 16%, #ffffff);
	color: var(--sscc-color);
	padding: 1px 8px;
	border-radius: 999px;
	font-size: 0.72rem;
	font-weight: 700;
}

.sscc-list__event-desc { margin: 6px 0 0; font-size: 0.88rem; color: var(--sscc-muted); line-height: 1.4; }

@media (max-width: 560px) {
	.sscc-list__day { grid-template-columns: 60px 1fr; gap: 10px; padding: 12px; }
	.sscc-list__day-num { font-size: 1.4rem; }
	.sscc-list__event-img { width: 48px; height: 48px; }
}

/* =========================================
 * [sscc_this_week] — full-width "This Week" agenda slider
 * ========================================= */
.sscc-tw {
	width: 100%;
	max-width: 100%;
	margin: 0 auto;
	font-family: inherit;
}

.sscc-tw__card {
	background: #fff;
	border: 1px solid var(--sscc-border);
	border-radius: 14px;
	overflow: hidden;
	display: flex;
	flex-direction: column;
}

/* --- Top bar (label + range + small arrows) --- */
.sscc-tw__bar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 12px 16px;
	border-bottom: 1px solid var(--sscc-border);
	background: var(--sscc-bg-soft);
}

.sscc-tw__bar-text {
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
}

.sscc-tw__label {
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.09em;
	color: var(--sscc-brand);
}

.sscc-tw__range {
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--sscc-text);
	line-height: 1.2;
}

.sscc-tw__counter {
	font-size: 0.72rem;
	font-weight: 700;
	color: var(--sscc-muted);
	background: #fff;
	padding: 4px 10px;
	border-radius: 999px;
	border: 1px solid var(--sscc-border);
	font-variant-numeric: tabular-nums;
	letter-spacing: 0.02em;
}

/* --- Slider body --- */
.sscc-tw__slider {
	position: relative;
}

.sscc-tw__track {
	display: flex;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	scroll-behavior: smooth;
	-webkit-overflow-scrolling: touch;
	overscroll-behavior-x: contain;
	scrollbar-width: none;
}

.sscc-tw__track::-webkit-scrollbar { display: none; }

.sscc-tw__slide {
	flex: 0 0 100%;
	scroll-snap-align: start;
	scroll-snap-stop: always;
	display: grid;
	grid-template-columns: 96px 1fr auto;
	align-items: center;
	column-gap: 24px;
	padding: 24px clamp(20px, 4vw, 48px);
	text-decoration: none;
	color: inherit;
	transition: background 0.15s ease;
	min-height: 140px;
}

.sscc-tw__slide:hover {
	background: var(--sscc-bg-soft);
	color: inherit;
}

.sscc-tw__slide:hover .sscc-tw__chevron { transform: translateX(3px); color: var(--sscc-brand); }

/* Date block (left) */
.sscc-tw__date {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	padding: 14px 8px;
	background: var(--sscc-brand-soft);
	border-radius: 12px;
	position: relative;
	line-height: 1;
	gap: 4px;
	min-height: 96px;
	justify-content: center;
}

.sscc-tw__slide.is-today .sscc-tw__date {
	background: var(--sscc-brand);
	color: #fff;
}

.sscc-tw__date-dow {
	font-size: 0.7rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--sscc-brand);
}

.sscc-tw__slide.is-today .sscc-tw__date-dow { color: rgba(255, 255, 255, 0.85); }

.sscc-tw__date-num {
	font-size: 2.2rem;
	font-weight: 800;
	color: var(--sscc-text);
	letter-spacing: -0.02em;
}

.sscc-tw__slide.is-today .sscc-tw__date-num { color: #fff; }

.sscc-tw__date-month {
	font-size: 0.7rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--sscc-muted);
}

.sscc-tw__slide.is-today .sscc-tw__date-month { color: rgba(255, 255, 255, 0.85); }

.sscc-tw__date-today {
	position: absolute;
	top: -7px;
	left: 50%;
	transform: translateX(-50%);
	background: var(--sscc-accent);
	color: #2b1f00;
	font-size: 0.58rem;
	font-weight: 800;
	padding: 2px 7px;
	border-radius: 999px;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	white-space: nowrap;
}

/* Info (middle) */
.sscc-tw__info {
	display: flex;
	flex-direction: column;
	gap: 4px;
	min-width: 0;
}

.sscc-tw__pill {
	display: inline-flex;
	align-self: flex-start;
	align-items: center;
	padding: 2px 8px;
	background: var(--sscc-color);
	color: #fff;
	font-size: 0.65rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	border-radius: 999px;
	margin-bottom: 2px;
}

.sscc-tw__slide-title {
	margin: 0;
	font-size: clamp(1.05rem, 1.6vw, 1.35rem);
	font-weight: 700;
	line-height: 1.25;
	color: var(--sscc-text);
	letter-spacing: -0.005em;
	overflow: hidden;
	text-overflow: ellipsis;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	line-clamp: 2;
	-webkit-box-orient: vertical;
	max-width: 760px;
}

.sscc-tw__slide-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 4px 12px;
	margin-top: 2px;
	font-size: 0.82rem;
	color: var(--sscc-muted);
}

.sscc-tw__meta-item {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	min-width: 0;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	max-width: 100%;
}

.sscc-tw__meta-item svg { opacity: 0.7; flex-shrink: 0; }

.sscc-tw__meta-item--muted {
	font-style: italic;
	text-transform: uppercase;
	font-size: 0.7rem;
	letter-spacing: 0.06em;
}

/* Chevron (right) */
.sscc-tw__chevron {
	color: var(--sscc-muted);
	display: inline-flex;
	align-items: center;
	transition: transform 0.15s ease, color 0.15s ease;
	flex-shrink: 0;
}

/* Dots */
.sscc-tw__dots {
	display: flex;
	justify-content: center;
	gap: 6px;
	padding: 0 16px 16px;
}

.sscc-tw__dot {
	width: 8px;
	height: 8px;
	padding: 0;
	border: 0;
	border-radius: 50%;
	background: var(--sscc-border-strong);
	cursor: pointer;
	transition: background 0.2s ease, width 0.2s ease, border-radius 0.2s ease;
	-webkit-tap-highlight-color: transparent;
}

.sscc-tw__dot:hover { background: var(--sscc-accent-dark); }

.sscc-tw__dot.is-active {
	background: var(--sscc-accent);
	width: 22px;
	border-radius: 999px;
}

/* Footer link */
.sscc-tw__footer-link {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 4px;
	padding: 12px 16px;
	border-top: 1px solid var(--sscc-border);
	color: var(--sscc-brand);
	font-size: 0.88rem;
	font-weight: 700;
	text-decoration: none;
	background: #fff;
	transition: background 0.15s ease, color 0.15s ease;
}

.sscc-tw__footer-link:hover {
	background: var(--sscc-accent);
	color: #2b1f00;
}

/* Empty state */
.sscc-tw__empty {
	padding: 32px 20px;
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
}

.sscc-tw__empty p {
	margin: 0;
	color: var(--sscc-muted);
	font-size: 0.9rem;
}

.sscc-tw__empty-link {
	color: var(--sscc-brand);
	font-size: 0.85rem;
	font-weight: 600;
	text-decoration: none;
}

.sscc-tw__empty-link:hover { text-decoration: underline; }

/* Optional compact list */
.sscc-tw__list {
	list-style: none;
	padding: 6px 0;
	margin: 0;
	border-top: 1px solid var(--sscc-border);
}

.sscc-tw__list-day {
	padding: 8px 16px;
	display: grid;
	grid-template-columns: 70px 1fr;
	gap: 12px;
	border-bottom: 1px solid var(--sscc-border);
}

.sscc-tw__list-day:last-child { border-bottom: none; }

.sscc-tw__list-day.is-today .sscc-tw__list-day-label { color: var(--sscc-brand); }

.sscc-tw__list-day-label {
	font-size: 0.78rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--sscc-muted);
	padding-top: 4px;
}

.sscc-tw__list-events {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.sscc-tw__list-events li {
	border-left: 3px solid var(--sscc-color);
	padding-left: 8px;
}

.sscc-tw__list-events a {
	display: flex;
	gap: 8px;
	align-items: baseline;
	text-decoration: none;
	color: var(--sscc-text);
	font-size: 0.88rem;
	padding: 2px 0;
	min-height: 28px;
}

.sscc-tw__list-events a:hover { color: var(--sscc-brand); }

.sscc-tw__list-time {
	color: var(--sscc-muted);
	font-size: 0.78rem;
	font-weight: 600;
	font-variant-numeric: tabular-nums;
	white-space: nowrap;
	flex-shrink: 0;
	min-width: 64px;
}

.sscc-tw__list-title {
	flex: 1;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

/* --- Responsive --- */
@media (max-width: 760px) {
	.sscc-tw__slide {
		grid-template-columns: 84px 1fr auto;
		column-gap: 16px;
		padding: 20px;
		min-height: 130px;
	}
	.sscc-tw__date { min-height: 80px; padding: 10px 6px; }
	.sscc-tw__date-num { font-size: 1.85rem; }
	.sscc-tw__slide-title { font-size: 1.02rem; }
}

@media (max-width: 480px) {
	.sscc-tw__card { border-radius: 12px; }
	.sscc-tw__slide {
		grid-template-columns: 72px 1fr auto;
		padding: 14px 14px 16px;
		column-gap: 12px;
	}
	.sscc-tw__date { padding: 8px 4px; min-height: 72px; }
	.sscc-tw__date-num { font-size: 1.55rem; }
	.sscc-tw__slide-title { font-size: 0.98rem; }
	.sscc-tw__slide-meta { font-size: 0.78rem; }
	.sscc-tw__bar { padding: 10px 14px; }
	.sscc-tw__list-day { grid-template-columns: 56px 1fr; padding: 8px 14px; }
	.sscc-tw__list-time { min-width: 56px; font-size: 0.72rem; }
}

@media (prefers-reduced-motion: reduce) {
	.sscc-tw__track { scroll-behavior: auto; }
}

/* =========================================
 * [newsletter] — archive
 * ========================================= */
.sscc-newsletter {
	max-width: 900px;
	margin: 0 auto;
	padding: 24px 0;
}

.sscc-newsletter--grid { max-width: 1200px; }

.sscc-newsletter--empty p {
	background: var(--sscc-bg-soft);
	border: 1px dashed var(--sscc-border);
	border-radius: 12px;
	padding: 40px 24px;
	text-align: center;
	color: var(--sscc-muted);
	margin: 0 16px;
}

/* --- Blog-style list (default) --- */
.sscc-nl-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
}

.sscc-nl-list__item {
	border-top: 1px solid var(--sscc-border);
}

.sscc-nl-list__item:last-child {
	border-bottom: 1px solid var(--sscc-border);
}

.sscc-nl-list__link {
	display: grid;
	grid-template-columns: 140px minmax(0, 1fr);
	gap: 28px;
	align-items: center;
	padding: 28px 16px;
	text-decoration: none;
	color: inherit;
	transition: background 0.15s ease;
}

.sscc-nl-list__link:hover {
	background: var(--sscc-bg-soft);
	color: inherit;
}

.sscc-nl-list__cover {
	position: relative;
	aspect-ratio: 3 / 4;
	border-radius: 6px;
	overflow: hidden;
	background: var(--sscc-bg-soft);
	border: 1px solid var(--sscc-border);
	box-shadow: 0 4px 12px rgba(45, 55, 118, 0.08);
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.sscc-nl-list__link:hover .sscc-nl-list__cover {
	transform: translateY(-2px);
	box-shadow: 0 8px 20px rgba(45, 55, 118, 0.18);
}

.sscc-nl-list__cover img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.sscc-nl-list__cover-placeholder {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, var(--sscc-brand-soft) 0%, #ffffff 100%);
	color: var(--sscc-brand-light);
}

.sscc-nl-list__badge {
	position: absolute;
	top: 8px;
	right: 8px;
	background: var(--sscc-brand);
	color: #fff;
	font-size: 0.6rem;
	font-weight: 800;
	padding: 3px 8px;
	border-radius: 999px;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
}

.sscc-nl-list__body {
	display: flex;
	flex-direction: column;
	gap: 8px;
	min-width: 0;
}

.sscc-nl-list__issue {
	font-size: 0.68rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	color: var(--sscc-muted);
	position: relative;
	padding-left: 28px;
}

.sscc-nl-list__issue::before {
	content: '';
	position: absolute;
	left: 0;
	top: 50%;
	width: 20px;
	height: 1.5px;
	background: var(--sscc-accent);
	transform: translateY(-50%);
}

.sscc-nl-list__title {
	margin: 0;
	font-size: clamp(1.2rem, 2vw, 1.45rem);
	font-weight: 700;
	line-height: 1.25;
	color: var(--sscc-text);
	letter-spacing: -0.008em;
	transition: color 0.15s ease;
}

.sscc-nl-list__link:hover .sscc-nl-list__title {
	color: var(--sscc-brand);
}

.sscc-nl-list__excerpt {
	margin: 4px 0 0;
	font-size: 0.98rem;
	line-height: 1.55;
	color: var(--sscc-muted);
	display: -webkit-box;
	-webkit-line-clamp: 3;
	line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.sscc-nl-list__cta {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	color: var(--sscc-brand);
	font-weight: 700;
	font-size: 0.88rem;
	margin-top: 6px;
}

.sscc-nl-list__cta-arrow {
	transition: transform 0.2s ease;
	display: inline-block;
}

.sscc-nl-list__link:hover .sscc-nl-list__cta-arrow {
	transform: translateX(4px);
}

@media (max-width: 640px) {
	.sscc-nl-list__link {
		grid-template-columns: 96px minmax(0, 1fr);
		gap: 16px;
		padding: 20px 12px;
	}
	.sscc-nl-list__issue { padding-left: 0; }
	.sscc-nl-list__issue::before { display: none; }
	.sscc-nl-list__title { font-size: 1.1rem; }
	.sscc-nl-list__excerpt {
		font-size: 0.9rem;
		-webkit-line-clamp: 2;
		line-clamp: 2;
	}
}

@media (max-width: 400px) {
	.sscc-nl-list__link {
		grid-template-columns: 80px minmax(0, 1fr);
		gap: 14px;
	}
	.sscc-nl-list__excerpt { display: none; }
}

.sscc-newsletter__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 28px;
	padding: 0 16px;
}

.sscc-newsletter__card {
	display: flex;
	flex-direction: column;
}

.sscc-newsletter__link {
	display: flex;
	flex-direction: column;
	text-decoration: none;
	color: inherit;
	border-radius: 12px;
	overflow: hidden;
	background: #fff;
	border: 1px solid var(--sscc-border);
	transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.sscc-newsletter__link:hover {
	transform: translateY(-3px);
	box-shadow: 0 12px 28px rgba(45, 55, 118, 0.15);
	border-color: var(--sscc-brand-light);
	color: inherit;
}

.sscc-newsletter__cover {
	position: relative;
	aspect-ratio: 3 / 4;
	overflow: hidden;
	background: var(--sscc-bg-soft);
}

.sscc-newsletter__cover img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.4s ease;
}

.sscc-newsletter__link:hover .sscc-newsletter__cover img {
	transform: scale(1.04);
}

.sscc-newsletter__cover-placeholder {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, var(--sscc-brand-soft) 0%, #ffffff 100%);
	color: var(--sscc-brand-light);
}

.sscc-newsletter__badge {
	position: absolute;
	top: 12px;
	right: 12px;
	background: var(--sscc-brand);
	color: #fff;
	font-size: 0.68rem;
	font-weight: 800;
	padding: 4px 10px;
	border-radius: 999px;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
}

.sscc-newsletter__hover {
	position: absolute;
	inset: 0;
	background: linear-gradient(
		180deg,
		rgba(31, 40, 88, 0) 40%,
		rgba(31, 40, 88, 0.92) 100%
	);
	opacity: 0;
	transition: opacity 0.25s ease;
	display: flex;
	align-items: flex-end;
	padding: 18px;
}

.sscc-newsletter__link:hover .sscc-newsletter__hover {
	opacity: 1;
}

.sscc-newsletter__hover-label {
	background: var(--sscc-accent);
	color: #2b1f00;
	padding: 8px 16px;
	border-radius: 999px;
	font-size: 0.85rem;
	font-weight: 700;
	display: inline-flex;
	align-items: center;
	gap: 4px;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25);
}

.sscc-newsletter__body {
	padding: 16px 18px 20px;
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.sscc-newsletter__issue {
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--sscc-brand);
}

.sscc-newsletter__title {
	margin: 0;
	font-size: 1.05rem;
	font-weight: 700;
	line-height: 1.3;
	color: var(--sscc-text);
	letter-spacing: -0.005em;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* Touch-first: show the hover label always so it works on phones */
@media (hover: none) and (pointer: coarse) {
	.sscc-newsletter__hover { opacity: 1; background: linear-gradient(180deg, transparent 50%, rgba(31,40,88,0.75) 100%); }
	.sscc-newsletter__link:hover { transform: none; }
}

@media (max-width: 560px) {
	.sscc-newsletter__grid { gap: 18px; padding: 0 12px; }
	.sscc-newsletter__title { font-size: 0.98rem; }
	.sscc-newsletter__body { padding: 12px 14px 16px; }
}

/* --- Single newsletter --- */
.sscc-nl-single {
	max-width: 1000px;
	margin: 0 auto;
	padding: 24px 20px 60px;
}

.sscc-nl-single__header {
	text-align: center;
	margin-bottom: 32px;
}

.sscc-nl-single__back {
	display: inline-flex;
	align-items: center;
	color: var(--sscc-brand);
	text-decoration: none;
	font-weight: 600;
	font-size: 0.9rem;
	margin-bottom: 16px;
	min-height: 36px;
	padding: 6px 14px;
	border-radius: 999px;
	background: var(--sscc-brand-soft);
	transition: background 0.15s ease;
}

.sscc-nl-single__back:hover {
	background: var(--sscc-brand);
	color: #fff;
}

.sscc-nl-single__issue {
	display: inline-block;
	color: var(--sscc-brand);
	font-size: 0.8rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	margin-bottom: 6px;
}

.sscc-nl-single__title {
	margin: 0;
	font-size: clamp(1.6rem, 3.5vw, 2.4rem);
	font-weight: 800;
	line-height: 1.1;
	color: var(--sscc-text);
	letter-spacing: -0.01em;
}

.sscc-nl-single__layout {
	display: grid;
	grid-template-columns: minmax(0, 400px) minmax(0, 1fr);
	gap: 40px;
	align-items: start;
}

.sscc-nl-single__cover-wrap {
	position: sticky;
	top: 24px;
}

.sscc-nl-single__cover {
	width: 100%;
	height: auto;
	border-radius: 12px;
	display: block;
	box-shadow: 0 12px 32px rgba(45, 55, 118, 0.18);
}

.sscc-nl-single__cover-placeholder {
	aspect-ratio: 3 / 4;
	background: var(--sscc-brand-soft);
	color: var(--sscc-brand);
	border-radius: 12px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.sscc-nl-single__content .sscc-se__body {
	font-size: 1.05rem;
	line-height: 1.7;
}

.sscc-nl-single__actions {
	margin-top: 32px;
}

@media (max-width: 820px) {
	.sscc-nl-single__layout {
		grid-template-columns: 1fr;
		gap: 24px;
	}
	.sscc-nl-single__cover-wrap {
		position: static;
		max-width: 400px;
		margin: 0 auto;
	}
}

/* =========================================
 * [staff] — upscale gallery
 * Default style: "portrait" (magazine/club-roster feel)
 * ========================================= */
.sscc-staff {
	max-width: 1200px;
	margin: 0 auto;
	padding: 40px 0;
}

.sscc-staff--empty p {
	background: var(--sscc-bg-soft);
	border: 1px dashed var(--sscc-border);
	border-radius: 12px;
	padding: 40px 24px;
	text-align: center;
	color: var(--sscc-muted);
	margin: 0 16px;
}

.sscc-staff__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 64px 40px;
	padding: 0 24px;
}

.sscc-staff__card {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 18px;
}

.sscc-staff__photo-wrap {
	position: relative;
	flex-shrink: 0;
	overflow: hidden;
	background: var(--sscc-bg-soft);
	transition: transform 0.35s ease, box-shadow 0.35s ease;
}

.sscc-staff__photo {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.5s ease;
}


.sscc-staff__card:hover .sscc-staff__photo-wrap {
	box-shadow: 0 20px 40px rgba(45, 55, 118, 0.16);
}

.sscc-staff__card:hover .sscc-staff__photo {
	transform: scale(1.04);
}

.sscc-staff__body {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 10px;
	max-width: 100%;
	padding-top: 4px;
}

/* No-photo cards: center vertically within their grid row so a mixed roster
 * (some with photos, some without) still reads as intentional. */
.sscc-staff__card--no-photo {
	justify-content: center;
	align-self: center;
	padding: 8px 0;
}

.sscc-staff__card--no-photo .sscc-staff__body {
	padding-top: 0;
	gap: 12px;
}

.sscc-staff__card--no-photo .sscc-staff__name {
	font-size: 1.15rem;
}

.sscc-staff__card--no-photo .sscc-staff__divider {
	width: 36px;
	height: 2px;
}

.sscc-staff__name {
	margin: 0;
	font-size: 1rem;
	font-weight: 600;
	line-height: 1.2;
	color: var(--sscc-text);
	text-transform: uppercase;
	letter-spacing: 0.2em;
	padding: 0 4px;
}

.sscc-staff__divider {
	display: block;
	width: 24px;
	height: 1.5px;
	background: var(--sscc-accent);
	transition: width 0.3s ease;
}

.sscc-staff__card:hover .sscc-staff__divider {
	width: 42px;
}

.sscc-staff__position {
	margin: 0;
	font-size: 0.72rem;
	font-weight: 500;
	color: var(--sscc-muted);
	text-transform: uppercase;
	letter-spacing: 0.22em;
	line-height: 1.5;
}

.sscc-staff__contact {
	list-style: none;
	padding: 0;
	margin: 8px 0 0;
	display: flex;
	flex-direction: column;
	gap: 2px;
	font-size: 0.82rem;
}

.sscc-staff__contact a {
	color: var(--sscc-muted);
	text-decoration: none;
	border-bottom: 1px solid transparent;
	padding: 2px 0;
	letter-spacing: 0.02em;
}

.sscc-staff__contact a:hover {
	color: var(--sscc-brand);
	border-bottom-color: var(--sscc-accent);
}

/* --- Portrait style (default, upscale magazine feel) --- */
.sscc-staff--portrait .sscc-staff__photo-wrap {
	width: 100%;
	aspect-ratio: 3 / 4;
	border-radius: 2px;
	box-shadow: 0 12px 28px rgba(45, 55, 118, 0.1);
}

.sscc-staff--portrait .sscc-staff__photo {
	filter: saturate(0.95);
}

.sscc-staff--portrait .sscc-staff__card:hover .sscc-staff__photo {
	filter: saturate(1.05);
}

/* --- Circle style (legacy) --- */
.sscc-staff--circle .sscc-staff__photo-wrap {
	width: 180px;
	height: 180px;
	border-radius: 50%;
	box-shadow: 0 8px 20px rgba(45, 55, 118, 0.15);
}

.sscc-staff--circle .sscc-staff__photo {
	border-radius: 50%;
}

/* --- Square style --- */
.sscc-staff--square .sscc-staff__photo-wrap {
	width: 100%;
	aspect-ratio: 1 / 1;
	border-radius: 14px;
	box-shadow: 0 10px 22px rgba(45, 55, 118, 0.12);
}

.sscc-staff--square .sscc-staff__photo {
	border-radius: 14px;
}

/* --- Responsive --- */
@media (max-width: 860px) {
	.sscc-staff__grid {
		gap: 48px 28px;
	}
	.sscc-staff--circle .sscc-staff__photo-wrap {
		width: 150px;
		height: 150px;
	}
}

@media (max-width: 560px) {
	.sscc-staff__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 40px 16px;
		padding: 0 16px;
	}
	.sscc-staff__name {
		font-size: 0.88rem;
		letter-spacing: 0.12em;
	}
	.sscc-staff__position {
		font-size: 0.68rem;
		letter-spacing: 0.14em;
	}
	.sscc-staff__body { gap: 8px; }
	.sscc-staff--circle .sscc-staff__photo-wrap {
		width: 120px;
		height: 120px;
	}
}

@media (max-width: 380px) {
	.sscc-staff__grid {
		grid-template-columns: 1fr;
		gap: 48px 0;
	}
	.sscc-staff--circle .sscc-staff__photo-wrap {
		width: 160px;
		height: 160px;
	}
}

/* =========================================
 * [weather] — live weather + forecast
 * ========================================= */
.sscc-weather {
	max-width: 560px;
	margin: 0 auto;
}

.sscc-weather--setup p {
	background: #fffaeb;
	border: 1px solid #fde68a;
	color: #78350f;
	padding: 14px 18px;
	border-radius: 10px;
	margin: 16px;
	font-size: 0.92rem;
}

.sscc-weather__card {
	background: #ffffff;
	color: var(--sscc-text);
	border-radius: 12px;
	overflow: hidden;
	border: 1px solid var(--sscc-border);
	box-shadow: 0 1px 3px rgba(17, 24, 39, 0.04);
}

.sscc-weather__now {
	padding: 24px;
	display: flex;
	flex-direction: column;
	gap: 18px;
}

.sscc-weather__now-main {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.sscc-weather__title {
	font-size: 0.68rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	color: var(--sscc-muted);
}

.sscc-weather__temp-row {
	display: flex;
	align-items: center;
	gap: 16px;
}

.sscc-weather__icon {
	width: 72px;
	height: 72px;
	flex-shrink: 0;
}

.sscc-weather__temp {
	font-size: 3.4rem;
	font-weight: 300;
	line-height: 1;
	letter-spacing: -0.03em;
	color: var(--sscc-text);
}

.sscc-weather__deg {
	font-size: 1.2rem;
	font-weight: 400;
	color: var(--sscc-muted);
	vertical-align: super;
	margin-left: 2px;
}

.sscc-weather__desc {
	font-size: 0.92rem;
	font-weight: 500;
	color: var(--sscc-muted);
	letter-spacing: 0.01em;
}

.sscc-weather__stats {
	list-style: none;
	padding: 14px 0 0;
	margin: 0;
	display: flex;
	gap: 28px;
	border-top: 1px solid var(--sscc-border);
	font-size: 0.85rem;
}

.sscc-weather__stats li {
	display: flex;
	flex-direction: column;
	gap: 3px;
}

.sscc-weather__stat-label {
	font-size: 0.62rem;
	text-transform: uppercase;
	letter-spacing: 0.16em;
	color: var(--sscc-muted);
	font-weight: 600;
}

.sscc-weather__stat-value {
	font-weight: 600;
	font-size: 0.94rem;
	color: var(--sscc-text);
	font-variant-numeric: tabular-nums;
}

.sscc-weather__forecast {
	display: grid;
	grid-auto-flow: column;
	grid-auto-columns: 1fr;
	background: var(--sscc-bg-soft);
	padding: 16px 12px;
	border-top: 1px solid var(--sscc-border);
}

.sscc-weather__day {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 4px;
	padding: 4px;
	text-align: center;
}

.sscc-weather__day-name {
	font-size: 0.64rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	color: var(--sscc-muted);
}

.sscc-weather__day-icon {
	width: 40px;
	height: 40px;
}

.sscc-weather__day-high {
	font-weight: 600;
	font-size: 0.9rem;
	color: var(--sscc-text);
	font-variant-numeric: tabular-nums;
}

.sscc-weather__day-low {
	font-size: 0.78rem;
	color: var(--sscc-muted);
	font-variant-numeric: tabular-nums;
}

@media (max-width: 480px) {
	.sscc-weather__now { padding: 20px; }
	.sscc-weather__temp { font-size: 2.8rem; }
	.sscc-weather__icon { width: 60px; height: 60px; }
	.sscc-weather__stats { gap: 18px; font-size: 0.78rem; }
	.sscc-weather__day-icon { width: 34px; height: 34px; }
}

/* =========================================
 * [leaderboard] — elegant, minimal tournament leaderboard
 * ========================================= */
.sscc-leaderboard {
	max-width: 1080px;
	margin: 0 auto;
	padding: 40px 0;
}

.sscc-leaderboard--empty p {
	background: var(--sscc-bg-soft);
	border: 1px dashed var(--sscc-border);
	border-radius: 10px;
	padding: 48px 24px;
	text-align: center;
	color: var(--sscc-muted);
	margin: 0 16px;
	font-size: 0.95rem;
}

/* --- Header --- */
.sscc-leaderboard__header {
	padding: 0 8px 28px;
	margin-bottom: 0;
	text-align: center;
	border-bottom: 0;
	position: relative;
}

.sscc-leaderboard__header::after {
	content: "";
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	bottom: 16px;
	width: 36px;
	height: 2px;
	background: var(--sscc-accent);
}

.sscc-leaderboard__header-main {
	display: flex;
	flex-direction: column;
	gap: 10px;
	align-items: center;
}

.sscc-leaderboard__status {
	display: inline-block;
	font-size: 0.65rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	padding: 5px 14px;
	border-radius: 999px;
	background: transparent;
	border: 1px solid var(--sscc-border-strong);
	color: var(--sscc-muted);
}

.sscc-leaderboard__status--upcoming    { color: var(--sscc-brand); border-color: var(--sscc-brand-light); }
.sscc-leaderboard__status--in_progress { color: #92400e; border-color: #fbbf24; background: #fffaeb; }
.sscc-leaderboard__status--completed   { color: #065f46; border-color: #34d399; background: #ecfdf5; }

.sscc-leaderboard__title {
	margin: 0;
	font-size: clamp(1.5rem, 3vw, 2.1rem);
	font-weight: 700;
	letter-spacing: -0.01em;
	color: var(--sscc-text);
	line-height: 1.15;
}

.sscc-leaderboard__meta {
	list-style: none;
	padding: 0;
	margin: 2px 0 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 2px 20px;
	color: var(--sscc-muted);
	font-size: 0.82rem;
	font-weight: 500;
}

.sscc-leaderboard__meta li {
	display: flex;
	align-items: center;
}

.sscc-leaderboard__meta li + li::before {
	content: "";
	display: inline-block;
	width: 3px;
	height: 3px;
	border-radius: 50%;
	background: var(--sscc-border-strong);
	margin-right: 20px;
}

.sscc-leaderboard__meta li::after {
	content: none;
}

/* --- Table --- */
.sscc-leaderboard__table-wrap {
	overflow-x: auto;
	margin: 0 16px;
	-webkit-overflow-scrolling: touch;
}

.sscc-leaderboard__table {
	width: 100%;
	border-collapse: collapse;
	min-width: 600px;
	font-variant-numeric: tabular-nums;
}

.sscc-leaderboard__table thead {
	background: transparent;
	color: var(--sscc-muted);
}

.sscc-leaderboard__table thead th {
	padding: 14px 12px 12px;
	text-align: left;
	font-size: 0.64rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.16em;
	color: var(--sscc-muted);
	border-bottom: 1px solid var(--sscc-border);
	background: transparent;
}

.sscc-leaderboard__table tbody tr {
	border-bottom: 1px solid var(--sscc-border);
	transition: background 0.15s ease;
}

.sscc-leaderboard__table tbody tr:last-child { border-bottom: none; }

.sscc-leaderboard__table tbody tr:hover {
	background: var(--sscc-bg-soft);
}

.sscc-leaderboard__table tbody td {
	padding: 16px 12px;
	font-size: 0.92rem;
	color: var(--sscc-text);
	vertical-align: middle;
}

.sscc-lb-rank { width: 60px; text-align: center; }
.sscc-lb-name { font-weight: 500; letter-spacing: -0.005em; }
.sscc-lb-round, .sscc-lb-total, .sscc-lb-net, .sscc-lb-hcp, .sscc-lb-flight {
	text-align: center;
	width: 62px;
	color: var(--sscc-muted);
}
.sscc-lb-total {
	color: var(--sscc-text);
	font-weight: 700;
}
.sscc-lb-total strong { font-weight: 700; }
.sscc-lb-net { font-weight: 600; }

.sscc-lb-dash { color: #d1d5db; }

/* Rank chip — minimal by default, podium accents */
.sscc-lb-rank-chip {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 26px;
	height: 26px;
	padding: 0 8px;
	border-radius: 4px;
	background: transparent;
	color: var(--sscc-muted);
	font-weight: 700;
	font-size: 0.78rem;
	letter-spacing: 0.03em;
	border: 0;
}

/* Podium — subtle, not garish. Color on the number only. */
.sscc-lb-rank-chip--1 {
	color: var(--sscc-accent-dark, #c89a45);
	font-size: 0.92rem;
	font-weight: 800;
}

.sscc-lb-rank-chip--2 {
	color: #8b94a4;
	font-size: 0.86rem;
	font-weight: 800;
}

.sscc-lb-rank-chip--3 {
	color: #a87c4c;
	font-size: 0.84rem;
	font-weight: 800;
}

/* First-place row gets a subtle gold accent on the left edge */
.sscc-leaderboard__table tbody tr:first-child {
	position: relative;
}

.sscc-leaderboard__table tbody tr:first-child .sscc-lb-name {
	font-weight: 700;
}

.sscc-leaderboard__table tbody tr:first-child .sscc-lb-rank::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	width: 3px;
	background: var(--sscc-accent);
}

/* Compact variant */
.sscc-leaderboard--compact { padding: 16px 0; }
.sscc-leaderboard--compact .sscc-leaderboard__table-wrap { margin: 0; }
.sscc-leaderboard--compact .sscc-leaderboard__table thead th,
.sscc-leaderboard--compact .sscc-leaderboard__table tbody td {
	padding: 10px 10px;
	font-size: 0.82rem;
}

@media (max-width: 640px) {
	.sscc-leaderboard { padding: 28px 0; }
	.sscc-leaderboard__header { padding-bottom: 24px; }
	.sscc-leaderboard__meta { font-size: 0.76rem; gap: 2px 14px; }
	.sscc-leaderboard__meta li + li::before { margin-right: 14px; }
	.sscc-leaderboard__table thead th,
	.sscc-leaderboard__table tbody td {
		padding: 12px 8px;
		font-size: 0.82rem;
	}
	.sscc-leaderboard__table thead th {
		letter-spacing: 0.12em;
	}
}

/* --- Leaderboard: live refresh bar + stats sidebar + par / to-par --- */
.sscc-leaderboard__live-dot {
	display: inline-block;
	width: 8px;
	height: 8px;
	background: #dc2626;
	border-radius: 50%;
	margin-right: 4px;
	vertical-align: middle;
	animation: sscc-pulse-dot 1.4s ease-in-out infinite;
}

@keyframes sscc-pulse-dot {
	0%, 100% { opacity: 1; transform: scale(1); }
	50%      { opacity: 0.5; transform: scale(0.85); }
}

.sscc-leaderboard__filter {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin-top: 12px;
	font-size: 0.85rem;
	color: var(--sscc-muted);
}

.sscc-leaderboard__filter label {
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.14em;
}

.sscc-leaderboard__filter select {
	padding: 6px 28px 6px 10px;
	border-radius: 6px;
	border: 1px solid var(--sscc-border-strong);
	background: #fff;
	font-size: 0.85rem;
	font-weight: 500;
	color: var(--sscc-text);
	cursor: pointer;
}

.sscc-lb-topar {
	text-align: center;
	width: 62px;
	font-variant-numeric: tabular-nums;
	font-weight: 600;
}

.sscc-lb-under { color: #dc2626; font-weight: 700; }
.sscc-lb-over  { color: #6b7280; }
.sscc-lb-par   { color: #059669; font-weight: 700; }

.sscc-lb-empty {
	padding: 32px 16px;
	text-align: center;
	color: var(--sscc-muted);
	font-style: italic;
}

.sscc-leaderboard__live-bar {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin: 20px 16px 0;
	padding: 10px 14px;
	background: var(--sscc-bg-soft);
	border-radius: 8px;
	font-size: 0.78rem;
	color: var(--sscc-muted);
}

.sscc-leaderboard__live-indicator {
	font-weight: 700;
	letter-spacing: 0.12em;
	color: var(--sscc-text);
}

.sscc-leaderboard__stats {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 12px;
	margin: 24px 16px 0;
	padding: 20px;
	background: var(--sscc-bg-soft);
	border-radius: 10px;
	border: 1px solid var(--sscc-border);
}

.sscc-lb-stat {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.sscc-lb-stat__label {
	font-size: 0.62rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.16em;
	color: var(--sscc-muted);
}

.sscc-lb-stat__val {
	font-size: 1.3rem;
	font-weight: 700;
	color: var(--sscc-brand);
	font-variant-numeric: tabular-nums;
	line-height: 1.1;
}

.sscc-lb-stat__name {
	font-size: 0.82rem;
	color: var(--sscc-text);
	font-weight: 500;
}

/* --- Kiosk mode (TV display) --- */
body.sscc-kiosk {
	background: #0f1433;
	color: #fff;
	margin: 0;
}

body.sscc-kiosk .site-header,
body.sscc-kiosk .site-footer,
body.sscc-kiosk header.site-header,
body.sscc-kiosk footer.site-footer,
body.sscc-kiosk nav,
body.sscc-kiosk .sscc-tournament-single__kiosk-link {
	display: none !important;
}

.sscc-leaderboard--kiosk {
	max-width: none;
	padding: 40px;
	background: #0f1433;
	color: #fff;
}

.sscc-leaderboard--kiosk .sscc-leaderboard__table {
	min-width: 0;
	font-size: 1.15rem;
}

.sscc-leaderboard--kiosk .sscc-leaderboard__table thead th {
	color: rgba(255,255,255,0.65);
	border-bottom-color: rgba(255,255,255,0.2);
	font-size: 0.82rem;
	padding: 16px 14px;
}

.sscc-leaderboard--kiosk .sscc-leaderboard__table tbody tr {
	border-bottom-color: rgba(255,255,255,0.1);
}

.sscc-leaderboard--kiosk .sscc-leaderboard__table tbody td {
	padding: 20px 14px;
	color: #fff;
	font-size: 1.08rem;
}

.sscc-leaderboard--kiosk .sscc-lb-name { font-weight: 600; }
.sscc-leaderboard--kiosk .sscc-lb-total { color: var(--sscc-accent); font-size: 1.3rem; }
.sscc-leaderboard--kiosk .sscc-lb-under { color: #fca5a5; }
.sscc-leaderboard--kiosk .sscc-lb-par   { color: #6ee7b7; }
.sscc-leaderboard--kiosk .sscc-lb-rank-chip--1 { color: var(--sscc-accent); font-size: 1.6rem; }
.sscc-leaderboard--kiosk .sscc-lb-rank-chip--2 { color: #cbd5e1; font-size: 1.4rem; }
.sscc-leaderboard--kiosk .sscc-lb-rank-chip--3 { color: #fbbf24; font-size: 1.3rem; }

/* --- Tournament registration form --- */
.sscc-t-reg {
	max-width: 560px;
	margin: 32px auto 40px;
	padding: 32px;
	background: #fff;
	border: 1px solid var(--sscc-border);
	border-top: 2px solid var(--sscc-brand);
	border-radius: 12px;
}

.sscc-t-reg__title {
	margin: 0 0 16px;
	font-size: 1.2rem;
	font-weight: 700;
	letter-spacing: -0.005em;
	color: var(--sscc-text);
}

.sscc-t-reg__meta {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	gap: 12px;
	margin-bottom: 20px;
	padding-bottom: 16px;
	border-bottom: 1px solid var(--sscc-border);
	font-size: 0.9rem;
	color: var(--sscc-muted);
}

.sscc-t-reg__fee {
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--sscc-brand);
	font-variant-numeric: tabular-nums;
}

.sscc-t-reg__form { display: flex; flex-direction: column; gap: 14px; }

.sscc-t-reg__field {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.sscc-t-reg__field span {
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	color: var(--sscc-muted);
}

.sscc-t-reg__field input {
	padding: 12px 14px;
	border: 1px solid var(--sscc-border);
	border-radius: 8px;
	background: #fff;
	font-size: 0.95rem;
	color: var(--sscc-text);
}

.sscc-t-reg__field input:focus {
	outline: none;
	border-color: var(--sscc-brand);
	box-shadow: 0 0 0 3px rgba(45, 55, 118, 0.12);
}

.sscc-t-reg__field-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 12px;
}

.sscc-t-reg__full,
.sscc-t-reg__ok {
	padding: 14px 16px;
	border-radius: 8px;
	font-size: 0.9rem;
	font-weight: 500;
	margin-bottom: 14px;
}

.sscc-t-reg__full {
	background: #fffaeb;
	color: #78350f;
	border-left: 3px solid #e4b55d;
}

.sscc-t-reg__ok {
	background: #d1fae5;
	color: #065f46;
	border-left: 3px solid #10b981;
}

/* --- Pairings (tee-time sheet) --- */
.sscc-pairings {
	max-width: 900px;
	margin: 32px auto;
	padding: 0 16px;
}

.sscc-pairings__header { text-align: center; margin-bottom: 24px; }

.sscc-pairings__eyebrow {
	display: block;
	font-size: 0.7rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.22em;
	color: var(--sscc-muted);
	margin-bottom: 4px;
}

.sscc-pairings__title {
	margin: 0;
	font-size: 1.4rem;
	font-weight: 700;
	color: var(--sscc-text);
	letter-spacing: -0.01em;
}

.sscc-pairings__list {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 16px;
}

.sscc-pairings__group {
	border: 1px solid var(--sscc-border);
	border-radius: 10px;
	padding: 14px 16px;
	background: #fff;
}

.sscc-pairings__time {
	display: flex;
	align-items: baseline;
	gap: 10px;
	padding-bottom: 10px;
	margin-bottom: 10px;
	border-bottom: 1px solid var(--sscc-border);
}

.sscc-pairings__time strong {
	font-size: 1.05rem;
	font-weight: 700;
	color: var(--sscc-brand);
	font-variant-numeric: tabular-nums;
}

.sscc-pairings__time span {
	font-size: 0.72rem;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--sscc-muted);
	font-weight: 600;
}

.sscc-pairings__players { list-style: none; padding: 0; margin: 0; }

.sscc-pairings__players li {
	padding: 6px 0;
	font-size: 0.92rem;
	display: flex;
	align-items: baseline;
	gap: 8px;
}

.sscc-pairings__name { flex: 1; font-weight: 500; }
.sscc-pairings__flight, .sscc-pairings__hcp {
	font-size: 0.72rem;
	color: var(--sscc-muted);
	font-weight: 600;
	letter-spacing: 0.04em;
}

/* --- Hall of Champions --- */
.sscc-champions {
	max-width: 900px;
	margin: 40px auto;
	padding: 0 20px;
}

.sscc-champions__group { margin-bottom: 40px; }
.sscc-champions__group:last-child { margin-bottom: 0; }

.sscc-champions__group-title {
	margin: 0 0 14px;
	font-size: 0.8rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.2em;
	color: var(--sscc-brand);
	position: relative;
	padding-bottom: 12px;
}

.sscc-champions__group-title::after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	width: 36px;
	height: 2px;
	background: var(--sscc-accent);
}

.sscc-champions__list {
	list-style: none;
	padding: 0;
	margin: 0;
}

.sscc-champions__row {
	display: grid;
	grid-template-columns: 80px 1fr auto;
	gap: 20px;
	align-items: baseline;
	padding: 16px 0;
	border-bottom: 1px solid var(--sscc-border);
}

.sscc-champions__row:last-child { border-bottom: 0; }

.sscc-champions__year {
	font-size: 1.2rem;
	font-weight: 700;
	color: var(--sscc-brand);
	font-variant-numeric: tabular-nums;
	letter-spacing: -0.01em;
}

.sscc-champions__winner a { text-decoration: none; color: var(--sscc-text); }
.sscc-champions__winner strong { font-size: 1.05rem; font-weight: 700; }
.sscc-champions__winner:hover strong { color: var(--sscc-brand); }

.sscc-champions__meta {
	display: block;
	font-size: 0.72rem;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--sscc-muted);
	margin-top: 2px;
}

.sscc-champions__score {
	font-size: 0.9rem;
	color: var(--sscc-muted);
	font-variant-numeric: tabular-nums;
	text-align: right;
}

.sscc-champions__score small { display: block; font-size: 0.72rem; opacity: 0.8; }

.sscc-champions__title-small {
	grid-column: 2;
	font-size: 0.82rem;
	color: var(--sscc-muted);
	font-weight: 500;
}

.sscc-champions--empty p {
	background: var(--sscc-bg-soft);
	border: 1px dashed var(--sscc-border);
	border-radius: 10px;
	padding: 32px 20px;
	text-align: center;
	color: var(--sscc-muted);
}

/* --- Bracket --- */
.sscc-bracket {
	max-width: 100%;
	margin: 32px auto;
	padding: 0 16px;
}

.sscc-bracket__scroll {
	display: flex;
	gap: 40px;
	overflow-x: auto;
	padding: 20px 4px;
	-webkit-overflow-scrolling: touch;
}

.sscc-bracket__round {
	display: flex;
	flex-direction: column;
	justify-content: space-around;
	min-width: 200px;
}

.sscc-bracket__round-label {
	font-size: 0.7rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	color: var(--sscc-muted);
	margin-bottom: 12px;
	padding-bottom: 8px;
	border-bottom: 1px solid var(--sscc-border);
	text-align: center;
}

.sscc-bracket__match {
	margin: 14px 0;
	border: 1px solid var(--sscc-border);
	border-radius: 8px;
	overflow: hidden;
	background: #fff;
}

.sscc-bracket__slot {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 10px 12px;
	border-bottom: 1px solid var(--sscc-border);
	font-size: 0.88rem;
}

.sscc-bracket__slot:last-child { border-bottom: 0; }

.sscc-bracket__slot.is-winner {
	background: color-mix(in srgb, var(--sscc-accent) 12%, #fff);
	font-weight: 700;
}

.sscc-bracket__seed {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 22px;
	height: 22px;
	background: var(--sscc-brand-soft);
	color: var(--sscc-brand);
	border-radius: 4px;
	font-size: 0.7rem;
	font-weight: 700;
	flex-shrink: 0;
}

.sscc-bracket__name--bye, .sscc-bracket__name--tbd { color: var(--sscc-muted); font-style: italic; }

.sscc-bracket--empty p {
	background: var(--sscc-bg-soft);
	border: 1px dashed var(--sscc-border);
	border-radius: 10px;
	padding: 32px 20px;
	text-align: center;
	color: var(--sscc-muted);
}

/* --- Single tournament — kiosk link --- */
.sscc-tournament-single__kiosk-link {
	text-align: center;
	margin-top: 30px;
	padding: 20px 0;
	border-top: 1px dashed var(--sscc-border);
}

.sscc-tournament-single__kiosk-link a {
	display: inline-block;
	padding: 8px 18px;
	color: var(--sscc-muted);
	font-size: 0.82rem;
	font-weight: 600;
	text-decoration: none;
	border: 1px solid var(--sscc-border);
	border-radius: 999px;
}

.sscc-tournament-single__kiosk-link a:hover {
	color: var(--sscc-brand);
	border-color: var(--sscc-brand);
}

@media (max-width: 640px) {
	.sscc-t-reg { padding: 24px 20px; }
	.sscc-t-reg__field-row { grid-template-columns: 1fr; }
	.sscc-champions__row { grid-template-columns: 56px 1fr auto; gap: 12px; padding: 14px 0; }
	.sscc-champions__year { font-size: 1rem; }
	.sscc-leaderboard--kiosk { padding: 20px 16px; }
	.sscc-leaderboard--kiosk .sscc-leaderboard__table tbody td { padding: 14px 8px; font-size: 0.95rem; }
}

/* =========================================
 * Single tournament page hero — minimal, elegant
 * ========================================= */
.sscc-tournament-single__hero {
	min-height: 280px;
	background-size: cover;
	background-position: center;
	position: relative;
	isolation: isolate;
	margin-bottom: 8px;
	max-width: 1200px;
	margin-left: auto;
	margin-right: auto;
	overflow: hidden;
}

.sscc-tournament-single__hero-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(31,40,88,0.15) 0%, rgba(31,40,88,0.75) 100%);
	z-index: 1;
}

.sscc-tournament-single__hero-inner {
	position: relative;
	z-index: 2;
	display: flex;
	align-items: flex-end;
	min-height: 280px;
	padding: 32px 24px;
	max-width: 1080px;
	margin: 0 auto;
}

.sscc-tournament-single__title {
	margin: 0;
	font-size: clamp(1.6rem, 3.6vw, 2.3rem);
	font-weight: 700;
	color: #fff;
	line-height: 1.1;
	letter-spacing: -0.01em;
	text-shadow: 0 2px 12px rgba(0, 0, 0, 0.25);
}

.sscc-tournament-single__header {
	text-align: center;
	padding: 36px 20px 0;
	max-width: 1080px;
	margin: 0 auto;
}

.sscc-tournament-single__title--no-hero {
	color: var(--sscc-text);
	text-shadow: none;
}

/* When the leaderboard comes right after the hero, remove its top padding to
 * visually connect them. */
.sscc-tournament-single .sscc-leaderboard {
	padding-top: 28px;
}

/* =========================================
 * Fallback for browsers without color-mix()
 * ========================================= */
@supports not (background: color-mix(in srgb, #000 10%, #fff)) {
	.sscc-month__event-link {
		background: rgba(11, 107, 58, 0.1);
	}
	.sscc-list__event-tag {
		background: #eef2f7;
	}
}
