/* ==================== App Shell (Grid) ==================== */

.app-container {
    display: grid;
    grid-template-columns: 220px 1fr;
    grid-template-rows: 1fr;
    min-height: 100vh;
}

/* ==================== Sidebar ==================== */

.sidebar {
    background: var(--color-primary);
    color: white;
    display: grid;
    grid-template-rows: auto 1fr auto;
    padding: var(--spacing-md) 0;
}

.sidebar-header {
    padding: var(--spacing-md) var(--spacing-lg);
    border-bottom: 1px solid rgba(255,255,255,0.15);
    margin-bottom: var(--spacing-md);
}

.sidebar-header h1 { font-size: var(--font-size-lg); }
.sidebar-header small { opacity: 0.6; }

.nav-section { margin-bottom: var(--spacing-md); }

.nav-section-title {
    padding: var(--spacing-xs) var(--spacing-lg);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    opacity: 0.5;
}

.nav-item {
    display: block;
    width: 100%;
    padding: var(--spacing-sm) var(--spacing-lg);
    background: none;
    border: none;
    color: rgba(255,255,255,0.8);
    text-align: left;
    cursor: pointer;
    font-size: var(--font-size-sm);
    transition: background 0.15s;
}

.nav-item:hover { background: rgba(255,255,255,0.1); }
.nav-item.active { background: rgba(255,255,255,0.15); color: white; font-weight: 600; }

.sidebar-footer {
    border-top: 1px solid rgba(255,255,255,0.15);
    padding-top: var(--spacing-sm);
}

/* ==================== Main Content ==================== */

main {
    padding: var(--spacing-lg);
    overflow-y: auto;
    max-height: 100vh;
}

.loading { color: var(--color-text-light); }
.error { color: var(--color-danger); }

/* ==================== View Header (Grid) ==================== */

.view-header {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    margin-bottom: var(--spacing-lg);
    gap: var(--spacing-md);
}

.view-header h2 { margin: 0; }

.view-actions {
    display: grid;
    grid-auto-flow: column;
    gap: var(--spacing-sm);
    align-items: center;
}

/* ==================== Tables ==================== */

.table-container { overflow-x: auto; }

.data-table {
    width: 100%;
    border-collapse: collapse;
    background: var(--color-surface);
    border-radius: var(--radius);
    overflow: hidden;
    box-shadow: var(--shadow);
}

.data-table th {
    text-align: left;
    padding: var(--spacing-sm) var(--spacing-md);
    background: var(--color-bg);
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-text-light);
    border-bottom: 2px solid var(--color-border);
    position: sticky;
    top: 0;
    z-index: 10;
}

.data-table td {
    padding: var(--spacing-sm) var(--spacing-md);
    border-bottom: 1px solid var(--color-border);
    font-size: var(--font-size-sm);
    max-width: 400px;
    overflow: hidden;
    text-overflow: ellipsis;
}

.data-table tr:last-child td { border-bottom: none; }

.clickable-row { cursor: pointer; }
.clickable-row:hover { background: rgba(26, 82, 118, 0.04); }

.text-center { text-align: center; }
.text-light { color: var(--color-text-light); }

/* ==================== Buttons ==================== */

.btn {
    padding: var(--spacing-sm) var(--spacing-md);
    border: none;
    border-radius: var(--radius);
    cursor: pointer;
    font-size: var(--font-size-sm);
    font-weight: 500;
}

.btn-primary { background: var(--color-primary); color: white; }
.btn-primary:hover { background: var(--color-primary-light); }

.btn-sm { padding: var(--spacing-xs) var(--spacing-sm); font-size: 12px; }

.btn-icon {
    background: none;
    border: none;
    cursor: pointer;
    font-size: 18px;
    color: var(--color-text-light);
    padding: 2px 6px;
    border-radius: var(--radius);
}

.btn-icon:hover { color: var(--color-danger); background: rgba(231, 76, 60, 0.08); }

/* ==================== Search / Inputs ==================== */

.search-input {
    padding: var(--spacing-sm) var(--spacing-md);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    font-size: var(--font-size-sm);
    min-width: 180px;
}

/* ==================== Badges ==================== */

.badge {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 12px;
    font-size: 11px;
    font-weight: 600;
    color: white;
    background: var(--color-text-light);
}

.badge-offen { background: var(--color-warning); }
.badge-in_bearbeitung { background: var(--color-primary-light); }
.badge-erledigt { background: var(--color-success); }
.badge-geschlossen { background: var(--color-text-light); }

/* ==================== KPI Cards (Grid) ==================== */

.kpi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-xl);
}

.kpi-card {
    background: var(--color-surface);
    border-radius: var(--radius);
    padding: var(--spacing-lg);
    box-shadow: var(--shadow);
    text-align: center;
}

.kpi-value { font-size: 28px; font-weight: 700; color: var(--color-primary); }
.kpi-label { font-size: var(--font-size-sm); color: var(--color-text-light); margin-top: var(--spacing-xs); }

/* ==================== Cards (Grid + Subgrid) ==================== */

.card-list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    grid-template-rows: subgrid;
    gap: var(--spacing-md);
}

/* Fallback: Wenn subgrid nicht unterstuetzt, normales Grid */
@supports not (grid-template-rows: subgrid) {
    .card-list { grid-template-rows: auto; }
}

.card {
    position: relative;
    display: grid;
    grid-row: span 2;
    grid-template-rows: subgrid;
    background: var(--color-surface);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    padding: var(--spacing-md);
    padding-top: calc(var(--spacing-md) + 4px);
    cursor: pointer;
    transition: box-shadow 0.15s;
    overflow: hidden;
}

/* Fallback */
@supports not (grid-template-rows: subgrid) {
    .card { grid-template-rows: auto 1fr; }
}

.card:hover { box-shadow: 0 4px 16px rgba(0,0,0,0.12); }

.card-header {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    margin-bottom: var(--spacing-sm);
    overflow: hidden;
}

.card-header > strong {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.card-body { font-size: var(--font-size-sm); }

.card-body > div {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* ==================== Modal (Grid) ==================== */

.modal {
    position: fixed;
    inset: 0;
    z-index: 1000;
    display: grid;
    place-items: center;
}

/* Sub-Modals (innerhalb eines offenen Modals geoeffnet) */
#cl-detail-dialog,
#cl-tpl-dialog,
#kontakt-edit-modal {
    z-index: 1100;
}

.modal[hidden] {
    display: none;
}

.modal-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.5);
}

.modal-content {
    position: relative;
    background: var(--color-surface);
    border-radius: var(--radius);
    box-shadow: 0 8px 32px rgba(0,0,0,0.2);
    display: grid;
    grid-template-rows: auto 1fr;
    max-height: 95vh;
    width: 95%;
    max-width: 1100px;
    resize: both;
    overflow: auto;
    min-width: 400px;
    min-height: 300px;
}

/* Schadenfall-Modal braucht Platz fuer 12 Tabs + Fieldsets */
.modal-content.modal-large {
    max-width: 1100px;
}

/* Schadenfall-Detail: Body erbt Spalten vom Modal fuer durchgaengige Ausrichtung */
.modal-body > .form-grid {
    grid-template-columns: subgrid;
}
@supports not (grid-template-columns: subgrid) {
    .modal-body > .form-grid { grid-template-columns: 140px 1fr; }
}

.modal-header {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    padding: var(--spacing-md) var(--spacing-lg);
    border-bottom: 1px solid var(--color-border);
}

.modal-header h2 { font-size: var(--font-size-lg); margin: 0; }

.modal-close {
    background: none;
    border: none;
    font-size: 24px;
    cursor: pointer;
    color: var(--color-text-light);
    padding: 0 var(--spacing-sm);
}

/* Tabs: Flexbox ist hier korrekt (Inline-Navigation, Ausnahme von Grid-Regel) */
.modal-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 0;
    border-bottom: 2px solid var(--color-border);
    padding: 0 var(--spacing-lg);
}

.tab-btn {
    padding: var(--spacing-sm) var(--spacing-md);
    background: none;
    border: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    cursor: pointer;
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    white-space: nowrap;
}

.tab-btn:hover { color: var(--color-text); }
.tab-btn.active { color: var(--color-primary); border-bottom-color: var(--color-primary); font-weight: 600; }
.tab-btn.tab-dragging { opacity: 0.4; }
.tab-btn[draggable="true"] { cursor: grab; }

.modal-body {
    padding: var(--spacing-lg);
    overflow-y: auto;
}

.tab-header {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-md);
}

/* ==================== Dialog-Varianten ==================== */

/* Breiter Dialog fuer Kostenpositionen etc. */
.modal-dialog-wide {
    max-width: 900px;
}

/* KP-Formular: 2x2 Spalten-Grid, bricht auf 1x2 um bei schmalen Fenstern */
.kp-form-grid {
    display: grid;
    grid-template-columns: 160px 1fr 160px 1fr;
    gap: var(--spacing-sm) var(--spacing-md);
    align-items: center;
}

@media (max-width: 800px) {
    .kp-form-grid {
        grid-template-columns: 120px 1fr;
    }
    .kp-form-grid .kp-span-right,
    .kp-form-grid .kp-half-left,
    .kp-form-grid .kp-half-right {
        grid-column: 2;
    }
}

.kp-form-grid label {
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-text-light);
}

.kp-form-grid input,
.kp-form-grid select {
    padding: var(--spacing-sm) var(--spacing-md);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    font-size: var(--font-size-sm);
}

/* Volle Breite (4 Spalten) fuer Firma-Select, Buttons etc. */
.kp-form-grid .kp-full { grid-column: 1 / -1; }
.kp-form-grid .kp-span-right { grid-column: 2 / -1; }
.kp-form-grid .kp-half-left { grid-column: 1 / 3; }
.kp-form-grid .kp-half-right { grid-column: 3 / 5; }

/* ==================== Vermerk-Formular: 4-Spalten-Grid ==================== */
.vermerk-form-grid {
    display: grid;
    grid-template-columns: 120px 1fr 120px 1fr;
    gap: var(--spacing-sm) var(--spacing-md);
    align-items: center;
}

@media (max-width: 800px) {
    .vermerk-form-grid {
        grid-template-columns: 120px 1fr;
    }
    .vermerk-form-grid .ve-span-right,
    .vermerk-form-grid .ve-half-left,
    .vermerk-form-grid .ve-half-right {
        grid-column: 2;
    }
}

.vermerk-form-grid label {
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-text-light);
}

.vermerk-form-grid input,
.vermerk-form-grid select,
.vermerk-form-grid textarea {
    padding: var(--spacing-sm) var(--spacing-md);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    font-size: var(--font-size-sm);
}

.vermerk-form-grid input:focus,
.vermerk-form-grid select:focus,
.vermerk-form-grid textarea:focus {
    outline: none;
    border-color: var(--color-primary-light);
    box-shadow: 0 0 0 2px rgba(41, 128, 185, 0.15);
}

.vermerk-form-grid .ve-full { grid-column: 1 / -1; }
.vermerk-form-grid .ve-span-right { grid-column: 2 / -1; }
.vermerk-form-grid .ve-half-left { grid-column: 1 / 3; }
.vermerk-form-grid .ve-half-right { grid-column: 3 / 5; }

/* Schnellsuche-Dropdown */
.ve-schnellsuche-wrap {
    position: relative;
}

.ve-schnellsuche-ergebnisse {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    z-index: 9999;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-md);
    max-height: 260px;
    overflow-y: auto;
}

.ve-schnellsuche-ergebnisse .ve-sse-kategorie {
    padding: var(--spacing-xs) var(--spacing-sm);
    font-weight: 700;
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    cursor: pointer;
}

.ve-schnellsuche-ergebnisse .ve-sse-kategorie:hover {
    background: var(--color-bg-hover);
}

.ve-schnellsuche-ergebnisse .ve-sse-item {
    padding: var(--spacing-xs) var(--spacing-sm) var(--spacing-xs) var(--spacing-xl);
    font-size: var(--font-size-sm);
    cursor: pointer;
}

.ve-schnellsuche-ergebnisse .ve-sse-item:hover {
    background: var(--color-primary-light);
    color: var(--color-bg);
}

/* Text-Bausteine Dropdown */
.ve-textbausteine-dropdown {
    position: absolute;
    right: 0;
    top: 100%;
    z-index: 9999;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-md);
    max-height: 200px;
    overflow-y: auto;
    min-width: 250px;
}

.ve-textbausteine-dropdown .ve-tb-item {
    padding: var(--spacing-xs) var(--spacing-sm);
    font-size: var(--font-size-sm);
    cursor: pointer;
}

.ve-textbausteine-dropdown .ve-tb-item:hover {
    background: var(--color-primary-light);
    color: var(--color-bg);
}

/* Sektions-Trenner innerhalb des KP-Formulars */
.kp-form-grid .kp-section {
    grid-column: 1 / -1;
    font-weight: 700;
    font-size: var(--font-size-sm);
    color: var(--color-primary);
    border-bottom: 1px solid var(--color-border);
    padding: var(--spacing-sm) 0 var(--spacing-xs);
    margin-top: var(--spacing-sm);
}

/* ==================== Forms (Grid) ==================== */

.form-grid {
    display: grid;
    grid-template-columns: 140px 1fr;
    gap: var(--spacing-sm) var(--spacing-md);
    align-items: center;
}

.form-grid label {
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-text-light);
}

.sf-input-with-sync {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: var(--spacing-xs);
    align-items: center;
}

.form-grid input,
.form-grid select,
.form-grid textarea {
    padding: var(--spacing-sm) var(--spacing-md);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    font-size: var(--font-size-sm);
}

.form-grid input:focus,
.form-grid select:focus {
    outline: none;
    border-color: var(--color-primary-light);
    box-shadow: 0 0 0 2px rgba(41, 128, 185, 0.15);
}

.form-actions {
    padding-top: var(--spacing-md);
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: max-content;
    gap: var(--spacing-sm);
}

/* ==================== Fieldset-Gruppen (Schadenfall-Detail) ==================== */

.schadenfall-fieldset {
    border: 1px solid var(--border-color, #ddd);
    border-radius: 4px;
    padding: 1rem;
    margin-bottom: 1rem;
}
.schadenfall-fieldset legend {
    font-weight: 600;
    font-size: 0.9rem;
    padding: 0 0.5rem;
    color: var(--primary-color, #1a5276);
}

/* ==================== Toast ==================== */

#toast-container {
    position: fixed;
    bottom: var(--spacing-lg);
    right: var(--spacing-lg);
    z-index: 2000;
    display: grid;
    gap: var(--spacing-sm);
}

.toast {
    padding: var(--spacing-sm) var(--spacing-lg);
    border-radius: var(--radius);
    color: white;
    font-size: var(--font-size-sm);
    opacity: 0;
    transform: translateY(10px);
    transition: opacity 0.3s, transform 0.3s;
}

.toast.show { opacity: 1; transform: translateY(0); }
.toast-info { background: var(--color-primary); }
.toast-success { background: var(--color-success); }
.toast-error { background: var(--color-danger); }

/* ==================== Arbeitsplaner (Grid) ==================== */

.planer-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: var(--spacing-sm);
}

.planer-grid {
    grid-template-rows: auto auto 1fr;
}

.planer-day {
    display: grid;
    grid-row: span 3;
    grid-template-rows: subgrid;
    background: var(--color-surface);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    min-height: 200px;
}

@supports not (grid-template-rows: subgrid) {
    .planer-grid { grid-template-rows: auto; }
    .planer-day { grid-row: auto; grid-template-rows: auto auto 1fr; }
}

.planer-today { border: 2px solid var(--color-primary-light); }

.planer-day-header {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    padding: var(--spacing-sm) var(--spacing-md);
    border-bottom: 1px solid var(--color-border);
    font-size: var(--font-size-sm);
}

.planer-hours { color: var(--color-text-light); font-size: 12px; }
.planer-hours.overload { color: var(--color-danger); font-weight: 600; }

.planer-day-tasks {
    padding: var(--spacing-xs);
    min-height: 100px;
}

.planer-day-tasks.drag-over { background: rgba(41, 128, 185, 0.06); }
.planer-pool.drag-over { background: rgba(231, 76, 60, 0.06); border: 1px dashed var(--color-danger); }

.planer-task-dragging { opacity: 0.4; }

/* Wochen-Kapazitaetsbalken */
.planer-week-bar {
    background: var(--color-surface);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    padding: var(--spacing-sm) var(--spacing-md);
    margin-bottom: var(--spacing-md);
}

.planer-week-label {
    display: grid;
    grid-template-columns: 1fr auto;
    font-size: var(--font-size-sm);
    margin-bottom: var(--spacing-xs);
}

.planer-capacity-bar {
    height: 8px;
    background: var(--color-border);
    border-radius: 4px;
    overflow: hidden;
}

.planer-capacity-fill {
    height: 100%;
    background: var(--color-success);
    border-radius: 4px;
    transition: width 0.3s;
}

.planer-capacity-overload { background: var(--color-danger); }

/* Tages-Kapazitaetsbalken */
.planer-day-capacity {
    height: 4px;
    background: var(--color-border);
    overflow: hidden;
}

.planer-day-capacity-fill {
    height: 100%;
    background: var(--color-primary-light);
    transition: width 0.3s;
}

.planer-task {
    display: grid;
    grid-template-columns: 1fr auto auto;
    align-items: center;
    gap: var(--spacing-xs);
    padding: var(--spacing-xs) var(--spacing-sm);
    margin-bottom: 2px;
    background: var(--color-bg);
    border-radius: 4px;
    font-size: 12px;
    cursor: grab;
}

.planer-task:active { cursor: grabbing; }

.planer-task-title { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.planer-task-hours { color: var(--color-text-light); }

.planer-unplan {
    font-size: 14px;
    padding: 0 2px;
}

.planer-empty {
    color: var(--color-text-light);
    font-size: 12px;
    text-align: center;
    padding: var(--spacing-lg) var(--spacing-sm);
}

.planer-pool {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: var(--spacing-xs);
    padding: var(--spacing-sm) 0;
}

/* ==================== Einstellungen (Grid) ==================== */

.settings-layout {
    display: grid;
    grid-template-columns: 180px 1fr;
    gap: var(--spacing-lg);
    min-height: 60vh;
}

.settings-tabs {
    display: grid;
    grid-auto-rows: max-content;
    gap: 2px;
}

.settings-tab-btn {
    padding: var(--spacing-sm) var(--spacing-md);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    cursor: pointer;
    font-size: var(--font-size-sm);
    text-align: left;
    color: var(--color-text);
}

.settings-tab-btn:hover { background: var(--color-bg); }
.settings-tab-btn.active {
    background: var(--color-primary);
    color: white;
    border-color: var(--color-primary);
    font-weight: 600;
}

.settings-content {
    background: var(--color-surface);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    padding: var(--spacing-lg);
}

.settings-section { margin-bottom: var(--spacing-lg); }

.settings-section-header {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    margin-bottom: var(--spacing-md);
}

.settings-section-header h3 { margin: 0; }

.settings-list {
    display: grid;
    gap: 2px;
}

.settings-list-item {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    padding: var(--spacing-sm) var(--spacing-md);
    background: var(--color-bg);
    border-radius: 4px;
    font-size: var(--font-size-sm);
}

.settings-item-actions {
    display: grid;
    grid-auto-flow: column;
    gap: var(--spacing-xs);
}

/* Collapsible Categories */

.collapsible-category {
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    margin-bottom: var(--spacing-sm);
    overflow: hidden;
}

.collapsible-category-header {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    padding: var(--spacing-sm) var(--spacing-md);
    background: var(--color-bg);
    cursor: pointer;
    -webkit-user-select: none;
    user-select: none;
}

.collapsible-category-header:hover { background: var(--color-border); }

.collapsible-header-left {
    display: grid;
    grid-template-columns: auto auto auto;
    align-items: center;
    gap: var(--spacing-sm);
}

.collapsible-header-right {
    display: grid;
    grid-auto-flow: column;
    gap: var(--spacing-xs);
}

.collapsible-toggle {
    font-size: 12px;
    color: var(--color-text-light);
    width: 16px;
    text-align: center;
}

.collapsible-category-content { padding: 0; }

.category-items {
    padding: var(--spacing-sm) var(--spacing-md);
    display: grid;
    gap: 2px;
}

/* ==================== Globale Suche ==================== */

.main-wrapper {
    display: grid;
    grid-template-rows: auto 1fr;
    overflow: hidden;
    max-height: 100vh;
}

.global-search-bar {
    position: relative;
    padding: var(--spacing-sm) var(--spacing-lg);
    background: var(--color-surface);
    border-bottom: 1px solid var(--color-border);
}

.global-search-input { width: 100%; }

.search-dropdown {
    position: absolute;
    top: 100%;
    left: var(--spacing-lg);
    right: var(--spacing-lg);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    box-shadow: 0 8px 24px rgba(0,0,0,0.15);
    z-index: 500;
    max-height: 400px;
    overflow-y: auto;
}

.search-item {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-md);
    cursor: pointer;
    border-bottom: 1px solid var(--color-border);
}

.search-item:last-child { border-bottom: none; }
.search-item:hover { background: var(--color-bg); }

.search-icon { font-size: 16px; }
.search-item-title { font-weight: 500; font-size: var(--font-size-sm); }
.search-item-sub { font-size: 12px; color: var(--color-text-light); }

.search-type-badge {
    font-size: 10px;
    text-transform: uppercase;
    color: var(--color-text-light);
    background: var(--color-bg);
    padding: 1px 6px;
    border-radius: 8px;
}

/* ==================== Backup ==================== */

.backup-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-lg);
}

.backup-card {
    background: var(--color-surface);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    padding: var(--spacing-lg);
}

.backup-card h3 { margin-bottom: var(--spacing-sm); }

/* ==================== Wetterdaten ==================== */

.wetter-form-card {
    background: var(--color-surface);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    padding: var(--spacing-lg);
    margin-bottom: var(--spacing-lg);
}

.wetter-form-grid {
    display: grid;
    grid-template-columns: 80px 1fr;
    gap: var(--spacing-sm) var(--spacing-md);
    align-items: center;
}

.wetter-form-grid label {
    font-weight: 500;
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
}

.wetter-form-actions {
    grid-column: 1 / -1;
    margin-top: var(--spacing-sm);
}

.wetter-card {
    background: var(--color-surface);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    padding: var(--spacing-lg);
    margin-bottom: var(--spacing-md);
}

.wetter-card h4 { margin-bottom: var(--spacing-md); }

.wetter-header-card {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: var(--spacing-sm);
    background: var(--color-surface);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    padding: var(--spacing-md) var(--spacing-lg);
    margin-bottom: var(--spacing-md);
}

.wetter-header-card h3 { margin: 0; grid-column: 1; }
.wetter-header-card .text-light { grid-column: 1; }

/* Sturm-Banner */
.wetter-sturm-banner {
    background: var(--color-danger);
    color: white;
    padding: var(--spacing-md) var(--spacing-lg);
    border-radius: var(--radius);
    margin-bottom: var(--spacing-md);
    font-size: var(--font-size-sm);
}

.wetter-row-sturm { background: rgba(231, 76, 60, 0.08); }

/* VersicherungsRecht */
.vr-details { font-size: var(--font-size-sm); color: var(--color-text-light); padding-left: var(--spacing-lg); }

.vr-block {
    border-radius: var(--radius);
    margin-bottom: var(--spacing-md);
    overflow: hidden;
}

.vr-block-header {
    padding: var(--spacing-sm) var(--spacing-md);
    font-weight: 600;
    font-size: var(--font-size-sm);
    color: white;
}

.vr-standard .vr-block-header { background: var(--color-primary); }
.vr-elementar .vr-block-header { background: var(--color-accent); }

.vr-gefahr {
    padding: var(--spacing-sm) var(--spacing-md);
    border-bottom: 1px solid var(--color-border);
    font-size: var(--font-size-sm);
}

.vr-gefahr:last-child { border-bottom: none; }
.vr-ziff { color: var(--color-text-light); font-size: 12px; }
.vr-detail { color: var(--color-text-light); font-size: 12px; margin-top: 2px; }
.vr-hinweis { font-size: 12px; color: var(--color-text-light); padding: var(--spacing-sm) var(--spacing-md); font-style: italic; }

.vr-folgeschaden {
    background: rgba(243, 156, 18, 0.1);
    border-left: 3px solid var(--color-warning);
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: var(--font-size-sm);
    border-radius: var(--radius);
    margin-top: var(--spacing-sm);
}

/* Schneelast */
.schneelast-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-md);
}

.schneelast-wert {
    text-align: center;
    padding: var(--spacing-sm);
    background: var(--color-bg);
    border-radius: var(--radius);
}

.schneelast-label {
    display: block;
    font-size: 11px;
    color: var(--color-text-light);
    margin-bottom: 2px;
}

.schneelast-warnstufe {
    padding: var(--spacing-sm) var(--spacing-md);
    border-radius: var(--radius);
    font-weight: 600;
    font-size: var(--font-size-sm);
    text-align: center;
}

.schneelast-gruen { background: rgba(39, 174, 96, 0.15); color: var(--color-success); }
.schneelast-gelb { background: rgba(243, 156, 18, 0.15); color: var(--color-warning); }
.schneelast-orange { background: rgba(230, 126, 34, 0.2); color: var(--color-accent); }
.schneelast-rot { background: rgba(231, 76, 60, 0.15); color: var(--color-danger); }
.schneelast-dunkelrot { background: var(--color-danger); color: white; }

/* Wetter: KPI-Grid */
.wetter-kpi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-md);
}
.wetter-kpi {
    background: var(--color-bg-secondary);
    border-radius: var(--border-radius);
    padding: var(--spacing-md);
    text-align: center;
}
.wetter-kpi-value {
    font-size: 1.25rem;
    font-weight: 700;
}
.wetter-kpi-label {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    margin-top: var(--spacing-xs);
}
.wetter-kpi.kpi-danger .wetter-kpi-value { color: var(--color-danger); }
.wetter-kpi.kpi-warning .wetter-kpi-value { color: var(--color-warning); }

/* Wetter: Datenquelle-Radios */
.wetter-source-radios {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: max-content;
    gap: var(--spacing-md);
    align-items: center;
}
.wetter-source-radios label {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: max-content;
    gap: var(--spacing-xs);
    align-items: center;
    cursor: pointer;
    font-weight: normal;
}

/* Wetter: Beaufort-Badges */
.bft-badge {
    display: inline-block;
    padding: 2px 6px;
    border-radius: 3px;
    font-size: 11px;
    font-weight: 600;
    white-space: nowrap;
}
.bft-gruen { background: rgba(39, 174, 96, 0.15); color: var(--color-success); }
.bft-gelb { background: rgba(243, 156, 18, 0.2); color: #b87a00; }
.bft-rot { background: rgba(231, 76, 60, 0.2); color: var(--color-danger); }
.bft-dunkelrot { background: var(--color-danger); color: white; }

/* Wetter: Stundentabelle Tag-Header */
.wetter-tag-header td {
    background: var(--color-bg-secondary);
    font-weight: 600;
    font-size: var(--font-size-sm);
    padding: var(--spacing-xs) var(--spacing-sm) !important;
}

.wetter-stunden-tabelle td { font-size: var(--font-size-sm); white-space: nowrap; }
.wetter-stunden-tabelle th { font-size: var(--font-size-sm); white-space: nowrap; }

/* Wetter: Stationen-Grid */
.wetter-stationen-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-md);
}

.wetter-station-card {
    all: unset;
    display: block;
    cursor: pointer;
    background: var(--color-bg-secondary);
    border: 2px solid transparent;
    border-radius: var(--radius);
    padding: var(--spacing-sm) var(--spacing-md);
    transition: border-color 0.15s, background 0.15s;
}

.wetter-station-card:hover {
    border-color: var(--color-primary);
    background: var(--color-bg);
}

.wetter-station-card.active {
    border-color: var(--color-primary);
    background: rgba(52, 152, 219, 0.08);
}

.wetter-station-name {
    font-weight: 600;
    font-size: var(--font-size-sm);
    margin-bottom: 2px;
}

.wetter-station-details {
    font-size: 11px;
    color: var(--color-text-light);
}

.wetter-station-result {
    margin-top: var(--spacing-md);
    padding-top: var(--spacing-md);
    border-top: 1px solid var(--color-border);
}

.wetter-station-result h5 {
    margin: 0 0 var(--spacing-sm) 0;
    font-size: var(--font-size-base);
}

/* Wetter: Leaflet-Karte */
#wetter-map-fallback {
    z-index: 1;
}

#wetter-map-fallback .leaflet-control-attribution {
    font-size: 10px;
}

/* ==================== Vermerke Toolbar + Timeline ==================== */

.vermerke-toolbar {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-md);
}

.vermerke-toolbar-left {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: max-content;
    gap: var(--spacing-sm);
    align-items: center;
}

.vermerke-toolbar-right {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: max-content;
    gap: var(--spacing-xs);
}

/* Timeline-Gruppen */
.tl-container { display: grid; gap: var(--spacing-md); }

.tl-group-header {
    display: grid;
    grid-template-columns: 20px 1fr auto;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-md);
    background: var(--color-primary);
    color: white;
    border-radius: var(--radius);
    cursor: pointer;
    font-size: var(--font-size-sm);
}

.tl-group-toggle { font-size: 12px; }
.tl-group-stats { font-size: 12px; opacity: 0.8; }

.tl-group-items { display: grid; gap: 0; margin-left: var(--spacing-md); }

/* Timeline-Items */
.tl-item {
    display: grid;
    grid-template-columns: 70px 16px 1fr auto;
    gap: var(--spacing-sm);
    align-items: start;
    padding: var(--spacing-sm) 0;
    border-left: 2px solid var(--color-border);
    margin-left: 7px;
    padding-left: var(--spacing-md);
    font-size: var(--font-size-sm);
}

.tl-date {
    color: var(--color-text-light);
    font-size: 12px;
    text-align: right;
    padding-top: 2px;
}

.tl-dot {
    width: 10px;
    height: 10px;
    background: var(--color-primary);
    border-radius: 50%;
    margin-top: 4px;
    margin-left: -22px;
    position: relative;
    z-index: 1;
}

.tl-content { min-width: 0; }
.tl-title { font-weight: 500; }
.tl-desc { color: var(--color-text-light); margin-top: 2px; }

.tl-bar-row {
    display: grid;
    grid-template-columns: 1fr auto auto;
    gap: var(--spacing-sm);
    align-items: center;
    margin-top: var(--spacing-xs);
}

.tl-bar {
    height: 6px;
    background: var(--color-border);
    border-radius: 3px;
    overflow: hidden;
}

.tl-bar-fill {
    height: 100%;
    background: var(--color-primary-light);
    border-radius: 3px;
}

.tl-duration { font-size: 12px; color: var(--color-text-light); white-space: nowrap; }
.tl-km { font-size: 12px; color: var(--color-text-light); white-space: nowrap; }

/* ==================== Dokumentation ==================== */

.doku-grid { display: grid; gap: var(--spacing-lg); margin-top: var(--spacing-md); }
.doku-block { background: var(--color-bg); border-radius: var(--radius); padding: var(--spacing-md); }
.doku-block h4 { margin-bottom: var(--spacing-sm); }
.doku-list { padding-left: var(--spacing-lg); font-size: var(--font-size-sm); display: grid; gap: var(--spacing-xs); }

/* ==================== Dashboard Filter ==================== */

/* ==================== Korrespondenz Diagramme ==================== */

.korr-chart {
    margin-bottom: var(--spacing-md);
}

.korr-chart h4 { margin-bottom: var(--spacing-sm); font-size: var(--font-size-sm); }

.korr-bar-row {
    display: grid;
    grid-template-columns: 150px 1fr 40px;
    gap: var(--spacing-sm);
    align-items: center;
    margin-bottom: 2px;
    font-size: 12px;
}

.korr-bar-label {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: var(--color-text-light);
}

.korr-bar {
    height: 16px;
    background: var(--color-border);
    border-radius: 3px;
    overflow: hidden;
}

.korr-bar-fill {
    height: 100%;
    background: var(--color-primary-light);
    border-radius: 3px;
    min-width: 2px;
}

.korr-bar-value {
    text-align: right;
    font-weight: 500;
}

.korr-bar-fill-alt {
    background: var(--color-success, #27ae60);
}

/* ==================== Korrespondenz Tabs + Statistik ==================== */

.korr-tabs {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(120px, max-content));
    gap: var(--spacing-xs);
    margin-bottom: var(--spacing-md);
}

.korr-tab-btn {
    padding: var(--spacing-sm) var(--spacing-md);
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    cursor: pointer;
    font-size: var(--font-size-sm);
    transition: background 0.15s, border-color 0.15s;
}

.korr-tab-btn.active {
    background: var(--color-primary);
    color: white;
    border-color: var(--color-primary);
}

.korr-tab-btn:hover:not(.active) {
    border-color: var(--color-primary-light);
}

.korr-statistik-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-lg);
}

@media (max-width: 900px) {
    .korr-statistik-grid { grid-template-columns: 1fr; }
}

.korr-stat-section {
    background: var(--color-surface);
    border-radius: var(--radius);
    padding: var(--spacing-md);
}

.korr-stat-section h3 {
    margin-bottom: var(--spacing-md);
    font-size: var(--font-size-base);
}

/* ==================== MD-Editor (Dokumentation) ==================== */

.md-editor-layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-md);
    min-height: 400px;
}

@media (max-width: 900px) {
    .md-editor-layout { grid-template-columns: 1fr; }
}

.md-editor-layout.mode-editor { grid-template-columns: 1fr; }
.md-editor-layout.mode-editor .md-preview-pane { display: none; }
.md-editor-layout.mode-preview { grid-template-columns: 1fr; }
.md-editor-layout.mode-preview .md-editor-pane { display: none; }

.md-editor-pane,
.md-preview-pane {
    display: grid;
    grid-template-rows: auto 1fr;
}

.md-editor-pane h4,
.md-preview-pane h4 {
    margin-bottom: var(--spacing-sm);
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
}

.md-editor-textarea {
    width: 100%;
    min-height: 350px;
    padding: var(--spacing-sm);
    font-family: monospace;
    font-size: var(--font-size-sm);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    resize: vertical;
}

.md-preview-content {
    padding: var(--spacing-sm) var(--spacing-md);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    background: var(--color-bg);
    overflow-y: auto;
    max-height: 500px;
    font-size: var(--font-size-sm);
    line-height: 1.6;
}

.md-preview-content h1 { font-size: 1.5em; margin: 0.5em 0 0.3em; }
.md-preview-content h2 { font-size: 1.3em; margin: 0.5em 0 0.3em; }
.md-preview-content h3 { font-size: 1.15em; margin: 0.4em 0 0.2em; }
.md-preview-content ul, .md-preview-content ol { padding-left: 1.5em; }
.md-preview-content code { background: var(--color-border); padding: 0.15em 0.4em; border-radius: 3px; font-size: 0.9em; }
.md-preview-content pre { background: var(--color-bg); padding: var(--spacing-sm); border-radius: var(--radius); overflow-x: auto; }
.md-preview-content pre code { background: none; padding: 0; }
.md-preview-content blockquote { border-left: 3px solid var(--color-primary-light); padding-left: var(--spacing-sm); color: var(--color-text-light); margin: 0.5em 0; }

.md-toolbar {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(80px, max-content));
    gap: var(--spacing-xs);
    margin-bottom: var(--spacing-md);
}

/* ==================== MD Import Ergebnis ==================== */

.md-import-result {
    padding: var(--spacing-md);
    border-radius: var(--radius);
    margin-top: var(--spacing-sm);
}

.md-import-result.success { background: rgba(39, 174, 96, 0.1); border: 1px solid var(--color-success, #27ae60); }
.md-import-result.error { background: rgba(231, 76, 60, 0.1); border: 1px solid var(--color-danger); }

/* ==================== Kostenposition Edit ==================== */

/* ==================== Kosten-Tab Kopf + Toolbar ==================== */

.kp-kopf {
    background: var(--color-bg);
    border-radius: var(--radius);
    padding: var(--spacing-md);
    margin-bottom: var(--spacing-md);
    font-size: var(--font-size-sm);
}

.kp-kopf-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-xs) var(--spacing-lg);
}

.kp-toolbar {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-sm);
}

.kp-toolbar-left, .kp-toolbar-right {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: max-content;
    gap: var(--spacing-xs);
}

.kp-toolbar-right { justify-self: end; }

.kp-table { font-size: 12px; }
.kp-table th { white-space: nowrap; font-size: 11px; }
.kp-table .num { text-align: right; }

.kp-sum-row { background: var(--color-bg); }
.kp-sum-row td { border-top: 2px solid var(--color-primary); }

.kp-edit-grid { display: grid; gap: var(--spacing-md); }

.kp-section {
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: var(--spacing-md);
}

.kp-section legend {
    font-weight: 600;
    font-size: var(--font-size-sm);
    color: var(--color-primary);
    padding: 0 var(--spacing-xs);
}

.kp-status-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--spacing-sm);
}

.kp-status-grid label {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: var(--spacing-xs);
    align-items: center;
    font-size: var(--font-size-sm);
    cursor: pointer;
}

/* ==================== Korrespondenz Tab (im Schadenfall) ==================== */

.korr-upload-sm {
    border: 2px dashed var(--color-border);
    border-radius: var(--radius);
    padding: var(--spacing-md);
    text-align: center;
    cursor: pointer;
    color: var(--color-text-light);
    font-size: var(--font-size-sm);
    margin-bottom: var(--spacing-md);
}

.korr-upload-sm:hover { border-color: var(--color-primary-light); }
.korr-upload-sm.drag-over { border-color: var(--color-primary); background: rgba(41,128,185,0.05); }

.korr-mail-item {
    padding: var(--spacing-xs) var(--spacing-sm);
    border-bottom: 1px solid var(--color-border);
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
}

/* ==================== Checkliste Kategorien-Ansicht ==================== */

.cl-kat-container { display: grid; gap: var(--spacing-sm); }

.cl-kat-group {
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    overflow: hidden;
}

.cl-kat-header {
    display: grid;
    grid-template-columns: 20px 1fr auto auto;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-md);
    background: var(--color-primary);
    color: white;
    cursor: pointer;
    font-size: var(--font-size-sm);
}

.cl-kat-toggle { font-size: 12px; }
.cl-kat-count { font-size: 12px; opacity: 0.8; }

.cl-kat-items { display: grid; gap: 0; }

.cl-kat-item {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    padding: var(--spacing-xs) var(--spacing-md);
    font-size: var(--font-size-sm);
    border-bottom: 1px solid var(--color-border);
}

.cl-kat-item:last-child { border-bottom: none; }
.cl-kat-item-added { background: rgba(39, 174, 96, 0.06); }

/* Checkliste Suche-Dropdown */
.cl-search-dropdown {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--color-surface);
    border: 2px solid var(--color-primary);
    border-radius: var(--radius);
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
    max-height: 300px;
    overflow-y: auto;
    z-index: 100;
    margin-top: 4px;
}

.cl-search-item {
    display: grid;
    grid-template-columns: 24px 1fr auto;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-md);
    cursor: pointer;
    border-bottom: 1px solid var(--color-border);
    font-size: var(--font-size-sm);
}

.cl-search-item:hover { background: var(--color-bg); }
.cl-search-item:last-child { border-bottom: none; }
.cl-search-added { cursor: default; opacity: 0.6; }
.cl-search-added:hover { background: transparent; }

.cl-search-icon {
    font-size: 16px;
    color: var(--color-primary);
    text-align: center;
}

.cl-search-added .cl-search-icon { color: var(--color-success); }

.cl-search-empty {
    padding: var(--spacing-md);
    text-align: center;
    color: var(--color-text-light);
    font-size: var(--font-size-sm);
}

/* ==================== Wiedervorlage Ampel ==================== */

.wv-dot {
    display: inline-block;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--color-text-light);
}

.wv-rot .wv-dot, .wv-dot.wv-rot { background: var(--color-danger); }
.wv-gelb .wv-dot, .wv-dot.wv-gelb { background: var(--color-warning); }
.wv-gruen .wv-dot, .wv-dot.wv-gruen { background: var(--color-success); }

tr.wv-rot { background: rgba(231, 76, 60, 0.06); }
tr.wv-gelb { background: rgba(243, 156, 18, 0.06); }

tr.vermerk-erledigt td:not(:first-child):not(:last-child) { opacity: 0.5; text-decoration: line-through; }
/* Klickbare Vermerk-Zeilen: Hover-Feedback */
tr.vermerk-row:hover { background: var(--color-bg-hover, rgba(0,0,0,0.03)); }
.tl-item.vermerk-row:hover { background: var(--color-bg-hover, rgba(0,0,0,0.03)); border-radius: var(--radius); }

/* Besonderheiten Header */
.besonderheit-header {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: start;
}

.besonderheit-actions {
    display: grid;
    grid-auto-flow: column;
    gap: 2px;
}

/* ==================== Wortverwaltung ==================== */

.wort-index-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
    gap: 2px;
    max-height: 300px;
    overflow-y: auto;
    margin-bottom: var(--spacing-md);
}

.wort-index-item {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: var(--spacing-xs);
    padding: 2px var(--spacing-xs);
    font-size: 12px;
    border-radius: 2px;
}

.wort-index-item:hover { background: var(--color-bg); }

/* Stoppwort-Karten (wie alte App: Checkbox + Titel + Vorschau + Anzahl) */
.stoppwort-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: var(--spacing-sm);
}

.stoppwort-card {
    display: grid;
    grid-template-rows: auto auto auto;
    gap: 2px;
    padding: var(--spacing-sm) var(--spacing-md);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    cursor: pointer;
    font-size: var(--font-size-sm);
    transition: border-color 0.15s;
}
.stoppwort-card:hover { border-color: var(--color-primary-light); }
.stoppwort-card.active { border-color: var(--color-primary); background: rgba(41,128,185,0.04); }
.stoppwort-card-head { display: grid; grid-template-columns: auto 1fr; gap: var(--spacing-xs); align-items: center; }
.stoppwort-card-body { font-size: 11px; color: var(--color-text-light); line-height: 1.3; }
.stoppwort-card-foot { font-size: 11px; color: var(--color-text-light); }

/* Kontaktnamen-Tags */
.kontaktnamen-tags {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(80px, max-content));
    gap: 4px;
    max-height: 200px;
    overflow-y: auto;
}
.kontaktname-tag {
    padding: 2px var(--spacing-sm);
    font-size: 11px;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: 10px;
    color: var(--color-text-light);
    white-space: nowrap;
}

/* Whitelist/Blacklist Tags */
.wv-list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(80px, max-content));
    gap: 4px;
}
.wv-tag {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 4px;
    align-items: center;
    padding: 2px var(--spacing-sm);
    font-size: var(--font-size-sm);
    border-radius: 10px;
    white-space: nowrap;
}
.wv-tag-white { background: rgba(39,174,96,0.1); border: 1px solid var(--color-success); color: var(--color-success); }
.wv-tag-black { background: rgba(231,76,60,0.1); border: 1px solid var(--color-danger); color: var(--color-danger); }

/* ==================== Checkbox-Regeln Editor ==================== */

.regeln-liste { display: grid; gap: var(--spacing-sm); }

.regel-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    overflow: hidden;
}

.regel-card-header {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    padding: var(--spacing-sm) var(--spacing-md);
    background: var(--color-bg);
}

.regel-card-actions {
    display: grid;
    grid-auto-flow: column;
    gap: var(--spacing-xs);
    align-items: center;
}

.regel-card-body {
    padding: var(--spacing-xs) var(--spacing-md);
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
}

.regel-trigger-row, .regel-aktion-row {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    padding: var(--spacing-xs) var(--spacing-sm);
    background: var(--color-bg);
    border-radius: 4px;
    font-size: var(--font-size-sm);
    margin-bottom: 2px;
}

.dashboard-sf-header {
    display: grid;
    grid-template-columns: auto 1fr;
    align-items: center;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-sm);
}

.dashboard-sf-controls {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: max-content;
    gap: var(--spacing-xs);
    justify-self: end;
}

.dashboard-filter {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-lg);
}

/* ==================== Pausen-Timer (Sidebar) ==================== */

.pausen-timer {
    display: grid;
    grid-template-columns: 1fr auto auto;
    align-items: center;
    gap: var(--spacing-xs);
    padding: var(--spacing-xs) var(--spacing-lg);
    margin-bottom: var(--spacing-xs);
}

.pausen-display {
    font-family: monospace;
    font-size: 14px;
    color: rgba(255,255,255,0.5);
    cursor: pointer;
}

.pausen-display.pausen-running { color: rgba(255,255,255,0.9); }

.pausen-status-text {
    font-size: 10px;
    color: rgba(255,255,255,0.4);
}

.pausen-btn {
    background: none;
    border: none;
    color: rgba(255,255,255,0.4);
    cursor: pointer;
    font-size: 14px;
}

.pausen-btn:hover { color: white; }

/* ==================== Pausen-Animation Modal (Werner-Style) ==================== */

.pausen-modal {
    position: fixed;
    inset: 0;
    z-index: 99999;
    display: grid;
    place-items: center;
    animation: pausenFadeIn 0.5s ease;
}

.pausen-modal[hidden] { display: none; }

@keyframes pausenFadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

.pausen-dialog {
    position: relative;
    max-width: 750px;
    width: 95%;
    border-radius: 70px;
    overflow: hidden;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
}

.pausen-gif {
    display: block;
    width: 100%;
    height: 690px;
    object-fit: cover;
    object-position: 44% 30%;
}

.pausen-overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    background: linear-gradient(transparent, rgba(0, 0, 0, 0.85));
    padding: 30px 22px 22px;
    text-align: center;
}

.pausen-text { margin-bottom: 16px; }

.pausen-text h2 {
    font-size: 24px;
    color: #fff;
    margin-bottom: 8px;
    font-family: 'Comic Sans MS', cursive, sans-serif;
    text-shadow: 2px 2px 4px rgba(0,0,0,0.8);
}

.pausen-text p {
    color: #eee;
    font-size: 16px;
    text-shadow: 1px 1px 2px rgba(0,0,0,0.8);
}

.pausen-buttons {
    display: grid;
    gap: 10px;
    justify-items: center;
}

.pausen-buttons .btn {
    min-width: 260px;
    padding: 12px 24px;
    font-size: 16px;
}

/* ==================== DOCX Import + Korrespondenz ==================== */

.docx-upload-zone,
.korr-upload-zone {
    border: 2px dashed var(--color-border);
    border-radius: var(--radius);
    padding: var(--spacing-xl);
    text-align: center;
    cursor: pointer;
    margin-bottom: var(--spacing-lg);
    color: var(--color-text-light);
    transition: border-color 0.2s, background 0.2s;
}

.docx-upload-zone:hover,
.korr-upload-zone:hover,
.docx-upload-zone.drag-over,
.korr-upload-zone.drag-over {
    border-color: var(--color-primary-light);
    background: rgba(41, 128, 185, 0.04);
}

/* ==================== Kalender ==================== */

.kalender { margin-bottom: var(--spacing-lg); }

.kalender-header {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    text-align: center;
    margin-bottom: var(--spacing-sm);
}

.kalender-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 2px;
}

.kalender-weekday {
    text-align: center;
    font-size: 11px;
    font-weight: 600;
    color: var(--color-text-light);
    padding: var(--spacing-xs);
}

.kalender-day {
    position: relative;
    text-align: center;
    padding: var(--spacing-sm) var(--spacing-xs);
    background: var(--color-surface);
    border-radius: 4px;
    font-size: var(--font-size-sm);
    min-height: 36px;
}

.kalender-empty { background: transparent; }
.kalender-today { background: var(--color-primary); color: white; font-weight: 600; border-radius: 4px; }

.kalender-dot {
    position: absolute;
    bottom: 2px;
    right: 4px;
    font-size: 9px;
    background: var(--color-accent);
    color: white;
    border-radius: 8px;
    padding: 0 4px;
    min-width: 14px;
    text-align: center;
}

/* ==================== Dashboard Fristen ==================== */

.kpi-danger .kpi-value { color: var(--color-danger); }
.kpi-warning .kpi-value { color: var(--color-warning); }

.fristen-alert {
    background: rgba(231, 76, 60, 0.06);
    border: 1px solid var(--color-danger);
    border-radius: var(--radius);
    padding: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
}

.fristen-alert h3 { color: var(--color-danger); margin-bottom: var(--spacing-sm); }

.fristen-item {
    padding: var(--spacing-xs) var(--spacing-sm);
    cursor: pointer;
    border-radius: 4px;
    font-size: var(--font-size-sm);
}

.fristen-item:hover { background: rgba(231, 76, 60, 0.1); }

/* ==================== Kontakte-Tab im Modal ==================== */

.kontakte-zugeordnet {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-lg);
}

.kontakt-card {
    background: var(--color-bg);
    border-radius: var(--radius);
    padding: var(--spacing-md);
    font-size: var(--font-size-sm);
}

.kontakt-card-header {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    margin-bottom: var(--spacing-xs);
}

.kontakt-rollen { margin-top: var(--spacing-xs); }

.kontakt-picker { margin-top: var(--spacing-sm); }

.kontakt-picker-results {
    max-height: 200px;
    overflow-y: auto;
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    margin-top: var(--spacing-xs);
}

.kontakt-picker-item {
    padding: var(--spacing-sm) var(--spacing-md);
    cursor: pointer;
    font-size: var(--font-size-sm);
    border-bottom: 1px solid var(--color-border);
}

.kontakt-picker-item:last-child { border-bottom: none; }
.kontakt-picker-item:hover { background: var(--color-bg); }

/* ==================== Besonderheiten ==================== */

.besonderheiten-list { display: grid; gap: var(--spacing-sm); }

.besonderheit-item {
    background: rgba(230, 126, 34, 0.06);
    border-left: 3px solid var(--color-accent);
    border-radius: var(--radius);
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: var(--font-size-sm);
}

.besonderheit-label { font-weight: 600; color: var(--color-accent); margin-bottom: 2px; }
.besonderheit-note { color: var(--color-text-light); font-style: italic; margin-top: 4px; }

/* ==================== Kontakt Hover-Preview ==================== */

.hover-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.3);
    z-index: 1500;
}

.hover-preview-card {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) scale(0.8);
    background: var(--color-surface);
    border-radius: var(--radius);
    box-shadow: 0 12px 48px rgba(0,0,0,0.25);
    padding: var(--spacing-xl);
    z-index: 1501;
    max-width: 400px;
    width: 90%;
    opacity: 0;
    transition: transform 0.2s, opacity 0.2s;
}

.hover-preview-card.show { transform: translate(-50%, -50%) scale(1); opacity: 1; }
.hover-name { font-size: 22px; font-weight: 700; margin-bottom: 4px; }
.hover-firma { font-size: 15px; color: var(--color-text-light); margin-bottom: var(--spacing-sm); }
.hover-rollen { margin-bottom: var(--spacing-md); }
.hover-details { display: grid; gap: var(--spacing-xs); font-size: 14px; }
.hover-details a { color: var(--color-primary-light); text-decoration: none; }
.hover-details a:hover { text-decoration: underline; }
.hover-notizen { color: var(--color-text-light); font-style: italic; margin-top: var(--spacing-sm); }

/* ==================== Tourenplaner ==================== */

.tour-stopps-list { display: grid; gap: var(--spacing-sm); }

.tour-stopp {
    display: grid;
    grid-template-columns: 40px 1fr auto;
    gap: var(--spacing-sm);
    align-items: center;
    background: var(--color-surface);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    padding: var(--spacing-md);
}

.tour-stopp-nr {
    background: var(--color-primary);
    color: white;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    font-weight: 600;
}

.tour-stopp-controls {
    display: grid;
    grid-auto-flow: column;
    gap: var(--spacing-xs);
    align-items: center;
    font-size: var(--font-size-sm);
}

.tour-route-info {
    grid-column: 1 / -1;
    text-align: center;
    color: var(--color-text-light);
    font-size: 12px;
    padding: var(--spacing-xs) 0;
}

/* ==================== Form Inputs ==================== */

.input-field {
    width: 100%;
    padding: var(--spacing-sm) var(--spacing-md);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    font-size: var(--font-size-sm);
    font-family: var(--font-family);
    color: var(--color-text);
    background: var(--color-surface);
}

.input-field:focus {
    outline: none;
    border-color: var(--color-primary-light);
    box-shadow: 0 0 0 2px rgba(41, 128, 185, 0.15);
}

textarea.input-field { resize: vertical; }

/* ==================== Kontakt-Modal (Formular-Grid) ==================== */

.kontakt-form-grid {
    display: grid;
    grid-template-columns: 100px 1fr;
    gap: var(--spacing-sm) var(--spacing-md);
    align-items: start;
}

.kontakt-form-grid label {
    font-weight: 500;
    font-size: var(--font-size-sm);
    padding-top: var(--spacing-sm);
    color: var(--color-text-light);
}

.kontakt-form-actions {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: auto auto;
    gap: var(--spacing-sm);
    justify-content: end;
    margin-top: var(--spacing-md);
    padding-top: var(--spacing-md);
    border-top: 1px solid var(--color-border);
}

/* ==================== Rollen-Picker ==================== */

.rollen-picker {
    display: grid;
    gap: var(--spacing-sm);
}

.rollen-tags {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: max-content;
    gap: var(--spacing-xs);
    overflow-x: auto;
    min-height: 28px;
    align-items: center;
}

.rolle-tag {
    display: grid;
    grid-template-columns: auto auto auto;
    align-items: center;
    gap: 4px;
    padding: 2px 8px;
    background: var(--color-primary);
    color: white;
    border-radius: 4px;
    font-size: var(--font-size-sm);
    white-space: nowrap;
}

.rolle-tag-name { font-weight: 500; }
.rolle-tag-kat { opacity: 0.7; font-size: 11px; }

.rolle-tag-remove {
    background: none;
    border: none;
    color: white;
    cursor: pointer;
    padding: 0;
    font-size: 14px;
    line-height: 1;
    opacity: 0.8;
}

.rolle-tag-remove:hover { opacity: 1; }

.rollen-selects {
    display: grid;
    grid-template-columns: 1fr 1fr auto;
    gap: var(--spacing-xs);
    align-items: center;
}

.rollen-select { font-size: var(--font-size-sm); }

/* Badge-Variante fuer kleine Kontexte */
.badge-sm {
    padding: 1px 6px;
    font-size: 10px;
    border-radius: 10px;
}

/* ==================== Checkliste (erweitert) ==================== */

.cl-toolbar {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-sm);
}

.cl-toolbar-left {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: max-content;
    gap: var(--spacing-sm);
    align-items: center;
}

.cl-count {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    background: var(--color-bg);
    padding: 2px 8px;
    border-radius: 12px;
}

.cl-toolbar-right {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: max-content;
    gap: var(--spacing-xs);
}

.cl-progress-bar {
    height: 6px;
    background: var(--color-border);
    border-radius: 3px;
    margin-bottom: var(--spacing-md);
    overflow: hidden;
}

.cl-progress-fill {
    height: 100%;
    background: var(--color-success);
    border-radius: 3px;
    transition: width 0.3s ease;
}

.cl-add-row {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-md);
}

.cl-items { display: grid; gap: var(--spacing-xs); }

.cl-item {
    display: grid;
    grid-template-columns: 20px 20px 24px 1fr auto;
    gap: var(--spacing-xs);
    align-items: start;
    padding: var(--spacing-sm) var(--spacing-md);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    font-size: var(--font-size-sm);
}

.cl-item-checked {
    background: rgba(39, 174, 96, 0.05);
    border-color: var(--color-success);
}

.cl-item-checked .cl-item-text {
    text-decoration: line-through;
    color: var(--color-text-light);
}

.cl-item-marked {
    background: rgba(243, 156, 18, 0.08);
    border-color: var(--color-warning);
}

.cl-item-dragging { opacity: 0.4; }
.cl-item-dragover { border-color: var(--color-primary-light); border-style: dashed; }

.cl-drag-handle {
    color: var(--color-text-light);
    cursor: grab;
    font-size: 12px;
    line-height: 1.4;
    -webkit-user-select: none;
    -webkit-user-select: none;
    user-select: none;
}

.cl-star {
    background: none;
    border: none;
    cursor: pointer;
    font-size: 14px;
    padding: 0;
    line-height: 1.4;
}

.cl-item-body { min-width: 0; }

.cl-item-text { font-weight: 500; }

.cl-meilenstein {
    font-size: 11px;
    color: var(--color-warning);
    margin-left: var(--spacing-sm);
}

.cl-notiz {
    margin-top: var(--spacing-xs);
    padding: var(--spacing-xs) var(--spacing-sm);
    background: var(--color-bg);
    border-left: 3px solid var(--color-primary);
    border-radius: 2px;
    font-size: 12px;
    color: var(--color-text-light);
}

.cl-link {
    margin-top: var(--spacing-xs);
    font-size: 12px;
}

.cl-link a {
    color: var(--color-primary-light);
    text-decoration: none;
}

.cl-link a:hover { text-decoration: underline; }

.cl-item-actions {
    display: grid;
    grid-auto-flow: column;
    gap: 2px;
    align-items: start;
}

.cl-item-actions .btn-icon { font-size: 14px; padding: 2px 4px; }

/* Template-Picker */
.cl-template-list { display: grid; gap: var(--spacing-sm); }

.cl-template-item {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-md);
    background: var(--color-bg);
    border-radius: var(--radius);
}

.cl-template-actions {
    display: grid;
    grid-auto-flow: column;
    gap: var(--spacing-xs);
    align-items: center;
}

.tour-summary { margin-top: var(--spacing-lg); }

.modal-header-actions {
    display: grid;
    grid-auto-flow: column;
    gap: var(--spacing-sm);
    align-items: center;
}

/* ==================== Taetigkeitsarten-Schnellfilter ==================== */

.taetigkeitsarten-bar {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-xs);
    margin-bottom: var(--spacing-md);
    padding: var(--spacing-xs) 0;
}

.ta-filter.active {
    background: var(--color-primary);
    color: white;
}

/* ==================== DataTable Action Cell ==================== */

.action-cell {
    display: grid;
    grid-auto-flow: column;
    gap: var(--spacing-xs);
    justify-content: end;
}

/* ==================== Navigation Back-Button ==================== */

.nav-back-button {
    background: var(--color-bg-light);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: var(--spacing-xs) var(--spacing-md);
    cursor: pointer;
    font-size: var(--font-size-sm);
    color: var(--color-primary);
    margin-bottom: var(--spacing-sm);
}

.nav-back-button:hover {
    background: var(--color-primary);
    color: white;
}

/* ==================== Autocomplete Popup ==================== */

.autocomplete-popup {
    position: fixed;
    z-index: 9999;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-lg);
    max-width: 500px;
    min-width: 250px;
    max-height: 300px;
    overflow-y: auto;
}

.autocomplete-popup--sentence { min-width: 400px; }
.autocomplete-popup--abbreviation { min-width: 350px; }

.autocomplete-header {
    padding: var(--spacing-xs) var(--spacing-sm);
    font-size: var(--font-size-xs);
    color: var(--color-text-light);
    border-bottom: 1px solid var(--color-border);
}

.autocomplete-item {
    padding: var(--spacing-xs) var(--spacing-sm);
    cursor: pointer;
    font-size: var(--font-size-sm);
}

.autocomplete-item:hover,
.autocomplete-item--active {
    background: var(--color-primary-light);
    color: white;
}

.autocomplete-item--sentence {
    padding: var(--spacing-sm);
}

.autocomplete-match {
    color: var(--color-primary);
}

.autocomplete-item--active .autocomplete-match {
    color: white;
}

.autocomplete-count {
    color: var(--color-text-light);
    font-size: var(--font-size-xs);
}

.autocomplete-kuerzel {
    color: var(--color-primary);
    font-family: monospace;
}

.autocomplete-kuerzel--warning {
    color: var(--color-warning);
}

.autocomplete-badge {
    font-size: var(--font-size-xs);
    padding: 1px var(--spacing-xs);
    border-radius: var(--radius);
    background: var(--color-primary-light);
    color: white;
}

.autocomplete-item__row {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: var(--spacing-sm);
    align-items: center;
}

.autocomplete-item__desc,
.autocomplete-item__hint {
    font-size: var(--font-size-xs);
    color: var(--color-text-light);
    margin-top: 2px;
}

.autocomplete-item__hint--warning {
    color: var(--color-warning);
}

/* ==================== QR-Code Popup ==================== */

.qr-dropdown-wrap {
    position: relative;
}

.qr-dropdown-menu {
    position: absolute;
    top: 100%;
    right: 0;
    z-index: 1000;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    min-width: 180px;
    display: grid;
    gap: 0;
}
.qr-dropdown-menu[hidden] {
    display: none !important;
}

.qr-dropdown-item {
    background: none;
    border: none;
    padding: var(--spacing-sm) var(--spacing-md);
    text-align: left;
    cursor: pointer;
    font-size: var(--font-size-sm);
    color: var(--color-text);
}

.qr-dropdown-item:hover {
    background: var(--color-primary-light);
    color: white;
}

.qr-overlay {
    position: fixed;
    inset: 0;
    z-index: 10000;
    background: rgba(0, 0, 0, 0.6);
    display: grid;
    place-items: center;
}

.qr-popup {
    background: var(--color-bg);
    border-radius: var(--radius-lg, var(--radius));
    padding: var(--spacing-lg);
    display: grid;
    gap: var(--spacing-md);
    justify-items: center;
    max-width: 360px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
}

.qr-popup h3 {
    margin: 0;
    font-size: var(--font-size-md);
    text-align: center;
    word-break: break-word;
}

.qr-img {
    border-radius: var(--radius);
}

.qr-url {
    font-size: var(--font-size-xs);
    color: var(--color-text-light);
    word-break: break-all;
    text-align: center;
    margin: 0;
    max-width: 300px;
}

.qr-actions {
    display: grid;
    grid-auto-flow: column;
    gap: var(--spacing-sm);
}

/* ==================== Dringlichkeits-Anzeige (Dashboard) ==================== */

.urgency-bar {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    border-radius: var(--radius) var(--radius) 0 0;
}

.urgency-rot { background: var(--color-danger); }
.urgency-orange { background: #e67e22; }
.urgency-gelb { background: var(--color-warning); }
.urgency-hellgruen { background: #2ecc71; }
.urgency-gruen { background: var(--color-success); }

.urgency-dot {
    display: inline-block;
    width: 10px;
    height: 10px;
    border-radius: 50%;
}

@keyframes urgency-blink {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.5; }
}

.urgency-blink {
    animation: urgency-blink 1.2s ease-in-out infinite;
}

/* ==================== Kalender: Tab-Leiste ==================== */

.kalender-tabs {
    display: grid;
    grid-template-columns: repeat(4, auto);
    gap: var(--spacing-xs);
    margin-bottom: var(--spacing-md);
    justify-content: start;
}

.kalender-tab {
    padding: var(--spacing-xs) var(--spacing-md);
    border: 1px solid var(--color-border);
    background: var(--color-surface);
    cursor: pointer;
    border-radius: 4px;
}

.kalender-tab-active {
    background: var(--color-primary);
    color: white;
    border-color: var(--color-primary);
}

/* ==================== Kalender: Heute-Button ==================== */

.kalender-header .cal-today {
    font-size: 12px;
}

.kalender-today-text {
    color: var(--color-primary);
}

/* ==================== Kalender: Wochenansicht ==================== */

.kalender-wochen-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 2px;
}

.kalender-wochen-header {
    text-align: center;
    padding: var(--spacing-sm);
    background: var(--color-surface);
    border-radius: 4px 4px 0 0;
    font-weight: 600;
    font-size: var(--font-size-sm);
}

.kalender-wochen-tag {
    display: block;
    font-size: 11px;
    color: var(--color-text-light);
}

.kalender-wochen-datum {
    display: block;
    font-size: var(--font-size-sm);
}

.kalender-wochen-zelle {
    background: var(--color-surface);
    padding: var(--spacing-xs);
    min-height: 120px;
    border-radius: 0 0 4px 4px;
}

.kalender-leer {
    color: var(--color-text-light);
    font-size: 11px;
    text-align: center;
    padding: var(--spacing-md);
}

/* ==================== Kalender: Event-Karten ==================== */

.kalender-event {
    padding: var(--spacing-xs) var(--spacing-sm);
    margin-bottom: 2px;
    border-radius: 3px;
    font-size: 12px;
    cursor: pointer;
    border-left: 3px solid transparent;
}

.kalender-event:hover {
    opacity: 0.85;
}

.kalender-event-compact {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.kalender-event-header {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: var(--spacing-xs);
    align-items: center;
}

.kalender-event-typ {
    font-weight: 700;
    font-size: 10px;
    opacity: 0.7;
}

.kalender-event-typ-badge {
    display: inline-block;
    width: 18px;
    height: 18px;
    line-height: 18px;
    text-align: center;
    border-radius: 3px;
    font-size: 10px;
    font-weight: 700;
    color: white;
    background: var(--color-text-light);
}

.kalender-event-nr {
    font-size: 11px;
    color: var(--color-text-light);
}

.kalender-event-details {
    font-size: 11px;
    color: var(--color-text-light);
    margin-top: 2px;
}

/* Farben */
.kalender-farbe-rot { border-left-color: #e74c3c; background: #fdecea; }
.kalender-farbe-gelb { border-left-color: #f39c12; background: #fef5e7; }
.kalender-farbe-gruen { border-left-color: #27ae60; background: #eafaf1; }
.kalender-farbe-lila { border-left-color: #8e44ad; background: #f4ecf7; }
.kalender-farbe-blau { border-left-color: #2980b9; background: #ebf5fb; }

.kalender-farbe-rot .kalender-event-typ-badge { background: #e74c3c; }
.kalender-farbe-gelb .kalender-event-typ-badge { background: #f39c12; }
.kalender-farbe-gruen .kalender-event-typ-badge { background: #27ae60; }
.kalender-farbe-lila .kalender-event-typ-badge { background: #8e44ad; }
.kalender-farbe-blau .kalender-event-typ-badge { background: #2980b9; }

/* ==================== Kalender: Tagesansicht ==================== */

.kalender-tag-content {
    padding: var(--spacing-sm) 0;
}

.kalender-tag-leer {
    text-align: center;
    padding: var(--spacing-xl);
    color: var(--color-text-light);
    font-size: var(--font-size-sm);
}

.kalender-tag-gruppe {
    margin-bottom: var(--spacing-md);
}

.kalender-tag-gruppe-titel {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    margin-bottom: var(--spacing-xs);
    padding-bottom: var(--spacing-xs);
    border-bottom: 1px solid var(--color-border);
}

.kalender-tag-liste {
    display: grid;
    gap: var(--spacing-xs);
}

.kalender-tag-liste .kalender-event {
    padding: var(--spacing-sm) var(--spacing-md);
}

/* ==================== Kalender: Quartalsansicht ==================== */

.kalender-quartal-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-lg);
}

.kalender-mini {
    background: var(--color-surface);
    border-radius: 4px;
    padding: var(--spacing-sm);
}

.kalender-mini-titel {
    text-align: center;
    font-weight: 600;
    margin-bottom: var(--spacing-xs);
    font-size: var(--font-size-sm);
}

.kalender-mini-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 1px;
}

.kalender-mini-weekday {
    text-align: center;
    font-size: 9px;
    font-weight: 600;
    color: var(--color-text-light);
    padding: 2px;
}

.kalender-mini-day {
    text-align: center;
    font-size: 11px;
    padding: 3px 1px;
    border-radius: 2px;
    cursor: pointer;
}

.kalender-mini-day:hover {
    outline: 1px solid var(--color-primary);
}

.kalender-mini-day.kalender-empty {
    cursor: default;
}

.kalender-mini-day.kalender-empty:hover {
    outline: none;
}

/* Heatmap-Farben */
.heat-0 { background: var(--color-background); }
.heat-1 { background: #d4e6f1; }
.heat-2 { background: #85c1e9; }
.heat-3 { background: #2980b9; color: white; }

.kalender-legende {
    display: grid;
    grid-template-columns: repeat(4, auto);
    gap: var(--spacing-md);
    justify-content: end;
    margin-top: var(--spacing-sm);
    font-size: 11px;
    color: var(--color-text-light);
}

.kalender-legende-item {
    display: grid;
    grid-template-columns: auto auto;
    gap: 4px;
    align-items: center;
}

.kalender-legende-box {
    display: inline-block;
    width: 14px;
    height: 14px;
    border-radius: 2px;
    border: 1px solid var(--color-border);
}

/* ==================== Versicherer-Hinweise ====================  */

.versicherer-hinweise-box {
    background: var(--color-success-bg, #d4edda);
    border: 2px solid var(--color-success, #28a745);
    border-radius: var(--radius);
    padding: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
}

.versicherer-hinweise-box h4 {
    margin: 0 0 var(--spacing-sm) 0;
    color: var(--color-success-text, #155724);
}

.versicherer-hinweise-box ul {
    margin: 0;
    padding-left: var(--spacing-lg);
    list-style: disc;
}

.versicherer-hinweise-box li {
    margin-bottom: var(--spacing-xs);
    color: var(--color-success-text, #155724);
}

/* ==================== Aktivitaet-Box ==================== */

.aktivitaet-box {
    background: var(--bg-secondary, #f8fafc);
    border-radius: 8px;
    border-left: 3px solid var(--primary, #6366f1);
    padding: var(--spacing-md);
    margin-top: var(--spacing-lg);
    margin-bottom: var(--spacing-md);
}

.aktivitaet-box h4 {
    margin: 0 0 var(--spacing-sm) 0;
}

.aktivitaet-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 0.75rem;
    font-size: 0.9rem;
}

.aktivitaet-stats span {
    padding: var(--spacing-xs) var(--spacing-sm);
    background: var(--color-bg, #fff);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    font-size: var(--font-size-sm);
    text-align: center;
}

.aktivitaet-meta {
    margin-top: 0.5rem;
    font-size: 0.82rem;
    color: var(--text-muted, #64748b);
}

.aktivitaet-chart {
    display: flex;
    gap: 2px;
    align-items: flex-end;
    height: 40px;
    margin-top: 0.5rem;
}

.aktivitaet-chart-labels {
    display: flex;
    gap: 2px;
    font-size: 0.65rem;
    color: var(--text-muted, #94a3b8);
    margin-top: 2px;
}

.aktivitaet-chart-labels span,
.aktivitaet-chart div {
    width: 18px;
    text-align: center;
}

/* Responsive: Quartal auf schmalem Bildschirm */
@media (max-width: 768px) {
    .kalender-quartal-grid {
        grid-template-columns: 1fr;
    }
    .kalender-wochen-grid {
        grid-template-columns: repeat(7, 1fr);
        font-size: 11px;
    }
}

/* ==================== Arbeitsplaner: Wirtschaftlichkeit ==================== */

.tab-bar {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(120px, max-content));
    gap: 0;
    border-bottom: 2px solid var(--color-border);
    margin-bottom: var(--spacing-md);
}

.wirt-kpi-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
}
@media (max-width: 1100px) {
    .wirt-kpi-grid { grid-template-columns: repeat(2, 1fr); }
}

.wirt-kpi {
    background: white;
    border-radius: 8px;
    padding: var(--spacing-md);
    box-shadow: 0 1px 3px rgba(0,0,0,0.08);
    border: 1px solid var(--color-border);
}
.wirt-kpi-label {
    font-size: 0.7rem;
    text-transform: uppercase;
    color: var(--color-text-light);
    letter-spacing: 0.04em;
}
.wirt-kpi-value {
    font-size: 1.4rem;
    font-weight: 700;
    margin: 4px 0 2px;
}
.wirt-kpi-sub {
    font-size: 0.72rem;
    color: var(--color-text-light);
}

.wirt-filter-bar {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: var(--spacing-md);
    align-items: center;
    margin-bottom: var(--spacing-md);
}
.wirt-filter-buttons {
    display: grid;
    grid-template-columns: repeat(6, max-content);
    gap: var(--spacing-xs);
}
@media (max-width: 1200px) {
    .wirt-filter-bar { grid-template-columns: 1fr; }
    .wirt-filter-buttons { grid-template-columns: repeat(3, 1fr); }
}
.wirt-search {
    width: 280px;
    padding: 0.4rem 0.6rem;
    border: 1px solid var(--color-border);
    border-radius: 4px;
    font-size: 0.85rem;
}
@media (max-width: 1200px) {
    .wirt-search { width: 100%; }
}

.wirt-table-wrap {
    overflow-x: auto;
    background: white;
    border-radius: 8px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.08);
}
.wirt-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.8rem;
}
.wirt-table thead tr {
    background: #1976d2;
    color: white;
    font-size: 0.7rem;
}
.wirt-table th, .wirt-table td {
    padding: 0.4rem 0.5rem;
    text-align: left;
    border-bottom: 1px solid #eee;
}
.wirt-table th.num, .wirt-table td.num { text-align: right; }
.wirt-table tbody tr:hover { background: #f9f9f9; }
.wirt-table .small { font-size: 0.72rem; }
.wirt-table .wirt-versicherer { font-size: 0.72rem; color: var(--color-text-light); }
.wirt-table .wirt-clickable { cursor: pointer; }
.wirt-table .wirt-clickable:hover { color: var(--color-primary); }
.wirt-table .wirt-pauschale {
    font-size: 0.7rem;
    padding: 0.15rem 0.25rem;
    width: 110px;
    border: 1px solid #ddd;
    border-radius: 3px;
}
.wirt-table .wirt-checkbox { width: auto; cursor: pointer; }
.wirt-table .wirt-ampel {
    display: inline-block;
    font-size: 0.7rem;
    font-weight: 600;
    padding: 0.15rem 0.45rem;
    border-radius: 3px;
}
.wirt-table .wirt-summe {
    font-weight: 700;
    border-top: 2px solid #333;
    background: #f5f5f5;
}
.wirt-table .wirt-summe td { padding: 0.55rem 0.5rem; }

.wirt-footer {
    margin-top: var(--spacing-sm);
    font-size: 0.72rem;
    color: var(--color-text-light);
}
.wirt-footer-rule {
    margin-top: var(--spacing-xs);
    font-size: 0.72rem;
    color: var(--color-text);
    background: #f5f5f5;
    padding: var(--spacing-sm);
    border-radius: 4px;
}

/* ==================== Statistiken-Tab ==================== */
.stat-header {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    margin-bottom: var(--spacing-md);
}
.stat-kpi-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-md);
}
@media (max-width: 1100px) { .stat-kpi-grid { grid-template-columns: repeat(2, 1fr); } }
.stat-kpi {
    padding: 1rem;
    border-radius: 8px;
}
.stat-kpi-label { font-size: 0.75rem; color: #666; text-transform: uppercase; letter-spacing: 0.04em; }
.stat-kpi-value { font-size: 1.5rem; font-weight: 700; margin: 4px 0 2px; }
.stat-kpi-sub { font-size: 0.72rem; color: #999; }
.stat-charts-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-md);
}
@media (max-width: 1100px) { .stat-charts-grid { grid-template-columns: 1fr; } }
.stat-card {
    background: white;
    padding: 1rem;
    border-radius: 8px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.08);
    border: 1px solid var(--color-border);
}
.stat-table { width: 100%; border-collapse: collapse; font-size: 0.85rem; }
.stat-table th { padding: 0.4rem; text-align: left; border-bottom: 2px solid #1976d2; }
.stat-table td { padding: 0.4rem; border-bottom: 1px solid #eee; }
.stat-table th.num, .stat-table td.num { text-align: right; }
.stat-table .stat-summe { background: #f5f5f5; border-top: 2px solid #1976d2; }
.stat-table .stat-summe td { padding: 0.5rem; }
.stat-table tr:hover { background: #f9f9f9; }
