/**
 * Public styles for Cleveland Hockey Hub Core.
 *
 * Loaded only on hub-related front-end screens and pages containing hub
 * shortcodes.
 */

:root {
	--chh-core-ink: #17202a;
	--chh-core-muted: #5e6b78;
	--chh-core-line: #d8e1ea;
	--chh-core-surface: #ffffff;
	--chh-core-soft: #f5f8fb;
	--chh-core-blue: #1f6feb;
	--chh-core-blue-dark: #0f4fb8;
}

.chh-card-grid {
	display: grid;
	gap: 16px;
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 280px), 1fr));
	margin: 24px 0;
}

.chh-card {
	background: var(--chh-core-surface);
	border: 1px solid var(--chh-core-line);
	border-radius: 8px;
	box-shadow: 0 8px 22px rgba(23, 32, 42, 0.06);
	display: flex;
	flex-direction: column;
	gap: 10px;
	padding: 18px;
}

.chh-card h3 {
	font-size: 1.12rem;
	line-height: 1.25;
	margin: 0;
}

.chh-card h3 a,
.chh-text-link,
.chh-source a {
	color: var(--chh-core-blue-dark);
	text-decoration-thickness: 1px;
	text-underline-offset: 3px;
}

.chh-card p {
	color: var(--chh-core-muted);
	margin: 0;
}

.chh-card-meta,
.chh-card-detail {
	color: var(--chh-core-muted);
	font-size: 0.92rem;
}

.chh-term-list {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	list-style: none;
	margin: 2px 0 0;
	padding: 0;
}

.chh-term-list li {
	background: var(--chh-core-soft);
	border: 1px solid var(--chh-core-line);
	border-radius: 999px;
	color: var(--chh-core-muted);
	font-size: 0.78rem;
	padding: 4px 8px;
}

.chh-source {
	align-items: center;
	border-top: 1px solid var(--chh-core-line);
	color: var(--chh-core-muted);
	display: flex;
	flex-wrap: wrap;
	font-size: 0.82rem;
	gap: 6px 10px;
	margin-top: auto;
	padding-top: 12px;
}

.chh-empty {
	background: var(--chh-core-soft);
	border: 1px solid var(--chh-core-line);
	border-radius: 8px;
	color: var(--chh-core-muted);
	margin: 0;
	padding: 18px;
}

.chh-newsletter {
	background: var(--chh-core-soft);
	border: 1px solid var(--chh-core-line);
	border-radius: 8px;
	margin: 24px 0;
	padding: 18px;
}

.chh-newsletter h2 {
	color: var(--chh-core-ink);
	font-size: 1.25rem;
	margin: 0 0 12px;
}

.chh-newsletter label {
	display: block;
	font-weight: 700;
	margin-bottom: 6px;
}

.chh-newsletter-row {
	display: flex;
	gap: 8px;
}

.chh-newsletter input[type="email"] {
	border: 1px solid var(--chh-core-line);
	border-radius: 6px;
	flex: 1 1 auto;
	min-height: 42px;
	padding: 8px 10px;
}

.chh-newsletter button {
	background: var(--chh-core-blue);
	border: 0;
	border-radius: 6px;
	color: #ffffff;
	cursor: pointer;
	font-weight: 700;
	min-height: 42px;
	padding: 8px 14px;
}

.chh-newsletter button:hover,
.chh-newsletter button:focus {
	background: var(--chh-core-blue-dark);
}

.chh-notice {
	border-radius: 6px;
	margin: 0 0 12px;
	padding: 10px 12px;
}

.chh-notice-success {
	background: #e8f6ee;
	color: #0b5b2a;
}

.chh-notice-error {
	background: #fff0f0;
	color: #8a1f1f;
}

.chh-master-calendar {
	color: var(--chh-core-ink);
	display: grid;
	gap: 42px;
	margin: 0 auto;
	max-width: 1180px;
}

.chh-master-calendar *,
.chh-master-calendar *::before,
.chh-master-calendar *::after {
	box-sizing: border-box;
}

.chh-calendar-dependency,
.chh-calendar-empty {
	background: var(--chh-core-soft);
	border: 1px solid var(--chh-core-line);
	border-radius: 6px;
	color: var(--chh-core-muted);
	margin: 0;
	padding: 14px 16px;
}

.chh-calendar-dependency strong {
	color: var(--chh-core-ink);
	margin-right: 4px;
}

.chh-calendar-section-heading,
.chh-calendar-browser__header {
	align-items: end;
	display: flex;
	gap: 20px;
	justify-content: space-between;
	margin-bottom: 18px;
}

.chh-calendar-section-heading h2,
.chh-calendar-browser__header h2 {
	color: var(--chh-core-ink);
	font-size: 1.65rem;
	letter-spacing: 0;
	line-height: 1.15;
	margin: 0;
}

.chh-calendar-eyebrow {
	color: #a32937;
	font-size: 0.78rem;
	font-weight: 800;
	letter-spacing: 0;
	margin: 0 0 4px;
	text-transform: uppercase;
}

.chh-calendar-featured__grid {
	display: grid;
	gap: 14px;
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.chh-calendar-event-card {
	background: var(--chh-core-surface);
	border: 1px solid var(--chh-core-line);
	border-radius: 8px;
	display: grid;
	gap: 18px;
	grid-template-columns: 64px minmax(0, 1fr);
	padding: 18px;
}

.chh-calendar-event-card--featured {
	gap: 12px;
	grid-template-columns: 52px minmax(0, 1fr);
	padding: 16px;
}

.chh-calendar-event-card__date {
	align-items: center;
	align-self: start;
	background: #15324a;
	border-radius: 5px;
	color: #ffffff;
	display: flex;
	flex-direction: column;
	justify-content: center;
	min-height: 68px;
	padding: 8px 5px;
	text-align: center;
}

.chh-calendar-event-card--featured .chh-calendar-event-card__date {
	min-height: 58px;
}

.chh-calendar-event-card__date span {
	font-size: 0.72rem;
	font-weight: 800;
	text-transform: uppercase;
}

.chh-calendar-event-card__date strong {
	font-size: 1.55rem;
	line-height: 1;
}

.chh-calendar-event-card__body {
	min-width: 0;
}

.chh-calendar-event-card__time,
.chh-calendar-event-card__location,
.chh-calendar-event-card__connections {
	color: var(--chh-core-muted);
	font-size: 0.88rem;
	margin: 0;
}

.chh-calendar-event-card h3 {
	font-size: 1.15rem;
	letter-spacing: 0;
	line-height: 1.22;
	margin: 4px 0 7px;
	overflow-wrap: anywhere;
}

.chh-calendar-event-card h3 a,
.chh-calendar-event-card__link {
	color: var(--chh-core-blue-dark);
	text-underline-offset: 3px;
}

.chh-calendar-event-card__tags {
	display: flex;
	flex-wrap: wrap;
	gap: 5px;
	list-style: none;
	margin: 10px 0 0;
	padding: 0;
}

.chh-calendar-event-card__tags li {
	background: #edf4fb;
	border: 1px solid #d2e2f1;
	border-radius: 4px;
	color: #23445f;
	font-size: 0.75rem;
	font-weight: 700;
	padding: 3px 6px;
}

.chh-calendar-event-card__connections {
	margin-top: 10px;
}

.chh-calendar-event-card__link {
	display: inline-block;
	font-size: 0.88rem;
	font-weight: 800;
	margin-top: 11px;
}

.chh-calendar-browser {
	min-width: 0;
}

.chh-calendar-views {
	background: var(--chh-core-soft);
	border: 1px solid var(--chh-core-line);
	border-radius: 6px;
	display: inline-grid;
	grid-template-columns: repeat(2, minmax(76px, 1fr));
	padding: 3px;
}

.chh-calendar-view-actions {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	justify-content: flex-end;
}

.chh-calendar-views a {
	border-radius: 4px;
	color: var(--chh-core-muted);
	font-size: 0.9rem;
	font-weight: 800;
	padding: 8px 12px;
	text-align: center;
	text-decoration: none;
}

.chh-calendar-views a.is-active {
	background: var(--chh-core-surface);
	box-shadow: 0 1px 4px rgba(23, 32, 42, 0.12);
	color: var(--chh-core-blue-dark);
}

.chh-calendar-archive-link {
	color: var(--chh-core-blue-dark);
	font-size: 0.88rem;
	font-weight: 800;
	text-underline-offset: 3px;
}

.chh-calendar-filters {
	align-items: end;
	background: var(--chh-core-soft);
	border: 1px solid var(--chh-core-line);
	border-radius: 8px;
	display: grid;
	gap: 12px;
	grid-template-columns: repeat(2, minmax(180px, 1fr)) auto auto;
	margin-bottom: 22px;
	padding: 16px;
}

.chh-calendar-filter label {
	color: var(--chh-core-ink);
	display: block;
	font-size: 0.84rem;
	font-weight: 800;
	margin-bottom: 5px;
}

.chh-calendar-filter select {
	background: var(--chh-core-surface);
	border: 1px solid #b8c6d2;
	border-radius: 5px;
	color: var(--chh-core-ink);
	font: inherit;
	min-height: 44px;
	padding: 8px 34px 8px 10px;
	width: 100%;
}

.chh-calendar-filter-button {
	background: var(--chh-core-blue);
	border: 1px solid var(--chh-core-blue);
	border-radius: 5px;
	color: #ffffff;
	cursor: pointer;
	font: inherit;
	font-weight: 800;
	min-height: 44px;
	padding: 8px 14px;
}

.chh-calendar-filter-button:hover,
.chh-calendar-filter-button:focus {
	background: var(--chh-core-blue-dark);
	border-color: var(--chh-core-blue-dark);
}

.chh-calendar-clear {
	align-items: center;
	color: var(--chh-core-blue-dark);
	display: inline-flex;
	font-size: 0.88rem;
	font-weight: 800;
	min-height: 44px;
}

.chh-calendar-month-nav {
	align-items: center;
	display: grid;
	gap: 16px;
	grid-template-columns: 1fr auto 1fr;
	margin: 0 0 12px;
}

.chh-calendar-month-nav h3 {
	font-size: 1.35rem;
	letter-spacing: 0;
	margin: 0;
	text-align: center;
}

.chh-calendar-month-nav a {
	color: var(--chh-core-blue-dark);
	font-size: 0.9rem;
	font-weight: 800;
	text-decoration: none;
}

.chh-calendar-month-nav a:last-child {
	text-align: right;
}

.chh-calendar-month {
	border-left: 1px solid var(--chh-core-line);
	border-top: 1px solid var(--chh-core-line);
	display: grid;
	grid-template-columns: repeat(7, minmax(0, 1fr));
}

.chh-calendar-month__weekday {
	background: #15324a;
	border-bottom: 1px solid #15324a;
	border-right: 1px solid #365269;
	color: #ffffff;
	font-size: 0.78rem;
	font-weight: 800;
	padding: 8px;
	text-align: center;
	text-transform: uppercase;
}

.chh-calendar-month__day {
	background: var(--chh-core-surface);
	border-bottom: 1px solid var(--chh-core-line);
	border-right: 1px solid var(--chh-core-line);
	min-height: 142px;
	min-width: 0;
	padding: 8px;
}

.chh-calendar-month__day.is-outside {
	background: #f1f4f7;
}

.chh-calendar-month__day > time {
	color: var(--chh-core-muted);
	display: block;
	font-size: 0.82rem;
	font-weight: 800;
	margin-bottom: 7px;
}

.chh-calendar-month__mobile-date {
	display: none;
}

.chh-calendar-month__events {
	display: grid;
	gap: 5px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.chh-calendar-month__events a {
	background: #edf4fb;
	border-left: 3px solid var(--chh-core-blue);
	color: #173d5e;
	display: block;
	font-size: 0.75rem;
	font-weight: 700;
	line-height: 1.25;
	overflow-wrap: anywhere;
	padding: 5px 6px;
	text-decoration: none;
}

.chh-calendar-month__events a:hover,
.chh-calendar-month__events a:focus {
	background: #dceaf6;
}

.chh-calendar-month__event-time {
	color: var(--chh-core-muted);
	display: block;
	font-size: 0.68rem;
	font-weight: 600;
}

.chh-calendar-month__event-time:empty {
	display: none;
}

.chh-calendar-month__more {
	color: var(--chh-core-muted);
	font-size: 0.72rem;
	font-weight: 700;
	margin: 6px 0 0;
}

.chh-calendar-month + .chh-calendar-empty {
	margin-top: 16px;
}

.chh-calendar-list {
	display: grid;
	gap: 12px;
}

.chh-calendar-list .chh-calendar-event-card {
	grid-template-columns: 70px minmax(0, 1fr);
}

.chh-master-calendar :focus-visible {
	outline: 3px solid #70b7f2;
	outline-offset: 2px;
}

.chh-event-connections {
	border-top: 1px solid var(--chh-core-line);
	margin-top: 28px;
	padding-top: 24px;
}

.chh-event-connections > h2 {
	font-size: 1.35rem;
	letter-spacing: 0;
	margin: 0 0 16px;
}

.chh-event-connections__groups {
	display: grid;
	gap: 20px;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.chh-event-connections__group h3 {
	font-size: 0.92rem;
	letter-spacing: 0;
	margin: 0 0 7px;
}

.chh-event-connections__group ul {
	margin: 0;
	padding-left: 18px;
}

.chh-event-connections__group li + li {
	margin-top: 4px;
}

.chh-event-connections__group a {
	color: var(--chh-core-blue-dark);
	text-underline-offset: 3px;
}

.chh-submit-news {
	margin: 0 auto;
	max-width: 900px;
}

.chh-submit-news__intro {
	margin-bottom: 24px;
	max-width: 760px;
}

.chh-submit-news__intro h2 {
	color: var(--chh-core-ink);
	font-size: 1.55rem;
	letter-spacing: 0;
	line-height: 1.18;
	margin: 0 0 10px;
}

.chh-submit-news__intro p {
	color: var(--chh-core-muted);
	margin: 0 0 8px;
}

.chh-submit-news__form {
	background: var(--chh-core-surface);
	border: 1px solid var(--chh-core-line);
	border-radius: 8px;
	padding: 24px;
}

.chh-submit-news__grid {
	display: grid;
	gap: 18px;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.chh-submit-news__field {
	margin: 0;
	min-width: 0;
}

.chh-submit-news__field--wide {
	grid-column: 1 / -1;
}

.chh-submit-news__field label,
.chh-submit-news__confirmations legend {
	color: var(--chh-core-ink);
	font-size: 0.9rem;
	font-weight: 800;
}

.chh-submit-news__field label {
	display: block;
	margin-bottom: 6px;
}

.chh-submit-news__field input,
.chh-submit-news__field select,
.chh-submit-news__field textarea {
	background: #ffffff;
	border: 1px solid #b8c6d2;
	border-radius: 5px;
	color: var(--chh-core-ink);
	font: inherit;
	padding: 9px 10px;
	width: 100%;
}

.chh-submit-news__field input,
.chh-submit-news__field select {
	min-height: 44px;
}

.chh-submit-news__field textarea {
	resize: vertical;
}

.chh-submit-news__help {
	color: var(--chh-core-muted);
	display: block;
	font-size: 0.82rem;
	margin-top: 5px;
}

.chh-submit-news__confirmations {
	border: 0;
	border-top: 1px solid var(--chh-core-line);
	display: grid;
	gap: 10px;
	margin: 24px 0 0;
	padding: 20px 0 0;
}

.chh-submit-news__confirmations legend {
	margin-bottom: 9px;
	padding: 0;
}

.chh-submit-news__confirmations label {
	align-items: start;
	display: grid;
	font-size: 0.9rem;
	gap: 9px;
	grid-template-columns: 18px minmax(0, 1fr);
}

.chh-submit-news__confirmations input {
	height: 18px;
	margin: 2px 0 0;
	width: 18px;
}

.chh-submit-news__privacy {
	color: var(--chh-core-muted);
	font-size: 0.82rem;
	margin: 18px 0 12px;
}

.chh-submit-news__button {
	background: var(--chh-core-blue);
	border: 1px solid var(--chh-core-blue);
	border-radius: 5px;
	color: #ffffff;
	cursor: pointer;
	font: inherit;
	font-weight: 800;
	min-height: 46px;
	padding: 9px 16px;
}

.chh-submit-news__button:hover,
.chh-submit-news__button:focus {
	background: var(--chh-core-blue-dark);
	border-color: var(--chh-core-blue-dark);
}

.chh-submit-news__field input:focus,
.chh-submit-news__field select:focus,
.chh-submit-news__field textarea:focus,
.chh-submit-news__button:focus-visible {
	outline: 3px solid #70b7f2;
	outline-offset: 2px;
}

.chh-submit-news__honeypot {
	height: 1px;
	left: -10000px;
	overflow: hidden;
	position: absolute;
	top: auto;
	width: 1px;
}

@media (max-width: 980px) {
	.chh-calendar-featured__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.chh-calendar-filters {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.chh-calendar-filter-button,
	.chh-calendar-clear {
		justify-content: center;
		width: 100%;
	}
}

@media (max-width: 720px) {
	.chh-submit-news__grid {
		grid-template-columns: 1fr;
	}

	.chh-submit-news__field--wide {
		grid-column: auto;
	}

	.chh-master-calendar {
		gap: 34px;
	}

	.chh-calendar-browser__header {
		align-items: stretch;
		flex-direction: column;
	}

	.chh-calendar-views {
		width: 100%;
	}

	.chh-calendar-month {
		border: 0;
		display: block;
	}

	.chh-calendar-month__weekday,
	.chh-calendar-month__day.is-outside,
	.chh-calendar-month__day.is-empty {
		display: none;
	}

	.chh-calendar-month__day {
		border: 1px solid var(--chh-core-line);
		border-radius: 7px;
		min-height: 0;
		padding: 14px;
	}

	.chh-calendar-month__day + .chh-calendar-month__day {
		margin-top: 10px;
	}

	.chh-calendar-month__day > time {
		border-bottom: 1px solid var(--chh-core-line);
		font-size: 0.92rem;
		margin-bottom: 10px;
		padding-bottom: 8px;
	}

	.chh-calendar-month__day-number {
		display: none;
	}

	.chh-calendar-month__mobile-date {
		display: inline;
	}

	.chh-calendar-month__events a {
		font-size: 0.88rem;
		padding: 8px;
	}

	.chh-calendar-month__event-time {
		font-size: 0.76rem;
	}
}

@media (max-width: 560px) {
	.chh-submit-news__form {
		padding: 18px;
	}

	.chh-submit-news__button {
		width: 100%;
	}

	.chh-newsletter-row {
		flex-direction: column;
	}

	.chh-calendar-section-heading {
		align-items: start;
	}

	.chh-calendar-featured__grid,
	.chh-calendar-filters {
		grid-template-columns: 1fr;
	}

	.chh-calendar-event-card,
	.chh-calendar-event-card--featured,
	.chh-calendar-list .chh-calendar-event-card {
		gap: 12px;
		grid-template-columns: 54px minmax(0, 1fr);
		padding: 14px;
	}

	.chh-calendar-event-card__date,
	.chh-calendar-event-card--featured .chh-calendar-event-card__date {
		min-height: 58px;
	}

	.chh-calendar-month-nav {
		gap: 8px;
	}

	.chh-calendar-month-nav h3 {
		font-size: 1.12rem;
	}

	.chh-calendar-month-nav a {
		font-size: 0.8rem;
	}
}
