/*
 * Super Events Calendar — Featured Events
 *
 * Styles for the [sec_featured_events] shortcode and the matching
 * Elementor widget. Layout variants:
 *
 *   .sec-featured--image-left   image left, content right (rows)
 *   .sec-featured--image-right  image right, content left (rows)
 *   .sec-featured--zigzag       alternates per row
 *   .sec-featured--grid         image-on-top cards in N columns
 *   .sec-featured--template-grid saved Elementor template per event
 *
 * CSS custom properties drive Elementor controls so authored styles
 * cleanly override the defaults.
 */

.sec-featured {
	--sec-featured-gap: 32px;
	--sec-featured-content-gap: 12px;
	--sec-featured-image-ratio: 4 / 3;
	--sec-featured-image-radius: 4px;
	--sec-featured-mobile-breakpoint: 600px;
	--sec-featured-columns: 3;

	box-sizing: border-box;
	display: flex;
	flex-direction: column;
	gap: var(--sec-featured-gap);
	margin: 0;
	padding: 0;
}

.sec-featured *,
.sec-featured *::before,
.sec-featured *::after {
	box-sizing: inherit;
}

/* ---------------------------------------------------------------
 * Item shell
 * ------------------------------------------------------------- */
.sec-featured__item {
	display: flex;
	flex-direction: row;
	align-items: center;
	gap: var(--sec-featured-gap);
	margin: 0;
	padding: 0;
}

.sec-featured__media {
	display: block;
	flex: 1 1 50%;
	overflow: hidden;
	border-radius: var(--sec-featured-image-radius);
	line-height: 0;
	text-decoration: none;
}

.sec-featured__media img {
	display: block;
	width: 100%;
	height: 100%;
	max-width: 100%;
	aspect-ratio: var(--sec-featured-image-ratio);
	object-fit: cover;
}

.sec-featured__content {
	flex: 1 1 50%;
	display: flex;
	flex-direction: column;
	gap: var(--sec-featured-content-gap);
}

.sec-featured__date {
	font-size: 0.875em;
	letter-spacing: 0.02em;
	text-transform: uppercase;
	opacity: 0.8;
}

.sec-featured__time {
	display: inline-block;
	margin-left: 0.5em;
	opacity: 0.85;
}

.sec-featured__title {
	margin: 0;
	font-size: 1.5em;
	line-height: 1.25;
}

.sec-featured__title a {
	color: inherit;
	text-decoration: none;
}

.sec-featured__title a:hover,
.sec-featured__title a:focus {
	text-decoration: underline;
}

.sec-featured__venue {
	font-size: 0.95em;
	opacity: 0.85;
}

.sec-featured__excerpt {
	font-size: 1em;
	line-height: 1.55;
}

.sec-featured__button {
	align-self: flex-start;
	display: inline-block;
	padding: 0.6em 1.2em;
	border: 1px solid currentColor;
	border-radius: 3px;
	background-color: transparent;
	color: inherit;
	font-size: 0.95em;
	text-decoration: none;
	cursor: pointer;
	transition: background-color 0.15s ease, color 0.15s ease, border-color 0.15s ease, opacity 0.15s ease;
}

.sec-featured__button:hover,
.sec-featured__button:focus {
	opacity: 0.8;
}

/* ---------------------------------------------------------------
 * Layout: image-right (all rows mirrored)
 * ------------------------------------------------------------- */
.sec-featured--image-right .sec-featured__item {
	flex-direction: row-reverse;
}

/* ---------------------------------------------------------------
 * Layout: zigzag (alternating rows)
 * ------------------------------------------------------------- */
.sec-featured--zigzag .sec-featured__item--reversed {
	flex-direction: row-reverse;
}

/* ---------------------------------------------------------------
 * Layout: grid (image-on-top cards)
 * ------------------------------------------------------------- */
.sec-featured--grid {
	display: grid;
	grid-template-columns: repeat(var(--sec-featured-columns, 3), minmax(0, 1fr));
	gap: var(--sec-featured-gap);
}

.sec-featured--cols-1 { --sec-featured-columns: 1; }
.sec-featured--cols-2 { --sec-featured-columns: 2; }
.sec-featured--cols-3 { --sec-featured-columns: 3; }
.sec-featured--cols-4 { --sec-featured-columns: 4; }
.sec-featured--cols-5 { --sec-featured-columns: 5; }
.sec-featured--cols-6 { --sec-featured-columns: 6; }

.sec-featured--grid .sec-featured__item {
	flex-direction: column;
	align-items: stretch;
}

.sec-featured--grid .sec-featured__media,
.sec-featured--grid .sec-featured__content {
	flex: 0 0 auto;
	width: 100%;
}

.sec-featured--grid .sec-featured__media img {
	aspect-ratio: var(--sec-featured-image-ratio);
}

/* ---------------------------------------------------------------
 * Layout: Elementor template per selected event
 * ------------------------------------------------------------- */
.sec-featured--template-grid {
	display: grid;
	grid-template-columns: repeat(var(--sec-featured-columns, 1), minmax(0, 1fr));
	gap: var(--sec-featured-gap);
}

.sec-featured__template-item {
	display: block;
	min-width: 0;
	width: 100%;
}

.sec-featured--template-grid > .sec-featured__template-item {
	display: block;
	min-width: 0;
}

.sec-featured__template-item > * {
	display: block;
	width: 100%;
	max-width: 100%;
	height: 100%;
}

/* ---------------------------------------------------------------
 * Single-event safety: never appear stretched on big screens
 * ------------------------------------------------------------- */
.sec-featured--single .sec-featured__item {
	max-width: 100%;
}

/* ---------------------------------------------------------------
 * Responsive: stack rows on small screens for non-grid layouts
 * ------------------------------------------------------------- */
@media (max-width: 600px) {
	.sec-featured--image-left .sec-featured__item,
	.sec-featured--image-right .sec-featured__item,
	.sec-featured--zigzag .sec-featured__item,
	.sec-featured--zigzag .sec-featured__item--reversed {
		flex-direction: column;
		align-items: stretch;
	}

	.sec-featured--grid {
		grid-template-columns: 1fr;
	}

	.sec-featured--template-grid {
		grid-template-columns: 1fr;
	}
}
