/* ============================================================
   01. The Events Calendar: Topbar, Suche, View-Switcher, Navigation und Hinweise
   ============================================================ */

/* Topbar & View-Switcher Buttons: kein eigener Hintergrund */
.tribe-events-header button,
.tribe-events-c-top-bar button,
button.tribe-events-c-view-selector__button,
button.tribe-events-c-search__button {
    background-color: transparent !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    color: var(--negz-dunkel) !important;
}

/* Suchleiste: Farben, Hover-Effekte & Abrundungen – kein Layout-Eingriff */
.tribe-events-c-events-bar__search-container {
    background: var(--negz-weiss) !important;
    border: 1.5px solid var(--negz-grau-mittel) !important;
    border-radius: var(--negz-radius) !important;
    box-sizing: border-box !important;
    padding: 8px 12px !important;
}

.tribe-common-form-control-text__input.tribe-events-c-search__input {
    background: var(--negz-grau-hell) !important;
    border: 1.5px solid var(--negz-grau-mittel) !important;
    border-radius: var(--negz-radius) !important;
    color: var(--negz-dunkel) !important;
    font-family: var(--negz-sans) !important;
    transition: border-color 0.15s, box-shadow 0.15s !important;
}

.tribe-common-form-control-text__input.tribe-events-c-search__input::placeholder {
    color: var(--negz-grau-text) !important;
}

.tribe-common-form-control-text__input.tribe-events-c-search__input:focus {
    background: var(--negz-weiss) !important;
    border-color: var(--negz-blau) !important;
    box-shadow: 0 0 0 3px rgba(48, 144, 176, 0.15) !important;
    outline: none !important;
}

.tribe-events-c-search__input-control-icon-svg {
    fill: var(--negz-grau-text) !important;
    transition: fill 0.15s !important;
}

.tribe-events-c-search__input-control:focus-within .tribe-events-c-search__input-control-icon-svg {
    fill: var(--negz-blau) !important;
}

.tribe-common-c-btn.tribe-events-c-search__button {
    background: var(--negz-blau) !important;
    border: 2px solid var(--negz-blau) !important;
    border-radius: var(--negz-radius) !important;
    color: var(--negz-weiss) !important;
    font-family: var(--negz-sans) !important;
    font-weight: 600 !important;
    transition: background 0.15s, border-color 0.15s !important;
}

.tribe-common-c-btn.tribe-events-c-search__button:hover {
    background: var(--negz-dunkel) !important;
    border-color: var(--negz-dunkel) !important;
    color: var(--negz-weiss) !important;
}

.tribe-events-c-search__button--search-icon,
.tribe-events-c-top-bar__actions button,
button.tribe-events-c-view-selector__button {
    border-radius: var(--negz-radius) !important;
    transition: background 0.15s, color 0.15s !important;
}

.tribe-events-c-top-bar__actions button:hover,
button.tribe-events-c-view-selector__button:hover {
    background: var(--negz-grau-hell) !important;
    color: var(--negz-blau) !important;
}

.tribe-events-c-top-bar__actions button svg,
button.tribe-events-c-view-selector__button svg {
    transition: stroke 0.15s, fill 0.15s !important;
}

.tribe-events-c-top-bar__actions button:hover svg *,
button.tribe-events-c-view-selector__button:hover svg * {
    fill: var(--negz-blau) !important;
    stroke: var(--negz-blau) !important;
}

/* View-Selector Dropdown */
.tribe-events-c-view-selector__content,
.tribe-events-c-view-selector__list {
    background: var(--negz-weiss) !important;
    border: 1px solid var(--negz-grau-mittel) !important;
    border-radius: var(--negz-radius) !important;
    box-shadow: 0 4px 12px rgba(18, 54, 81, 0.12) !important;
    padding: 4px 0 !important;
    z-index: 999 !important;
}

.tribe-events-c-view-selector__list-item a,
.tribe-events-c-view-selector__list-item button {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    width: 100% !important;
    background: transparent !important;
    color: var(--negz-dunkel) !important;
    font-family: var(--negz-sans) !important;
    font-size: 0.9rem !important;
    padding: 8px 16px !important;
}

.tribe-events-c-view-selector__list-item a:hover,
.tribe-events-c-view-selector__list-item button:hover {
    background: var(--negz-grau-hell) !important;
    color: var(--negz-blau) !important;
}

.tribe-events-c-view-selector__list-item--active a,
.tribe-events-c-view-selector__list-item--active button {
    color: var(--negz-blau) !important;
    font-weight: 600 !important;
}

/* Datepicker-Button in der Topbar */
.tribe-events-c-top-bar__datepicker,
.tribe-events-c-top-bar__datepicker-button {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: max-content !important;
    padding: 8px 14px !important;
    background: var(--negz-weiss) !important;
    border: 1.5px solid var(--negz-blau) !important;
    border-radius: var(--negz-radius) !important;
    color: var(--negz-dunkel) !important;
    cursor: pointer !important;
    font-family: var(--negz-sans) !important;
    font-size: 0.95rem !important;
    font-weight: 500 !important;
    transition: background 0.2s, border-color 0.2s !important;
}

.tribe-events-c-top-bar__datepicker:hover,
.tribe-events-c-top-bar__datepicker-button:hover {
    background: #eef6fa !important;
    border-color: var(--negz-dunkel) !important;
}

.tribe-events-c-top-bar__datepicker::after,
.tribe-events-c-top-bar__datepicker-button::after {
    content: none !important;
    display: none !important;
}

.tribe-events-c-top-bar__datepicker svg,
.tribe-events-c-top-bar__datepicker-button svg {
    display: inline-block !important;
    width: 12px !important;
    height: 12px !important;
    min-width: 12px !important;
    min-height: 12px !important;
    margin-left: 8px !important;
    margin-right: 0 !important;
    flex-shrink: 0 !important;
    pointer-events: none !important;
}

.tribe-events-c-top-bar__datepicker svg *,
.tribe-events-c-top-bar__datepicker-button svg * {
    vector-effect: non-scaling-stroke;
}

/* Navigation Prev / Next */
.tribe-events-c-nav__prev,
.tribe-events-c-nav__next {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 6px !important;
    min-width: 80px !important;
    padding: 8px 20px !important;
    background: transparent !important;
    border: 1.5px solid var(--negz-blau) !important;
    border-radius: var(--negz-radius) !important;
    color: var(--negz-blau) !important;
    text-align: center !important;
}

.tribe-events-c-nav__prev a,
.tribe-events-c-nav__next a,
.tribe-events-c-nav__prev *,
.tribe-events-c-nav__next * {
    background: transparent !important;
    color: var(--negz-blau) !important;
    font-family: var(--negz-sans) !important;
    font-weight: 500 !important;
    text-decoration: none !important;
}

.tribe-events-c-nav__prev:hover,
.tribe-events-c-nav__next:hover {
    background: var(--negz-blau) !important;
}

.tribe-events-c-nav__prev:hover *,
.tribe-events-c-nav__next:hover * {
    color: var(--negz-weiss) !important;
}

/* Kalender abonnieren: Button und Dropdown */
.tribe-events-c-subscribe-dropdown,
.tribe-events-c-subscribe-dropdown__container,
#tribe-events-subscribe-dropdown-container {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
}

.tribe-events-c-subscribe-dropdown__button,
button.tribe-events-c-subscribe-dropdown__button,
div.tribe-common-c-btn-border.tribe-events-c-subscribe-dropdown__button {
    width: 100% !important;
    padding: 10px 20px !important;
    background: var(--negz-blau) !important;
    border: 2px solid var(--negz-blau) !important;
    border-radius: var(--negz-radius) !important;
    color: var(--negz-weiss) !important;
    font-family: var(--negz-sans) !important;
    font-weight: 600 !important;
}

.tribe-events-c-subscribe-dropdown__button *,
button.tribe-events-c-subscribe-dropdown__button * {
    color: var(--negz-weiss) !important;
}

.tribe-events-c-subscribe-dropdown__button:hover,
button.tribe-events-c-subscribe-dropdown__button:hover,
div.tribe-common-c-btn-border.tribe-events-c-subscribe-dropdown__button:hover {
    background: var(--negz-dunkel) !important;
    border-color: var(--negz-dunkel) !important;
}

.tribe-events-c-subscribe-dropdown__button:hover *,
button.tribe-events-c-subscribe-dropdown__button:hover * {
    color: var(--negz-weiss) !important;
}

.tribe-events-c-subscribe-dropdown__list {
    background: var(--negz-weiss) !important;
    border: 1px solid var(--negz-grau-mittel) !important;
    border-radius: var(--negz-radius) !important;
}

.tribe-events-c-subscribe-dropdown__list-item a {
    color: var(--negz-dunkel) !important;
    font-family: var(--negz-sans) !important;
}

.tribe-events-c-subscribe-dropdown__list-item a:hover {
    background: var(--negz-grau-hell) !important;
    color: var(--negz-blau) !important;
}

/* Hinweisboxen */
.tribe-events-notices,
.tribe-events .tribe-events-c-messages__message {
    background: var(--negz-grau-hell);
    border-left: 4px solid var(--negz-blau-hell);
    border-radius: 0 var(--negz-radius) var(--negz-radius) 0;
    color: var(--negz-dunkel) !important;
    font-family: var(--negz-sans) !important;
    font-size: 0.95rem;
    padding: 16px 20px;
}


/* ============================================================
   02. The Events Calendar: Monatsansicht
   ============================================================ */

/* Zellen */
.tribe-events-calendar-month__calendar-cell,
.tribe-events-calendar-month__body button,
.tribe-events-calendar-month__grid button,
button.tribe-events-calendar-month__calendar-cell,
button.tribe-events-calendar-month__day-cell {
    background-color: var(--negz-weiss) !important;
    border: 1px solid var(--negz-grau-mittel) !important;
    box-shadow: none !important;
    padding: 8px !important;
}

.tribe-events-calendar-month__calendar-cell--past button {
    background-color: #fafafa !important;
}

.tribe-events-calendar-month__calendar-cell--current button {
    background-color: #eef6fa !important;
}

.tribe-events-calendar-month__body button:hover {
    background-color: #f0f6fa !important;
}

/* Wochentag-Header */
.tribe-events-calendar-month__header-column,
.tribe-events-calendar-month__header,
.tribe-events-calendar-month__header button {
    height: auto !important;
    min-height: auto !important;
    padding: 8px 4px !important;
    background: var(--negz-dunkel) !important;
    border: none !important;
}

.tribe-events-calendar-month__header-column *,
.tribe-events-calendar-month__header * {
    color: var(--negz-weiss) !important;
    font-family: var(--negz-sans) !important;
    font-size: 0.75rem !important;
    font-weight: 600 !important;
    letter-spacing: 0.05em !important;
    text-decoration: none !important;
    text-transform: uppercase !important;
}

/* Tageszahlen */
.tribe-events-calendar-month__day-date,
.tribe-events-calendar-month__day-date-daynum {
    color: #000000 !important;
    font-size: 0.95rem !important;
    font-weight: 400 !important;
    line-height: 1.2 !important;
}

/* Aktiver / ausgewählter Tag */
.tribe-events-calendar-month__calendar-cell--selected,
.tribe-events-calendar-month__calendar-cell--selected button,
.tribe-events-calendar-month__day-cell--selected,
.tribe-events-calendar-month__day-cell--selected button,
.tribe-events-calendar-month__calendar-cell button[aria-selected="true"],
.tribe-events-calendar-month__day-cell button[aria-selected="true"] {
    background: #eef6fa !important;
    border: 2px solid var(--negz-blau) !important;
    box-shadow: inset 0 0 0 1px rgba(48, 144, 176, 0.12) !important;
}

.tribe-events-calendar-month__calendar-cell--selected .tribe-events-calendar-month__day-date,
.tribe-events-calendar-month__day-cell--selected .tribe-events-calendar-month__day-date,
.tribe-events-calendar-month__calendar-cell button[aria-selected="true"] .tribe-events-calendar-month__day-date,
.tribe-events-calendar-month__day-cell button[aria-selected="true"] .tribe-events-calendar-month__day-date,
.tribe-events-calendar-month__calendar-cell--selected .tribe-events-calendar-month__day-date-daynum,
.tribe-events-calendar-month__day-cell--selected .tribe-events-calendar-month__day-date-daynum {
    color: #000000 !important;
    font-size: 1.1rem !important;
    font-weight: 600 !important;
}

/* Event-Punkt im aktiven Tag */
.tribe-events-calendar-month__calendar-cell--selected .tribe-events-calendar-month__calendar-event-dots,
.tribe-events-calendar-month__day-cell--selected .tribe-events-calendar-month__calendar-event-dots,
.tribe-events-calendar-month__calendar-cell--selected .tribe-events-calendar-month__calendar-event-dot,
.tribe-events-calendar-month__day-cell--selected .tribe-events-calendar-month__calendar-event-dot {
    color: var(--negz-blau) !important;
}

/* Detailbereich unter dem Monatsgrid */
.tribe-events-calendar-month__events,
.tribe-events-calendar-month__day-detail,
.tribe-events-calendar-month-mobile-events__mobile-day {
    margin-top: 20px !important;
    padding-top: 0 !important;
}

.tribe-events-calendar-month__events .tribe-events-calendar-month__events-title,
.tribe-events-calendar-month__day-detail .tribe-events-calendar-month__events-title,
.tribe-events-calendar-month-mobile-events__mobile-day .tribe-events-calendar-month-mobile-events__mobile-day-title {
    color: #000000 !important;
    font-family: var(--negz-sans) !important;
    font-size: 1.5rem !important;
    font-weight: 400 !important;
    margin: 0 0 12px 0 !important;
}

.tribe-events-calendar-month__events .tribe-events-calendar-month__multiday-event-bar,
.tribe-events-calendar-month__events .tribe-events-calendar-month__calendar-event,
.tribe-events-calendar-month__day-detail .tribe-events-calendar-month__calendar-event,
.tribe-events-calendar-month-mobile-events__mobile-day .tribe-events-calendar-month-mobile-events__mobile-event {
    background: transparent !important;
    border-bottom: 1px solid var(--negz-grau-mittel) !important;
    margin: 0 0 18px 0 !important;
    padding: 0 0 18px 0 !important;
}

.tribe-events-calendar-month__events .tribe-events-calendar-month__event-datetime,
.tribe-events-calendar-month__day-detail .tribe-events-calendar-month__event-datetime,
.tribe-events-calendar-month-mobile-events__mobile-day .tribe-events-calendar-month-mobile-events__mobile-event-datetime {
    color: var(--negz-blau) !important;
    font-family: var(--negz-sans) !important;
    font-size: 0.95rem !important;
    font-weight: 500 !important;
    margin-bottom: 8px !important;
}

.tribe-events-calendar-month__events .tribe-events-calendar-month__event-title,
.tribe-events-calendar-month__events .tribe-events-calendar-month__event-title a,
.tribe-events-calendar-month__day-detail .tribe-events-calendar-month__event-title,
.tribe-events-calendar-month__day-detail .tribe-events-calendar-month__event-title a,
.tribe-events-calendar-month-mobile-events__mobile-day .tribe-events-calendar-month-mobile-events__mobile-event-title,
.tribe-events-calendar-month-mobile-events__mobile-day .tribe-events-calendar-month-mobile-events__mobile-event-title a {
    color: #000000 !important;
    font-family: var(--negz-sans) !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    margin: 0 !important;
    text-decoration: none !important;
}


/* ============================================================
   03. The Events Calendar: Listenansicht und Latest Past Events
   ============================================================ */

/* Event-Zeilen */
.tribe-events-calendar-list__event-row,
.tribe-events-calendar-latest-past__event-row {
    background: transparent !important;
    border: none !important;
    border-bottom: 1px solid var(--negz-grau-mittel) !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    margin: 0 0 28px 0 !important;
    padding: 0 0 28px 0 !important;
}

.tribe-events-calendar-list__event-row:hover,
.tribe-events-calendar-latest-past__event-row:hover {
    border-color: var(--negz-grau-mittel) !important;
    box-shadow: none !important;
}

/* Datum-Tag-Spalte ausblenden */
.tribe-events-calendar-list__event-date-tag,
.tribe-events-calendar-list__event-date-tag-datetime,
.tribe-events-calendar-latest-past__event-date-tag {
    display: none !important;
}

/* Wrapper neutralisieren */
.tribe-events-calendar-list__event-wrapper,
.tribe-events-calendar-latest-past__event-wrapper {
    display: block !important;
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
}

/* Desktop: Grid-Layout Bild links / Inhalt rechts */
@media (min-width: 769px) {
    .tribe-events-calendar-list__event,
    .tribe-events-calendar-latest-past__event {
        display: grid !important;
        grid-template-columns: 220px minmax(0, 1fr) !important;
        column-gap: 16px !important;
        align-items: start !important;
        margin: 0 !important;
        padding: 0 !important;
    }

    .tribe-events-calendar-list__event-datetime-wrapper,
    .tribe-events-calendar-list__event-details,
    .tribe-events-calendar-list__event-title,
    .tribe-events-calendar-list__event-description,
    .tribe-events-calendar-list__event-venue,
    .tribe-events-calendar-latest-past__event-datetime-wrapper,
    .tribe-events-calendar-latest-past__event-details,
    .tribe-events-calendar-latest-past__event-title,
    .tribe-events-calendar-latest-past__event-description,
    .tribe-events-calendar-latest-past__event-venue {
        grid-column: 2 !important;
        margin: 0 !important;
        padding: 0 !important;
        min-width: 0 !important;
        align-self: start !important;
    }
}

/* Bild-Wrapper: tribe-common-g-col override für feste 220 px */
div.tribe-events-calendar-list__event-featured-image-wrapper,
div.tribe-events-calendar-latest-past__event-featured-image-wrapper {
    width: 220px !important;
    max-width: 220px !important;
    min-width: 0 !important;
    flex: 0 0 220px !important;
    grid-column: 1 !important;
    overflow: hidden !important;
    margin: 0 !important;
    padding: 0 !important;
    align-self: start !important;
    background: transparent !important;
}

div.tribe-events-calendar-list__event-featured-image-wrapper a,
div.tribe-events-calendar-latest-past__event-featured-image-wrapper a {
    display: block !important;
    width: 220px !important;
    height: 140px !important;
    overflow: hidden !important;
}

div.tribe-events-calendar-list__event-featured-image-wrapper img,
div.tribe-events-calendar-latest-past__event-featured-image-wrapper img {
    display: block !important;
    width: 220px !important;
    height: 140px !important;
    max-width: none !important;
    object-fit: cover !important;
    object-position: center top !important;
    border-radius: var(--negz-radius) !important;
}

/* Plugin-Platzhalterbilder ausblenden */
div.tribe-events-calendar-list__event-featured-image-wrapper img[src*="tribe-events"],
div.tribe-events-calendar-list__event-featured-image-wrapper img[src*="placeholder"],
div.tribe-events-calendar-latest-past__event-featured-image-wrapper img[src*="tribe-events"],
div.tribe-events-calendar-latest-past__event-featured-image-wrapper img[src*="placeholder"] {
    display: none !important;
}

/* Datum/Uhrzeit */
.tribe-events-calendar-list__event-datetime,
.tribe-events-calendar-list__event-datetime-featured-text,
.tribe-events-calendar-latest-past__event-datetime,
.tribe-events-calendar-latest-past__event-datetime-featured-text,
.tribe-events .tribe-event-date-start,
.tribe-events .tribe-event-time {
    color: var(--negz-blau) !important;
    font-family: var(--negz-sans) !important;
    font-size: 0.9rem !important;
    font-weight: 500 !important;
    margin: 0 0 8px 0 !important;
    padding: 0 !important;
}

/* Titel */
.tribe-events-calendar-list__event-title,
.tribe-events-calendar-list__event-title a,
.tribe-events-calendar-latest-past__event-title,
.tribe-events-calendar-latest-past__event-title a {
    color: #000000 !important;
    font-family: var(--negz-sans) !important;
    font-size: 1.5rem !important;
    font-weight: 600 !important;
    line-height: 1.25 !important;
    margin: 0 0 10px 0 !important;
    padding: 0 !important;
    text-decoration: none !important;
}

.tribe-events-calendar-list__event-title a:hover,
.tribe-events-calendar-latest-past__event-title a:hover {
    color: var(--negz-blau) !important;
}

/* Beschreibung */
.tribe-events-calendar-list__event-description,
.tribe-events-calendar-list__event-description p,
.tribe-events-calendar-latest-past__event-description,
.tribe-events-calendar-latest-past__event-description p {
    color: #000000 !important;
    font-family: var(--negz-serif) !important;
    font-size: 1rem !important;
    line-height: 1.6 !important;
    margin-top: 8px !important;
}

/* Veranstaltungsort */
.tribe-events-calendar-list__event-venue,
.tribe-events-calendar-list__event-venue-title,
.tribe-events-calendar-list__event-address,
.tribe-events-calendar-latest-past__event-venue,
.tribe-events-calendar-latest-past__event-venue-title,
.tribe-events-calendar-latest-past__event-address {
    color: var(--negz-grau-text) !important;
    font-family: var(--negz-sans) !important;
    font-size: 0.95rem !important;
}

/* Abstand nach Monatsseparator */
.tribe-events-calendar-list__month-separator + .tribe-events-calendar-list__event-row,
.tribe-events-calendar-list__event-row + .tribe-events-calendar-list__event-row {
    margin-top: 8px !important;
}

/* Überschrift "Vergangene Veranstaltungen" */
.tribe-events-calendar-latest-past__heading {
    margin-bottom: 28px !important;
}

@media (max-width: 768px) {
    .tribe-events-calendar-list__event,
    .tribe-events-calendar-latest-past__event {
        display: block !important;
    }

    div.tribe-events-calendar-list__event-featured-image-wrapper,
    div.tribe-events-calendar-latest-past__event-featured-image-wrapper {
        width: 100% !important;
        max-width: 100% !important;
        flex: none !important;
        margin: 0 0 14px 0 !important;
    }

    div.tribe-events-calendar-list__event-featured-image-wrapper a,
    div.tribe-events-calendar-latest-past__event-featured-image-wrapper a {
        width: 100% !important;
        height: 200px !important;
    }

    div.tribe-events-calendar-list__event-featured-image-wrapper img,
    div.tribe-events-calendar-latest-past__event-featured-image-wrapper img {
        width: 100% !important;
        height: 200px !important;
        max-width: 100% !important;
    }

    .tribe-events-calendar-list__event-title,
    .tribe-events-calendar-list__event-title a,
    .tribe-events-calendar-latest-past__event-title,
    .tribe-events-calendar-latest-past__event-title a {
        font-size: 1.2rem !important;
    }

    .tribe-events-calendar-list__event-row,
    .tribe-events-calendar-latest-past__event-row {
        padding: 0 0 22px 0 !important;
    }
}


/* ============================================================
   04. The Events Calendar: Einzelansicht / Single Event
   ============================================================ */

.tribe-events-single {
    max-width: 860px;
    margin: 0 auto;
}

/* Veranstaltungstitel */
.single-tribe_events .tribe-events-single-event-title,
.single-tribe_events h1.tribe-events-single-event-title {
    color: #111111 !important;
    font-family: var(--negz-sans) !important;
    font-size: 42px !important;
    font-weight: 400 !important;
    letter-spacing: normal !important;
    line-height: 1.2 !important;
    margin-bottom: 20px !important;
}

/* Featured Image */
.wp-block-post-featured-image {
    margin-bottom: 10px !important;
}

/* Layout-Reset: verhindert Overflow in die Sidebar */
.single-tribe_events .tribe-events-single__aside,
.single-tribe_events .tribe-events-event-meta {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    clear: both !important;
    float: none !important;
    overflow: hidden !important;
}

.single-tribe_events .tribe-events-event-meta.primary {
    display: block !important;
    flex-direction: unset !important;
    flex-wrap: unset !important;
    gap: unset !important;
}

.single-tribe_events .tribe-events-schedule,
.single-tribe_events .tribe-block.tribe-block__venue,
.single-tribe_events .tribe-events-meta-group-organizer,
.single-tribe_events .tribe-events-meta-group-venue {
    width: 100% !important;
    max-width: 100% !important;
    flex: 0 0 100% !important;
    box-sizing: border-box !important;
    float: none !important;
}

/* WANN/WO – Karten-Look */
.single-tribe_events .tribe-events-schedule.tribe-clearfix,
.single-tribe_events .tribe-block.tribe-block__venue.tribe-clearfix {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    background: #f4f7f9 !important;
    border: 1px solid var(--negz-grau-mittel) !important;
    border-radius: 10px !important;
    box-shadow: 0 6px 18px rgba(18, 54, 81, 0.08) !important;
    box-sizing: border-box !important;
    clear: both !important;
    float: none !important;
    margin: 0 0 16px 0 !important;
    overflow: hidden !important;
    padding: 24px !important;
    position: relative !important;
}

.single-tribe_events .tribe-events-schedule.tribe-clearfix::before,
.single-tribe_events .tribe-block.tribe-block__venue.tribe-clearfix::before {
    display: block !important;
    color: var(--negz-blau) !important;
    font-family: var(--negz-sans) !important;
    font-size: 0.75rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.08em !important;
    margin-bottom: 14px !important;
    text-transform: uppercase !important;
}

.single-tribe_events .tribe-events-schedule.tribe-clearfix::before {
    content: "Wann?" !important;
}

.single-tribe_events .tribe-block.tribe-block__venue.tribe-clearfix::before {
    content: "Wo?" !important;
}

/* Legacy-Selektor aus dem Original unverändert beibehalten. */
.span.tribe-delimiter {
    display: none;
}

/* Datum/Uhrzeit Typografie im Wann-Block */
.single-tribe_events .tribe-events-schedule__datetime,
.single-tribe_events .tribe-events-schedule__datetime *,
.single-tribe_events .tribe-events-schedule p {
    color: var(--negz-dunkel) !important;
    font-family: var(--negz-serif) !important;
    font-size: 1.05rem !important;
    font-weight: 400 !important;
    line-height: 1.6 !important;
}

/* p-Margin-Reset: volle Spezifität damit Theme/Browser-Defaults nicht gewinnen */
.single-tribe_events .tribe-events-schedule.tribe-clearfix > p.tribe-events-schedule__datetime {
    display: block !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Venue: Meta-Container */
.single-tribe_events .tribe-block__venue__meta {
    display: block !important;
    width: 100% !important;
    overflow-wrap: break-word !important;
    padding: 0 !important;
    word-break: normal !important;
}

/* Venue: Name */
.single-tribe_events .tribe-block__venue__name {
    display: block !important;
    width: 100% !important;
}

.single-tribe_events .tribe-block__venue__name h3,
.single-tribe_events .tribe-block__venue__name h3 * {
    color: var(--negz-dunkel) !important;
    font-family: var(--negz-serif) !important;
    font-size: 1.05rem !important;
    font-weight: 400 !important;
    letter-spacing: normal !important;
    line-height: 1.6 !important;
    margin: 0 !important;
    text-transform: none !important;
    white-space: normal !important;
    word-break: normal !important;
    writing-mode: horizontal-tb !important;
}

/* Venue: Adresse */
.single-tribe_events .tribe-block__venue__address {
    display: block !important;
    width: 100% !important;
    color: var(--negz-dunkel) !important;
    font-family: var(--negz-serif) !important;
    font-size: 1rem !important;
    font-style: normal !important;
    line-height: 1.7 !important;
    white-space: normal !important;
    word-break: normal !important;
    writing-mode: horizontal-tb !important;
}

/* Adresse auf Single-Terminseiten: PLZ vor Ort anzeigen */
.single-tribe_events .tribe-block__venue__address .tribe-address {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: baseline !important;
    column-gap: 0.25em !important;
}

.single-tribe_events .tribe-block__venue__address span.tribe-street-address {
    display: block !important;
    flex: 0 0 100% !important;
    order: 1 !important;
}

.single-tribe_events .tribe-block__venue__address span.tribe-postal-code {
    display: inline !important;
    order: 2 !important;
}

.single-tribe_events .tribe-block__venue__address span.tribe-locality {
    display: inline !important;
    order: 3 !important;
}

/* Versteckte Felder: konsolidiert aus den doppelten Original-Blöcken */
.single-tribe_events .tribe-block__venue__address span.tribe-address > br,
.single-tribe_events .tribe-block__venue__address abbr.tribe-region,
.single-tribe_events .tribe-block__venue__address span.tribe-country-name,
.single-tribe_events .tribe-block__venue__address span.tribe-delimiter,
.single-tribe_events .tribe-block__venue__phone,
.single-tribe_events .tribe-block__venue__phone + br {
    display: none !important;
}

/* Google Maps Link */
.single-tribe_events .tribe-events-gmap {
    display: inline-flex !important;
    align-items: center !important;
    width: fit-content !important;
    margin-top: 14px !important;
    padding: 10px 14px !important;
    background: #fff !important;
    border: 1px solid var(--negz-blau) !important;
    border-radius: 6px !important;
    color: var(--negz-blau) !important;
    font-family: var(--negz-sans) !important;
    font-size: 0.95rem !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    transition: all 0.2s ease !important;
}

.single-tribe_events .tribe-events-gmap:hover {
    background: var(--negz-blau) !important;
    color: #fff !important;
    text-decoration: none !important;
}

/* Venue: Karte */
.single-tribe_events .tribe-block__venue__map {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    border-radius: 8px !important;
    overflow: hidden !important;
}

.single-tribe_events .tribe-block__venue__map iframe {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 100% !important;
    height: 320px !important;
    min-height: 320px !important;
    border: 0 !important;
}

/* Tribe-Block Overflow-Fix */
.single-tribe_events .tribe-block__venue,
.single-tribe_events .tribe-block__organizer,
.single-tribe_events [class*="tribe-block"] {
    max-width: 100% !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
}

/* Meta-Gruppen: älterer DOM (Wann/Wo/Veranstalter) */
.single-tribe_events .tribe-events-meta-group,
.single-tribe_events .tribe-events-single-section {
    background: #f3f4f6 !important;
    border: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    padding: 28px 24px !important;
}

.single-tribe_events .tribe-events-meta-group-heading,
.single-tribe_events .tribe-events-meta-group h2,
.single-tribe_events .tribe-events-meta-group dt,
.single-tribe_events .tribe-events-single-section-title,
.single-tribe_events .tribe-events-single-section h2 {
    color: var(--negz-blau) !important;
    border: none !important;
    font-family: var(--negz-sans) !important;
    font-size: 0.75rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.08em !important;
    margin-bottom: 10px !important;
    text-transform: uppercase !important;
}

.single-tribe_events .tribe-events-meta-group *,
.single-tribe_events .tribe-events-single-section * {
    color: #111111 !important;
    font-family: var(--negz-sans) !important;
    line-height: 1.7 !important;
}

.single-tribe_events .tribe-events-meta-group dd,
.single-tribe_events .tribe-events-meta-group address,
.single-tribe_events .tribe-events-meta-group p,
.single-tribe_events .tribe-events-meta-group span,
.single-tribe_events .tribe-events-meta-group a {
    color: var(--negz-dunkel) !important;
    font-family: var(--negz-serif) !important;
    font-size: 1rem !important;
    font-style: normal !important;
    line-height: 1.65 !important;
    text-decoration: none !important;
}

.single-tribe_events .tribe-events-meta-group a:hover,
.single-tribe_events .tribe-events-single-section a:hover {
    color: var(--negz-blau) !important;
    text-decoration: underline !important;
}

/* Venue & Organizer: älterer DOM */
.tribe-venue-location,
.tribe-events-single .tribe-venue,
.tribe-organizer-tel,
.tribe-organizer-url,
.tribe-events-single .tribe-organizer {
    background: var(--negz-grau-hell);
    border: 1px solid var(--negz-grau-mittel);
    border-radius: var(--negz-radius);
    margin: 24px 0;
    padding: 20px 24px;
}

.tribe-venue-location,
.tribe-events-single .tribe-venue {
    border-top: 3px solid var(--negz-salbei);
}

.tribe-organizer-tel,
.tribe-organizer-url,
.tribe-events-single .tribe-organizer {
    border-top: 3px solid var(--negz-blau-hell);
}

/* Zeitzeile: einfaches Block-Display ohne Badge-Look */
.single-tribe_events .tribe-event-schedule-details,
.single-tribe_events .tribe-events-schedule,
.single-tribe_events .tribe-events-abbr {
    display: block !important;
    background: transparent !important;
    border-left: none !important;
    border-radius: 0 !important;
    color: #111111 !important;
    font-family: var(--negz-sans) !important;
    font-size: 1rem !important;
    font-weight: 400 !important;
    margin-bottom: 0 !important;
    padding: 0 !important;
}

/* Datums-Separator sichtbar lassen */
.tribe-events-schedule__separator--date {
    display: inline !important;
}

/* Subscribe-Button im Single Event: volle Breite, kein Float */
.single-tribe_events .tribe-block.tribe-block__events-link,
.single-tribe_events .tribe-events-c-subscribe-dropdown,
.single-tribe_events #tribe-events-subscribe-dropdown-container {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    background: transparent !important;
    box-sizing: border-box !important;
    clear: both !important;
    float: none !important;
    margin-top: 16px !important;
    overflow: hidden !important;
}

.single-tribe_events .tribe-events-c-subscribe-dropdown__button,
.single-tribe_events .tribe-common-c-btn-border.tribe-events-c-subscribe-dropdown__button {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    float: none !important;
}

@media (max-width: 768px) {
    .single-tribe_events .tribe-events-single-event-title,
    .single-tribe_events h1.tribe-events-single-event-title {
        font-size: 32px !important;
        line-height: 1.25 !important;
    }
}


/* ============================================================
   05. The Events Calendar: Datepicker Dropdown
   ============================================================ */

.datepicker.dropdown-menu {
    min-width: 280px !important;
    padding: 12px 16px 16px 16px !important;
    background: var(--negz-weiss) !important;
    border: 1px solid var(--negz-grau-mittel) !important;
    border-radius: var(--negz-radius) !important;
    box-shadow: 0 4px 16px rgba(18, 54, 81, 0.12) !important;
    font-family: var(--negz-sans) !important;
}

.datepicker table.table-condensed {
    width: 100% !important;
    border-collapse: collapse !important;
    border-spacing: 0 !important;
    table-layout: fixed !important;
}

.datepicker table.table-condensed th,
.datepicker table.table-condensed td {
    width: calc(100% / 7) !important;
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
    box-sizing: border-box !important;
    text-align: center !important;
    vertical-align: middle !important;
}

/* Wochentag-Labels */
.datepicker table th.dow abbr {
    display: block !important;
    width: 100% !important;
    border-bottom: none !important;
    color: var(--negz-grau-text) !important;
    cursor: default !important;
    font-family: var(--negz-sans) !important;
    font-size: 0.72rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.05em !important;
    padding: 4px 0 10px 0 !important;
    pointer-events: none !important;
    text-align: center !important;
    text-decoration: none !important;
    text-transform: uppercase !important;
}

/* Navigation Prev / Switch / Next */
.datepicker table th.prev,
.datepicker table th.next,
.datepicker table th.datepicker-switch {
    padding: 4px 0 12px 0 !important;
    background: transparent !important;
}

.datepicker table th.prev button,
.datepicker table th.next button,
.datepicker table th.datepicker-switch button {
    width: 100% !important;
    padding: 4px 8px !important;
    background: transparent !important;
    border: none !important;
    border-radius: var(--negz-radius) !important;
    color: var(--negz-dunkel) !important;
    cursor: pointer !important;
    font-family: var(--negz-sans) !important;
    font-size: 0.95rem !important;
    font-weight: 600 !important;
    transition: background 0.15s, color 0.15s !important;
}

.datepicker table th.prev button,
.datepicker table th.next button {
    color: var(--negz-blau) !important;
}

.datepicker table th.prev button:hover,
.datepicker table th.next button:hover,
.datepicker table th.datepicker-switch button:hover {
    background: var(--negz-grau-hell) !important;
    color: var(--negz-blau) !important;
}

.datepicker table th.prev button svg,
.datepicker table th.next button svg {
    display: block !important;
    width: 10px !important;
    height: 14px !important;
    fill: var(--negz-blau) !important;
    margin: 0 auto !important;
}

/* Tages-Buttons */
.datepicker table td button.day {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 32px !important;
    height: 32px !important;
    margin: 2px auto !important;
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
    border-radius: 50% !important;
    box-sizing: border-box !important;
    color: var(--negz-dunkel) !important;
    cursor: pointer !important;
    font-family: var(--negz-sans) !important;
    font-size: 0.88rem !important;
    line-height: 1 !important;
    transition: background 0.15s, color 0.15s !important;
}

.datepicker table td button.day:hover {
    background: var(--negz-grau-mittel) !important;
}

.datepicker table td button.day.active {
    background: var(--negz-blau) !important;
    color: var(--negz-weiss) !important;
    font-weight: 600 !important;
}

.datepicker table td button.day.active:hover {
    background: var(--negz-dunkel) !important;
    color: var(--negz-weiss) !important;
}

.datepicker table td button.day.current {
    background: transparent !important;
    box-shadow: inset 0 0 0 1.5px var(--negz-blau) !important;
    color: var(--negz-blau) !important;
    font-weight: 700 !important;
}

.datepicker table td button.day.current:hover {
    background: var(--negz-grau-mittel) !important;
}

.datepicker table td button.day.past {
    color: var(--negz-grau-text) !important;
}

.datepicker table td button.day.old,
.datepicker table td button.day.new {
    color: var(--negz-grau-mittel) !important;
}

/* Monat/Jahr/Jahrzehnt-Grid */
.datepicker .datepicker-grid {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 4px !important;
    padding: 8px 0 !important;
}

.datepicker .datepicker-grid button {
    background: transparent !important;
    border: none !important;
    border-radius: var(--negz-radius) !important;
    color: var(--negz-dunkel) !important;
    cursor: pointer !important;
    font-family: var(--negz-sans) !important;
    font-size: 0.88rem !important;
    padding: 8px 4px !important;
    text-align: center !important;
    transition: background 0.15s, color 0.15s !important;
}

.datepicker .datepicker-grid button:hover {
    background: var(--negz-grau-mittel) !important;
}

.datepicker .datepicker-grid button.active {
    background: var(--negz-blau) !important;
    color: var(--negz-weiss) !important;
    font-weight: 600 !important;
}

.datepicker .datepicker-grid button.current {
    box-shadow: inset 0 0 0 1.5px var(--negz-blau) !important;
    color: var(--negz-blau) !important;
    font-weight: 700 !important;
}

.datepicker .datepicker-grid button.past {
    color: var(--negz-grau-text) !important;
}

.datepicker .datepicker-grid button.old,
.datepicker .datepicker-grid button.new {
    color: var(--negz-grau-mittel) !important;
}


/* ============================================================
   06. The Events Calendar Blocks / ECS Event List
   ============================================================ */

.ecs-event-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.ecs-event {
    display: grid;
    grid-template-columns: 180px 1fr;
    grid-template-areas:
        "image title"
        "image time"
        "image venue"
        "image excerpt";
    column-gap: 20px;
    row-gap: 4px;
    align-items: center;
    background: rgb(247, 248, 249);
    border: none;
    border-radius: var(--negz-radius);
    margin-bottom: 16px;
    padding: 20px;
}

.ecs-event > a {
    display: block;
    grid-area: image;
}

.ecs-event img {
    display: block;
    width: 100%;
    height: auto;
    aspect-ratio: 3 / 2;
    object-fit: cover;
    border-radius: var(--negz-radius);
}

.ecs-event .entry-title {
    grid-area: title;
    margin: 0 0 6px 0;
}

.ecs-event .entry-title a {
    color: var(--negz-dunkel);
    text-decoration: none;
}

.ecs-event .entry-title a:hover {
    color: #000000;
    text-decoration: underline;
}

.ecs-event .duration.time {
    display: block;
    grid-area: time;
    margin: 0;
    color: var(--negz-blau);
}

.ecs-event .duration.venue {
    display: block;
    grid-area: venue;
    margin: 0;
}

.ecs-event .duration.venue em {
    display: none;
}

.ecs-event .ecs-excerpt {
    grid-area: excerpt;
    margin: 4px 0 0 0;
}

.ecs-no-events {
    margin-bottom: 20px;
}

@media (max-width: 768px) {
    .ecs-event {
        grid-template-columns: 1fr;
        grid-template-areas:
            "image"
            "title"
            "time"
            "venue"
            "excerpt";
        row-gap: 8px;
        padding: 18px;
    }

    .ecs-event img {
        width: 100%;
    }
}


/* ============================================================
   07. The Events Calendar: Filter Bar
   ============================================================ */

/* Gesamtrahmen */
.tribe-filter-bar {
    background: var(--negz-grau-hell) !important;
    border: 1px solid var(--negz-grau-mittel) !important;
    border-radius: var(--negz-radius) !important;
    box-sizing: border-box !important;
    font-family: var(--negz-sans) !important;
    padding: 20px !important;
}

.tribe-filter-bar__form {
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
}

/* „Deine Auswahl" / aktive Filter-Pills */
.tribe-filter-bar__selected-filters {
    border-bottom: 1px solid var(--negz-grau-mittel) !important;
    margin-bottom: 16px !important;
    padding-bottom: 16px !important;
}

.tribe-filter-bar__selected-filters-header {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    margin-bottom: 10px !important;
}

.tribe-filter-bar__selected-filters-label {
    color: var(--negz-blau) !important;
    font-family: var(--negz-sans) !important;
    font-size: 0.72rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
}

.tribe-filter-bar-c-pill {
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    margin-bottom: 8px !important;
}

.tribe-filter-bar-c-pill__pill {
    display: inline-flex !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    gap: 3px !important;
    background: var(--negz-dunkel) !important;
    border-radius: 20px !important;
    color: var(--negz-weiss) !important;
    font-family: var(--negz-sans) !important;
    font-size: 0.82rem !important;
    font-weight: 500 !important;
    line-height: 1.3 !important;
    padding: 5px 12px !important;
}

.tribe-filter-bar-c-pill__pill-label,
.tribe-filter-bar-c-pill__pill-label-colon {
    color: rgba(255, 255, 255, 0.65) !important;
}

.tribe-filter-bar-c-pill__pill-label {
    font-weight: 400 !important;
}

.tribe-filter-bar-c-pill__pill-label-colon {
    margin-right: 3px !important;
}

.tribe-filter-bar-c-pill__pill-selections {
    color: var(--negz-weiss) !important;
    font-weight: 600 !important;
}

.tribe-filter-bar-c-pill__remove-button {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 22px !important;
    height: 22px !important;
    background: rgba(255, 255, 255, 0.15) !important;
    border: none !important;
    border-radius: 50% !important;
    cursor: pointer !important;
    flex-shrink: 0 !important;
    padding: 0 !important;
    transition: background 0.15s !important;
}

.tribe-filter-bar-c-pill__remove-button:hover {
    background: rgba(255, 255, 255, 0.30) !important;
}

.tribe-filter-bar-c-pill__remove-button-icon {
    width: 8px !important;
    height: 8px !important;
    stroke: var(--negz-weiss) !important;
}

/* „Leeren"-Button (Clear) */
.tribe-filter-bar-c-clear-button {
    display: inline-flex !important;
    align-items: center !important;
    gap: 5px !important;
    background: transparent !important;
    border: 1px solid var(--negz-grau-mittel) !important;
    border-radius: var(--negz-radius) !important;
    box-shadow: none !important;
    color: var(--negz-grau-text) !important;
    cursor: pointer !important;
    font-family: var(--negz-sans) !important;
    font-size: 0.8rem !important;
    font-weight: 500 !important;
    padding: 5px 10px !important;
    transition: border-color 0.15s, color 0.15s !important;
}

.tribe-filter-bar-c-clear-button:hover {
    background: transparent !important;
    border-color: var(--negz-blau) !important;
    color: var(--negz-blau) !important;
}

.tribe-filter-bar-c-clear-button__text {
    color: inherit !important;
    font-family: var(--negz-sans) !important;
}

.tribe-filter-bar-c-clear-button .tribe-common-c-svgicon--reset {
    width: 11px !important;
    height: 11px !important;
    flex-shrink: 0 !important;
    stroke: currentColor !important;
}

/* Aktionszeile (Erledigt / Leeren) */
.tribe-filter-bar__actions {
    display: flex !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
    border-bottom: 1px solid var(--negz-grau-mittel) !important;
    margin-bottom: 20px !important;
    padding-bottom: 20px !important;
}

.tribe-filter-bar__action-done {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: var(--negz-blau) !important;
    border: 2px solid var(--negz-blau) !important;
    border-radius: var(--negz-radius) !important;
    box-shadow: none !important;
    color: var(--negz-weiss) !important;
    cursor: pointer !important;
    font-family: var(--negz-sans) !important;
    font-size: 0.85rem !important;
    font-weight: 600 !important;
    letter-spacing: normal !important;
    padding: 7px 16px !important;
    text-transform: none !important;
    transition: background 0.15s, border-color 0.15s !important;
}

.tribe-filter-bar__action-done:hover {
    background: var(--negz-dunkel) !important;
    border-color: var(--negz-dunkel) !important;
    color: var(--negz-weiss) !important;
}

.tribe-filter-bar__action-clear {
    padding: 7px 12px !important;
    font-size: 0.85rem !important;
}

/* Einzelne Filter-Akkordeons */
.tribe-filter-bar__filters {
    display: flex !important;
    flex-direction: column !important;
    gap: 2px !important;
}

.tribe-filter-bar-c-filter {
    border-bottom: 1px solid var(--negz-grau-mittel) !important;
}

.tribe-filter-bar-c-filter:last-child {
    border-bottom: none !important;
}

.tribe-filter-bar-c-filter__toggle {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    width: 100% !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    cursor: pointer !important;
    font-family: var(--negz-sans) !important;
    padding: 13px 0 !important;
    text-align: left !important;
    transition: color 0.15s !important;
}

.tribe-filter-bar-c-filter__toggle:hover,
.tribe-filter-bar-c-filter__toggle:hover .tribe-filter-bar-c-filter__toggle-label {
    color: var(--negz-blau) !important;
}

.tribe-filter-bar-c-filter__toggle-text {
    display: flex !important;
    align-items: baseline !important;
    flex-wrap: wrap !important;
    gap: 4px !important;
    min-width: 0 !important;
}

.tribe-filter-bar-c-filter__toggle-label {
    color: var(--negz-dunkel) !important;
    font-family: var(--negz-sans) !important;
    font-size: 0.88rem !important;
    font-weight: 600 !important;
    transition: color 0.15s !important;
}

.tribe-filter-bar-c-filter__toggle-label-colon {
    color: var(--negz-dunkel) !important;
    font-weight: 600 !important;
    margin-right: 2px !important;
}

.tribe-filter-bar-c-filter__toggle-selections-count {
    background: var(--negz-blau) !important;
    border-radius: 10px !important;
    color: var(--negz-weiss) !important;
    flex-shrink: 0 !important;
    font-family: var(--negz-sans) !important;
    font-size: 0.78rem !important;
    font-weight: 700 !important;
    line-height: 1.4 !important;
    padding: 1px 6px !important;
}

.tribe-filter-bar-c-filter__toggle-selections {
    color: var(--negz-blau) !important;
    font-family: var(--negz-sans) !important;
    font-size: 0.82rem !important;
    font-weight: 500 !important;
}

.tribe-filter-bar-c-filter__toggle-icon {
    color: var(--negz-blau) !important;
    flex-shrink: 0 !important;
    margin-left: 10px !important;
}

.tribe-filter-bar-c-filter__toggle-plus-icon,
.tribe-filter-bar-c-filter__toggle-minus-icon {
    display: block !important;
    width: 12px !important;
    height: 12px !important;
    stroke: var(--negz-blau) !important;
}

.tribe-filter-bar-c-filter__toggle[aria-expanded="true"] .tribe-filter-bar-c-filter__toggle-icon--plus {
    display: none !important;
}

.tribe-filter-bar-c-filter__toggle[aria-expanded="false"] .tribe-filter-bar-c-filter__toggle-icon--minus {
    display: none !important;
}

.tribe-filter-bar-c-filter--has-selections .tribe-filter-bar-c-filter__toggle-label {
    color: var(--negz-blau) !important;
}

/* Aufklapp-Container (Dropdown-Inhalt) */
.tribe-filter-bar-c-filter__container {
    padding-bottom: 14px !important;
}

.tribe-filter-bar-c-filter__filters-fieldset {
    border: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

.tribe-filter-bar-c-filter__filter-fields {
    width: 100% !important;
}

/* Select2 Dropdown */
.tribe-filter-bar-c-dropdown .select2-container--default .select2-selection--single {
    display: flex !important;
    align-items: center !important;
    height: 38px !important;
    background: var(--negz-weiss) !important;
    border: 1.5px solid var(--negz-grau-mittel) !important;
    border-radius: var(--negz-radius) !important;
    transition: border-color 0.15s !important;
}

.tribe-filter-bar-c-dropdown .select2-container--focus .select2-selection--single,
.tribe-filter-bar-c-dropdown .select2-container--open .select2-selection--single {
    border-color: var(--negz-blau) !important;
    box-shadow: 0 0 0 2px rgba(48, 144, 176, 0.15) !important;
    outline: none !important;
}

.tribe-filter-bar-c-dropdown .select2-selection__rendered {
    color: var(--negz-dunkel) !important;
    font-family: var(--negz-sans) !important;
    font-size: 0.88rem !important;
    line-height: 36px !important;
    padding: 0 28px 0 10px !important;
}

.tribe-filter-bar-c-dropdown .select2-selection__placeholder .select2-selection__choice__text,
.tribe-filter-bar-c-dropdown .select2-selection__placeholder {
    color: var(--negz-grau-text) !important;
    font-style: normal !important;
}

.tribe-filter-bar-c-dropdown .select2-selection__arrow {
    height: 36px !important;
    right: 8px !important;
}

.tribe-filter-bar-c-dropdown .select2-selection__arrow b {
    border-color: var(--negz-blau) transparent transparent transparent !important;
    border-width: 5px 4px 0 4px !important;
    margin-top: -2px !important;
}

.tribe-filter-bar-c-dropdown .select2-selection__clear {
    color: var(--negz-grau-text) !important;
    font-size: 1.1rem !important;
    font-weight: 400 !important;
    line-height: 1 !important;
    margin-right: 4px !important;
}

.tribe-filter-bar-c-dropdown .select2-selection__clear:hover {
    color: var(--negz-blau) !important;
}

.tribe-filter-bar-c-dropdown--has-selection .select2-selection__rendered {
    color: var(--negz-dunkel) !important;
    font-weight: 600 !important;
}

.tribe-filter-bar-c-dropdown .select2-dropdown {
    background: var(--negz-weiss) !important;
    border: 1px solid var(--negz-grau-mittel) !important;
    border-radius: var(--negz-radius) !important;
    box-shadow: 0 4px 16px rgba(18, 54, 81, 0.12) !important;
    font-family: var(--negz-sans) !important;
    z-index: 9999 !important;
}

.tribe-filter-bar-c-dropdown .select2-search--dropdown {
    border-bottom: 1px solid var(--negz-grau-mittel) !important;
    padding: 8px 10px !important;
}

.tribe-filter-bar-c-dropdown .select2-search__field {
    width: 100% !important;
    border: 1.5px solid var(--negz-grau-mittel) !important;
    border-radius: var(--negz-radius) !important;
    box-sizing: border-box !important;
    color: var(--negz-dunkel) !important;
    font-family: var(--negz-sans) !important;
    font-size: 0.85rem !important;
    outline: none !important;
    padding: 5px 8px !important;
    transition: border-color 0.15s !important;
}

.tribe-filter-bar-c-dropdown .select2-search__field:focus {
    border-color: var(--negz-blau) !important;
    box-shadow: 0 0 0 2px rgba(48, 144, 176, 0.15) !important;
}

.tribe-filter-bar-c-dropdown .select2-results__options {
    max-height: 240px !important;
    overflow-y: auto !important;
    padding: 4px 0 !important;
}

.tribe-filter-bar-c-dropdown .select2-results__option {
    color: var(--negz-dunkel) !important;
    cursor: pointer !important;
    font-family: var(--negz-sans) !important;
    font-size: 0.85rem !important;
    line-height: 1.4 !important;
    padding: 8px 12px !important;
    transition: background 0.1s !important;
}

.tribe-filter-bar-c-dropdown .select2-results__option--highlighted {
    background: var(--negz-grau-hell) !important;
    color: var(--negz-dunkel) !important;
}

.tribe-filter-bar-c-dropdown .select2-results__option[aria-selected="true"] {
    background: rgba(48, 144, 176, 0.1) !important;
    color: var(--negz-blau) !important;
    font-weight: 600 !important;
}

/* Scrollbar im Dropdown (Webkit) */
.tribe-filter-bar-c-dropdown .select2-results__options::-webkit-scrollbar {
    width: 5px !important;
}

.tribe-filter-bar-c-dropdown .select2-results__options::-webkit-scrollbar-thumb {
    background: var(--negz-grau-mittel) !important;
    border-radius: 3px !important;
}

.tribe-filter-bar-c-dropdown .select2-results__options::-webkit-scrollbar-track {
    background: transparent !important;
}

@media (max-width: 768px) {
    .tribe-filter-bar {
        padding: 16px !important;
        border-radius: var(--negz-radius) !important;
    }

    .tribe-filter-bar__action-done,
    .tribe-filter-bar__action-clear {
        width: 100% !important;
        justify-content: center !important;
    }

    .tribe-filter-bar__actions {
        flex-direction: column !important;
    }
}

/* ============================================================
   SIDEBAR – The Events Calendar Block
   Scope: nur Event-Listen innerhalb der rechten Sidebar
   Das Main-Content-Styling der Event-Blocks bleibt unverändert
   ============================================================ */

/* Event-Liste */
#right-sidebar.widget-area.sidebar .inside-right-sidebar .ecs-event-list {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Event-Einträge: globales Main-Content-Grid nur in der Sidebar aufheben */
#right-sidebar.widget-area.sidebar .inside-right-sidebar .ecs-event-list .ecs-event {
    display: block !important;
    grid-template-columns: none !important;
    grid-template-areas: none !important;
    column-gap: 0 !important;
    row-gap: 0 !important;
    align-items: initial !important;

    background: transparent !important;
    border: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;

    margin: 0 0 18px 0 !important;
    padding: 0 !important;
    box-sizing: border-box !important;

    transform: none !important;
    transition: none !important;
}

#right-sidebar.widget-area.sidebar .inside-right-sidebar .ecs-event-list .ecs-event:last-child {
    margin-bottom: 0 !important;
}

/* Kein Card-Hover in der Sidebar */
#right-sidebar.widget-area.sidebar .inside-right-sidebar .ecs-event-list .ecs-event:hover {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    transform: none !important;
}

/* Falls der Block später doch Bilder ausgibt */
#right-sidebar.widget-area.sidebar .inside-right-sidebar .ecs-event-list .ecs-event > a {
    display: block !important;
    grid-area: auto !important;
    margin: 0 0 10px 0 !important;
}

#right-sidebar.widget-area.sidebar .inside-right-sidebar .ecs-event-list .ecs-event img {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    aspect-ratio: 3 / 2 !important;
    object-fit: cover !important;
    margin: 0 !important;
}

/* Event-Titel */
#right-sidebar.widget-area.sidebar .inside-right-sidebar .ecs-event-list .ecs-event .entry-title,
#right-sidebar.widget-area.sidebar .inside-right-sidebar .ecs-event-list .ecs-event h4.entry-title {
    grid-area: auto !important;
    font-family: var(--negz-sans) !important;
    font-size: 1.05rem !important;
    line-height: 1.35 !important;
    font-weight: 600 !important;
    color: var(--negz-dunkel) !important;
    margin: 0 0 8px 0 !important;
    padding: 0 !important;
    letter-spacing: normal !important;
    text-transform: none !important;
}

#right-sidebar.widget-area.sidebar .inside-right-sidebar .ecs-event-list .ecs-event .entry-title a,
#right-sidebar.widget-area.sidebar .inside-right-sidebar .ecs-event-list .ecs-event h4.entry-title a {
    color: var(--negz-dunkel) !important;
    text-decoration: none !important;
    overflow-wrap: anywhere !important;
}

#right-sidebar.widget-area.sidebar .inside-right-sidebar .ecs-event-list .ecs-event .entry-title a:hover,
#right-sidebar.widget-area.sidebar .inside-right-sidebar .ecs-event-list .ecs-event .entry-title a:focus,
#right-sidebar.widget-area.sidebar .inside-right-sidebar .ecs-event-list .ecs-event h4.entry-title a:hover,
#right-sidebar.widget-area.sidebar .inside-right-sidebar .ecs-event-list .ecs-event h4.entry-title a:focus {
    color: var(--negz-blau) !important;
    text-decoration: underline !important;
    text-decoration-thickness: 1px !important;
    text-underline-offset: 3px !important;
}

#right-sidebar.widget-area.sidebar .inside-right-sidebar .ecs-event-list .ecs-event .entry-title a:focus-visible,
#right-sidebar.widget-area.sidebar .inside-right-sidebar .ecs-event-list .ecs-event h4.entry-title a:focus-visible {
    outline: 2px solid var(--negz-blau) !important;
    outline-offset: 3px !important;
}

/* Datum / Uhrzeit */
#right-sidebar.widget-area.sidebar .inside-right-sidebar .ecs-event-list .ecs-event .duration.time {
    grid-area: auto !important;
    display: block !important;
    margin: 0 0 7px 0 !important;
    padding: 0 !important;

    font-family: var(--negz-sans) !important;
    font-size: 0.88rem !important;
    line-height: 1.5 !important;
    font-weight: 500 !important;
    color: var(--negz-blau) !important;
}

#right-sidebar.widget-area.sidebar .inside-right-sidebar .ecs-event-list .ecs-event .duration.time span,
#right-sidebar.widget-area.sidebar .inside-right-sidebar .ecs-event-list .ecs-event .duration.time .tribe-event-date-start,
#right-sidebar.widget-area.sidebar .inside-right-sidebar .ecs-event-list .ecs-event .duration.time .tribe-event-date-end,
#right-sidebar.widget-area.sidebar .inside-right-sidebar .ecs-event-list .ecs-event .duration.time .tribe-event-time {
    font-family: inherit !important;
    font-size: inherit !important;
    line-height: inherit !important;
    font-weight: inherit !important;
    color: inherit !important;
}

/* Veranstaltungsort in der Sidebar ausblenden */
#right-sidebar.widget-area.sidebar .inside-right-sidebar .ecs-event-list .ecs-event .duration.venue {
    display: none !important;
}

/* Optionaler Excerpt, falls der Shortcode später Auszüge ausgibt */
#right-sidebar.widget-area.sidebar .inside-right-sidebar .ecs-event-list .ecs-event .ecs-excerpt {
    grid-area: auto !important;
    font-family: var(--negz-serif) !important;
    font-size: 0.9rem !important;
    line-height: 1.55 !important;
    color: #111111 !important;
    margin: 8px 0 0 0 !important;
}

/* Fallback, falls keine Termine vorhanden sind */
#right-sidebar.widget-area.sidebar .inside-right-sidebar .ecs-no-events {
    margin: 0 !important;
    padding: 0 !important;
    font-family: var(--negz-serif) !important;
    font-size: 0.95rem !important;
    line-height: 1.55 !important;
    color: var(--negz-dunkel) !important;
}


/* ============================================================
   SIDEBAR – Mobile Feinjustierung
   ============================================================ */

@media (max-width: 768px) {
    #right-sidebar.widget-area.sidebar .inside-right-sidebar .ecs-event-list .ecs-event {
        margin-bottom: 16px !important;
    }

    #right-sidebar.widget-area.sidebar .inside-right-sidebar .ecs-event-list .ecs-event .entry-title,
    #right-sidebar.widget-area.sidebar .inside-right-sidebar .ecs-event-list .ecs-event h4.entry-title {
        font-size: 1rem !important;
    }
}