/* ==============================================
   ZELFSPOT EVENTS DISPLAY
   Branding: cream #EBE6D7 / bordeaux #5C1F1C / goud #EAD786
   ============================================== */

/* --- Shared tokens --- */
:root {
    --zs-cream: #EBE6D7;
    --zs-cream-light: #FFFDF5;
    --zs-bordeaux: #5C1F1C;
    --zs-gold: #EAD786;
    --zs-black: #000000;
    --zs-text: #333333;
    --zs-muted: #666666;
    --zs-font-head: "Right Grotesk Wide Medium", Helvetica, sans-serif;
    --zs-font-body: "KOBE regular", Helvetica, sans-serif;
}

/* ==============================================
   EVENT GRID (homepage)
   ============================================== */

.zs-events-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 24px;
    max-width: 1200px;
    margin: 40px auto;
    padding: 0 20px;
}

.zs-event-card {
    display: flex;
    flex-direction: column;
    background: var(--zs-cream-light);
    border-radius: 16px;
    overflow: hidden;
    text-decoration: none;
    color: var(--zs-text);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
}

.zs-event-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.12);
}

.zs-event-card__media {
    position: relative;
    aspect-ratio: 1 / 1;
    overflow: hidden;
    background: var(--zs-cream);
}

.zs-event-card__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.zs-event-card__date-badge {
    position: absolute;
    top: 16px;
    left: 16px;
    background: var(--zs-cream-light);
    padding: 10px 14px;
    border-radius: 10px;
    display: flex;
    flex-direction: column;
    align-items: center;
    min-width: 60px;
    z-index: 2;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
}

.zs-event-card__date-day {
    font-family: var(--zs-font-head);
    font-size: 24px;
    font-weight: 500;
    color: var(--zs-bordeaux);
    line-height: 1;
}

.zs-event-card__date-month {
    font-family: var(--zs-font-body);
    font-size: 12px;
    color: var(--zs-bordeaux);
    text-transform: lowercase;
    margin-top: 2px;
}

.zs-event-card__body {
    padding: 20px 24px 24px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.zs-event-card__title {
    font-family: var(--zs-font-head);
    font-size: 22px;
    font-weight: 500;
    color: var(--zs-black);
    margin: 0 0 6px;
    line-height: 1.2;
}

.zs-event-card__meta {
    font-family: var(--zs-font-body);
    font-size: 14px;
    color: var(--zs-text);
    margin: 0;
    display: flex;
    align-items: center;
    gap: 8px;
}

.zs-event-card__icon {
    display: inline-block;
    font-size: 14px;
    opacity: 0.7;
}

.zs-event-card__excerpt {
    font-family: var(--zs-font-body);
    font-size: 14px;
    color: var(--zs-muted);
    margin: 8px 0 0;
    line-height: 1.5;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.zs-event-card__cost {
    font-family: var(--zs-font-head);
    font-size: 16px;
    color: var(--zs-bordeaux);
    margin: 8px 0 0;
    font-weight: 500;
}

.zs-events-empty {
    text-align: center;
    padding: 40px;
    color: var(--zs-muted);
    font-family: var(--zs-font-body);
}

/* ==============================================
   SINGLE EVENT DETAILS
   ============================================== */

.zs-event-details {
    max-width: 1100px;
    margin: 0 auto 40px;
    padding: 0 20px;
}

.zs-event-details__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 20px;
    margin-bottom: 30px;
}

.zs-event-details__box {
    background: var(--zs-cream);
    border-radius: 16px;
    padding: 24px;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
}

.zs-event-details__icon {
    font-size: 28px;
    color: var(--zs-bordeaux);
    margin-bottom: 4px;
}

.zs-event-details__label {
    font-family: var(--zs-font-body);
    font-size: 14px;
    color: var(--zs-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.zs-event-details__value {
    font-family: var(--zs-font-head);
    font-size: 22px;
    color: var(--zs-black);
    font-weight: 500;
}

.zs-event-details__info-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 20px;
}

.zs-event-details__card {
    background: var(--zs-cream-light);
    border-radius: 16px;
    padding: 28px;
    border: 1px solid rgba(0, 0, 0, 0.06);
}

.zs-event-details__heading {
    font-family: var(--zs-font-head);
    font-size: 24px;
    color: var(--zs-black);
    margin: 0 0 16px;
    font-weight: 500;
    border-bottom: 2px solid var(--zs-gold);
    padding-bottom: 10px;
    display: inline-block;
}

.zs-event-details__name {
    font-family: var(--zs-font-body);
    font-size: 16px;
    color: var(--zs-text);
    margin: 0 0 8px;
    font-weight: 600;
}

.zs-event-details__address {
    font-family: var(--zs-font-body);
    font-size: 15px;
    color: var(--zs-text);
    margin: 0 0 12px;
    line-height: 1.5;
}

.zs-event-details__contact {
    font-family: var(--zs-font-body);
    font-size: 14px;
    color: var(--zs-text);
    margin: 6px 0;
    display: flex;
    align-items: center;
    gap: 8px;
}

.zs-event-details__contact-icon {
    font-size: 14px;
    opacity: 0.7;
}

.zs-event-details__contact a {
    color: var(--zs-bordeaux);
    text-decoration: underline;
    text-decoration-color: var(--zs-gold);
    text-decoration-thickness: 2px;
    text-underline-offset: 3px;
}

.zs-event-details__contact a:hover {
    color: var(--zs-black);
}

.zs-event-details__cost {
    font-family: var(--zs-font-head);
    font-size: 24px;
    color: var(--zs-bordeaux);
    margin: 0 0 12px;
    font-weight: 500;
}

.zs-event-details__btn {
    display: inline-block;
    background: var(--zs-gold);
    color: var(--zs-black);
    padding: 10px 20px;
    border-radius: 50px;
    border: 1px solid var(--zs-black);
    text-decoration: none;
    font-family: var(--zs-font-head);
    font-size: 14px;
    transition: all 0.2s ease;
}

.zs-event-details__btn:hover {
    background: var(--zs-black);
    color: var(--zs-gold);
}

/* ==============================================
   HIDE LEGACY EMPTY DIVI MODULES
   Op event pagina's zijn er nog oude Divi text-modules die voorheen
   door DECM gevuld werden via dynamic content. Verberg lege cards.
   ============================================== */

body.single-tribe_events .et_pb_column .et_pb_text:has(> .et_pb_text_inner:empty),
body.single-tribe_events .et_pb_row:has(> .et_pb_column > .et_pb_text_inner:empty) .et_pb_text:has(> .et_pb_text_inner:empty) {
    display: none !important;
}

/* Fallback: verberg Divi rows die alleen drie text modules met een h3/h4 bevatten
   en geen andere content (de lege Organizator/Locatie/Info row). */
body.single-tribe_events .et_pb_row.et_pb_equal_columns:has(> .et_pb_column:empty),
body.single-tribe_events .et_pb_row.et_pb_equal_columns:has(> .et_pb_column > .et_pb_text:only-child:has(h3:only-child)),
body.single-tribe_events .et_pb_row.et_pb_equal_columns:has(> .et_pb_column > .et_pb_text:only-child:has(h4:only-child)) {
    display: none !important;
}

/* ==============================================
   RESPONSIVE
   ============================================== */

@media (max-width: 768px) {
    .zs-events-grid {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .zs-event-details__grid {
        grid-template-columns: 1fr;
    }

    .zs-event-details__info-grid {
        grid-template-columns: 1fr;
    }

    .zs-event-card__title {
        font-size: 20px;
    }
}
