/* ==========================================================================
   GS Venue Blocks — events.css  (V3 — Variant 1: V2 Classic+)
   Event list rendered by acf/gs-events.
   Each event = horizontal card: name+desc on left, schedule pill on right.
   Hover inverts to solid black with subtle lift. Footer CTA links to the
   /event-organisers/ pillar page beneath the list.

   MOBILE SPECIFICITY FIX (2026-04-20):
   Events is the only venue block that renders its card as <article> (others
   use <div>), which makes it uniquely vulnerable to GeneratePress mobile
   CSS that resets article chrome at ≤768px. Desktop was fine because GP's
   reset is inside a media query that doesn't fire. On mobile, GP's rule
   and our class-level !important tied on specificity and GP won on source
   order — stripping background/border/radius and the pill badge.
   Fix: scope all card rules under `.gs-venue__events .gs-venue__event`
   (specificity 0,2,0) so they outrank any bare `article` selector (0,0,1)
   regardless of !important or source order. PHP and HTML unchanged.
   ========================================================================== */

/* List wrapper */
.gs-venue__events {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

/* Single event card — scoped under .gs-venue__events for specificity (0,2,0). */
.gs-venue__events .gs-venue__event {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    padding: 18px 22px;
    background: #fafafa !important;
    border: 1.5px solid #000 !important;
    border-radius: 14px !important;
    transition: background .2s ease, color .2s ease, transform .2s ease, box-shadow .2s ease;
}
.gs-venue__events .gs-venue__event:hover {
    background: #000 !important;
    color: #fff !important;
    transform: translateY(-1px);
    box-shadow: 0 6px 18px rgba(0, 0, 0, .18);
}

/* Left side — name + description */
.gs-venue__events .gs-venue__event-info { flex: 1; min-width: 0; }
.gs-venue__events .gs-venue__event-name {
    font-size: 15px;
    font-weight: 700;
    color: #000;
    transition: color .2s ease;
}
.gs-venue__events .gs-venue__event:hover .gs-venue__event-name { color: #fff; }
.gs-venue__events .gs-venue__event-desc {
    font-size: 13px;
    color: #000;
    margin-top: 4px;
    transition: color .2s ease;
}
.gs-venue__events .gs-venue__event:hover .gs-venue__event-desc { color: #fff; }
.gs-venue__events .gs-venue__event-desc p { margin: 0; }

/* Right side — schedule pill */
.gs-venue__events .gs-venue__event-badge {
    flex-shrink: 0;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #000 !important;
    background: #fff !important;
    border: 1.5px solid #000 !important;
    border-radius: 100px !important;
    padding: 6px 14px;
    white-space: nowrap;
    transition: background .2s ease, color .2s ease;
}
.gs-venue__events .gs-venue__event:hover .gs-venue__event-badge {
    background: #fff;
    color: #000;
}

/* Footer CTA — pillar link to /event-organisers/ (sibling of .gs-venue__events,
   not a descendant, so scope under .gs-venue__section instead for a matching
   specificity boost). */
.gs-venue__section .gs-venue__events-cta {
    margin-top: 18px;
    padding: 14px 20px;
    background: #fff !important;
    border: 1.5px dashed #000 !important;
    border-radius: 14px !important;
    font-size: 13px;
    color: #000;
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 8px 12px;
}
.gs-venue__section .gs-venue__events-cta-text {
    font-weight: 600;
    color: #000;
}
.gs-venue__section .gs-venue__events-cta-link {
    font-weight: 700;
    color: #000 !important;
    text-decoration: underline;
    text-decoration-thickness: 2px;
    text-underline-offset: 3px;
}
.gs-venue__section .gs-venue__events-cta-link:hover {
    color: #000 !important;
    text-decoration-thickness: 3px;
}

/* Mobile — stack badge below info (matches 640px breakpoint used across
   venue blocks). Drop the card out of flex to display:block so any
   unbreakable token inside .gs-venue__event-info (long word, URL) can't
   push min-width past the viewport. facilities.css dodges the same issue
   with display:grid; events uses block because the layout is one column
   with an inline pill. All selectors keep the 0,2,0 specificity scope. */
@media (max-width: 640px) {
    .gs-venue__events { gap: 10px; }
    .gs-venue__events .gs-venue__event {
        display: block;
        padding: 14px 16px;
        width: 100%;
        box-sizing: border-box;
        background: #fafafa !important;
        border: 1.5px solid #000 !important;
        border-radius: 14px !important;
    }
    .gs-venue__events .gs-venue__event-info {
        display: block;
        width: 100%;
        margin-bottom: 12px;
    }
    .gs-venue__events .gs-venue__event-name { font-size: 14px; }
    .gs-venue__events .gs-venue__event-desc { font-size: 12.5px; }
    .gs-venue__events .gs-venue__event-badge {
        display: inline-block;
        margin-left: 0;
        font-size: 10.5px;
        letter-spacing: 0.06em;
        padding: 5px 11px;
        white-space: normal;
        max-width: 100%;
        line-height: 1.3;
        color: #000 !important;
        background: #fff !important;
        border: 1.5px solid #000 !important;
        border-radius: 100px !important;
        overflow-wrap: break-word;
        word-wrap: break-word;
        word-break: break-word;
    }
    .gs-venue__section .gs-venue__events-cta {
        padding: 12px 14px;
        font-size: 12.5px;
        background: #fff !important;
        border: 1.5px dashed #000 !important;
        border-radius: 14px !important;
    }
}
