/* Multi Events Calendar. */

.mecal {
	margin: 1.5em 0;
}

.mecal-heading {
	margin: 0 0 0.8em;
}

.mecal-notice {
	padding: 0.75em 1em;
	border: 1px dashed #c3c4c7;
	color: #50575e;
}

.mecal-ical {
	margin: -0.25em 0 1em;
}

.mecal-ical-link {
	display: inline-flex;
	align-items: center;
	gap: 0.4em;
	padding: 0.42em 0.8em;
	border: 1px solid color-mix(in srgb, currentColor 24%, transparent);
	border-radius: 6px;
	color: inherit;
	font-size: 0.86em;
	font-weight: 600;
	text-decoration: none;
}

.mecal-ical-link::before {
	content: "+";
	font-weight: 800;
}

.mecal-ical-link:hover,
.mecal-ical-link:focus {
	border-color: currentColor;
	text-decoration: none;
}

.mecal-items {
	display: grid;
	gap: 14px;
}

.mecal-view-cards .mecal-items {
	grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
}

.mecal-item {
	display: grid;
	gap: 14px;
	padding: 16px 0;
	border-top: 1px solid color-mix(in srgb, currentColor 18%, transparent);
}

.mecal-view-list .mecal-item {
	grid-template-columns: minmax(140px, 220px) minmax(0, 1fr);
	align-items: start;
}

.mecal-view-cards .mecal-item {
	grid-template-rows: auto 1fr;
	padding: 0;
	border: 1px solid color-mix(in srgb, currentColor 16%, transparent);
	border-radius: 8px;
	overflow: hidden;
	background: Canvas;
}

.mecal-item.is-featured {
	border-left: 4px solid #b2263e;
	padding-left: 14px;
}

.mecal-image {
	display: block;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	border-radius: 6px;
}

.mecal-image img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.mecal-body {
	min-width: 0;
}

.mecal-view-cards .mecal-body {
	padding: 14px;
}

.mecal-date {
	display: block;
	margin-bottom: 0.3em;
	font-size: 0.82em;
	letter-spacing: 0.02em;
	text-transform: uppercase;
	opacity: 0.72;
}

.mecal-title {
	margin: 0;
	font-size: 1.08em;
	line-height: 1.3;
}

.mecal-title a {
	color: inherit;
	text-decoration: none;
}

.mecal-title a:hover,
.mecal-title a:focus {
	text-decoration: underline;
	text-underline-offset: 3px;
}

.mecal-meta,
.mecal-artists,
.mecal-excerpt {
	margin: 0.45em 0 0;
	line-height: 1.45;
}

.mecal-meta {
	font-size: 0.92em;
	opacity: 0.75;
}

.mecal-artists {
	font-weight: 600;
}

.mecal-excerpt {
	font-size: 0.95em;
}

.mecal-calendar-grid {
	display: grid;
	grid-template-columns: repeat(7, minmax(0, 1fr));
	gap: 8px;
	width: 100%;
}

.mecal-calendar-week {
	grid-template-columns: repeat(7, minmax(132px, 1fr));
	min-width: 960px;
}

.mecal-calendar-month {
	grid-template-columns: repeat(7, minmax(126px, 1fr));
	min-width: 930px;
}

.mecal-calendar-day {
	min-height: 148px;
	padding: 10px;
	border: 1px solid color-mix(in srgb, currentColor 14%, transparent);
	border-radius: 6px;
}

.mecal-calendar-date {
	margin: 0 0 0.6em;
	font-size: 0.82em;
	text-transform: uppercase;
	opacity: 0.7;
}

.mecal-calendar-event {
	display: block;
	margin: 0.35em 0 0;
	padding: 0.45em 0.55em;
	border-left: 3px solid color-mix(in srgb, currentColor 28%, transparent);
	border-radius: 4px;
	background: color-mix(in srgb, currentColor 5%, transparent);
	color: inherit;
	font-size: 0.9em;
	line-height: 1.35;
	text-decoration: none;
}

.mecal-calendar-event.is-featured {
	border-color: #b2263e;
}

.mecal-calendar-event time {
	display: block;
	margin-bottom: 0.1em;
	font-size: 0.78em;
	opacity: 0.72;
}

.mecal-template {
	box-sizing: border-box;
	width: min(100%, 1120px);
	max-width: none !important;
	margin: 0 auto;
	padding: 2rem 1.25rem;
}

.mecal-template-full {
	width: 100%;
	max-width: 100% !important;
}

.mecal-index {
	margin: 2rem 0;
}

.mecal-index-sections {
	display: grid;
	grid-template-columns: repeat(var(--mecal-index-columns, 3), minmax(0, 1fr));
	gap: 1.25rem;
}

.mecal-index-section {
	border-top: 1px solid #d8dee4;
	padding-top: 1rem;
}

.mecal-index-heading {
	font-size: 0.95rem;
	margin: 0 0 0.75rem;
	text-transform: uppercase;
}

.mecal-index-list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.mecal-index-list .mecal-index-list {
	border-left: 1px solid #d8dee4;
	margin: 0.45rem 0 0.45rem 0.6rem;
	padding-left: 0.75rem;
}

.mecal-index-item {
	margin: 0.25rem 0;
}

.mecal-index-item a {
	align-items: center;
	color: inherit;
	display: flex;
	gap: 0.5rem;
	justify-content: space-between;
	text-decoration: none;
}

.mecal-index-item a:hover span {
	text-decoration: underline;
}

.mecal-index-item mark {
	background: #f2f4f7;
	border-radius: 999px;
	color: #57606a;
	font-size: 0.75rem;
	padding: 0.05rem 0.45rem;
}

.mecal-archive-template {
	overflow-x: clip;
}

.mecal-archive-template .mecal-view-week,
.mecal-archive-template .mecal-view-month {
	max-width: 100%;
	overflow-x: auto;
	padding-bottom: 0.5rem;
	scrollbar-gutter: stable;
}

.mecal-single-header {
	display: grid;
	grid-template-columns: minmax(260px, 0.9fr) minmax(0, 1.1fr);
	gap: clamp(1.25rem, 4vw, 3rem);
	align-items: start;
	margin-bottom: 2rem;
}

.mecal-single-image {
	margin: 0;
}

.mecal-single-image img {
	display: block;
	width: 100%;
	border-radius: 8px;
	object-fit: cover;
}

.mecal-single-title,
.mecal-archive-title {
	margin: 0 0 0.7em;
}

.mecal-meta-list {
	display: grid;
	gap: 0.65em;
	margin: 1rem 0;
}

.mecal-meta-list div {
	display: grid;
	grid-template-columns: minmax(110px, 0.35fr) 1fr;
	gap: 1em;
	padding-bottom: 0.65em;
	border-bottom: 1px solid color-mix(in srgb, currentColor 12%, transparent);
}

.mecal-meta-list dt {
	font-size: 0.78em;
	font-weight: 700;
	text-transform: uppercase;
	opacity: 0.65;
}

.mecal-meta-list dd {
	margin: 0;
}

.mecal-event-button {
	display: inline-flex;
	align-items: center;
	margin-top: 0.5rem;
	padding: 0.62em 1em;
	border-radius: 6px;
	background: #1f3148;
	color: #fff;
	font-weight: 700;
	text-decoration: none;
}

.mecal-event-button:hover,
.mecal-event-button:focus {
	color: #fff;
	text-decoration: underline;
	text-underline-offset: 3px;
}

.mecal-single-content {
	max-width: 760px;
}

.mecal-map {
	margin-top: 2rem;
}

.mecal-map iframe {
	width: 100%;
	min-height: 320px;
	border: 0;
	border-radius: 8px;
}

.mecal-archive-header {
	margin-bottom: 1.5rem;
}

.mecal-archive-toggles {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin: 0.75rem 0;
}

.mecal-archive-toggles a {
	padding: 0.38em 0.75em;
	border: 1px solid color-mix(in srgb, currentColor 22%, transparent);
	border-radius: 999px;
	color: inherit;
	font-size: 0.88em;
	text-decoration: none;
}

.mecal-archive-toggles a.is-active {
	background: currentColor;
	color: Canvas;
}

@media (max-width: 760px) {
	.mecal-single-header,
	.mecal-view-list .mecal-item,
	.mecal-meta-list div {
		grid-template-columns: 1fr;
	}

	.mecal-index-sections {
		grid-template-columns: 1fr;
	}

	.mecal-template-full {
		width: 100%;
	}
}
