/* ============================================================
   TRENDING NOW — reusable dark carousel section
   Ported from SPL_Trending_Now.html. Everything is scoped under
   .spl-trending so it cannot collide with theme / event-listings.
   !important is used on text/link/heading props to beat the theme's
   `main a`, `main h2/h3`, `main p` !important rules.
   ============================================================ */

.spl-trending {
    /* design tokens (scoped) */
    --bg: #08070e;
    --bg-2: #0c0a16;
    --surface: #14111f;
    --border: rgba(255, 255, 255, 0.08);
    --border-2: rgba(255, 255, 255, 0.14);
    --text: #f5f3fa;
    --dim: rgba(247, 245, 252, 0.84);
    --mute: rgba(247, 245, 252, 0.64);
    --accent: #7a4fe0;
    --accent-2: #d06fd2;
    --grad: linear-gradient(118deg, #9e7bff 0%, #b45fe6 52%, #d06fd2 100%);
    --cta: #7a4fe0;
    --cta-hover: #8e66f2;
    --cta-press: #6840c8;
    --teal: #5fd0c6;
    --amber: #f0b35e;
    --amber-line: rgba(240, 179, 94, 0.40);
    --rad: 18px;
    --maxw: 1320px;
    --pad: 20px;
    --ease: cubic-bezier(.22, .61, .36, 1);
    /* --font-d / --font-b inherited from the global :root (theme style.css) */

    position: relative;
    font-family: var(--font-b);
    color: var(--text);
    background:
        radial-gradient(70% 40% at 50% 0%, rgba(122, 79, 224, 0.14), transparent 62%),
        var(--bg);
    padding: 46px 0 6px;
    overflow: hidden;
}

/* Full-bleed: WordPress's `alignfull` (added by the shortcode) is handled by the
   block theme's constrained layout to span the full content width. This fallback
   only applies if the surrounding layout doesn't already stretch alignfull. */
.spl-trending.alignfull {
    max-width: none;
}

.spl-trending *,
.spl-trending *::before,
.spl-trending *::after {
    box-sizing: border-box;
}

.spl-trending .wrap {
    max-width: var(--maxw);
    margin: 0 auto;
    padding: 0 clamp(20px, 4vw, 56px);
}

/* ---------- Row head ---------- */
.spl-trending .row-head {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 20px;
    margin-bottom: 22px;
}

.spl-trending .titles {
    min-width: 0;
}

.spl-trending .eyebrow {
    font-family: var(--font-b) !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    letter-spacing: 0.18em !important;
    text-transform: uppercase !important;
    background: var(--grad);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent !important;
    margin: 0 0 10px !important;
}

.spl-trending .row-head h2 {
    font-family: var(--font-d) !important;
    font-weight: 700 !important;
    font-size: clamp(24px, 2.6vw, 34px) !important;
    letter-spacing: -0.025em !important;
    line-height: 1.05 !important;
    color: var(--text) !important;
    margin: 0 !important;
    text-shadow: none !important;
}

.spl-trending .row-head h2 .g {
    background: var(--grad);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent !important;
}

.spl-trending .row-head .sub {
    font-family: var(--font-b) !important;
    color: var(--mute) !important;
    font-size: 14.5px !important;
    line-height: 1.5 !important;
    margin: 8px 0 0 !important;
    max-width: 460px !important;
}

/* ---------- Row actions ---------- */
.spl-trending .row-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-shrink: 0;
}

.spl-trending .viewall {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    font-family: var(--font-b) !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: var(--dim) !important;
    text-decoration: none !important;
    border: none !important;
    padding: 8px 4px !important;
    transition: color .2s !important;
    white-space: nowrap !important;
}

.spl-trending .viewall:hover {
    color: var(--text) !important;
    text-decoration: none !important;
}

.spl-trending .viewall svg {
    width: 16px;
    height: 16px;
    transition: transform .2s;
}

.spl-trending .viewall:hover svg {
    transform: translateX(3px);
}

.spl-trending .row-arrows {
    display: flex;
    gap: 8px;
}

.spl-trending .arrow {
    width: 42px;
    height: 42px;
    border-radius: 50%;
    border: 1px solid var(--border-2);
    background: rgba(255, 255, 255, 0.04);
    color: var(--text);
    display: grid;
    place-items: center;
    cursor: pointer;
    transition: all .22s var(--ease);
    padding: 0;
}

.spl-trending .arrow:hover:not(:disabled) {
    background: var(--grad);
    border-color: transparent;
    box-shadow: 0 10px 30px -8px rgba(122, 79, 224, 0.55);
}

.spl-trending .arrow:disabled {
    opacity: 0.32;
    cursor: default;
}

.spl-trending .arrow svg {
    width: 17px;
    height: 17px;
}

/* ---------- Track ---------- */
.spl-trending .track {
    display: flex;
    gap: 20px;
    overflow-x: auto;
    scroll-snap-type: x proximity;
    padding: 4px 0 14px;
    scrollbar-width: none;
    cursor: grab;
}

.spl-trending .track::-webkit-scrollbar {
    display: none;
}

.spl-trending .track.dragging {
    cursor: grabbing;
    scroll-snap-type: none;
}

.spl-trending .track.dragging * {
    pointer-events: none;
}

/* ---------- Card ---------- */
.spl-trending .card {
    position: relative;
    flex: 0 0 clamp(260px, 27vw, 312px);
    scroll-snap-align: start;
    color: inherit;
    border-radius: var(--rad);
    overflow: hidden;
    border: 1px solid var(--border);
    background: var(--surface);
    transition: transform .34s var(--ease), border-color .34s var(--ease), box-shadow .34s var(--ease);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    /* No card-wide click target: default cursor on the card surface (overrides
       the track's grab); only the inner links below opt back into pointer. */
    cursor: default;
}

.spl-trending .card:hover {
    transform: translateY(-6px);
    border-color: var(--border-2);
    box-shadow: 0 24px 50px -22px rgba(0, 0, 0, 0.85), 0 0 0 1px rgba(122, 79, 224, 0.18);
}

/* Only the individual links are clickable (competition, title, venue, watch,
   CTA). They keep their resting appearance and brighten slightly on hover. */
.spl-trending .card a {
    cursor: pointer;
}

.spl-trending .card h3 .title-link {
    color: var(--text) !important;
    text-decoration: none !important;
    transition: opacity .2s var(--ease) !important;
}

.spl-trending .card h3 .title-link:hover {
    opacity: 0.85 !important;
    text-decoration: underline !important;
}

.spl-trending .cat-tag .cat-link {
    color: var(--teal) !important;
    text-decoration: none !important;
    transition: opacity .2s var(--ease) !important;
}

.spl-trending .cat-tag .cat-link:hover {
    opacity: 0.85 !important;
    text-decoration: underline !important;
}

.spl-trending .cmeta .venue-link {
    color: inherit !important;
    text-decoration: none !important;
    transition: color .2s var(--ease) !important;
}

.spl-trending .cmeta .venue-link:hover {
    color: var(--text) !important;
    text-decoration: underline !important;
}

.spl-trending .card .media {
    position: relative;
    aspect-ratio: 16 / 10;
    overflow: hidden;
    /* Dark backing so the sub-pixel clip seam under the image can never flash
       white during the hover transform. (No transform/will-change here — that
       would make .media a stacking context and drop the fav button below the
       card overlay.) */
    background-color: var(--bg-2);
}

/* Keep the card on a stable GPU layer so the hover lift doesn't re-rasterise. */
.spl-trending .card {
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    will-change: transform;
}

/* Image has no hover zoom/transition (removed to avoid the edge-seam flash). */
.spl-trending .card .ph {
    position: absolute;
    inset: 0;
    background-color: #0c0a16;
}

.spl-trending .card .ph-img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.spl-trending .card .media .scrim {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(8, 7, 14, 0) 55%, rgba(8, 7, 14, 0.92) 100%);
}

.spl-trending .card .body {
    padding: 14px 16px 16px;
    display: flex;
    flex-direction: column;
    gap: 0;
}

.spl-trending .card h3 {
    font-family: var(--font-d) !important;
    font-weight: 600 !important;
    font-size: 18px !important;
    letter-spacing: -0.01em !important;
    line-height: 1.18 !important;
    color: var(--text) !important;
    margin: 0 !important;
    text-transform: none !important;
    text-shadow: none !important;
}

.spl-trending .cat-tag {
    font-family: var(--font-b) !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    letter-spacing: 0.13em !important;
    text-transform: uppercase !important;
    color: var(--teal) !important;
}

.spl-trending .cat-inline {
    display: block;
    margin-bottom: 7px;
}

.spl-trending .card .cmeta {
    display: flex;
    align-items: center;
    gap: 8px;
    color: var(--dim) !important;
    font-size: 13px !important;
    margin-top: 6px;
    min-width: 0;
}

.spl-trending .card .cmeta:first-of-type {
    margin-top: 8px;
}

.spl-trending .card .cmeta .emj {
    font-size: 12.5px;
    line-height: 1;
    flex-shrink: 0;
    filter: saturate(0.9);
}

.spl-trending .card .cmeta span:last-child {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* Watch-location row: keep its link clickable above the stretched card link */
.spl-trending .cmeta--watch .watch-link {
    position: relative;
    z-index: 4;
    color: var(--dim) !important;
    text-decoration: none !important;
    transition: color .2s var(--ease) !important;
}

.spl-trending .cmeta--watch .watch-link:hover {
    color: var(--text) !important;
    text-decoration: underline !important;
}

.spl-trending .card .price {
    font-family: var(--font-d) !important;
    font-weight: 600 !important;
    font-size: 15px !important;
    margin-top: 12px !important;
    color: #fff !important;
}

.spl-trending .card-cta {
    position: relative;
    z-index: 4;
    margin-top: 12px;
    width: 100%;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    gap: 7px;
    font-family: var(--font-b) !important;
    font-weight: 700 !important;
    font-size: 13px !important;
    color: #fff !important;
    background: var(--cta);
    border-radius: 11px;
    padding: 11px 14px;
    text-decoration: none !important;
    box-shadow: 0 8px 20px -14px rgba(122, 79, 224, 0.8);
    transition: transform .2s var(--ease), background .2s var(--ease), box-shadow .2s var(--ease);
}

.spl-trending .card:hover .card-cta {
    background: var(--cta-hover);
    transform: translateY(-1px);
    box-shadow: 0 12px 26px -14px rgba(122, 79, 224, 0.9);
}

.spl-trending .card-cta:hover {
    color: #fff !important;
    text-decoration: none !important;
}

.spl-trending .card-cta:active {
    background: var(--cta-press);
}

.spl-trending .card-cta svg {
    width: 14px;
    height: 14px;
}

/* ---------- Demand badge (dark glass pill, top-right) ---------- */
.spl-trending .demand-badge {
    position: absolute;
    top: 12px;
    right: 12px;
    z-index: 4;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-family: var(--font-b);
    font-size: 10.5px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    white-space: nowrap;
    padding: 6px 11px;
    border-radius: 999px;
    background: rgba(8, 7, 14, 0.5);
    -webkit-backdrop-filter: blur(8px);
    backdrop-filter: blur(8px);
    border: 1px solid var(--amber-line);
    color: var(--amber);
}

/* high + medium share the amber treatment; low uses teal */
.spl-trending .demand-badge--low {
    border-color: var(--teal-line);
    color: var(--teal);
}

.spl-trending .demand-badge__emoji {
    font-size: 12px;
    line-height: 1;
    filter: saturate(0.95);
}

/* ---------- Date chip (Trending Play) ---------- */
.spl-trending .datechip {
    position: absolute;
    top: 13px;
    left: 13px;
    z-index: 4;
    pointer-events: none;
    background: rgba(8, 7, 14, 0.62);
    border: 1px solid rgba(255, 255, 255, 0.18);
    -webkit-backdrop-filter: blur(6px);
    backdrop-filter: blur(6px);
    border-radius: 12px;
    padding: 8px 11px;
    text-align: center;
    min-width: 50px;
    line-height: 1;
}

.spl-trending .datechip .d-dow {
    font-size: 10px !important;
    font-weight: 700 !important;
    letter-spacing: 0.12em !important;
    color: var(--accent) !important;
    text-transform: uppercase !important;
}

.spl-trending .datechip .d-day {
    font-family: var(--font-d) !important;
    font-weight: 700 !important;
    font-size: 21px !important;
    color: #fff !important;
    margin: 3px 0 1px;
}

.spl-trending .datechip .d-mon {
    font-size: 10px !important;
    font-weight: 700 !important;
    letter-spacing: 0.12em !important;
    color: var(--dim) !important;
    text-transform: uppercase !important;
}

/* ====================== MOBILE (<=600px) ====================== */
@media (max-width: 600px) {
    .spl-trending {
        padding: 30px 0 6px;
    }

    .spl-trending .wrap {
        padding: 0;
        max-width: none;
    }

    .spl-trending .row-head {
        padding: 0 var(--pad);
        align-items: flex-end;
        gap: 14px;
        margin-bottom: 18px;
    }

    .spl-trending .row-head h2 {
        font-size: 27px !important;
    }

    .spl-trending .row-head .sub {
        font-size: 13.5px !important;
        margin-top: 7px !important;
        max-width: 30ch !important;
    }

    .spl-trending .eyebrow {
        font-size: 11px !important;
        letter-spacing: 0.16em !important;
        background: none;
        -webkit-text-fill-color: initial;
        color: var(--teal) !important;
        margin-bottom: 8px !important;
    }

    /* mobile uses swipe, no arrow buttons */
    .spl-trending .row-arrows {
        display: none;
    }

    .spl-trending .viewall {
        font-size: 13px !important;
        font-weight: 700 !important;
        color: var(--text) !important;
    }

    .spl-trending .viewall svg {
        color: var(--accent-2);
    }

    .spl-trending .track {
        gap: 15px;
        padding: 2px var(--pad) 14px;
        scroll-snap-type: x mandatory;
    }

    .spl-trending .card {
        flex: 0 0 78%;
    }

    .spl-trending .card:hover {
        transform: none;
        box-shadow: none;
        border-color: var(--border);
    }

    .spl-trending .card:active {
        transform: scale(.985);
        border-color: var(--border-2);
    }

    .spl-trending .card:hover .ph {
        transform: none;
    }

    .spl-trending .card .body {
        padding: 15px 16px 17px;
    }

    .spl-trending .card h3 {
        font-size: 18px !important;
        line-height: 1.15 !important;
        margin-bottom: 3px !important;
    }

    .spl-trending .card .price {
        font-size: 16px !important;
        font-weight: 700 !important;
        margin: 11px 0 13px !important;
    }

    .spl-trending .card-cta {
        font-size: 14px !important;
        padding: 12px 16px;
        border-radius: 12px;
    }

    .spl-trending .card:hover .card-cta {
        background: var(--cta);
        transform: none;
        box-shadow: 0 12px 26px -14px rgba(122, 79, 224, 0.85);
    }

    .spl-trending .demand-badge {
        top: 11px;
        right: 11px;
    }
}

@media (prefers-reduced-motion: reduce) {

    .spl-trending .card,
    .spl-trending .ph,
    .spl-trending .arrow,
    .spl-trending .card-cta,
    .spl-trending .viewall svg {
        transition: none !important;
    }
}

/* ====================== GUIDE CARD ([latest_guides]) ======================
   Additive styles for the guide card used by [latest_guides]. These selectors
   (.card.guide, .badge, .cmeta.gmeta) are not used by the event cards, so they
   cannot affect the trending / next_7_days / coming_soon sections. */

/* Unlike event cards (which expose inner links), the whole guide card is a single
   link to the post, so opt the card surface back into a pointer cursor. */
.spl-trending .card.guide {
    cursor: pointer;
}

/* Category pill overlaid top-left on the image. */
.spl-trending .badge {
    position: absolute;
    top: 13px;
    left: 13px;
    z-index: 3;
    font-family: var(--font-b) !important;
    font-size: 10.5px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    padding: 6px 11px;
    border-radius: 999px;
    white-space: nowrap;
    backdrop-filter: blur(6px);
}

.spl-trending .badge.cat {
    background: rgba(8, 7, 14, 0.55);
    border: 1px solid rgba(255, 255, 255, 0.18);
    color: var(--teal) !important;
}

/* Slightly more muted meta line for the guide's published date. */
.spl-trending .card .cmeta.gmeta {
    color: var(--mute) !important;
}
