.ttvb-terminkalender {
    --ttvb-border: #e5e7eb;
    --ttvb-text: #111827;
    --ttvb-muted: #6b7280;
    --ttvb-accent: #1f6f8b;
    margin: 0;
    color: var(--ttvb-text);
}

.ttvb-terminkalender [hidden] {
    display: none !important;
}

.ttvb-terminkalender,
.ttvb-terminkalender * {
    box-sizing: border-box;
    border-radius: 0 !important;
    box-shadow: none !important;
}

.ttvb-terminkalender__toolbar {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    margin-bottom: 0.9rem;
}

.ttvb-terminkalender__status {
    min-width: 12rem;
    text-align: center;
    font-weight: 700;
}

.ttvb-nav-button {
    width: 2.4rem;
    height: 2.4rem;
    border: 1px solid var(--ttvb-border);
    background: #fff;
    color: var(--ttvb-accent);
    font-size: 1.65rem;
    line-height: 1;
    cursor: pointer;
}

.ttvb-nav-button:hover:not(:disabled),
.ttvb-nav-button:focus-visible:not(:disabled) {
    background: #f9fafb;
}

.ttvb-nav-button:disabled {
    cursor: not-allowed;
    opacity: 0.35;
}

.ttvb-terminkalender-list {
    display: grid;
    gap: 0;
    border: 1px solid var(--ttvb-border);
    border-bottom: 0;
}

.ttvb-event {
    display: grid;
    grid-template-columns: 0.28rem 1fr;
    gap: 0.15rem 0.75rem;
    align-items: center;
    padding: 0.3rem 1rem;
    border: 0;
    border-bottom: 1px solid var(--ttvb-border);
    background: #fff;
}

.ttvb-event::before {
    content: "";
    display: block;
    grid-column: 1;
    grid-row: 1 / span 2;
    align-self: stretch;
    min-height: 2.5rem;
    background: var(--ttvb-pastel, #cbd5e1);
}

.ttvb-event__date {
    grid-column: 2;
    grid-row: 1;
    color: var(--ttvb-accent);
    font-weight: bold;
    line-height: 1.15;
    white-space: nowrap;
    align-self: end;
}

.ttvb-event__title {
    grid-column: 2;
    grid-row: 2;
    font-weight: 400;
    line-height: 1.2;
    align-self: start;
}

.ttvb-event--national { --ttvb-pastel: #dbeafe; }
.ttvb-event--rl-ol-vol { --ttvb-pastel: #ede9fe; }
.ttvb-event--ttvb-wettbewerbe { --ttvb-pastel: #dcfce7; }
.ttvb-event--ttvb-ligen { --ttvb-pastel: #ffedd5; }
.ttvb-event--sitzungen-sonstiges { --ttvb-pastel: #e2e8f0; }
.ttvb-event--sonstiges { --ttvb-pastel: #f1f5f9; }

.ttvb-terminkalender-legend {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
    margin: 0 0 0.9rem;
}

.ttvb-legend-item {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.35rem 0.6rem;
    background: var(--ttvb-pastel, #f1f5f9);
    border: 1px solid rgba(17, 24, 39, 0.08);
    font-size: 0.85rem;
    font-weight: 700;
    white-space: nowrap;
}

.ttvb-legend-swatch {
    width: 0.75rem;
    height: 0.75rem;
    background: rgba(17, 24, 39, 0.22);
}

.ttvb-calendar-grid {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 0.45rem;
}

.ttvb-calendar-grid--head {
    margin-bottom: 0.45rem;
}

.ttvb-calendar-weekday {
    padding: 0.5rem 0.35rem;
    background: var(--ttvb-accent);
    color: #fff;
    font-size: 0.85rem;
    font-weight: 800;
    text-align: center;
}

.ttvb-calendar-weeks {
    display: grid;
    gap: 0.45rem;
}

.ttvb-calendar-week {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    grid-template-rows: 2rem repeat(var(--ttvb-lanes, 1), minmax(1.7rem, auto));
    gap: 0.25rem 0;
    min-height: calc(4.2rem + (var(--ttvb-lanes, 1) * 1.9rem));
    border-left: 1px solid var(--ttvb-border);
    border-top: 1px solid var(--ttvb-border);
    background: #fff;
}

.ttvb-calendar-day {
    grid-row: 1 / -1;
    min-height: 100%;
    padding: 0.45rem 0.45rem 0.35rem;
    border-right: 1px solid var(--ttvb-border);
    border-bottom: 1px solid var(--ttvb-border);
    background: #fff;
    overflow: hidden;
    z-index: 1;
}

.ttvb-calendar-day.is-empty {
    background: #f9fafb;
}

.ttvb-calendar-day__number {
    color: var(--ttvb-muted);
    font-size: 0.8rem;
    font-weight: 800;
}

.ttvb-calendar-event {
    z-index: 2;
    align-self: start;
    min-height: 1.55rem;
    margin: 0.05rem 0.12rem 0;
    padding: 0.25rem 0.45rem;
    background: var(--ttvb-pastel, #f1f5f9);
    border-left: 3px solid rgba(17, 24, 39, 0.18);
    font-size: 0.76rem;
    font-weight: 650;
    line-height: 1.2;
    word-break: break-word;
    overflow: hidden;
}

.ttvb-calendar-event.is-continued-before {
    margin-left: 0;
    border-left-width: 0;
}

.ttvb-calendar-event.is-continued-after {
    margin-right: 0;
}

.ttvb-terminkalender-ics {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    align-items: center;
    margin-top: 1rem;
    padding-top: 0.8rem;
    border-top: 1px solid var(--ttvb-border);
}

.ttvb-terminkalender-ics__label {
    font-weight: 800;
}

.ttvb-terminkalender-ics__links {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.ttvb-ics-link {
    display: inline-flex;
    align-items: center;
    padding: 0.35rem 0.6rem;
    background: var(--ttvb-pastel, #f1f5f9);
    border: 1px solid rgba(17, 24, 39, 0.08);
    color: var(--ttvb-text);
    font-size: 0.85rem;
    font-weight: 700;
    line-height: 1.2;
    text-decoration: none;
}

.ttvb-ics-link:hover,
.ttvb-ics-link:focus-visible {
    filter: brightness(0.98);
    text-decoration: underline;
}

.ttvb-terminkalender-empty {
    padding: 1rem;
    border: 1px dashed #cbd5e1;
}

@media (max-width: 760px) {

    .ttvb-calendar-grid {
        gap: 0.25rem;
    }

    .ttvb-calendar-day {
        min-height: 5.9rem;
        padding: 0.35rem;
    }

    .ttvb-calendar-event {
        font-size: 0.68rem;
        padding: 0.28rem 0.35rem;
    }
}
