/**
 * SIB Institutional Events Calendar v3 — all views + filter bar.
 *
 * v3: SIB brand colors (Brand Guidelines pp. 17–20) are the DEFAULTS.
 * The full palette is declared as --sib-* custom properties, and every
 * component variable maps onto it. Any component variable can still be
 * overridden per instance from the WPBakery Design tab (scoped <style>
 * block) or globally in a child theme — the cascade is:
 *
 *   brand default  <  per-instance WPBakery picker  <  child-theme CSS
 *
 * Component variables:
 *   --sibec-accent            Links, active states       (Burgundy 500)
 *   --sibec-head-bg / -text   Weekday header row         (Navy 500 / Off-White 100)
 *   --sibec-today / -text     Current-day highlight      (Mustard 500 / Dark Gray 900)
 *   --sibec-filter-*          Filter + toolbar buttons   (Off-White / Dark Gray / Burgundy)
 *
 * Typography and radii still inherit The7 — only color defaults are branded.
 */

.sibec-calendar {
	/* ------------------------- SIB brand palette ------------------------ */
	--sib-mustard-100: #FFDFAD; --sib-mustard-300: #FFCD85; --sib-mustard-500: #F6B143; --sib-mustard-700: #C88E33; --sib-mustard-900: #8F6022;
	--sib-burgundy-100: #D98BA2; --sib-burgundy-300: #B64F68; --sib-burgundy-500: #800020; --sib-burgundy-700: #5C0017; --sib-burgundy-900: #33000D;
	--sib-darkgray-100: #B3B3B3; --sib-darkgray-300: #8C8C8C; --sib-darkgray-500: #666666; --sib-darkgray-700: #4D4D4D; --sib-darkgray-900: #333333;
	--sib-offwhite-100: #F9F6F0; --sib-offwhite-300: #F4F1EA; --sib-offwhite-500: #D9D6CC; --sib-offwhite-700: #BFBBAF; --sib-offwhite-900: #A6A190;
	--sib-teal-100: #C8F1F0; --sib-teal-300: #66D3D1; --sib-teal-500: #1CABB0; --sib-teal-700: #117A7E; --sib-teal-900: #0A5053;
	--sib-navy-100: #D3D2E5; --sib-navy-300: #7B79AD; --sib-navy-500: #211F60; --sib-navy-700: #18154C; --sib-navy-900: #0B0A2F;
	--sib-coral-100: #FFE4E0; --sib-coral-300: #FFA195; --sib-coral-500: #FF7769; --sib-coral-700: #D95D51; --sib-coral-900: #A93F35;
	--sib-olive-100: #F1F6C3; --sib-olive-300: #C9D356; --sib-olive-500: #95A800; --sib-olive-700: #6F7E00; --sib-olive-900: #4A5300;

	/* ------------------- Structural tokens (The7-inherited) ------------- */
	--sibec-radius: var(--the7-elements-border-radius, 8px);
	--sibec-gap: var(--the7-content-boxes-gap, 20px);

	/* --------------------- Component defaults (brand) -------------------
	   Primaries (Burgundy, Mustard) lead but are used sparingly: Burgundy
	   for the header band and active/selected states, Mustard only for the
	   today badge. Controls (filters, nav, view switcher) stay muted in
	   Off-White and Dark Gray so content — not chrome — carries the color.
	   Navy remains available in the palette above but is not used by any
	   default — reach for it only as a last resort. */
	--sibec-accent: var(--sib-burgundy-500);
	--sibec-border: var(--sib-offwhite-700);
	--sibec-card-bg: var(--sib-offwhite-100);

	--sibec-head-bg: var(--sib-burgundy-500);
	--sibec-head-text: var(--sib-offwhite-100);
	--sibec-today: var(--sib-mustard-500);
	--sibec-today-text: var(--sib-darkgray-900);
	--sibec-filter-bg: var(--sib-offwhite-300);
	--sibec-filter-text: var(--sib-darkgray-700);
	--sibec-filter-hover-bg: var(--sib-darkgray-700);
	--sibec-filter-hover-text: var(--sib-offwhite-100);

	margin: 0 0 2em;
}

/* ------------------------------------------------------------ Filter bar */

.sibec-filters {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.6em 1em;
	margin-bottom: 1.1em;
}
.sibec-filters:empty { display: none; }

.sibec-filter {
	padding: 0.45em 0.9em;
	font: inherit;
	font-size: 0.88em;
	color: var(--sibec-filter-text);
	background: var(--sibec-filter-bg);
	border: 1px solid var(--sibec-border);
	border-radius: var(--sibec-radius);
}
.sibec-filter:focus-visible {
	outline: 2px solid var(--sibec-accent);
	outline-offset: 2px;
}
.sibec-filter--search { flex: 1 1 14em; min-width: 10em; }

.sibec-datejump { display: inline-flex; gap: 0.4em; }

/* Color-coded Event Type pills */
.sibec-pills { display: inline-flex; flex-wrap: wrap; gap: 0.4em; }

.sibec-pill {
	display: inline-flex;
	align-items: center;
	gap: 0.45em;
	padding: 0.4em 0.95em;
	font: inherit;
	font-size: 0.85em;
	color: var(--sibec-filter-text);
	background: var(--sibec-filter-bg);
	border: 1px solid var(--sibec-border);
	border-radius: 999px;
	cursor: pointer;
	transition: background-color 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}
.sibec-pill::before {
	content: "";
	width: 0.7em;
	height: 0.7em;
	border-radius: 50%;
	background: var(--sibec-ev, var(--sibec-accent));
}
.sibec-pill:hover {
	background: var(--sibec-filter-hover-bg);
	border-color: var(--sibec-filter-hover-bg);
	color: var(--sibec-filter-hover-text);
}
.sibec-pill.is-active {
	background: var(--sibec-ev, var(--sibec-accent));
	border-color: var(--sibec-ev, var(--sibec-accent));
	color: #fff;
}
.sibec-pill:focus-visible { outline: 2px solid var(--sibec-accent); outline-offset: 2px; }

/* --------------------------------------------------------------- Toolbar */

.sibec-toolbar {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 0.75em;
	margin-bottom: 1em;
}

.sibec-toolbar__title {
	order: -1;
	flex: 1 1 100%;
	margin: 0;
	font-size: 1.35em;
	text-align: center;
}

@media (min-width: 760px) {
	.sibec-toolbar__title { order: 0; flex: 1; }
}

.sibec-toolbar__nav, .sibec-toolbar__views { display: inline-flex; flex-wrap: wrap; gap: 0.35em; }

.sibec-btn {
	padding: 0.45em 0.95em;
	font: inherit;
	font-size: 0.88em;
	line-height: 1.2;
	color: var(--sibec-filter-text);
	background: var(--sibec-filter-bg);
	border: 1px solid var(--sibec-border);
	border-radius: var(--sibec-radius);
	cursor: pointer;
	transition: background-color 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}
.sibec-btn:hover, .sibec-btn:focus-visible {
	background: var(--sibec-filter-hover-bg);
	border-color: var(--sibec-filter-hover-bg);
	color: var(--sibec-filter-hover-text);
}
.sibec-btn:focus-visible { outline: 2px solid var(--sibec-accent); outline-offset: 2px; }
.sibec-btn.is-active {
	background: var(--sibec-accent);
	border-color: var(--sibec-accent);
	color: #fff;
}

/* -------------------------------------------------- Month & Week grids */

.sibec-month {
	display: grid;
	grid-template-columns: repeat(7, minmax(0, 1fr));
	border: 1px solid var(--sibec-border);
	border-radius: var(--sibec-radius);
	overflow: hidden;
}

.sibec-month__weekday {
	padding: 0.55em 0.4em;
	font-size: 0.75em;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-align: center;
	text-transform: uppercase;
	color: var(--sibec-head-text);
	background: var(--sibec-head-bg);
	border-bottom: 1px solid var(--sibec-border);
}

.sibec-month__day {
	position: relative;
	box-sizing: border-box;
	min-height: 6.5em;
	padding: 0.35em;
	border-top: 1px solid var(--sibec-border);
	border-left: 1px solid var(--sibec-border);
	display: flex;
	flex-direction: column;
	gap: 2px;
}
.sibec-month__day:nth-child(7n + 8) { border-left: none; }

/* Week view: taller single row for more chips per day. */
.sibec-week .sibec-month__day { min-height: 14em; }

.sibec-month__day.is-outside { opacity: 0.38; }

.sibec-month__num { font-size: 0.78em; font-weight: 600; opacity: 0.75; }

.sibec-month__day.is-today .sibec-month__num {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.7em;
	height: 1.7em;
	border-radius: 50%;
	background: var(--sibec-today);
	color: var(--sibec-today-text, #fff);
	opacity: 1;
}
.sibec-month__day.is-today { box-shadow: inset 0 0 0 2px var(--sibec-today); }

.sibec-chip {
	display: block;
	overflow: hidden;
	padding: 0.15em 0.45em;
	font-size: 0.72em;
	line-height: 1.35;
	color: #fff;
	text-decoration: none;
	text-overflow: ellipsis;
	white-space: nowrap;
	background: var(--sibec-ev, var(--sibec-accent));
	border-radius: 4px;
}
.sibec-chip:hover, .sibec-chip:focus-visible { filter: brightness(1.12); color: #fff; }
.sibec-chip:focus-visible { outline: 2px solid currentColor; outline-offset: 1px; }
.sibec-chip--more { background: transparent; color: inherit; opacity: 0.7; font-weight: 600; }

@media (max-width: 600px) {
	.sibec-month__day { min-height: 4.2em; padding: 0.25em; }
	.sibec-week .sibec-month__day { min-height: 6em; }
	.sibec-chip { padding: 0; height: 6px; font-size: 0; border-radius: 3px; }
	.sibec-chip--more { display: none; }
}

/* ------------------------------------------------------------ Event card
   Shared by Day / List / Grid / Masonry / Carousel views. */

.sibec-card {
	display: flex;
	flex-direction: column;
	overflow: hidden;
	background: var(--sibec-card-bg);
	border: 1px solid var(--sibec-border);
	border-left: 4px solid var(--sibec-ev, var(--sibec-accent));
	border-radius: var(--sibec-radius);
	transition: box-shadow 0.2s ease, transform 0.2s ease;
}
.sibec-card:hover, .sibec-card:focus-within {
	box-shadow: 0 8px 22px rgba(0, 0, 0, 0.09);
	transform: translateY(-2px);
}
@media (prefers-reduced-motion: reduce) {
	.sibec-card, .sibec-card:hover { transform: none; transition: none; }
}

.sibec-card__media { display: block; aspect-ratio: 16 / 9; overflow: hidden; }
.sibec-card__img { display: block; width: 100%; height: 100%; object-fit: cover; }

.sibec-card__body {
	display: flex;
	flex-direction: column;
	gap: 0.45em;
	padding: 0.95em 1.1em;
}

.sibec-card__when {
	display: flex;
	align-items: center;
	gap: 0.5em;
	font-size: 0.82em;
	font-weight: 600;
	opacity: 0.8;
}
.sibec-card__recurring { font-size: 1.1em; color: var(--sibec-ev, var(--sibec-accent)); }

.sibec-card__title { margin: 0; font-size: 1.05em; line-height: 1.35; }
.sibec-card__title a { color: inherit; text-decoration: none; }
.sibec-card__title a:hover, .sibec-card__title a:focus { color: var(--sibec-accent); }

.sibec-card__meta { display: flex; flex-wrap: wrap; align-items: center; gap: 0.5em 0.9em; font-size: 0.8em; }
.sibec-card__badge {
	padding: 0.1em 0.65em;
	font-weight: 600;
	letter-spacing: 0.04em;
	color: #fff;
	text-transform: uppercase;
	background: var(--sibec-ev, var(--sibec-accent));
	border-radius: 999px;
}
.sibec-card__loc::before { content: "\1F4CD\00A0"; }
.sibec-card__org { opacity: 0.75; }

.sibec-card__excerpt { margin: 0; font-size: 0.9em; opacity: 0.8; }

.sibec-card__actions { display: flex; flex-wrap: wrap; gap: 0.5em 1.2em; margin-top: 0.35em; }
.sibec-card__action {
	font-size: 0.82em;
	font-weight: 600;
	color: var(--sibec-accent);
	text-decoration: none;
}
.sibec-card__action:hover, .sibec-card__action:focus { text-decoration: underline; }

/* -------------------------------------------------- List / Agenda / Day */

.sibec-agenda { display: flex; flex-direction: column; gap: 0.7em; }
.sibec-agenda .sibec-card { flex-direction: row; }
.sibec-agenda .sibec-card__body { flex: 1; }
@media (max-width: 500px) { .sibec-agenda .sibec-card { flex-direction: column; } }

/* ------------------------------------------------------------- Grid view */

.sibec-grid {
	display: grid;
	gap: var(--sibec-gap);
	grid-template-columns: 1fr;
}
@media (min-width: 600px) { .sibec-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (min-width: 992px) { .sibec-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } }

/* ---------------------------------------------------------- Masonry view */

.sibec-masonry { column-gap: var(--sibec-gap); }
.sibec-masonry .sibec-card { break-inside: avoid; margin-bottom: var(--sibec-gap); }
@media (min-width: 600px) { .sibec-masonry { column-count: 2; } }
@media (min-width: 992px) { .sibec-masonry { column-count: 3; } }

/* --------------------------------------------------------- Carousel view */

.sibec-carousel { position: relative; }
.sibec-carousel__viewport { overflow: hidden; }
.sibec-carousel__track {
	display: flex;
	gap: var(--sibec-gap);
	transition: transform 0.45s ease;
}
@media (prefers-reduced-motion: reduce) { .sibec-carousel__track { transition: none; } }
.sibec-carousel__slide { flex: none; width: 100%; display: flex; }
.sibec-carousel__slide .sibec-card { width: 100%; }

.sibec-carousel__arrow {
	position: absolute;
	top: 50%;
	z-index: 2;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.6em;
	height: 2.6em;
	color: inherit;
	background: var(--sibec-card-bg);
	border: 1px solid var(--sibec-border);
	border-radius: 50%;
	box-shadow: 0 3px 10px rgba(0, 0, 0, 0.12);
	cursor: pointer;
	transform: translateY(-50%);
}
.sibec-carousel__arrow--prev { left: -0.4em; }
.sibec-carousel__arrow--next { right: -0.4em; }
.sibec-carousel__arrow:hover, .sibec-carousel__arrow:focus-visible {
	background: var(--sibec-accent);
	border-color: var(--sibec-accent);
	color: #fff;
}
.sibec-carousel__arrow[disabled] { opacity: 0.35; cursor: default; }
.sibec-carousel__arrow:focus-visible { outline: 2px solid var(--sibec-accent); outline-offset: 2px; }

/* -------------------------------------------------------- Pagination */

.sibec-pagination {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 0.4em;
	margin-top: 1.2em;
}
.sibec-pagination__btn { min-width: 2.4em; justify-content: center; }
.sibec-pagination__btn[disabled] { opacity: 0.4; cursor: default; }
.sibec-pagination__btn[disabled]:hover {
	background: var(--sibec-filter-bg);
	border-color: var(--sibec-border);
	color: var(--sibec-filter-text);
}
.sibec-pagination__gap { padding: 0 0.2em; opacity: 0.6; }

/* ------------------------------------------------------------------ Misc */

.sibec-empty { padding: 1.5em 0; font-style: italic; text-align: center; opacity: 0.75; }
