/* ==========================================================================
   Event Master Pro — Frontend Styles
   ========================================================================== */

/* ── Variables ───────────────────────────────────────────────────────────── */
:root {
	--emp-gap: 1.5rem;
	--emp-radius: 12px;
	--emp-shadow: 0 4px 20px rgba(0, 0, 0, .08);
	--emp-shadow-hv: 0 8px 30px rgba(0, 0, 0, .14);
	--emp-accent: #6c63ff;
	--emp-accent-hv: #574fd6;
	--emp-text: #1a1a2e;
	--emp-meta: #666;
	--emp-bg-card: #ffffff;
	--emp-transition: .25s ease;
}

/* ── Wrapper ─────────────────────────────────────────────────────────────── */
.emp-widget-wrapper {
	position: relative;
	width: 100%;
}

/* ── Grid ────────────────────────────────────────────────────────────────── */
.emp-grid {
	display: grid;
	grid-template-columns: repeat(var(--emp-cols, 3), 1fr);
	gap: var(--emp-gap);
	width: 100%;
}

/* ── Card ────────────────────────────────────────────────────────────────── */
.emp-card {
	background-color: var(--emp-bg-card);
	border-radius: var(--emp-radius);
	box-shadow: var(--emp-shadow);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: transform var(--emp-transition), box-shadow var(--emp-transition);
}

.emp-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--emp-shadow-hv);
}

/* ── Card image ──────────────────────────────────────────────────────────── */
.emp-card__image {
	position: relative;
	overflow: hidden;
	background-color: #f0f0f5;
	display: block;
	min-height: 356px;
}

.emp-card__image--placeholder {
	background: linear-gradient(135deg, #e8e8f5 0%, #d0d0e8 100%);
}

.emp-card__image a {
	display: block;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
}

.emp-card__img {
	width: 100%;
	height: 100%;
	min-width: 100%;
	max-width: none !important;
	margin: 0;
	padding: 0;
	/* Consume las custom properties que Elementor escribe en .emp-card__image.
	   Los valores por defecto garantizan que las imágenes siempre llenen el contenedor. */
	object-fit: var(--emp-img-fit, cover);
	object-position: var(--emp-img-pos, center center);
	display: block;
	transition: transform .4s ease;
	min-height: 100%;
}

.emp-card:hover .emp-card__img {
	transform: scale(1.04);
}

/* ── Card body ───────────────────────────────────────────────────────────── */
.emp-card__body {
	padding: 1.25rem 1.5rem 1.5rem;
	display: flex;
	flex-direction: column;
	flex: 1;
	gap: .75rem;
}

/* ── Title ───────────────────────────────────────────────────────────────── */
.emp-card__title {
	font-size: 1.1rem;
	font-weight: 700;
	margin: 0;
	color: var(--emp-text);
	line-height: 1.3;
}

.emp-card__title a {
	color: inherit;
	text-decoration: none;
	transition: color var(--emp-transition);
}

.emp-card__title a:hover {
	color: var(--emp-accent);
}

/* ── Meta (date + time) ──────────────────────────────────────────────────── */
.emp-card__meta {
	display: flex;
	flex-wrap: wrap;
	gap: .5rem .875rem;
	color: var(--emp-meta);
	font-size: .875rem;
}

.emp-card__fecha,
.emp-card__hora,
.emp-card__donde {
	display: inline-flex;
	align-items: center;
	gap: .3rem;
}

.emp-icon {
	width: 1em;
	height: 1em;
	fill: currentColor;
	flex-shrink: 0;
}

/* ── Footer / Button ─────────────────────────────────────────────────────── */
.emp-card__footer {
	margin-top: auto;
	padding-top: .5rem;
}

.emp-card__btn {
	display: inline-block;
	padding: .55rem 1.25rem;
	background-color: var(--emp-accent);
	color: #fff;
	font-size: .875rem;
	font-weight: 600;
	text-decoration: none;
	border-radius: 8px;
	border: none;
	cursor: pointer;
	transition: background-color var(--emp-transition), transform var(--emp-transition);
}

.emp-card__btn:hover,
.emp-card__btn:focus-visible {
	background-color: var(--emp-accent-hv);
	transform: translateY(-1px);
	color: #fff;
	text-decoration: none;
}

/* ── No events ───────────────────────────────────────────────────────────── */
.emp-no-events {
	grid-column: 1 / -1;
	text-align: center;
	color: var(--emp-meta);
	padding: 2rem 0;
}

/* ── Pagination ──────────────────────────────────────────────────────────── */
.emp-pagination {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 1rem;
	margin-top: 2rem;
	flex-wrap: wrap;
}

/* Ajax pagination */
.emp-page-btn {
	display: inline-flex;
	align-items: center;
	gap: .4rem;
	padding: .55rem 1.25rem;
	background-color: var(--emp-accent);
	color: #fff;
	border: none;
	border-radius: 8px;
	font-size: .875rem;
	font-weight: 600;
	cursor: pointer;
	transition: background-color var(--emp-transition), transform var(--emp-transition), opacity var(--emp-transition);
}

.emp-page-btn:hover:not(:disabled) {
	background-color: var(--emp-accent-hv);
	transform: translateY(-1px);
}

.emp-page-btn:disabled {
	opacity: .4;
	cursor: not-allowed;
}

.emp-page-info {
	font-size: .875rem;
	color: var(--emp-meta);
	min-width: 4rem;
	text-align: center;
}

/* Standard WP pagination */
.emp-pagination--standard .page-numbers {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	gap: .5rem;
	flex-wrap: wrap;
	justify-content: center;
}

.emp-pagination--standard .page-numbers li {
	margin: 0;
}

.emp-pagination--standard .page-numbers a,
.emp-pagination--standard .page-numbers span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.25rem;
	height: 2.25rem;
	border-radius: 6px;
	font-size: .875rem;
	font-weight: 600;
	color: var(--emp-text);
	text-decoration: none;
	background-color: #f5f5fa;
	transition: background-color var(--emp-transition), color var(--emp-transition);
}

.emp-pagination--standard .page-numbers a:hover {
	background-color: var(--emp-accent);
	color: #fff;
}

.emp-pagination--standard .page-numbers .current {
	background-color: var(--emp-accent);
	color: #fff;
}

/* ── Spinner ─────────────────────────────────────────────────────────────── */
.emp-spinner {
	display: none;
	position: absolute;
	inset: 0;
	background: rgba(255, 255, 255, .75);
	z-index: 10;
	align-items: center;
	justify-content: center;
	border-radius: var(--emp-radius);
}

.emp-spinner.is-loading {
	display: flex;
}

.emp-spinner__ring {
	width: 40px;
	height: 40px;
	border: 4px solid #e0e0e0;
	border-top-color: var(--emp-accent);
	border-radius: 50%;
	animation: emp-spin .7s linear infinite;
}

@keyframes emp-spin {
	to {
		transform: rotate(360deg);
	}
}

/* ── Responsive Utilities ────────────────────────────────────────────────── */
@media (max-width: 1024px) {
	.emp-grid {
		grid-template-columns: repeat(var(--emp-cols-tablet, var(--emp-cols, 2)), 1fr);
	}
}

@media (max-width: 767px) {
	.emp-grid {
		grid-template-columns: repeat(var(--emp-cols-mobile, 1), 1fr);
	}
}