/**
 * Snap Events - Frontend Styles
 *
 * Styles for the Events Grid & List block display.
 */

/* ==========================================================================
   Grid Layout
   ========================================================================== */

.snap-events-grid {
    display: grid;
}

/* Column variations */
.snap-events-columns-1 {
    grid-template-columns: 1fr;
}

.snap-events-columns-2 {
    grid-template-columns: repeat(2, 1fr);
}

.snap-events-columns-3 {
    grid-template-columns: repeat(3, 1fr);
}

.snap-events-columns-4 {
    grid-template-columns: repeat(4, 1fr);
}

/* ==========================================================================
   Event Card
   ========================================================================== */

.snap-event-card {
    display: flex;
    flex-direction: column;
}

/* ==========================================================================
   Card Image
   ========================================================================== */

.snap-event-image {
    margin-bottom: 20px;
}

.snap-event-image img {
    width: 100%;
    height: auto;
    display: block;
}

/* ==========================================================================
   Card Content
   ========================================================================== */

.snap-event-content {
    flex: 1;
    display: flex;
    flex-direction: column;
}

.snap-event-title {
    font-size: 18px;
    font-weight: 700;
    line-height: 1.3;
    margin: 0 0 15px 0;
}

.snap-event-title a {
    color: var(--card-heading-color, var(--list-heading-color, #000000));
    text-decoration: none;
}

.snap-event-title a:hover {
    text-decoration: underline;
}

.snap-event-title a:focus-visible {
    outline: 2px solid currentColor;
    outline-offset: 2px;
}

.snap-event-date,
.snap-event-venue,
.snap-event-location {
    font-size: 14px;
    color: inherit;
    margin: 0 0 2px 0;
}

.snap-event-excerpt,
.snap-event-link {
    margin-top: 10px;
}

.snap-event-date strong,
.snap-event-venue strong,
.snap-event-location strong {
    font-weight: bold;
    color: var(--card-heading-color, var(--list-heading-color, #000000));
}

.snap-event-excerpt {
    font-size: 16px;
    font-weight: 400;
    line-height: 1.5;
    color: inherit;
    margin-bottom: 20px;
}

/* ==========================================================================
   Card Link
   ========================================================================== */

.snap-event-link {
    margin-top: auto;
    color: var(--card-link-color, var(--list-link-color, #0073aa));
    text-decoration: underline;
    text-transform: uppercase;
    font-size: 14px;
    font-weight: 700;
}

.snap-event-link:hover {
    text-decoration: none;
}

/* ==========================================================================
   Empty State
   ========================================================================== */

.snap-events-no-events {
    text-align: center;
    padding: 40px;
    color: #666;
}

/* ==========================================================================
   Responsive
   ========================================================================== */

/* Tablet */
@media (max-width: 980px) {
    .snap-events-columns-3,
    .snap-events-columns-4 {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* Mobile */
@media (max-width: 767px) {
    .snap-events-columns-2,
    .snap-events-columns-3,
    .snap-events-columns-4 {
        grid-template-columns: 1fr;
    }
}
