/* ── Messekalender Komponente ──────────────────────────────── */

/* Such- und Filterbereich (grauer Container, wie Downloads-Seite) */
.messekalender-toolbar {
    background: var(--mkpi-bg-secondary);
    padding: var(--mkpi-space-6) var(--mkpi-space-5);
    border-radius: var(--mkpi-radius-lg);
    margin-bottom: var(--space-xl);
}

/* Suchfeld */
.messekalender-toolbar .messekalender-search-input {
    border: 1px solid var(--mkpi-border-light);
    padding: var(--mkpi-space-3) var(--mkpi-space-4);
    font-size: var(--mkpi-text-body);
    width: 100%;
    border-radius: var(--mkpi-radius-sm);
    background: var(--mkpi-bg-primary);
    color: var(--mkpi-text-primary);
    transition: border-color var(--mkpi-transition-base), box-shadow var(--mkpi-transition-base);
    outline: none;
}

.messekalender-toolbar .messekalender-search-input:focus {
    border-color: var(--mkpi-accent);
    box-shadow: 0 0 0 0.2rem rgba(0, 113, 227, 0.15);
}

.messekalender-toolbar .messekalender-search-input::placeholder {
    color: var(--mkpi-text-secondary);
}

/* Reset-Button neben dem Suchfeld (wie Downloads-Seite, kein Pill) */
.messekalender-toolbar .filter-reset-btn.btn {
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--mkpi-space-3) var(--mkpi-space-5);
    border-radius: var(--mkpi-radius-sm) !important;
    border: 1px solid var(--mkpi-accent) !important;
    color: var(--mkpi-accent) !important;
    background-color: transparent !important;
}

.messekalender-toolbar .filter-reset-btn.btn:hover {
    background-color: var(--mkpi-accent) !important;
    border-color: var(--mkpi-accent) !important;
    color: #fff !important;
}

/* Branchen-Filter (Pill-Buttons) */
.messekalender-filter {
    display: flex;
    flex-wrap: wrap;
    gap: var(--mkpi-space-3);
    margin-top: var(--mkpi-space-4);
}

.messekalender-filter .filter-btn {
    background: var(--mkpi-bg-primary);
    border: 1px solid var(--mkpi-border-light);
    color: var(--mkpi-text-secondary);
    font-size: var(--mkpi-text-small);
    font-weight: var(--mkpi-weight-medium);
    padding: var(--mkpi-space-2) var(--mkpi-space-4);
    border-radius: var(--mkpi-radius-sm);
    cursor: pointer;
    transition: all var(--mkpi-transition-base);
    white-space: nowrap;
}

.messekalender-filter .filter-btn:hover {
    background: var(--mkpi-accent);
    border-color: var(--mkpi-accent);
    color: #fff;
}

.messekalender-filter .filter-btn.active {
    background: var(--mkpi-accent);
    border-color: var(--mkpi-accent);
    color: #fff;
}

/* Statistik-Zeile */
.messekalender-stats {
    font-size: var(--mkpi-text-h4);
    font-weight: var(--mkpi-weight-semibold);
    color: var(--mkpi-text-primary);
}

/* Messe-Liste (kompakte Zeilen) */
.messekalender-list {
    width: 100%;
}

/* Monats-Header */
.messekalender-month-header {
    font-size: var(--mkpi-text-body);
    font-weight: var(--mkpi-weight-semibold);
    color: var(--mkpi-text-primary);
    padding: var(--mkpi-space-4) 0 var(--mkpi-space-2);
    border-bottom: 1px solid var(--mkpi-text-secondary);
    margin-bottom: 0;
}

.messekalender-month-group + .messekalender-month-group .messekalender-month-header {
    margin-top: var(--mkpi-space-4);
}

/* Einzelne Zeile */
.messekalender-row {
    display: flex;
    align-items: center;
    gap: var(--mkpi-space-4);
    padding: var(--mkpi-space-3) var(--mkpi-space-3);
    border-bottom: 1px solid var(--mkpi-border-light);
    background: var(--mkpi-bg-primary);
    transition: background-color var(--mkpi-transition-base);
}

.messekalender-row:hover {
    background: var(--mkpi-bg-secondary);
}

/* Datum */
.messekalender-row-datum {
    flex: 0 0 140px;
    font-size: var(--mkpi-text-body);
    font-weight: var(--mkpi-weight-regular);
    color: var(--mkpi-text-primary);
    white-space: nowrap;
}

/* Messename (klickbar fuer Accordion) */
.messekalender-row-name {
    flex: 1;
    font-size: var(--mkpi-text-body);
    font-weight: var(--mkpi-weight-semibold);
    color: var(--mkpi-text-primary);
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: var(--mkpi-space-2);
    min-width: 0;
}

.messekalender-row-name:hover {
    color: var(--mkpi-accent);
}

.messekalender-row-chevron {
    font-size: var(--mkpi-text-caption);
    transition: transform var(--mkpi-transition-base);
    flex-shrink: 0;
    color: var(--mkpi-text-secondary);
}

.messekalender-row-name[aria-expanded="true"] .messekalender-row-chevron {
    transform: rotate(180deg);
}

/* Branche-Tag */
.messekalender-row-branche {
    flex: 0 0 170px;
    font-size: var(--mkpi-text-caption);
    font-weight: var(--mkpi-weight-medium);
    padding: var(--mkpi-space-1) var(--mkpi-space-3);
    border-radius: var(--mkpi-radius-sm);
    background: var(--mkpi-bg-secondary);
    color: var(--mkpi-text-secondary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    text-align: center;
}

/* Ort */
.messekalender-row-ort {
    flex: 0 0 200px;
    font-size: var(--mkpi-text-caption);
    color: var(--mkpi-text-secondary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.messekalender-row-ort > i {
    margin-right: var(--mkpi-space-1);
}

/* CTA-Button in der Zeile */
.messekalender-row-cta {
    flex: 0 0 auto;
}

.messekalender-row-cta .btn {
    white-space: nowrap;
}

/* Aufklappbare Beschreibung */
.messekalender-row-desc {
    padding: var(--mkpi-space-3) var(--mkpi-space-3) var(--mkpi-space-3) calc(140px + var(--mkpi-space-4) + var(--mkpi-space-3));
    background: var(--mkpi-bg-secondary);
    border-bottom: 1px solid var(--mkpi-border-light);
}

.messekalender-row-desc p {
    font-size: var(--mkpi-text-caption);
    color: var(--mkpi-text-secondary);
    margin: 0;
    line-height: 1.5;
}

/* Filter-Zustand */
.messekalender-item {
    transition: opacity var(--mkpi-transition-slow);
}

.messekalender-item.filtered-out {
    display: none;
}

/* Keine Ergebnisse */
.messekalender-no-results {
    text-align: center;
    color: var(--mkpi-text-secondary);
    padding: var(--mkpi-space-10) 0;
    display: none;
}

.messekalender-no-results > i {
    font-size: var(--mkpi-text-h2);
    color: var(--mkpi-border-light);
}

/* Responsive */
@media (max-width: 991.98px) {
    .messekalender-row {
        flex-wrap: wrap;
        gap: var(--mkpi-space-2);
        padding: var(--mkpi-space-3);
    }

    .messekalender-row-datum {
        flex: 0 0 100px;
    }

    .messekalender-row-name {
        flex: 1 1 calc(100% - 120px);
        order: 0;
    }

    .messekalender-row-branche {
        flex: 0 0 auto;
        order: -1;
    }

    .messekalender-row-ort {
        flex: 1 1 auto;
    }

    .messekalender-row-cta {
        flex: 0 0 auto;
    }

    .messekalender-row-desc {
        padding-left: var(--mkpi-space-3);
    }
}

@media (max-width: 767.98px) {
    .messekalender-toolbar .filter-reset-btn.btn {
        margin-top: var(--mkpi-space-3);
    }

    .messekalender-filter {
        justify-content: center;
    }

    .messekalender-row {
        flex-wrap: wrap;
        gap: var(--mkpi-space-2);
    }

    .messekalender-row-datum {
        flex: 0 0 auto;
    }

    .messekalender-row-name {
        flex: 1 1 100%;
        order: 1;
    }

    .messekalender-row-branche {
        flex: 0 0 auto;
        order: 0;
    }

    .messekalender-row-ort {
        flex: 1 1 100%;
        order: 2;
    }

    .messekalender-row-cta {
        flex: 0 0 100%;
        order: 3;
    }

    .messekalender-row-cta .btn {
        width: 100%;
    }

    .messekalender-row-desc {
        padding-left: var(--mkpi-space-3);
    }
}
