/* EVENTS */
/* Wrapper */
.ek-events.ek-events--stack {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
}

/* Each event card */
.ek-event {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 1rem;
    padding: 1.25rem 1.5rem;
    border-radius: 0.75rem;
    border: 1px solid rgba(0, 0, 0, 0.06);
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.03);
    background: #ffffff;
    align-items: flex-start;
}

/* Date badge */
.ek-event-date-badge {
    width: 3.5rem;
    height: 3.5rem;
    border-radius: 0.75rem;
    background: #f3f4f6;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    font-weight: 600;
    text-transform: uppercase;
    line-height: 1.1;
}

.ek-event-date-month {
    font-size: 0.7rem;
    letter-spacing: 0.08em;
    opacity: 0.7;
}

.ek-event-date-day {
    font-size: 1.4rem;
}

/* Content */
.ek-event-content {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

/* Header */
.ek-event-header {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.ek-event-title {
    margin: 0;
    font-size: 1.1rem;
    font-weight: 600;
}

/* Date / time line */
.ek-event-datetime {
    font-size: 0.9rem;
    color: #4b5563;
}

.ek-event-datetime-separator {
    margin: 0 0.35rem;
}

/* Location */
.ek-event-location {
    font-size: 0.9rem;
    color: #6b7280;
}

/* Description */
.ek-event-description {
    margin-top: 0.5rem;
    font-size: 0.95rem;
    color: #374151;
}

/* Mobile stacking */
@media (max-width: 640px) {
    .ek-event {
        grid-template-columns: 1fr;
    }

    .ek-event-date-badge {
        width: 3rem;
        height: 3rem;
    }
}
/* ========================================
   GRID / CARD LAYOUT (layout="grid")
======================================== */

.ek-events.ek-events--grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.5rem;
    align-items: stretch; /* equal-height rows */
}

/* Tablet */
@media (max-width: 1024px) {
    .ek-events.ek-events--grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

/* Mobile */
@media (max-width: 640px) {
    .ek-events.ek-events--grid {
        grid-template-columns: 1fr;
    }
}

/* Ensure each card stretches fully */
.ek-events.ek-events--grid .ek-event {
    height: 100%;
    display: grid; /* keeps your badge/content layout */
}

/* Make content fill the card vertically */
.ek-events.ek-events--grid .ek-event-content {
    display: flex;
    flex-direction: column;
    height: 100%;
}

/* Optional: push CTA to bottom for tidy cards */
.ek-events.ek-events--grid .ek-event-footer,
.ek-events.ek-events--grid .ek-event-link {
    margin-top: auto;
}

.ek-event-contact {
    margin-top: 0.5rem;
    font-size: 0.9rem;
    color: #4b5563;
    font-weight: 500;
}
/* Events Query CSS */
.ek-events-filters { margin-bottom: 1.5rem; }
.ek-events-filters__row { display:flex; flex-wrap:wrap; gap:1rem 1.5rem; align-items:end; }
.ek-events-filters__tags { display:flex; flex-wrap:wrap; gap:.75rem 1rem; }
.ek-events-filters__check { display:inline-flex; gap:.5rem; align-items:center; cursor:pointer; }

/*Single Event Page Style*/
.ek-event-single-article {
    max-width: 800px;
    margin: 2rem auto;
    padding: 2rem;
    background: #ffffff;
    border-radius: 0.75rem;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.06);
    border: 1px solid rgba(0, 0, 0, 0.06);
}

.ek-event-single-header {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 1rem;
    align-items: center;
    margin-bottom: 1.5rem;
}

.ek-event-single-header-text {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.ek-event-single-title {
    margin: 0;
    font-size: 1.6rem;
}

.ek-event-single-datetime {
    font-size: 0.95rem;
    color: #4b5563;
}

.ek-event-single-location {
    font-size: 0.95rem;
    color: #6b7280;
}

.ek-event-single-body {
    font-size: 1rem;
    color: #374151;
    margin-top: 1rem;
}

.ek-event-single-footer {
    margin-top: 2rem;
}
/* Page wrapper for events shortcode */
.ek-events-page {
    width: 100%;
}
/* =========================================================
   FIX: Tiny event cards on some sites
   Forces sane sizing regardless of site root font-size
   ========================================================= */

.ek-events { font-size: 16px !important; }

/* Card */
.ek-event {
  gap: 16px !important;
  padding: 20px 24px !important;
  border-radius: 12px !important;
}

/* Date badge */
.ek-event-date-badge {
  width: 56px !important;
  height: 56px !important;
  border-radius: 12px !important;
}

.ek-event-date-month {
  font-size: 11px !important;
}

.ek-event-date-day {
  font-size: 22px !important;
}

/* Typography */
.ek-event-title {
  font-size: 18px !important;
}

.ek-event-datetime,
.ek-event-location,
.ek-event-contact {
  font-size: 14px !important;
}

.ek-event-description {
  font-size: 15px !important;
}