/* ================================================
   PraxisManager – Design System
   Branding: mpu-amme.de | Stil: Clean Schwarz/Weiß
   ================================================ */

:root {
    /* ── Bold Editorial: Schwarz / Weiß / Signal-Orange ── */
    --color-bg-page:         #f5f5f2;   /* helles Papierweiß */
    --color-bg-primary:      #ffffff;
    --color-bg-secondary:    #ededea;
    --color-bg-card:         #ffffff;
    --color-bg-card-hover:   #fafaf8;

    /* Akzent: Signal-Orange */
    --color-accent:          #ff5a36;
    --color-accent-hover:    #e8431f;
    --color-accent-light:    rgba(255, 90, 54, 0.10);

    /* Texthierarchie – neutral, hoher Kontrast */
    --color-text-primary:    #111111;
    --color-text-secondary:  #555555;
    --color-text-muted:      #8a8a85;
    --color-text-light:      #f5f5f3;   /* auf dunklen Flächen */
    --color-text-white:      #ffffff;

    /* Semantisch */
    --color-success:         #16a34a;
    --color-success-bg:      rgba(22, 163, 74, 0.10);
    --color-warning:         #c2750a;
    --color-warning-bg:      rgba(194, 117, 10, 0.10);
    --color-danger:          #dc2626;
    --color-danger-bg:       rgba(220, 38, 38, 0.10);

    /* Rahmen – präsente Trennlinien */
    --color-border:          #e2e2dc;
    --color-border-light:    #ededea;
    --color-border-strong:   #111111;

    /* Abstände */
    --spacing-xs: 4px;
    --spacing-sm: 8px;
    --spacing-md: 16px;
    --spacing-lg: 24px;
    --spacing-xl: 32px;

    /* Radius – crisp/editorial */
    --radius-sm:   3px;
    --radius-md:   5px;
    --radius-lg:   8px;
    --radius-xl:   12px;
    --radius-full: 999px;

    /* Schatten */
    --shadow-sm:  0 1px 3px rgba(0, 0, 0, 0.06);
    --shadow-md:  0 5px 18px rgba(0, 0, 0, 0.09);
    --shadow-lg:  0 18px 44px rgba(0, 0, 0, 0.14);

    --transition-fast: 160ms cubic-bezier(0.4, 0, 0.2, 1);

    /* Layout */
    --sidebar-width: 240px;
    --header-height: 60px;
}

/* ======================================
   Reset & Base
   ====================================== */
* { margin: 0; padding: 0; box-sizing: border-box; }

body {
    font-family: 'Inter', -apple-system, sans-serif;
    background: var(--color-bg-page);
    color: var(--color-text-primary);
    font-size: 15px;
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
}

a { text-decoration: none; color: inherit; }
button { cursor: pointer; border: none; background: none; font-family: inherit; }
input, select, textarea { font-family: inherit; }

/* Bold Editorial: fette Inter-Grotesk für alle Überschriften */
h1, h2, h3, .page-title, .modal-title, .auth-title, .dash-card-header h3 {
    font-family: 'Inter', -apple-system, sans-serif;
    font-weight: 800;
    letter-spacing: -0.02em;
}

/* ======================================
   Layout
   ====================================== */
#app { min-height: 100vh; }
.app-layout { display: flex; min-height: 100vh; }
.app-main {
    flex: 1;
    margin-left: var(--sidebar-width);
    display: flex;
    flex-direction: column;
    background: var(--color-bg-page);
}
.app-content {
    flex: 1;
    padding: 40px;
    margin-top: var(--header-height);
    animation: fadeIn 0.35s ease;
    max-width: 1400px;
    margin-left: auto;
    margin-right: auto;
    width: 100%;
    box-sizing: border-box;
}

@keyframes fadeIn {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ======================================
   Sidebar – dunkel, clean
   ====================================== */
.sidebar {
    width: var(--sidebar-width);
    height: 100vh;
    position: fixed;
    background: #141414;
    display: flex;
    flex-direction: column;
    z-index: 100;
    border-right: none;
    box-shadow: 2px 0 16px rgba(0, 0, 0, 0.14);
}

.sidebar-brand {
    padding: var(--spacing-lg);
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    border-bottom: 1px solid rgba(255, 255, 255, 0.07);
}

.brand-icon {
    width: 38px;
    height: 38px;
    background: #ffffff;
    color: #141414;
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    font-size: 0.8rem;
    flex-shrink: 0;
    letter-spacing: -0.5px;
}

.brand-text {
    font-size: 1.05rem;
    font-weight: 700;
    color: #f5f3ef;
    letter-spacing: -0.2px;
}

.brand-text span,
.gold {
    color: var(--color-accent);   /* warmes Gold – Referenz mpu-amme.de */
}

.sidebar-nav {
    flex: 1;
    padding: var(--spacing-md) var(--spacing-sm);
    overflow-y: auto;
}

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

.nav-group-title {
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: 0.68rem;
    color: rgba(255, 255, 255, 0.28);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1.2px;
}

.nav-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: 11px var(--spacing-md);
    margin: 2px 0;
    color: rgba(255, 255, 255, 0.52);
    border-radius: var(--radius-md);
    font-weight: 500;
    font-size: 0.875rem;
    transition: all var(--transition-fast);
    border-left: 3px solid transparent;
}

.nav-item:hover {
    background: rgba(255, 255, 255, 0.08);
    color: rgba(255, 255, 255, 0.9);
    transform: none;
}

.nav-item.active {
    background: #ffffff;
    color: #141414;
    border-left: 3px solid var(--color-accent);
    font-weight: 700;
}

.nav-badge {
    margin-left: auto;
    background: rgba(255, 255, 255, 0.12);
    color: rgba(255, 255, 255, 0.7);
    padding: 2px 8px;
    border-radius: var(--radius-full);
    font-size: 0.68rem;
    font-weight: 700;
}

.nav-badge-gold {
    background: var(--color-accent);
    color: #141414;
}

.sidebar-user {
    padding: var(--spacing-lg);
    border-top: 1px solid rgba(255, 255, 255, 0.07);
    display: flex;
    align-items: center;
    gap: 12px;
}

.user-avatar {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.12);
    color: rgba(255, 255, 255, 0.85);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 0.85rem;
    flex-shrink: 0;
}

.user-info { display: flex; flex-direction: column; overflow: hidden; }
.user-name {
    color: #f5f3ef;
    font-weight: 600;
    font-size: 0.85rem;
    white-space: nowrap;
    text-overflow: ellipsis;
    overflow: hidden;
}
.user-role { color: rgba(255, 255, 255, 0.38); font-size: 0.72rem; }

/* ======================================
   Header
   ====================================== */
.app-header {
    height: var(--header-height);
    background: rgba(247, 244, 239, 0.92);
    backdrop-filter: blur(10px);
    border-bottom: 1px solid var(--color-border);
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 40px;
    position: fixed;
    left: var(--sidebar-width);
    right: 0;
    z-index: 50;
}

.header-page-title {
    font-family: 'Lora', Georgia, serif;
    font-size: 1rem;
    font-weight: 600;
    color: var(--color-text-primary);
    letter-spacing: -0.2px;
}

.header-right {
    display: flex;
    align-items: center;
    gap: 10px;
}

.header-search {
    position: relative;
    display: flex;
    align-items: center;
}

.header-search-icon {
    position: absolute;
    left: 10px;
    font-size: 0.8rem;
    pointer-events: none;
}

.header-search input {
    padding: 7px 12px 7px 30px;
    border: 1px solid var(--color-border);
    border-radius: 999px;
    font-size: 0.82rem;
    background: #fff;
    outline: none;
    width: 180px;
    font-family: inherit;
    color: var(--color-text);
}

.header-search input:focus { border-color: var(--color-accent); }

.header-icon-btn {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border: 1px solid var(--color-border);
    background: #fff;
    border-radius: 50%;
    cursor: pointer;
    color: var(--color-text);
    transition: background 0.12s, border-color 0.12s;
    flex-shrink: 0;
}
.header-icon-btn:hover { background: var(--color-bg-page); border-color: #c8c0b4; }

/* Badge auf dem Bell-Button */
.badge {
    display: none;
    position: absolute;
    top: -3px;
    right: -3px;
}

.header-user-btn {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 12px 6px 6px;
    border: 1px solid var(--color-border);
    background: #fff;
    border-radius: 999px;
    cursor: pointer;
    font-family: inherit;
    transition: background 0.12s;
}
.header-user-btn:hover { background: var(--color-bg-page); }

.header-user-avatar {
    width: 28px;
    height: 28px;
    background: #1a1a1a;
    color: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.7rem;
    font-weight: 700;
    flex-shrink: 0;
}

.header-breadcrumb {
    font-size: 0.72rem;
    color: var(--color-text-secondary);
    margin-top: 1px;
}

/* ======================================
   Buttons – Pill-Form wie mpu-amme.de
   ====================================== */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 11px 22px;
    border-radius: var(--radius-md);
    font-weight: 700;
    font-size: 0.875rem;
    transition: all var(--transition-fast);
    border: none;
    cursor: pointer;
    letter-spacing: 0.1px;
    white-space: nowrap;
}

.btn-primary {
    background: var(--color-accent);
    color: #ffffff;
    box-shadow: none;
}
.btn-primary:hover {
    background: var(--color-accent-hover);
    transform: translateY(-1px);
    box-shadow: 0 5px 16px rgba(255, 90, 54, 0.32);
}

.btn-outline,
.btn-secondary {
    background: transparent;
    border: 1px solid var(--color-border);
    color: var(--color-text-primary);
}
.btn-outline:hover {
    background: var(--color-bg-card-hover);
    border-color: #c8c2b8;
}

.btn-danger-outline {
    color: var(--color-danger);
    border: 1px solid var(--color-danger);
}
.btn-danger {
    background: var(--color-danger);
    color: white;
}

.btn-icon {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-md);
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    color: var(--color-text-secondary);
    transition: all var(--transition-fast);
}
.btn-icon:hover {
    background: var(--color-bg-page);
    border-color: #c8c2b8;
    color: var(--color-text-primary);
}

/* ======================================
   Cards & Seitenkopf
   ====================================== */
.page-header-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    margin-bottom: var(--spacing-lg);
    padding-bottom: 16px;
    border-bottom: 2px solid var(--color-text-primary);
}

.page-title {
    font-size: 2rem;
    font-weight: 800;
    color: var(--color-text-primary);
    letter-spacing: -0.03em;
    line-height: 1.1;
}

.page-subtitle {
    color: var(--color-text-secondary);
    margin-top: 5px;
    font-size: 0.875rem;
}

.card,
.form-card,
.detail-card,
.dash-card {
    background: var(--color-bg-card);
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-sm);
    padding: 28px;
    transition: box-shadow var(--transition-fast);
}

.detail-card:hover { box-shadow: var(--shadow-md); }

/* ======================================
   Auth
   ====================================== */
.auth-layout {
    display: flex;
    height: 100vh;
    background: var(--color-bg-page);
}

.auth-form-side {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 40px 10%;
    max-width: 560px;
    background: white;
    border-right: 1px solid var(--color-border);
}

.auth-hero-side {
    flex: 1.5;
    background: #141414;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 60px;
}

.auth-hero-content { max-width: 520px; }

.auth-brand {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 48px;
    font-family: 'Lora', Georgia, serif;
    font-size: 1.4rem;
    font-weight: 600;
    color: #f5f3ef;
}

.auth-brand .brand-icon {
    background: #ffffff;
    color: #141414;
}

.auth-title {
    font-size: 2.2rem;
    font-weight: 600;
    margin-bottom: 8px;
    color: var(--color-text-primary);
    line-height: 1.2;
}

.auth-subtitle {
    color: var(--color-text-secondary);
    margin-bottom: 36px;
    font-size: 1rem;
}

.auth-hero-content h2 {
    font-size: 2.6rem;
    font-weight: 600;
    margin-bottom: 20px;
    line-height: 1.2;
    color: #f5f3ef;
}

.auth-hero-content p {
    font-size: 1.05rem;
    color: rgba(245, 243, 239, 0.58);
    margin-bottom: 40px;
}

.auth-features { display: flex; flex-direction: column; gap: 18px; }

.auth-feature {
    display: flex;
    align-items: center;
    gap: 14px;
    font-size: 1rem;
    font-weight: 500;
    color: rgba(245, 243, 239, 0.82);
}

.auth-feature-icon {
    width: 38px;
    height: 38px;
    background: rgba(255, 255, 255, 0.09);
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    flex-shrink: 0;
}

.auth-form { margin-bottom: 24px; }

.auth-error {
    background: var(--color-danger-bg);
    color: var(--color-danger);
    padding: 12px 16px;
    border-radius: var(--radius-md);
    font-weight: 600;
    font-size: 0.875rem;
    margin-bottom: 20px;
    border-left: 3px solid var(--color-danger);
}

.auth-link { color: var(--color-text-secondary); font-size: 0.9rem; }
.auth-link a { color: var(--color-accent); font-weight: 600; }
.auth-link a:hover { text-decoration: underline; }

@media (max-width: 900px) {
    .auth-hero-side { display: none; }
    .auth-form-side { max-width: 100%; padding: 30px; border-right: none; }
}

/* ======================================
   Formulare
   ====================================== */
.form-field { margin-bottom: var(--spacing-md); }

.form-field label {
    display: block;
    font-size: 0.8rem;
    font-weight: 600;
    margin-bottom: 6px;
    color: var(--color-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.form-field input,
.form-field select,
.form-field textarea {
    width: 100%;
    padding: 10px 14px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: var(--color-bg-page);
    font-size: 0.9rem;
    outline: none;
    transition: all var(--transition-fast);
    color: var(--color-text-primary);
}

.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus {
    border-color: var(--color-accent);
    background: white;
    box-shadow: 0 0 0 3px var(--color-accent-light);
}

.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--spacing-md); }
.form-actions { display: flex; gap: 10px; margin-top: 20px; }
.form-sep { height: 1px; background: var(--color-border-light); margin: 20px 0; }
.form-hint { font-size: 0.82rem; color: var(--color-text-secondary); margin-bottom: 12px; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--spacing-md); }
.span-2 { grid-column: span 2; }

/* ======================================
   Tabellen
   ====================================== */
.data-table {
    width: 100%;
    background: white;
    border-radius: var(--radius-lg);
    overflow: hidden;
    border: 1px solid var(--color-border);
}

table { width: 100%; border-collapse: collapse; text-align: left; }

th {
    background: var(--color-bg-page);
    padding: 10px 16px;
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--color-text-muted);
    font-weight: 700;
    border-bottom: 1px solid var(--color-border);
}

td {
    padding: 14px 16px;
    border-top: 1px solid var(--color-border-light);
    font-size: 0.875rem;
}

tr:hover td { background: var(--color-bg-card-hover); }
.clickable-row { cursor: pointer; }

/* ======================================
   Filter & Suche
   ====================================== */
.filter-bar {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    margin-bottom: 20px;
    background: white;
    padding: 14px 18px;
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-sm);
    flex-wrap: wrap;
    gap: 14px;
}

.search-bar-wrap { flex: 1; min-width: 250px; }

.search-input {
    width: 100%;
    padding: 9px 14px 9px 38px;
    border-radius: var(--radius-full);
    border: 1px solid var(--color-border);
    background: var(--color-bg-page) url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="15" height="15" viewBox="0 0 24 24" fill="none" stroke="%23a89e90" stroke-width="2.5" stroke-linecap="round" stroke-linejoin="round"><circle cx="11" cy="11" r="8"/><line x1="21" y1="21" x2="16.65" y2="16.65"/></svg>') no-repeat 12px center;
    font-size: 0.875rem;
    transition: all var(--transition-fast);
    color: var(--color-text-primary);
}

.search-input:focus {
    border-color: var(--color-accent);
    background-color: white;
    box-shadow: 0 0 0 3px var(--color-accent-light);
    outline: none;
}

.filter-tabs {
    display: flex;
    gap: 4px;
    background: var(--color-bg-page);
    padding: 3px;
    border-radius: var(--radius-full);
    overflow-x: auto;
}

.filter-tab {
    padding: 7px 16px;
    border-radius: var(--radius-full);
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--color-text-secondary);
    background: transparent;
    transition: all var(--transition-fast);
    white-space: nowrap;
}

.filter-tab:hover { color: var(--color-text-primary); }

.filter-tab.active {
    background: white;
    color: var(--color-accent);
    box-shadow: var(--shadow-sm);
}

/* ======================================
   Pills & Badges
   ====================================== */
.pill {
    padding: 3px 10px;
    border-radius: var(--radius-full);
    font-size: 0.72rem;
    font-weight: 600;
    display: inline-block;
}

.pill-blue   { background: rgba(59,130,246,0.09); color: #2563eb; }
.pill-yellow { background: var(--color-warning-bg); color: var(--color-warning); }
.pill-green  { background: var(--color-success-bg); color: var(--color-success); }
.pill-red    { background: var(--color-danger-bg); color: var(--color-danger); }
.pill-gray   { background: var(--color-bg-page); color: var(--color-text-secondary); }

.avatar-small {
    width: 30px;
    height: 30px;
    border-radius: var(--radius-full);
    background: var(--color-accent-light);
    color: var(--color-accent);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 0.7rem;
}

/* ======================================
   UI-Komponenten
   ====================================== */
.client-hero { display: flex; gap: 20px; align-items: center; margin-bottom: 20px; }

.avatar-large {
    width: 72px;
    height: 72px;
    border-radius: var(--radius-full);
    background: var(--color-accent-light);
    color: var(--color-accent);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'Lora', Georgia, serif;
    font-size: 1.8rem;
    font-weight: 600;
    border: 2px solid var(--color-border);
}

.client-header-card {
    background: white;
    padding: 28px;
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border);
    margin-bottom: 20px;
    display: flex;
    justify-content: space-between;
    box-shadow: var(--shadow-sm);
}

/* Spinner */
.loading-spinner {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 40px;
}
.spinner {
    width: 28px;
    height: 28px;
    border: 2.5px solid var(--color-border);
    border-top-color: var(--color-accent);
    border-radius: 50%;
    animation: spin 0.9s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* Modal */
.modal-overlay {
    position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(0, 0, 0, 0.55);
    backdrop-filter: blur(3px);
    z-index: 1000;
    display: flex;
    align-items: center;
    justify-content: center;
}

.modal {
    background: white;
    border-radius: var(--radius-lg);
    width: 100%;
    max-width: 520px;
    box-shadow: var(--shadow-lg);
    overflow: hidden;
    margin: 20px;
    max-height: calc(100vh - 40px);
    display: flex;
    flex-direction: column;
}

.modal-header {
    padding: 20px 24px;
    border-bottom: 1px solid var(--color-border-light);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.modal-title {
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--color-text-primary);
    margin: 0;
}

.modal-close {
    background: var(--color-bg-page);
    color: var(--color-text-muted);
    width: 30px;
    height: 30px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all var(--transition-fast);
    font-size: 1rem;
    border: none;
    cursor: pointer;
}
.modal-close:hover { background: var(--color-danger-bg); color: var(--color-danger); }

.modal-body { padding: 24px; overflow-y: auto; }
.modal-footer {
    padding: 16px 24px;
    border-top: 1px solid var(--color-border-light);
    display: flex;
    justify-content: flex-end;
    gap: 12px;
    background: var(--color-bg-page);
}

/* Toast */
.toast-container {
    position: fixed;
    bottom: 20px;
    right: 20px;
    z-index: 2000;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.toast {
    background: #141414;
    color: #f5f3ef;
    padding: 12px 20px;
    border-radius: var(--radius-full);
    box-shadow: var(--shadow-lg);
    font-weight: 500;
    font-size: 0.875rem;
    animation: slideInX 0.25s forwards;
    border: none;
    border-left: none;
}

.toast.success { background: #1a3d2b; color: #a7f3c0; }
.toast.error   { background: #3d1a1a; color: #fca5a5; }

@keyframes slideInX { from { transform: translateX(120%); } to { transform: translateX(0); } }

/* Empty State */
.empty-state {
    text-align: center;
    padding: 64px 24px;
    color: var(--color-text-muted);
}
.empty-state .empty-icon { font-size: 2.5rem; margin-bottom: 16px; opacity: 0.5; }
.empty-state h3 {
    font-family: 'Lora', Georgia, serif;
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--color-text-secondary);
    margin-bottom: 8px;
}
.empty-state p { font-size: 0.875rem; }

/* ======================================
   Dashboard KPIs
   ====================================== */
.kpi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--spacing-lg);
    margin-bottom: var(--spacing-xl);
}

.kpi-card {
    background: white;
    border-radius: var(--radius-lg);
    padding: 20px 22px;
    border: 1px solid var(--color-border);
    display: flex;
    gap: 16px;
    align-items: center;
    box-shadow: var(--shadow-sm);
    transition: box-shadow var(--transition-fast);
}
.kpi-card:hover { box-shadow: var(--shadow-md); }

.kpi-icon {
    width: 44px;
    height: 44px;
    border-radius: var(--radius-md);
    background: var(--color-bg-page);
    font-size: 1.3rem;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.kpi-value { font-size: 1.4rem; font-weight: 700; font-variant-numeric: tabular-nums; }
.kpi-label { font-size: 0.7rem; color: var(--color-text-muted); text-transform: uppercase; font-weight: 600; letter-spacing: 0.5px; margin-top: 2px; }

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

.dash-card {
    background: white;
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-sm);
    padding: 0;
}

.dash-card-header {
    padding: 18px 22px;
    border-bottom: 1px solid var(--color-border-light);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.dash-card-header h3 {
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--color-text-primary);
}

/* ======================================
   Kalender
   ====================================== */
.cal-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 1px;
    background: var(--color-border);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
}

.cal-header {
    background: var(--color-bg-page);
    padding: 10px;
    text-align: center;
    font-weight: 700;
    font-size: 0.68rem;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.cal-day {
    background: white;
    min-height: 110px;
    padding: 8px;
}

.cal-day.today { background: #faf8f5; }
.cal-day.other-month { background: var(--color-bg-page); }
.day-num { font-weight: 600; font-size: 0.82rem; margin-bottom: 6px; display: block; color: var(--color-text-secondary); }

.cal-appt {
    font-size: 0.68rem;
    padding: 3px 6px;
    border-radius: 4px;
    margin-bottom: 3px;
    cursor: pointer;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    font-weight: 600;
}

.appt-erst    { background: #ede9fe; color: #4c1d95; }
.appt-sitzung { background: #dcfce7; color: #14532d; }
.appt-mpu     { background: #fef9c3; color: #713f12; }
.appt-sonst   { background: var(--color-bg-page); color: var(--color-text-secondary); }

/* ======================================
   Detail-Raster
   ====================================== */
.detail-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--spacing-lg); }

.detail-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 11px 0;
    border-bottom: 1px solid var(--color-border-light);
    font-size: 0.875rem;
}

.detail-row span:first-child { color: var(--color-text-secondary); }
.detail-row span:last-child { font-weight: 600; }

/* Upload */
.upload-zone {
    border: 2px dashed var(--color-border);
    border-radius: var(--radius-lg);
    padding: 40px;
    text-align: center;
    margin-bottom: 20px;
    cursor: pointer;
    background: white;
    transition: all var(--transition-fast);
}
.upload-zone:hover { border-color: var(--color-accent); background: var(--color-bg-page); }
.upload-icon { font-size: 2.5rem; margin-bottom: 10px; opacity: 0.45; }

/* ======================================
   SEPA / Tab-Leiste (überschrieben von sepa.css,
   hier nur globaler Fallback)
   ====================================== */
.tabs-bar {
    display: flex;
    gap: 20px;
    border-bottom: 1px solid var(--color-border);
    margin-bottom: 20px;
}

.tab-btn {
    padding: 10px 0;
    border: none;
    background: transparent;
    font-weight: 600;
    color: var(--color-text-secondary);
    cursor: pointer;
    border-bottom: 2px solid transparent;
    font-size: 0.875rem;
    transition: all var(--transition-fast);
}

.tab-btn:hover { color: var(--color-text-primary); }
.tab-btn.active { color: var(--color-accent); border-bottom-color: var(--color-accent); }

/* ======================================
   Klientenakte (kakt-)
   ====================================== */
.kakt-selector-bar {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 20px;
    background: white;
    padding: 12px 16px;
    border-radius: var(--radius-md);
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-sm);
    flex-wrap: wrap;
}

.kakt-select {
    padding: 8px 12px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    font-size: 0.875rem;
    min-width: 260px;
    color: var(--color-text-primary);
    background: var(--color-bg-page);
    outline: none;
}
.kakt-select:focus { border-color: var(--color-accent); }

.kakt-card {
    background: white;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 20px;
    margin-bottom: 14px;
    box-shadow: var(--shadow-sm);
}

.kakt-sect-hdr {
    font-size: 0.68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1.2px;
    color: var(--color-accent);
    margin-bottom: 16px;
    padding-bottom: 8px;
    border-bottom: 2px solid var(--color-accent);
}

.kakt-amber-hdr { color: #c2750a !important; border-bottom-color: #c2750a !important; }

.kakt-top-row    { display: grid; grid-template-columns: 1fr 300px; gap: 16px; margin-bottom: 16px; align-items: start; }
.kakt-stamm-card { flex: 1; }
.kakt-mpu-card   { background: #fffbf5 !important; border-color: #f0d9b5 !important; }
.kakt-grid4      { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }

.kakt-f { display: flex; flex-direction: column; gap: 4px; }
.kakt-f label {
    font-size: 0.68rem;
    font-weight: 700;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.kakt-in {
    padding: 7px 10px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    font-size: 0.875rem;
    color: var(--color-text-primary);
    background: white;
    transition: border-color var(--transition-fast);
    width: 100%;
    box-sizing: border-box;
}
.kakt-in:focus { outline: none; border-color: var(--color-accent); box-shadow: 0 0 0 2px var(--color-accent-light); }
.kakt-in-sm { padding: 4px 8px; font-size: 0.8rem; }

.kakt-ta {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    font-size: 0.875rem;
    resize: vertical;
    color: var(--color-text-primary);
    box-sizing: border-box;
    line-height: 1.5;
    background: white;
}
.kakt-ta:focus { outline: none; border-color: var(--color-accent); }

/* Tags */
.kakt-tags-wrap { display: flex; flex-wrap: wrap; gap: 8px; }

.kakt-tag {
    display: inline-flex;
    align-items: center;
    padding: 5px 12px;
    border-radius: var(--radius-full);
    border: 1px solid var(--color-border);
    font-size: 0.78rem;
    font-weight: 500;
    cursor: pointer;
    transition: all var(--transition-fast);
    background: var(--color-bg-page);
    color: var(--color-text-secondary);
    user-select: none;
}
.kakt-tag:hover { border-color: var(--color-accent); color: var(--color-accent); }
.kakt-tag-on   { background: var(--color-accent); color: white; border-color: var(--color-accent); }

/* Hypothesen */
.kakt-hypo-grid { display: flex; gap: 20px; flex-wrap: wrap; }
.kakt-hypo-grp  { display: flex; gap: 8px; background: var(--color-bg-page); padding: 8px 12px; border-radius: 8px; border: 1px solid var(--color-border); }

.kakt-hypo-item {
    display: flex;
    align-items: center;
    gap: 5px;
    padding: 5px 10px;
    border: 1px solid var(--color-border);
    border-radius: 6px;
    cursor: pointer;
    font-size: 0.85rem;
    font-weight: 600;
    transition: all var(--transition-fast);
    background: white;
}
.kakt-hypo-item:has(input:checked) { border-color: var(--color-accent); color: var(--color-accent); background: var(--color-accent-light); }
.kakt-hypo-blocked { opacity: 0.35; cursor: not-allowed; background: var(--color-bg-page) !important; }
.kakt-hypo-blocked input { pointer-events: none; }

/* Progress-Stepper */
.kakt-progress { display: flex; align-items: center; overflow-x: auto; padding: 12px 0 4px; }
.kakt-ps       { display: flex; flex-direction: column; align-items: center; min-width: 72px; }

.kakt-ps-dot {
    width: 20px;
    height: 20px;
    border-radius: 50%;
    border: 2px solid var(--color-border);
    background: white;
    transition: all var(--transition-fast);
    flex-shrink: 0;
}
.kakt-ps-done .kakt-ps-dot { background: var(--color-accent); border-color: var(--color-accent); box-shadow: 0 0 0 3px var(--color-accent-light); }

.kakt-ps-label {
    font-size: 0.65rem;
    color: var(--color-text-muted);
    margin-top: 5px;
    text-align: center;
    white-space: nowrap;
    max-width: 72px;
    overflow: hidden;
    text-overflow: ellipsis;
}
.kakt-ps-done .kakt-ps-label { color: var(--color-accent); font-weight: 600; }

.kakt-ps-line      { flex: 1; height: 2px; background: var(--color-border); min-width: 16px; margin-top: -10px; }
.kakt-ps-line-done { background: var(--color-accent); }

/* Klienten-Tabellen */
.kakt-table { width: 100%; border-collapse: collapse; font-size: 0.85rem; }
.kakt-table th {
    text-align: left;
    padding: 8px 10px;
    background: var(--color-bg-page);
    color: var(--color-text-muted);
    font-size: 0.68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border-bottom: 1px solid var(--color-border);
    white-space: nowrap;
}
.kakt-table td { padding: 7px 10px; border-bottom: 1px solid var(--color-border-light); vertical-align: middle; }
.kakt-table tr:last-child td { border-bottom: none; }

.kakt-del-btn {
    background: var(--color-danger-bg);
    color: var(--color-danger);
    border: none;
    border-radius: 4px;
    padding: 3px 8px;
    cursor: pointer;
    font-size: 0.9rem;
    transition: background var(--transition-fast);
}
.kakt-del-btn:hover { background: #fecaca; }

/* Zahlungsstatus-Balken */
.kakt-zahl-bar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 16px;
    border-radius: var(--radius-md);
    font-size: 0.875rem;
    font-weight: 600;
    flex-wrap: wrap;
    gap: 8px;
}
.kakt-zahl-gruen { background: var(--color-success-bg); color: #15803d; }
.kakt-zahl-gelb  { background: var(--color-warning-bg); color: var(--color-warning); }
.kakt-zahl-rot   { background: var(--color-danger-bg);  color: var(--color-danger); }

/* Countdown */
.kakt-countdown { padding: 7px 12px; border-radius: var(--radius-sm); font-weight: 700; font-size: 0.875rem; }
.kakt-cd-ok     { background: var(--color-success-bg); color: #15803d; }
.kakt-cd-urgent { background: var(--color-warning-bg); color: var(--color-warning); }
.kakt-cd-past   { background: var(--color-bg-page);    color: var(--color-text-secondary); }

/* Banner */
.kakt-banner      { padding: 10px 16px; border-radius: var(--radius-md); margin-bottom: 12px; font-size: 0.875rem; font-weight: 600; }
.kakt-banner-amber { background: #fff7ed; color: #9a3412; border: 1px solid #fed7aa; }
.kakt-banner-warn  { background: #fefce8; color: #713f12; border: 1px solid #fde68a; }

/* Klientenliste */
.kliste-table-wrap { overflow-x: auto; }
.kliste-table tbody tr:hover td { background: var(--color-bg-card-hover) !important; }
.kliste-row-warn td { background: #fefce8 !important; }
.kliste-row-warn:hover td { background: #fef9c3 !important; }

/* Status-Buttons in der Klientenübersicht */
.kls-status-btns {
    display: flex;
    gap: 5px;
    align-items: center;
}

.kls-sbtn {
    width: 18px;
    height: 18px;
    border-radius: 50%;
    border: 2px solid var(--sc);
    background: transparent;
    cursor: pointer;
    padding: 0;
    transition: background 0.15s, box-shadow 0.15s, transform 0.1s;
    flex-shrink: 0;
    opacity: 0.3;
}
.kls-sbtn:hover {
    opacity: 0.7;
    transform: scale(1.15);
}
.kls-sbtn.kls-sbtn-active {
    opacity: 1;
    box-shadow: 0 0 0 3px var(--sg), 0 0 8px 2px var(--sg);
    transform: scale(1.1);
}

/* Status-Anzeige in der Klientenakte (nur-lesend) */
.kakt-status-display {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 0 2px;
}

.kakt-status-dot {
    display: inline-block;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    flex-shrink: 0;
    background: #d4cdc0;
    transition: background 0.2s, box-shadow 0.2s;
}

/* CSV-Import */
.csv-drop-zone {
    border: 2px dashed var(--color-border);
    border-radius: var(--radius-lg);
    padding: 40px 24px;
    text-align: center;
    cursor: pointer;
    background: var(--color-bg-page);
    transition: all var(--transition-fast);
}
.csv-drop-zone:hover,
.csv-drop-hover { border-color: var(--color-accent); background: var(--color-accent-light); }
.csv-example { background: var(--color-bg-page); border: 1px solid var(--color-border); border-radius: 6px; padding: 12px; font-size: 0.78rem; color: var(--color-text-secondary); margin-top: 10px; overflow-x: auto; white-space: pre; }
.csv-col-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 8px; }
.csv-map-row { display: flex; align-items: center; gap: 10px; background: var(--color-bg-page); padding: 8px 12px; border-radius: 8px; border: 1px solid var(--color-border); }
.csv-map-src { font-size: 0.78rem; font-weight: 600; color: var(--color-text-primary); min-width: 110px; max-width: 130px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.csv-map-sel { flex: 1; }

/* Suche + Plan-Btn */
.kakt-search-group { display: flex; align-items: center; gap: 6px; }
.kakt-plan-btn {
    background: var(--color-bg-page);
    color: var(--color-accent);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    padding: 3px 8px;
    cursor: pointer;
    font-size: 0.875rem;
    transition: background var(--transition-fast);
    margin-right: 4px;
}
.kakt-plan-btn:hover { background: var(--color-accent-light); }

/* Blutwerte */
.bw-trend    { font-weight: 700; font-size: 0.875rem; }
.bw-trend-up { color: var(--color-danger); }
.bw-trend-dn { color: var(--color-success); }
.bw-trend-eq { color: var(--color-text-muted); }
.bw-legende  { margin-top: 10px; font-size: 0.72rem; color: var(--color-text-muted); line-height: 1.8; }

/* ======================================
   Aufgaben-Seite
   ====================================== */

/* Controls-Leiste */
.aufg-controls {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
    flex-wrap: wrap;
}

.aufg-controls-right {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-left: auto;
    flex-wrap: wrap;
}

/* Farbpunkt in Tabs */
.aufg-tab-dot {
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    margin-right: 5px;
    vertical-align: middle;
}

/* Formular-Karte */
.aufg-form-card {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: 12px;
    padding: 22px 24px;
    margin-bottom: 16px;
}

.aufg-form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px 20px;
    margin-bottom: 18px;
}

/* Person-Auswahl im Formular */
.aufg-person-sel {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.aufg-person-opt input[type=radio] { display: none; }

.aufg-person-opt span {
    display: inline-block;
    padding: 6px 16px;
    border-radius: 999px;
    border: 1.5px solid;
    font-size: 0.82rem;
    font-weight: 600;
    cursor: pointer;
    transition: opacity 0.15s, box-shadow 0.15s;
    opacity: 0.45;
}

.aufg-person-opt input[type=radio]:checked + span {
    opacity: 1;
    box-shadow: 0 1px 4px rgba(0,0,0,0.14);
}

/* Custom Checkbox */
.aufg-check-wrap {
    flex-shrink: 0;
    cursor: pointer;
    position: relative;
    display: block;
    width: 20px;
    height: 20px;
}
.aufg-check-wrap input { position: absolute; opacity: 0; width: 0; height: 0; }
.aufg-checkmark {
    position: absolute;
    inset: 0;
    border: 2px solid var(--color-border);
    border-radius: 5px;
    background: white;
    transition: all var(--transition-fast);
}
.aufg-check-wrap input:checked ~ .aufg-checkmark {
    background: var(--color-accent);
    border-color: var(--color-accent);
}
.aufg-check-wrap input:checked ~ .aufg-checkmark::after {
    content: '';
    position: absolute;
    left: 4px; top: 1px;
    width: 5px; height: 9px;
    border: 2px solid white;
    border-top: none;
    border-left: none;
    transform: rotate(45deg);
}
.aufg-check-wrap:hover .aufg-checkmark { border-color: var(--color-accent); }

/* Tabelle */
.aufg-table-wrap {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: 12px;
    overflow: hidden;
}

.aufg-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.875rem;
}

.aufg-table thead tr {
    background: var(--color-bg-page);
    border-bottom: 2px solid var(--color-border);
}

.aufg-table th {
    padding: 10px 14px;
    text-align: left;
    font-size: 0.68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-text-secondary);
}

.aufg-table tbody tr {
    border-bottom: 1px solid var(--color-border);
    transition: background 0.12s;
}

.aufg-table tbody tr:last-child { border-bottom: none; }
.aufg-table tbody tr:hover { background: var(--color-bg-page); }

.aufg-table td {
    padding: 11px 14px;
    vertical-align: middle;
}

/* Klient-Link */
.aufg-client-link {
    font-size: 0.84rem;
    font-weight: 600;
    color: var(--color-text-primary);
    text-decoration: none;
    transition: color 0.15s;
}
.aufg-client-link:hover { color: var(--color-accent); text-decoration: underline; }

/* Person-Badge */
.aufg-person-badge {
    display: inline-flex;
    align-items: center;
    padding: 3px 10px;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 600;
    white-space: nowrap;
}

.aufg-person-dot {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    margin-right: 5px;
    flex-shrink: 0;
}

/* Datum-Badges */
.aufg-date-badge {
    display: inline-block;
    padding: 2px 9px;
    border-radius: 999px;
    font-size: 0.73rem;
    font-weight: 600;
    white-space: nowrap;
}
.aufg-overdue { background: #fee2e2; color: #dc2626; }
.aufg-today   { background: #fef3c7; color: #b45309; }
.aufg-soon    { background: #fef3c7; color: #b45309; }
.aufg-normal  { background: #f0ece5; color: #7a7060; }

/* Icon-Buttons (Bearbeiten / Löschen) */
.aufg-icon-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 26px;
    height: 26px;
    border: none;
    background: none;
    font-size: 0.82rem;
    cursor: pointer;
    border-radius: 50%;
    transition: background 0.12s;
    padding: 0;
}
.aufg-icon-btn:hover { background: #f0ece5; }

/* Lösch-Button */
.aufg-del-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 26px;
    height: 26px;
    border: none;
    background: none;
    color: #b0a898;
    font-size: 1.1rem;
    cursor: pointer;
    border-radius: 50%;
    transition: background 0.12s, color 0.12s;
    padding: 0;
}
.aufg-del-btn:hover { background: #fee2e2; color: #dc2626; }

/* Vermerk-Input in Tabelle */
.aufg-vermerk-input {
    width: 100%;
    max-width: 360px;
    padding: 4px 10px;
    border: 1px solid transparent;
    border-radius: 999px;
    font-size: 0.75rem;
    color: var(--color-text-secondary);
    background: transparent;
    outline: none;
    transition: border-color 0.15s, background 0.15s;
    font-family: inherit;
}
.aufg-vermerk-input:hover  { border-color: var(--color-border-light); background: var(--color-bg-page); }
.aufg-vermerk-input:focus  { border-color: var(--color-accent); background: white; }
.aufg-vermerk-input::placeholder { color: var(--color-text-muted); font-style: italic; }

/* ======================================
   Zeitstrahl (Aufgaben-Seite)
   ====================================== */

.ztl-card {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: 12px;
    padding: 22px 24px 16px;
    margin-top: 24px;
    overflow: hidden;
}

.ztl-card-header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 6px;
    flex-wrap: wrap;
}

.ztl-card-title {
    font-family: 'Lora', serif;
    font-size: 1rem;
    font-weight: 600;
    color: var(--color-text);
}

.ztl-card-range {
    font-size: 0.75rem;
    color: var(--color-text-secondary);
}

.ztl-zoom-ctrl {
    display: flex;
    align-items: center;
    gap: 0;
    border: 1px solid var(--color-border);
    border-radius: 999px;
    overflow: hidden;
    margin-left: 8px;
}

.ztl-zoom-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 26px;
    height: 26px;
    border: none;
    background: none;
    font-size: 1rem;
    font-weight: 700;
    cursor: pointer;
    color: var(--color-text);
    transition: background 0.12s;
    line-height: 1;
    padding: 0;
}
.ztl-zoom-btn:hover:not(:disabled) { background: var(--color-bg-page); }
.ztl-zoom-btn:disabled { color: #ccc; cursor: default; }

.ztl-zoom-label {
    font-size: 0.72rem;
    font-weight: 700;
    color: var(--color-text-secondary);
    padding: 0 6px;
    border-left: 1px solid var(--color-border);
    border-right: 1px solid var(--color-border);
    line-height: 26px;
    min-width: 28px;
    text-align: center;
}

.ztl-legend {
    margin-left: auto;
    display: flex;
    gap: 14px;
    align-items: center;
    flex-wrap: wrap;
}

.ztl-legend-item {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 0.72rem;
    font-weight: 600;
}

.ztl-legend-dot {
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
}

/* Szene */
.ztl-scene {
    position: relative;
    height: 210px;
    overflow-x: auto;
    overflow-y: visible;
    padding: 0 20px;
    scrollbar-width: thin;
    scrollbar-color: #d4cfc8 transparent;
    cursor: default;
}
.ztl-scene::-webkit-scrollbar       { height: 4px; }
.ztl-scene::-webkit-scrollbar-track { background: transparent; }
.ztl-scene::-webkit-scrollbar-thumb { background: #d4cfc8; border-radius: 2px; }

/* Track-Linie (y=105px Mitte) */
.ztl-track {
    position: absolute;
    top: 104px;
    left: 20px;
    right: 20px;
    height: 2px;
    background: #e5e0d8;
    border-radius: 1px;
    min-width: 560px;
}

/* Heute-Spalte */
.ztl-today-col {
    position: absolute;
    top: 0;
    height: 210px;
    width: 2px;
    background: #1a1a1a;
    transform: translateX(-50%);
    z-index: 10;
}

.ztl-today-label {
    position: absolute;
    top: 112px;
    left: 50%;
    transform: translateX(-50%);
    white-space: nowrap;
    font-size: 0.67rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: #fff;
    background: #1a1a1a;
    padding: 2px 7px;
    border-radius: 999px;
}

/* Pins */
.ztl-pin {
    position: absolute;
    transform: translateX(-50%);
    z-index: 5;
    cursor: pointer;
}
.ztl-pin:hover .ztl-pin-dot { transform: scale(1.4); }

.ztl-pin-dot {
    position: absolute;
    top: 99px;
    left: -6px;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    border: 2.5px solid #fff;
    transition: transform 0.15s;
}

.ztl-pin-connector {
    position: absolute;
    left: 0;
    width: 1.5px;
    opacity: 0.3;
}

.ztl-pin-label {
    position: absolute;
    text-align: center;
    white-space: nowrap;
    left: 50%;
    transform: translateX(-50%);
    line-height: 1.3;
    pointer-events: none;
}

.ztl-pin-name  { display: block; font-size: 0.71rem; font-weight: 700; }
.ztl-pin-date  { display: block; font-size: 0.64rem; opacity: 0.75; }
.ztl-pin-diff  { display: block; font-size: 0.61rem; font-weight: 600; opacity: 0.55; margin-top: 1px; }

/* Zahl-Badge auf dem Dot bei mehreren Aufgaben am selben Tag */
.ztl-pin-count {
    position: absolute;
    top: -7px;
    right: -8px;
    min-width: 16px;
    height: 16px;
    border-radius: 999px;
    color: #fff;
    font-size: 0.6rem;
    font-weight: 800;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 3px;
    border: 1.5px solid #fff;
    line-height: 1;
}

/* Oben */
.ztl-above .ztl-pin-label     { top: 26px; }
.ztl-above .ztl-pin-connector { top: 74px; height: 25px; }

/* Unten */
.ztl-below .ztl-pin-label     { top: 136px; }
.ztl-below .ztl-pin-connector { top: 111px; height: 25px; }

/* Tooltip */
.ztl-tooltip {
    position: fixed;
    z-index: 9999;
    width: 256px;
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: 10px;
    box-shadow: 0 8px 28px rgba(0,0,0,0.14);
    overflow: hidden;
    pointer-events: none;
}

.ztl-tt-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    padding: 9px 14px;
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--color-text);
    background: var(--color-bg-page);
    border-bottom: 1px solid var(--color-border);
}

.ztl-tt-count {
    font-size: 0.68rem;
    font-weight: 700;
    color: var(--color-text-secondary);
    background: #e5e0d8;
    padding: 1px 7px;
    border-radius: 999px;
}

.ztl-tt-body { padding: 8px 0; }

/* Eine Aufgabe im Tooltip */
.ztl-tt-task {
    padding: 7px 14px;
    border-bottom: 1px solid var(--color-border);
}
.ztl-tt-task:last-child { border-bottom: none; }

.ztl-tt-person {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 1px 8px;
    border-radius: 999px;
    font-size: 0.68rem;
    font-weight: 700;
    margin-bottom: 4px;
}

.ztl-tt-inhalt {
    font-size: 0.82rem;
    font-weight: 500;
    color: var(--color-text);
    line-height: 1.35;
}

.ztl-tt-client {
    font-size: 0.73rem;
    color: var(--color-text-secondary);
    margin-top: 2px;
}

/* ═══════════════════════════════════════════
   Master-Verlaufsübersicht (Klientenakte)
   ═══════════════════════════════════════════ */
.master-tl-outer {
    background: #faf8f5;
    border-radius: 10px;
    padding: 16px;
    min-height: 80px;
}

.master-tl-empty {
    color: #a89e90;
    font-size: 0.85rem;
    text-align: center;
    padding: 24px 0;
}

.master-tl-scroll {
    overflow-x: auto;
    overflow-y: visible;
}

.master-tl-inner {
    min-width: 800px;
    padding-left: 130px;
    padding-right: 16px;
    padding-bottom: 8px;
}

/* ── Zeitachse ── */
.master-tl-axis {
    position: relative;
    height: 28px;
    margin-bottom: 8px;
    border-bottom: 2px solid #e5e0d8;
}

.master-tl-yr {
    position: absolute;
    top: 0;
    bottom: 0;
    border-left: 1px solid #a89e90;
    padding-left: 4px;
}
.master-tl-yr span {
    font-size: 0.65rem;
    font-weight: 700;
    color: #5c5346;
    position: absolute;
    top: 3px;
    left: 4px;
    white-space: nowrap;
}

.master-tl-q {
    position: absolute;
    top: 12px;
    bottom: 0;
    border-left: 1px dashed #d4cdc0;
    padding-left: 3px;
}
.master-tl-q span {
    font-size: 0.58rem;
    color: #a89e90;
    position: absolute;
    top: 1px;
    left: 3px;
    white-space: nowrap;
}

/* ── Heute-Linie ── */
.master-tl-today {
    position: absolute;
    top: 0;
    bottom: 0;
    width: 2px;
    background: #ef4444;
    opacity: 0.85;
    z-index: 20;
    pointer-events: none;
}
.master-tl-today-lbl {
    position: absolute;
    bottom: 6px;
    left: 4px;
    background: #ef4444;
    color: #fff;
    font-size: 0.58rem;
    padding: 2px 5px;
    border-radius: 4px;
    white-space: nowrap;
    font-weight: 700;
}

/* ── Lanes ── */
.master-tl-lanes { overflow: visible; }

.master-tl-lane {
    display: flex;
    align-items: stretch;
    margin-bottom: 3px;
    position: relative;
}

.master-tl-lane-lbl {
    position: absolute;
    right: calc(100% + 8px);
    width: 120px;
    font-size: 0.65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .4px;
    text-align: right;
    top: 50%;
    transform: translateY(-50%);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.master-tl-lane-bar {
    position: relative;
    flex: 1;
    background: rgba(0,0,0,.018);
    border-radius: 4px;
    overflow: visible;
}

/* ── Marker-Typen ── */
.master-tl-diamond {
    position: absolute;
    top: 50%;
    width: 14px;
    height: 14px;
    background: #dc2626;
    border: 2px solid #fff;
    box-shadow: 0 2px 6px rgba(220,38,38,.45);
    transform: translate(-50%,-50%) rotate(45deg);
    cursor: pointer;
    z-index: 5;
}
.master-tl-diamond:hover { box-shadow: 0 3px 10px rgba(220,38,38,.7); }

.master-tl-dot {
    position: absolute;
    top: 50%;
    border-radius: 50%;
    border: 2px solid #fff;
    box-shadow: 0 1px 4px rgba(0,0,0,.25);
    transform: translate(-50%, -50%);
    cursor: pointer;
    z-index: 5;
}
.master-tl-dot:hover { box-shadow: 0 2px 8px rgba(0,0,0,.4); transform: translate(-50%,-50%) scale(1.2); }

.master-tl-tick {
    position: absolute;
    top: 2px;
    bottom: 2px;
    width: 3px;
    border-radius: 2px;
    transform: translateX(-50%);
    cursor: pointer;
    z-index: 5;
    opacity: .85;
}
.master-tl-tick:hover { opacity: 1; transform: translateX(-50%) scaleY(1.1); }

.master-tl-bar {
    position: absolute;
    top: 3px;
    bottom: 3px;
    border-radius: 4px;
    cursor: pointer;
    overflow: hidden;
    z-index: 4;
    min-width: 4px;
    border: 1px solid rgba(0,0,0,.08);
}
.master-tl-bar:hover { filter: brightness(.92); }

.master-tl-bar-lbl {
    position: absolute;
    left: 6px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 0.58rem;
    font-weight: 700;
    color: rgba(0,0,0,.5);
    white-space: nowrap;
    pointer-events: none;
}

.master-tl-bar-border {
    position: absolute;
    top: 0;
    bottom: 0;
    width: 3px;
    border-left: 3px solid #166534;
    border-radius: 0 2px 2px 0;
    z-index: 6;
    transform: translateX(-50%);
}

/* ── Meilenstein-Flaggen ── */
.master-tl-flag {
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    background: #1c1c1c;
    border: 2px solid #1c1c1c;
    border-radius: 3px;
    padding: 1px 5px;
    cursor: pointer;
    z-index: 6;
    white-space: nowrap;
}
.master-tl-flag span {
    font-size: 0.58rem;
    font-weight: 700;
    color: #fff;
    letter-spacing: .3px;
}
.master-tl-flag:hover { filter: brightness(1.15); }
.mstl-flag-mpu { background: #1c1c1c; border-color: #1c1c1c; }

/* Delikt-Tooltip im Abstinenz-Zeitstrahl */
#pm-delikt-tip {
    position: fixed;
    z-index: 9999;
    background: #fff;
    border: 1px solid #fca5a5;
    border-top: 3px solid #dc2626;
    border-radius: 10px;
    box-shadow: 0 8px 28px rgba(0,0,0,.14);
    padding: 12px 16px;
    font-size: 0.82rem;
    max-width: 280px;
    pointer-events: none;
    display: none;
}

@media (max-width: 640px) {
    .aufg-controls { flex-direction: column; align-items: flex-start; }
    .aufg-controls-right { margin-left: 0; }
    .aufg-form-grid { grid-template-columns: 1fr; }
    .aufg-table th:nth-child(3), .aufg-table td:nth-child(3) { display: none; }
    .ztl-card { padding: 14px; }
}

/* ======================================
   Responsive – Mobile
   ====================================== */
@media (max-width: 768px) {
    .app-main  { margin-left: 0; padding-bottom: 72px; }
    .app-header { left: 0; padding: 0 16px; }
    .app-content { padding: 16px; margin-top: calc(var(--header-height) + 8px); }
    .page-title { font-size: 1.3rem; }

    /* Sidebar → Bottom-Bar */
    .sidebar {
        top: auto;
        bottom: 0;
        width: 100%;
        height: 64px;
        flex-direction: row;
        border-right: none;
        border-top: 1px solid rgba(255,255,255,0.08);
        box-shadow: 0 -2px 12px rgba(0,0,0,0.2);
        padding: 0;
    }

    .sidebar-brand,
    .sidebar-user,
    .nav-group-title,
    .nav-badge { display: none !important; }

    .sidebar-nav {
        display: flex;
        flex-direction: row;
        justify-content: space-around;
        align-items: center;
        width: 100%;
        padding: 0;
    }

    .nav-group { margin: 0; display: flex; width: 100%; justify-content: space-around; }

    .nav-item {
        flex-direction: column;
        gap: 3px;
        padding: 8px 4px;
        margin: 0;
        font-size: 0.6rem;
        background: transparent !important;
        border-left: none !important;
        color: rgba(255, 255, 255, 0.45);
        width: 60px;
        text-align: center;
    }

    .nav-item:hover,
    .nav-item:active { transform: none; }
    .nav-item span:first-child { font-size: 1.2rem; margin-bottom: 2px; }
    .nav-item.active { color: white; border-bottom: 2px solid var(--color-accent) !important; border-radius: 0; }

    /* Cards */
    .card, .form-card, .detail-card, .dash-card { padding: 16px; }
    .kpi-grid, .dashboard-grid, .detail-grid, .form-row { grid-template-columns: 1fr; gap: 12px; }

    /* Tabellen */
    .data-table-wrap, .kliste-table-wrap { width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; }

    /* Klientenakte */
    .kakt-grid4    { grid-template-columns: 1fr 1fr; }
    .kakt-top-row  { grid-template-columns: 1fr; }
    .kakt-f[style*="grid-column"] { grid-column: span 1 !important; }
}

@media (max-width: 600px) {
    .kakt-grid4 { grid-template-columns: 1fr; }
}

/* ======================================
   Sidebar – Terminvorschau
   ====================================== */

#sidebar-termine {
    margin: 0 10px 8px;
}

/* Sidebar-Trigger-Schaltfläche */
.stv-trigger-wrap {
    padding: 2px 0;
}

.stv-trigger-btn {
    display: flex;
    align-items: center;
    gap: 7px;
    width: 100%;
    padding: 7px 10px;
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.10);
    border-radius: 8px;
    color: rgba(255,255,255,0.72);
    font-size: 0.8rem;
    font-weight: 600;
    font-family: inherit;
    cursor: pointer;
    transition: background 0.14s, border-color 0.14s;
    text-align: left;
}
.stv-trigger-btn:hover {
    background: rgba(255,255,255,0.09);
    border-color: rgba(255,255,255,0.18);
}

.stv-trigger-icon { font-size: 0.9rem; line-height: 1; }

.stv-trigger-label { flex: 1; }

.stv-trigger-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 16px;
    height: 16px;
    padding: 0 4px;
    background: rgba(255,255,255,0.14);
    color: rgba(255,255,255,0.6);
    border-radius: 999px;
    font-size: 0.62rem;
    font-weight: 700;
    line-height: 1;
}

/* ======================================
   Terminvorschau – Popup-Modal
   ====================================== */

.stv-popup-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.52);
    z-index: 1500;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 16px;
}

.stv-popup {
    background: #1c1c1c;
    border: 1px solid rgba(255,255,255,0.10);
    border-radius: 14px;
    width: 420px;
    max-width: 100%;
    max-height: 82vh;
    display: flex;
    flex-direction: column;
    box-shadow: 0 24px 64px rgba(0,0,0,0.55);
    overflow: hidden;
}

.stv-popup-hdr {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 18px 12px;
    border-bottom: 1px solid rgba(255,255,255,0.08);
    flex-shrink: 0;
}

.stv-popup-title {
    font-size: 0.95rem;
    font-weight: 700;
    color: rgba(255,255,255,0.88);
    letter-spacing: 0.01em;
}

.stv-popup-close {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border: 1px solid rgba(255,255,255,0.15);
    border-radius: 50%;
    background: none;
    color: rgba(255,255,255,0.45);
    font-size: 0.72rem;
    cursor: pointer;
    transition: background 0.12s, color 0.12s;
    padding: 0;
    font-family: inherit;
}
.stv-popup-close:hover { background: rgba(255,255,255,0.1); color: rgba(255,255,255,0.8); }

.stv-popup-body {
    flex: 1;
    overflow-y: auto;
    scrollbar-width: thin;
    scrollbar-color: rgba(255,255,255,0.15) transparent;
}
.stv-popup-body::-webkit-scrollbar       { width: 4px; }
.stv-popup-body::-webkit-scrollbar-track { background: transparent; }
.stv-popup-body::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.15); border-radius: 2px; }

.stv-urgent-dot {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 16px;
    height: 16px;
    padding: 0 4px;
    background: #ef4444;
    color: #fff;
    border-radius: 999px;
    font-size: 0.6rem;
    font-weight: 800;
    line-height: 1;
}

.stv-list {
    display: flex;
    flex-direction: column;
}

/* Einzelne Termin-Zeile */
.stv-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 6px;
    padding: 6px 10px;
    border-bottom: 1px solid rgba(255,255,255,0.05);
    transition: background 0.12s;
}
.stv-row:last-child { border-bottom: none; }
.stv-row:hover { background: rgba(255,255,255,0.06) !important; }

.stv-urgent {
    border-left: 2px solid #ef4444;
}

.stv-row-left {
    display: flex;
    flex-direction: column;
    gap: 1px;
    min-width: 0;
    flex: 1;
}

.stv-time {
    font-size: 0.65rem;
    font-weight: 700;
    color: rgba(255,255,255,0.5);
    white-space: nowrap;
}

.stv-name {
    font-size: 0.78rem;
    font-weight: 600;
    color: rgba(255,255,255,0.82);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 220px;
}

/* Aktions-Buttons (geplant → 3 kleine Knöpfe) */
.stv-actions {
    display: flex;
    gap: 3px;
    flex-shrink: 0;
}

.stv-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    border: 1px solid;
    background: none;
    font-size: 0.7rem;
    font-weight: 700;
    cursor: pointer;
    transition: background 0.12s, transform 0.1s;
    padding: 0;
    line-height: 1;
    flex-shrink: 0;
}
.stv-btn:hover { transform: scale(1.18); }

.stv-done   { border-color: #86c45e; color: #86c45e; }
.stv-done:hover   { background: rgba(134,196,94,0.18); }

.stv-cancel { border-color: #f87171; color: #f87171; }
.stv-cancel:hover { background: rgba(248,113,113,0.18); }

.stv-noshow { border-color: #fbbf24; color: #fbbf24; }
.stv-noshow:hover { background: rgba(251,191,36,0.18); }

/* Bereits gesetzt: Icon + Undo */
.stv-status-dot {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 0.78rem;
    font-weight: 700;
    flex-shrink: 0;
}

.stv-undo {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    border: 1px solid rgba(255,255,255,0.2);
    border-radius: 50%;
    background: none;
    color: rgba(255,255,255,0.35);
    font-size: 0.65rem;
    cursor: pointer;
    transition: background 0.12s, color 0.12s;
    padding: 0;
    line-height: 1;
}
.stv-undo:hover { background: rgba(255,255,255,0.1); color: rgba(255,255,255,0.7); }

/* Gespeicherter Sitzungsinhalt unter dem Namen */
.stv-saved-typ {
    font-size: 0.62rem;
    color: rgba(255,255,255,0.38);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 130px;
    display: block;
}

/* Formular-Label (Klient / Sitzungsinhalt) */
.stv-form-label {
    font-size: 0.62rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    color: rgba(255,255,255,0.35);
    margin-bottom: -2px;
}

/* Neuen Klienten anlegen – Mini-Formular */
.stv-new-client-form {
    display: flex;
    flex-direction: column;
    gap: 5px;
    padding: 6px 8px 4px;
    border-left: 2px solid rgba(134,196,94,0.4);
    margin-left: 2px;
}

/* Inline-Detailformular nach einer Termin-Zeile */
.stv-detail-form {
    background: rgba(255,255,255,0.06);
    border-top: 1px solid rgba(255,255,255,0.07);
    border-bottom: 1px solid rgba(255,255,255,0.07);
    padding: 10px 12px;
    display: flex;
    flex-direction: column;
    gap: 7px;
}

.stv-sel {
    width: 100%;
    padding: 5px 8px;
    border: 1px solid rgba(255,255,255,0.15);
    border-radius: 6px;
    background: rgba(255,255,255,0.08);
    color: rgba(255,255,255,0.85);
    font-size: 0.75rem;
    font-family: inherit;
    outline: none;
    cursor: pointer;
    appearance: auto;
}
.stv-sel:focus { border-color: rgba(255,255,255,0.35); }
.stv-sel option, .stv-sel optgroup {
    background: #2a2a2a;
    color: #fff;
}

.stv-notiz-inp {
    width: 100%;
    padding: 5px 8px;
    border: 1px solid rgba(255,255,255,0.15);
    border-radius: 6px;
    background: rgba(255,255,255,0.08);
    color: rgba(255,255,255,0.85);
    font-size: 0.75rem;
    font-family: inherit;
    outline: none;
    box-sizing: border-box;
}
.stv-notiz-inp:focus { border-color: rgba(255,255,255,0.35); }
.stv-notiz-inp::placeholder { color: rgba(255,255,255,0.3); }

.stv-form-btns {
    display: flex;
    gap: 6px;
}

.stv-save-btn {
    flex: 1;
    padding: 5px 0;
    background: #86c45e;
    color: #1a1a1a;
    border: none;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 700;
    cursor: pointer;
    font-family: inherit;
    transition: background 0.12s;
}
.stv-save-btn:hover { background: #9dd972; }

.stv-cancel-btn {
    padding: 5px 10px;
    background: none;
    color: rgba(255,255,255,0.45);
    border: 1px solid rgba(255,255,255,0.15);
    border-radius: 999px;
    font-size: 0.75rem;
    cursor: pointer;
    font-family: inherit;
    transition: background 0.12s;
}
.stv-cancel-btn:hover { background: rgba(255,255,255,0.06); }

/* ======================================
   Terminvorschau – Slide-in Panel
   ====================================== */

/* Backdrop */
.tv-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.22);
    z-index: 1100;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.25s;
}
.tv-backdrop.tv-open {
    opacity: 1;
    pointer-events: all;
}

/* Panel */
.tv-panel {
    position: fixed;
    top: 0;
    right: 0;
    height: 100%;
    width: 360px;
    max-width: 100vw;
    background: #fff;
    box-shadow: -4px 0 32px rgba(0,0,0,0.14);
    z-index: 1200;
    display: flex;
    flex-direction: column;
    transform: translateX(100%);
    transition: transform 0.28s cubic-bezier(0.4,0,0.2,1);
}
.tv-panel.tv-open {
    transform: translateX(0);
}

/* Panel-Kopf */
.tv-panel-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 18px 20px 14px;
    border-bottom: 1px solid var(--color-border);
    flex-shrink: 0;
}

.tv-panel-title {
    font-family: 'Lora', serif;
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--color-text);
}

.tv-close-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    border: none;
    background: none;
    font-size: 1.3rem;
    color: var(--color-text-secondary);
    cursor: pointer;
    border-radius: 50%;
    transition: background 0.12s, color 0.12s;
    padding: 0;
    line-height: 1;
}
.tv-close-btn:hover { background: #f0ece5; color: var(--color-text); }

/* Scrollbarer Body */
.tv-panel-body {
    flex: 1;
    overflow-y: auto;
    scrollbar-width: thin;
    scrollbar-color: #d4cfc8 transparent;
}
.tv-panel-body::-webkit-scrollbar       { width: 4px; }
.tv-panel-body::-webkit-scrollbar-track { background: transparent; }
.tv-panel-body::-webkit-scrollbar-thumb { background: #d4cfc8; border-radius: 2px; }

/* Reminder-Banner */
.tv-reminder-banner {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 14px 16px 0;
    padding: 10px 14px;
    background: #fef3c7;
    border: 1px solid #fde68a;
    border-radius: 10px;
    font-size: 0.82rem;
    font-weight: 600;
    color: #b45309;
}

/* Tages-Abschnitte */
.tv-section {
    padding: 14px 16px 6px;
}

.tv-section-title {
    font-size: 0.68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 8px;
    padding-bottom: 6px;
    border-bottom: 1px solid var(--color-border);
}

.tv-section-past   .tv-section-title { color: #dc2626; }
.tv-section-today  .tv-section-title { color: #1a1a1a; }
.tv-section-future .tv-section-title { color: var(--color-text-secondary); }

/* Termin-Zeile */
.tv-row {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 10px 12px;
    border-radius: 10px;
    margin-bottom: 6px;
    background: var(--color-bg-page);
    border: 1px solid var(--color-border);
    transition: border-color 0.15s;
}

.tv-row-urgent {
    border-color: #fca5a5;
    background: #fff5f5;
}

.tv-row-time {
    font-size: 0.8rem;
    font-weight: 700;
    color: var(--color-text);
    min-width: 36px;
    padding-top: 2px;
    flex-shrink: 0;
}

.tv-row-body {
    flex: 1;
    min-width: 0;
}

.tv-row-name {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: 2px;
}

.tv-row-meta {
    font-size: 0.75rem;
    color: var(--color-text-secondary);
    margin-bottom: 5px;
}

.tv-status-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px 8px;
    border-radius: 999px;
    font-size: 0.7rem;
    font-weight: 600;
}

/* Aktions-Buttons */
.tv-row-ctrl {
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 4px;
}

.tv-actions {
    display: flex;
    gap: 3px;
}

.tv-act {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    border: 1.5px solid;
    font-size: 0.8rem;
    font-weight: 700;
    cursor: pointer;
    background: #fff;
    transition: background 0.12s, transform 0.1s;
    padding: 0;
    line-height: 1;
}
.tv-act:hover { transform: scale(1.12); }

.tv-act-done   { border-color: #6b8c30; color: #4a6120; }
.tv-act-done:hover   { background: #eef3e6; }

.tv-act-cancel { border-color: #dc2626; color: #dc2626; }
.tv-act-cancel:hover { background: #fee2e2; }

.tv-act-noshow { border-color: #b45309; color: #b45309; }
.tv-act-noshow:hover { background: #fef3c7; }

.tv-act-move   { border-color: #7c6dc0; color: #5b4fa8; }
.tv-act-move:hover   { background: #ede9fe; }

.tv-undo-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 26px;
    height: 26px;
    border: 1px solid var(--color-border);
    background: none;
    border-radius: 50%;
    font-size: 0.82rem;
    color: var(--color-text-secondary);
    cursor: pointer;
    transition: background 0.12s;
    padding: 0;
}
.tv-undo-btn:hover { background: #f0ece5; color: var(--color-text); }

/* Leer-State */
.tv-empty {
    padding: 48px 24px;
    text-align: center;
    color: var(--color-text-secondary);
    font-size: 0.875rem;
}

/* Badge am Bell-Button */
.badge-visible {
    display: flex !important;
    align-items: center;
    justify-content: center;
    min-width: 16px;
    height: 16px;
    padding: 0 3px;
    font-size: 0.6rem;
    font-weight: 800;
    background: #dc2626;
    color: #fff;
    border-radius: 999px;
    line-height: 1;
}

@media (max-width: 480px) {
    .tv-panel { width: 100vw; }
}

/* ── Tagesplan / Heute ────────────────────────────────────── */
.heute-toolbar {
    display: flex;
    align-items: center;
    gap: 18px;
    padding: 14px 18px;
    background: var(--color-bg-card, #fff);
    border: 1px solid var(--color-border, #e5e0d8);
    border-radius: 10px;
    margin-bottom: 16px;
    flex-wrap: wrap;
    box-shadow: 0 1px 2px rgba(0,0,0,.03);
}
.heute-datepicker {
    padding: 8px 12px;
    font-size: 0.95rem;
    border: 1px solid var(--color-border, #e5e0d8);
    border-radius: 8px;
    background: #fff;
    cursor: pointer;
    font-variant-numeric: tabular-nums;
}
.heute-datelabel {
    font-weight: 600;
    color: #1c1c1c;
    text-transform: capitalize;
}
.heute-counts { display: flex; gap: 8px; margin-left: auto; flex-wrap: wrap; }
.hc-pill {
    padding: 4px 10px;
    border-radius: 999px;
    font-size: 0.78rem;
    font-weight: 600;
    border: 1px solid transparent;
}
.hc-pill.hc-done   { background: rgba(22,163,74,.08); color: #15803d; border-color: rgba(22,163,74,.2); }
.hc-pill.hc-cancel { background: rgba(220,38,38,.08); color: #b91c1c; border-color: rgba(220,38,38,.2); }
.hc-pill.hc-noshow { background: rgba(217,119,6,.08); color: #92400e; border-color: rgba(217,119,6,.2); }

.heute-grid {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: 16px;
    align-items: start;
}
@media (max-width: 900px) {
    .heute-grid { grid-template-columns: 1fr; }
}

.heute-plan, .heute-pool {
    background: var(--color-bg-card, #fff);
    border: 1px solid var(--color-border, #e5e0d8);
    border-radius: 10px;
    padding: 14px 16px;
}
.heute-section-hdr {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 10px;
    padding-bottom: 8px;
    border-bottom: 1px solid var(--color-border-light, #f0ece5);
}
.heute-section-hdr h3 {
    margin: 0;
    font-size: 0.95rem;
    font-weight: 700;
    color: #1c1c1c;
}
.heute-count {
    font-size: 0.72rem;
    font-weight: 700;
    color: #7a7060;
    background: #f0ece5;
    padding: 2px 8px;
    border-radius: 999px;
}
.heute-empty {
    text-align: center;
    color: #a89e90;
    font-size: 0.85rem;
    padding: 32px 16px;
}
.heute-empty-sm { color: #a89e90; font-size: 0.8rem; padding: 14px 4px; text-align: center; }

/* Pool */
.heute-search {
    width: 100%;
    padding: 8px 10px;
    border: 1px solid var(--color-border, #e5e0d8);
    border-radius: 8px;
    font-size: 0.85rem;
    margin-bottom: 8px;
    box-sizing: border-box;
}
.heute-pool-list {
    display: flex;
    flex-direction: column;
    gap: 3px;
    max-height: 60vh;
    overflow-y: auto;
}
.heute-pool-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 7px 10px;
    border-radius: 6px;
    cursor: pointer;
    font-size: 0.85rem;
    transition: background .12s;
}
.heute-pool-item:hover { background: #faf8f5; }
.heute-pool-item.is-added {
    background: rgba(22,163,74,.06);
    color: #15803d;
}
.heute-pool-item.is-added:hover { background: rgba(22,163,74,.1); }
.hpi-badge {
    font-size: 0.7rem;
    font-weight: 700;
    width: 18px; height: 18px;
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: 50%;
}
.hpi-add  { background: #f0ece5; color: #7a7060; }
.hpi-tick { background: #16a34a; color: #fff; }

/* Entry */
.heute-entry {
    border: 1px solid var(--color-border, #e5e0d8);
    border-radius: 8px;
    padding: 10px 12px;
    margin-bottom: 8px;
    background: #fff;
    transition: border-color .15s, background .15s;
}
.heute-entry.status-absolviert       { border-color: rgba(22,163,74,.35); background: rgba(22,163,74,.04); }
.heute-entry.status-abgesagt         { border-color: rgba(220,38,38,.35); background: rgba(220,38,38,.04); }
.heute-entry.status-nicht_erschienen { border-color: rgba(217,119,6,.35); background: rgba(217,119,6,.04); }

.he-row1 { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
.he-name { flex: 1; color: #1c1c1c; font-size: 0.95rem; }
.he-akte {
    text-decoration: none;
    color: #7a7060;
    font-size: 1rem;
    padding: 2px 6px;
    border-radius: 4px;
}
.he-akte:hover { background: #f0ece5; color: #1c1c1c; }
.he-remove {
    border: none;
    background: transparent;
    color: #a89e90;
    font-size: 1.1rem;
    cursor: pointer;
    padding: 0 6px;
    border-radius: 4px;
}
.he-remove:hover { background: #fee2e2; color: #dc2626; }

.he-status-row { display: flex; gap: 6px; margin-bottom: 8px; flex-wrap: wrap; }
.he-st-btn {
    flex: 1;
    min-width: 100px;
    padding: 6px 10px;
    border: 1px solid var(--color-border, #e5e0d8);
    border-radius: 6px;
    background: #fff;
    cursor: pointer;
    font-size: 0.82rem;
    font-weight: 600;
    color: #7a7060;
    transition: all .12s;
}
.he-st-btn:hover { background: #faf8f5; }
.he-st-btn.st-done.is-active   { background: #16a34a; border-color: #16a34a; color: #fff; }
.he-st-btn.st-cancel.is-active { background: #dc2626; border-color: #dc2626; color: #fff; }
.he-st-btn.st-noshow.is-active { background: #d97706; border-color: #d97706; color: #fff; }

.he-row2 { display: flex; gap: 8px; }
.he-time {
    width: 110px;
    padding: 5px 8px;
    border: 1px solid var(--color-border, #e5e0d8);
    border-radius: 6px;
    font-size: 0.82rem;
    font-variant-numeric: tabular-nums;
}
.he-notiz {
    flex: 1;
    padding: 5px 8px;
    border: 1px solid var(--color-border, #e5e0d8);
    border-radius: 6px;
    font-size: 0.82rem;
}

/* ── Stundenübersicht in der Klientenakte ──────────────── */
.kakt-stundenkpi {
    display: flex;
    align-items: center;
    gap: 18px;
    padding: 12px 14px;
    background: #faf8f5;
    border-radius: 8px;
    border: 1px solid #e5e0d8;
    flex-wrap: wrap;
}
.ksk-main { display: flex; align-items: baseline; gap: 8px; }
.ksk-num {
    font-size: 1.6rem;
    font-weight: 800;
    color: #15803d;
    font-variant-numeric: tabular-nums;
    line-height: 1;
}
.ksk-lbl { color: #7a7060; font-size: 0.85rem; }
.ksk-pills { display: flex; gap: 6px; margin-left: auto; flex-wrap: wrap; }
.ksk-pill {
    padding: 3px 9px;
    border-radius: 999px;
    font-size: 0.74rem;
    font-weight: 600;
    border: 1px solid transparent;
    font-variant-numeric: tabular-nums;
}
.ksk-pill-done   { background: rgba(22,163,74,.08);  color: #15803d; border-color: rgba(22,163,74,.2); }
.ksk-pill-cancel { background: rgba(220,38,38,.08);  color: #b91c1c; border-color: rgba(220,38,38,.2); }
.ksk-pill-noshow { background: rgba(217,119,6,.08);  color: #92400e; border-color: rgba(217,119,6,.2); }
.ksk-pill-total  { background: #f0ece5; color: #7a7060; border-color: #e5e0d8; }

.kakt-st-row { display: flex; gap: 4px; }
.kakt-st-btn {
    width: 28px;
    height: 26px;
    border: 1px solid var(--color-border, #e5e0d8);
    border-radius: 5px;
    background: #fff;
    cursor: pointer;
    font-size: 0.85rem;
    font-weight: 700;
    color: #a89e90;
    line-height: 1;
    padding: 0;
    transition: all .12s;
}
.kakt-st-btn:hover { background: #faf8f5; }
.kakt-st-btn.st-done.is-active   { background: #16a34a; border-color: #16a34a; color: #fff; }
.kakt-st-btn.st-cancel.is-active { background: #dc2626; border-color: #dc2626; color: #fff; }
.kakt-st-btn.st-noshow.is-active { background: #d97706; border-color: #d97706; color: #fff; }

/* INFO-Pille für Erst-Termine (aus Tagesplan-Neukunde/BAS/FES angelegt) */
.kakt-info-pill {
    display: inline-block;
    background: #eef2ff;
    color: #4338ca;
    border: 1px solid #c7d2fe;
    border-radius: 4px;
    padding: 1px 5px;
    font-size: 0.6rem;
    font-weight: 800;
    letter-spacing: 0.5px;
    margin-left: 4px;
    vertical-align: middle;
}
.kakt-sz-info td:first-child { white-space: nowrap; }

/* Kurs-Pille (K1..K4, KA, KD, KKT, KV) in der Sitzungs-Tabelle */
.kakt-kurs-pill {
    display: inline-block;
    background: #fef3c7;
    color: #713f12;
    border: 1px solid #fcd34d;
    border-radius: 4px;
    padding: 1px 5px;
    font-size: 0.6rem;
    font-weight: 800;
    letter-spacing: 0.5px;
    margin-left: 4px;
    vertical-align: middle;
}
.kakt-sz-kurs td:first-child { white-space: nowrap; }

/* Einzelpfad-Pille (ED1, ED2, ET1..ET4, EA1, EA2) */
.kakt-einzel-pill {
    display: inline-block;
    background: #ede9fe;
    color: #4c1d95;
    border: 1px solid #c4b5fd;
    border-radius: 4px;
    padding: 1px 5px;
    font-size: 0.6rem;
    font-weight: 800;
    letter-spacing: 0.5px;
    margin-left: 4px;
    vertical-align: middle;
}
.kakt-kurs-monat {
    display: inline-block;
    padding: 3px 9px;
    background: #fef3c7;
    color: #713f12;
    border: 1px solid #fcd34d;
    border-radius: 5px;
    font-size: 0.78rem;
    font-weight: 600;
    font-variant-numeric: tabular-nums;
}

/* ── Kurse-Reiter (Matrix-Layout) ──────────────────────── */
.kurse-toolbar {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 14px;
    flex-wrap: wrap;
}
.kurse-monatnav {
    display: flex;
    align-items: center;
    gap: 6px;
    background: var(--color-bg-card, #fff);
    border: 1px solid var(--color-border, #e5e0d8);
    border-radius: 999px;
    padding: 3px 6px;
}
.kurse-nav-btn {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    border: none;
    background: transparent;
    cursor: pointer;
    color: #1c1c1c;
    font-size: 0.85rem;
    transition: background .12s;
}
.kurse-nav-btn:hover:not(:disabled) { background: #f0ece5; }
.kurse-nav-btn:disabled { opacity: 0.35; cursor: not-allowed; }
.kurse-monatsel {
    border: none;
    background: transparent;
    font-weight: 700;
    font-size: 0.92rem;
    color: #1c1c1c;
    cursor: pointer;
    outline: none;
    padding: 4px 8px;
    font-variant-numeric: tabular-nums;
}

/* Matrix-Reihen */
.kurs-block-row {
    margin-bottom: 14px;
}
.kurs-block-label {
    font-size: 0.78rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: #5c5346;
    margin-bottom: 8px;
    padding-left: 4px;
}
.kurs-block-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 10px;
}
@media (max-width: 1100px) {
    .kurs-block-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
    .kurs-block-grid { grid-template-columns: 1fr; }
}

.kurs-cell {
    background: var(--color-bg-card, #fff);
    border: 1px solid var(--color-border, #e5e0d8);
    border-radius: 10px;
    overflow: hidden;
    box-shadow: 0 1px 2px rgba(0,0,0,.03);
    display: flex;
    flex-direction: column;
}
.kurs-cell-hdr {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 7px 12px;
    font-weight: 700;
    font-size: 0.85rem;
    border-bottom: 1px solid var(--color-border-light, #f0ece5);
    background: #faf8f5;
}
.kurs-cell-pin { opacity: .7; }
/* Header-Akzentfarbe pro Standort */
.kurs-cell-hdr.kurs-standort-dessau { background: #eef2ff; color: #4338ca; }
.kurs-cell-hdr.kurs-standort-zerbst { background: #ecfdf5; color: #047857; }
.kurs-cell-hdr.kurs-standort-burg   { background: #fdf2f8; color: #9d174d; }
.kurs-cell-hdr.kurs-standort-kothen,
.kurs-cell-hdr.kurs-standort-köthen { background: #fef3c7; color: #92400e; }

/* Header-Date + Edit-Button */
.kurs-cell-datum {
    margin-left: auto;
    font-size: 0.72rem;
    font-weight: 600;
    font-variant-numeric: tabular-nums;
    opacity: .9;
}
.kurs-cell-datum.is-moved {
    background: #fef3c7;
    color: #92400e;
    border: 1px solid #fcd34d;
    padding: 1px 6px;
    border-radius: 4px;
}
.kurs-cell-edit {
    width: 22px;
    height: 22px;
    border: none;
    background: transparent;
    cursor: pointer;
    color: inherit;
    opacity: .55;
    border-radius: 4px;
    font-size: 0.78rem;
    line-height: 1;
    padding: 0;
    margin-left: 4px;
    transition: opacity .12s, background .12s;
}
.kurs-cell-edit:hover { opacity: 1; background: rgba(0,0,0,.06); }

/* Inline-Form zum Verschieben */
.kurs-cell-editdate {
    padding: 9px 12px;
    background: #faf8f5;
    border-bottom: 1px solid var(--color-border-light, #f0ece5);
    display: flex;
    align-items: flex-end;
    gap: 8px;
    flex-wrap: wrap;
}
.kurs-cell-editdate label {
    display: flex;
    flex-direction: column;
    gap: 3px;
    font-size: 0.7rem;
    font-weight: 600;
    color: #7a7060;
}
.kurs-cell-editdate input {
    padding: 4px 8px;
    border: 1px solid #d4cdc0;
    border-radius: 5px;
    font-size: 0.82rem;
    background: #fff;
    color: #1c1c1c;
    font-variant-numeric: tabular-nums;
}
.kurs-cell-editdate input:focus { outline: none; border-color: #2563eb; }
.kurs-cell-editbtns { display: flex; gap: 4px; align-items: center; }
.kurs-reset-btn {
    background: #fff;
    color: #5c5346;
    border: 1px solid #d4cdc0;
    font-size: 0.7rem !important;
    padding: 3px 7px !important;
}
.kurs-reset-btn:hover { background: #f0ece5; }

/* Sub-Block (ein Kurs pro Standort) */
.kurs-sub {
    padding: 9px 12px;
    border-bottom: 1px solid var(--color-border-light, #f0ece5);
}
.kurs-sub:last-child { border-bottom: none; }

.kurs-sub-hdr {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 6px;
}
.kurs-sub-typ {
    display: inline-block;
    padding: 2px 9px;
    border-radius: 5px;
    font-weight: 800;
    font-size: 0.78rem;
    letter-spacing: .4px;
}
.kurs-sub-cnt {
    font-size: 0.72rem;
    font-weight: 700;
    color: #7a7060;
    background: #f0ece5;
    padding: 1px 7px;
    border-radius: 999px;
    font-variant-numeric: tabular-nums;
}
.kurs-sub-empty {
    color: #d4cdc0;
    font-size: 0.74rem;
    font-style: italic;
    padding: 4px 0;
    text-align: center;
}
.kurs-sub-tnlist { display: flex; flex-direction: column; gap: 3px; margin-bottom: 6px; }

/* Teilnehmer-Zeile */
.kurs-tn {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 4px 6px;
    border: 1px solid var(--color-border-light, #f0ece5);
    border-radius: 5px;
    background: #fff;
    transition: border-color .12s, background .12s;
}
.kurs-tn.status-absolviert       { border-color: rgba(22,163,74,.35); background: rgba(22,163,74,.04); }
.kurs-tn.status-abgesagt         { border-color: rgba(220,38,38,.35); background: rgba(220,38,38,.04); }
.kurs-tn.status-nicht_erschienen { border-color: rgba(217,119,6,.35); background: rgba(217,119,6,.04); }

.kurs-tn-name {
    flex: 1;
    font-size: 0.78rem;
    color: #1c1c1c;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    min-width: 0;
}
.kurs-tn-name.is-ohneakte {
    color: #7a7060;
    font-style: italic;
}
.kurs-tn-akte {
    text-decoration: none;
    color: #7a7060;
    font-size: 0.85rem;
    padding: 1px 4px;
    border-radius: 4px;
}
.kurs-tn-akte:hover { background: #f0ece5; color: #1c1c1c; }
.kurs-tn-ohneakte { color: #d4cdc0; font-size: 1rem; padding: 0 4px; }

.kurs-tn-buttons { display: flex; align-items: center; gap: 2px; }
.kurs-tn-st {
    width: 22px;
    height: 20px;
    border: 1px solid var(--color-border, #e5e0d8);
    border-radius: 4px;
    background: #fff;
    cursor: pointer;
    font-size: 0.72rem;
    font-weight: 700;
    color: #a89e90;
    line-height: 1;
    padding: 0;
    transition: all .12s;
}
.kurs-tn-st:hover { background: #faf8f5; }
.kurs-tn-absolviert.is-active       { background: #16a34a; border-color: #16a34a; color: #fff; }
.kurs-tn-abgesagt.is-active         { background: #dc2626; border-color: #dc2626; color: #fff; }
.kurs-tn-nicht_erschienen.is-active { background: #d97706; border-color: #d97706; color: #fff; }
.kurs-tn-x {
    width: 20px;
    height: 20px;
    border: none;
    background: transparent;
    cursor: pointer;
    color: #d4cdc0;
    font-size: 0.95rem;
    line-height: 1;
    padding: 0;
    border-radius: 4px;
    margin-left: 2px;
}
.kurs-tn-x:hover { background: #fee2e2; color: #dc2626; }

/* Add-Button + Picker */
.kurs-add {
    width: 100%;
    padding: 5px 8px;
    border: 1px dashed #d4cdc0;
    border-radius: 5px;
    background: transparent;
    color: #7a7060;
    font-size: 0.74rem;
    font-weight: 600;
    cursor: pointer;
    transition: all .12s;
}
.kurs-add:hover { border-color: #1c1c1c; color: #1c1c1c; background: #faf8f5; }

.kurs-picker {
    border: 1px solid #d4cdc0;
    border-radius: 6px;
    background: #faf8f5;
    padding: 6px;
}
.kurs-picker-hdr { display: flex; align-items: center; gap: 4px; margin-bottom: 5px; }
.kurs-picker-search {
    flex: 1;
    padding: 4px 8px;
    border: 1px solid #d4cdc0;
    border-radius: 5px;
    font-size: 0.78rem;
    background: #fff;
}
.kurs-picker-close {
    width: 22px; height: 22px;
    border: none;
    background: transparent;
    cursor: pointer;
    color: #7a7060;
    font-size: 0.95rem;
    border-radius: 4px;
}
.kurs-picker-close:hover { background: #fee2e2; color: #dc2626; }
.kurs-picker-list {
    display: flex;
    flex-direction: column;
    gap: 2px;
    max-height: 200px;
    overflow-y: auto;
    margin-bottom: 6px;
}
.kurs-picker-item {
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 0.78rem;
    cursor: pointer;
    background: #fff;
}
.kurs-picker-item:hover { background: #eef2ff; color: #4338ca; }
.kurs-picker-empty {
    padding: 6px 8px;
    font-size: 0.74rem;
    color: #a89e90;
    font-style: italic;
    text-align: center;
}
.kurs-picker-divider {
    font-size: 0.7rem;
    color: #a89e90;
    text-transform: uppercase;
    letter-spacing: .5px;
    text-align: center;
    margin: 4px 0 4px;
    font-weight: 700;
}
.kurs-picker-noakte {
    display: flex;
    gap: 4px;
}
.kurs-picker-name {
    flex: 1;
    padding: 4px 8px;
    border: 1px solid #d4cdc0;
    border-radius: 4px;
    font-size: 0.78rem;
    background: #fff;
}

/* Standort-Badge auf der Kurs-Karte */
.kurs-standort-badge {
    display: inline-block;
    margin-left: 6px;
    padding: 2px 8px;
    font-size: 0.7rem;
    font-weight: 600;
    border-radius: 999px;
    background: #f0ece5;
    color: #5c5346;
    border: 1px solid #e5e0d8;
    vertical-align: middle;
}
.kurs-standort-dessau { background: #eef2ff; color: #4338ca; border-color: #c7d2fe; }
.kurs-standort-zerbst { background: #ecfdf5; color: #047857; border-color: #a7f3d0; }
.kurs-standort-köthen,
.kurs-standort-kothen { background: #fef3c7; color: #92400e; border-color: #fcd34d; }
.kurs-standort-burg   { background: #fdf2f8; color: #9d174d; border-color: #fbcfe8; }

/* Standort-Pillen im Formular: ein bisschen weniger dominant als K-Typ */
.kurs-standort-pill { font-weight: 600; }
.kurse-empty {
    text-align: center;
    padding: 40px 16px;
    color: #5c5346;
    background: var(--color-bg-card, #fff);
    border: 1px solid var(--color-border, #e5e0d8);
    border-radius: 10px;
}
.kurs-card {
    background: var(--color-bg-card, #fff);
    border: 1px solid var(--color-border, #e5e0d8);
    border-radius: 10px;
    margin-bottom: 10px;
    overflow: hidden;
    box-shadow: 0 1px 2px rgba(0,0,0,.03);
}
.kurs-header {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 12px 16px;
    cursor: pointer;
    transition: background .12s;
}
.kurs-header:hover { background: rgba(0,0,0,.02); }
.kurs-badge {
    width: 44px;
    height: 44px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    font-size: 1rem;
    letter-spacing: .5px;
    flex-shrink: 0;
}
.kurs-badge-k1 { background: #fef3c7; color: #713f12; border: 1px solid #fcd34d; }
.kurs-badge-k2 { background: #ddd6fe; color: #4c1d95; border: 1px solid #a78bfa; }
.kurs-badge-k3 { background: #bae6fd; color: #075985; border: 1px solid #38bdf8; }
.kurs-badge-k4 { background: #d1fae5; color: #064e3b; border: 1px solid #34d399; }

.kurs-title { flex: 1; min-width: 0; }
.kurs-name {
    font-weight: 600;
    color: #1c1c1c;
    font-size: 0.92rem;
    margin-bottom: 2px;
}
.kurs-meta {
    font-size: 0.78rem;
    color: #7a7060;
    font-variant-numeric: tabular-nums;
}
.kurs-stats {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    line-height: 1.1;
    margin-right: 6px;
}
.kurs-stat-num {
    font-weight: 800;
    font-size: 1rem;
    color: #15803d;
    font-variant-numeric: tabular-nums;
}
.kurs-stat-lbl {
    font-size: 0.65rem;
    color: #a89e90;
    text-transform: uppercase;
    letter-spacing: .4px;
}
.kurs-actions { display: flex; align-items: center; gap: 6px; }
.kurs-del-btn {
    background: #fef2f2;
    color: #dc2626;
    border: 1px solid #fecaca;
    padding: 3px 7px !important;
    font-size: 0.72rem !important;
}
.kurs-del-btn:hover { background: #fee2e2; }
.kurs-chevron {
    color: #a89e90;
    font-size: 0.85rem;
    transition: transform .15s;
    padding: 0 4px;
}
.kurs-card.is-open .kurs-chevron { transform: rotate(180deg); }

.kurs-detail {
    padding: 12px 16px 14px;
    background: var(--color-bg-page, #faf8f5);
    border-top: 1px solid var(--color-border-light, #f0ece5);
}
.kurs-detail-grid {
    display: grid;
    grid-template-columns: 1fr 280px;
    gap: 14px;
}
@media (max-width: 900px) {
    .kurs-detail-grid { grid-template-columns: 1fr; }
}

.kurs-sub-hdr {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 8px;
    padding-bottom: 6px;
    border-bottom: 1px solid var(--color-border-light, #f0ece5);
}
.kurs-sub-hdr h4 {
    margin: 0;
    font-size: 0.85rem;
    font-weight: 700;
    color: #1c1c1c;
}
.kurs-count-pill {
    background: #f0ece5;
    color: #7a7060;
    padding: 2px 8px;
    border-radius: 999px;
    font-size: 0.7rem;
    font-weight: 700;
}
.kurs-empty-sm {
    color: #a89e90;
    font-size: 0.8rem;
    padding: 12px 4px;
    text-align: center;
}

.kurs-teilnehmer-row {
    background: #fff;
    border: 1px solid var(--color-border, #e5e0d8);
    border-radius: 8px;
    padding: 10px 12px;
    margin-bottom: 8px;
}
.kurs-teilnehmer-row.status-absolviert       { border-color: rgba(22,163,74,.35); background: rgba(22,163,74,.04); }
.kurs-teilnehmer-row.status-abgesagt         { border-color: rgba(220,38,38,.35); background: rgba(220,38,38,.04); }
.kurs-teilnehmer-row.status-nicht_erschienen { border-color: rgba(217,119,6,.35); background: rgba(217,119,6,.04); }

.ktr-head { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
.ktr-name { flex: 1; color: #1c1c1c; font-size: 0.92rem; }
.ktr-akte {
    text-decoration: none;
    color: #7a7060;
    padding: 2px 6px;
    border-radius: 4px;
}
.ktr-akte:hover { background: #f0ece5; color: #1c1c1c; }
.ktr-remove {
    border: none;
    background: transparent;
    color: #a89e90;
    font-size: 1.05rem;
    cursor: pointer;
    padding: 0 6px;
    border-radius: 4px;
}
.ktr-remove:hover { background: #fee2e2; color: #dc2626; }
.ktr-notiz {
    width: 100%;
    margin-top: 8px;
    padding: 5px 8px;
    border: 1px solid #d4cdc0;
    border-radius: 5px;
    font-size: 0.82rem;
    box-sizing: border-box;
}
.ktr-notiz:focus { outline: none; border-color: #2563eb; }

.kurs-pool-search {
    width: 100%;
    padding: 7px 10px;
    border: 1px solid var(--color-border, #e5e0d8);
    border-radius: 6px;
    font-size: 0.82rem;
    margin-bottom: 6px;
    box-sizing: border-box;
}
.kurs-pool-list {
    display: flex;
    flex-direction: column;
    gap: 2px;
    max-height: 50vh;
    overflow-y: auto;
}
.kurs-pool-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 6px 10px;
    border-radius: 6px;
    cursor: pointer;
    font-size: 0.82rem;
    transition: background .12s;
}
.kurs-pool-item:hover { background: #faf8f5; }
.kurs-pool-add {
    font-size: 0.7rem;
    font-weight: 700;
    width: 18px; height: 18px;
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: 50%;
    background: #f0ece5; color: #7a7060;
}

/* Neuer Kurs / Bearbeiten Formular */
.kurs-form-card {
    background: var(--color-bg-card, #fff);
    border: 1px solid var(--color-border, #e5e0d8);
    border-radius: 10px;
    padding: 14px 16px;
    margin-bottom: 12px;
    box-shadow: 0 1px 4px rgba(0,0,0,.04);
}
.kurs-form-hdr {
    font-weight: 700;
    margin-bottom: 10px;
    color: #1c1c1c;
}
.kurs-form-row {
    display: flex;
    gap: 10px;
    margin-bottom: 10px;
    flex-wrap: wrap;
}
.kurs-form-typ {
    display: flex;
    gap: 6px;
}
.kurs-typ-pill {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 6px 12px;
    border: 1px solid #d4cdc0;
    border-radius: 6px;
    background: #fff;
    cursor: pointer;
    font-weight: 700;
}
.kurs-typ-pill input { accent-color: #1c1c1c; cursor: pointer; }
.kurs-typ-pill:has(input:checked) { background: #1c1c1c; color: #fff; border-color: #1c1c1c; }

.kurs-form-lbl {
    display: flex;
    flex-direction: column;
    gap: 4px;
    font-size: 0.78rem;
    color: #7a7060;
    font-weight: 600;
}
.kurs-form-lbl input {
    padding: 6px 9px;
    border: 1px solid #d4cdc0;
    border-radius: 5px;
    font-size: 0.85rem;
    background: #fff;
    color: #1c1c1c;
}
.kurs-form-lbl input:focus { outline: none; border-color: #2563eb; }

.kurs-form-ta {
    width: 100%;
    padding: 7px 10px;
    border: 1px solid #d4cdc0;
    border-radius: 5px;
    font-size: 0.85rem;
    font-family: inherit;
    resize: vertical;
    box-sizing: border-box;
}
.kurs-form-ta:focus { outline: none; border-color: #2563eb; }

.kurs-form-btns { display: flex; gap: 6px; }

/* ── Heute: Neukunden-Direkt-Buttons (Pool, oben) ─────── */
.heute-newcontact-row {
    display: flex;
    gap: 6px;
    margin-bottom: 8px;
}
.hnc-btn {
    flex: 1;
    padding: 7px 8px;
    border: 1px solid #d4cdc0;
    border-radius: 6px;
    background: #fff;
    cursor: pointer;
    font-size: 0.78rem;
    font-weight: 600;
    color: #5c5346;
    transition: all .12s;
}
.hnc-btn:hover     { background: #faf8f5; }
.hnc-neukunde:hover { color: #4338ca; border-color: #c7d2fe; background: #eef2ff; }
.hnc-bas:hover      { color: #0e7490; border-color: #a5f3fc; background: #ecfeff; }
.hnc-fes:hover      { color: #9d174d; border-color: #fbcfe8; background: #fdf2f8; }

/* Tagesplan-Reihenfolge: Drag-and-Drop mit Handle links */
.heute-entry { position: relative; padding-left: 30px; }
.he-drag-handle {
    position: absolute;
    left: 6px;
    top: 50%;
    transform: translateY(-50%);
    width: 16px;
    color: #a89e90;
    font-size: 0.95rem;
    line-height: 1;
    letter-spacing: -2px;
    cursor: grab;
    user-select: none;
    text-align: center;
    transition: color .12s;
}
.heute-entry:hover .he-drag-handle { color: #5c5346; }
.he-drag-handle:active { cursor: grabbing; }
.heute-entry.is-dragging {
    opacity: 0.45;
    transform: scale(0.98);
}
.heute-entry.drop-before { box-shadow: 0 -3px 0 0 #2563eb inset, 0 -3px 0 0 #2563eb; }
.heute-entry.drop-after  { box-shadow: 0 3px 0 0 #2563eb inset, 0 3px 0 0 #2563eb; }

/* Themen-Feld */
.he-themen-row { margin-bottom: 8px; }
.he-themen {
    width: 100%;
    padding: 5px 9px;
    border: 1px solid #d4cdc0;
    border-radius: 5px;
    font-size: 0.82rem;
    background: rgba(59, 130, 246, 0.04);
    color: #1c1c1c;
    box-sizing: border-box;
}
.he-themen:focus { outline: none; border-color: #2563eb; background: #fff; }
.he-themen::placeholder { color: #a89e90; }

/* Inline Name/Vorname-Felder im Draft-Eintrag */
.he-row1-draft { gap: 6px; flex-wrap: wrap; }
.he-name-input,
.he-vorname-input {
    padding: 5px 9px;
    border: 1px solid #d4cdc0;
    border-radius: 5px;
    font-size: 0.88rem;
    font-weight: 600;
    background: #fff;
    color: #1c1c1c;
    min-width: 0;
}
.he-name-input    { flex: 2; min-width: 130px; }
.he-vorname-input { flex: 1; min-width: 90px; font-weight: 500; }
.he-name-input:focus,
.he-vorname-input:focus { outline: none; border-color: #2563eb; }

/* Draft-Eintrag im Tagesplan */
.heute-entry.is-draft {
    border-style: dashed;
    background: #fffbeb;
}
.heute-entry.is-draft.status-absolviert       { background: rgba(22,163,74,.04); }
.heute-entry.is-draft.status-abgesagt         { background: rgba(220,38,38,.04); }
.heute-entry.is-draft.status-nicht_erschienen { background: rgba(217,119,6,.04); }
.he-kundenart {
    font-size: 0.66rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .5px;
    padding: 2px 7px;
    border-radius: 999px;
    border: 1px solid transparent;
}
.he-ka-neukunde { background: #eef2ff; color: #4338ca; border-color: #c7d2fe; }
.he-ka-bas      { background: #ecfeff; color: #0e7490; border-color: #a5f3fc; }
.he-ka-fes      { background: #fdf2f8; color: #9d174d; border-color: #fbcfe8; }

.he-draft-actions {
    display: flex;
    gap: 6px;
    margin-top: 8px;
    padding-top: 8px;
    border-top: 1px dashed #e5e0d8;
}
.he-draft-save {
    background: #16a34a;
    color: #fff;
    border: 1px solid #16a34a;
    font-weight: 600;
}
.he-draft-save:hover { background: #15803d; border-color: #15803d; }
.he-draft-discard {
    background: #fff;
    color: #dc2626;
    border: 1px solid #fca5a5;
    font-weight: 600;
}
.he-draft-discard:hover { background: #fee2e2; }

/* ========================================================================
   REFRESH 2026-06 – fehlende Komponenten + globaler Feinschliff
   (rein additiv, am Dateiende; bei Bedarf als Block entfernbar)
   ======================================================================== */

/* ── Dashboard: Karteninhalte (waren zuvor unstilisiert) ── */
.dash-card-body { padding: 6px 22px 20px; }
.dash-card-body .loading-spinner { padding: 28px; }

.dash-link {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--color-text-secondary);
    transition: color var(--transition-fast);
    white-space: nowrap;
}
.dash-link:hover { color: var(--color-accent); }

/* Heutige Termine */
.appt-item {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 12px 0;
    border-bottom: 1px solid var(--color-border-light);
}
.appt-item:last-child { border-bottom: none; }
.appt-time {
    font-weight: 700;
    font-variant-numeric: tabular-nums;
    color: var(--color-accent);
    font-size: 0.9rem;
    min-width: 42px;
}
.appt-info { flex: 1; min-width: 0; }
.appt-title {
    font-weight: 600;
    font-size: 0.9rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.appt-meta { font-size: 0.8rem; color: var(--color-text-secondary); margin-top: 2px; }

/* Neueste Klienten (Mini-Liste) */
.mini-table { display: flex; flex-direction: column; }
.mini-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 0;
    border-bottom: 1px solid var(--color-border-light);
}
.mini-row:last-child { border-bottom: none; }
.mini-row-info { flex: 1; min-width: 0; }
.mini-name {
    font-weight: 600;
    font-size: 0.875rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.mini-meta { font-size: 0.78rem; color: var(--color-text-secondary); margin-top: 1px; }

/* Zahlungen-Übersicht */
.pay-summary { display: flex; flex-direction: column; gap: 10px; }
.pay-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.875rem;
    color: var(--color-text-secondary);
}
.pay-val { font-weight: 700; font-variant-numeric: tabular-nums; color: var(--color-text-primary); }
.pay-green { color: var(--color-success); }
.pay-red   { color: var(--color-danger); }

/* Fortschrittsbalken */
.progress-section { display: flex; align-items: center; gap: 12px; margin-top: 8px; }
.progress-section.compact { margin-top: 14px; }
.progress-track {
    flex: 1;
    height: 8px;
    background: var(--color-bg-secondary);
    border-radius: var(--radius-full);
    overflow: hidden;
}
.progress-bar-fill {
    height: 100%;
    background: var(--color-success);
    border-radius: var(--radius-full);
    transition: width 0.7s cubic-bezier(0.4, 0, 0.2, 1);
}
.progress-pct {
    font-size: 0.8rem;
    font-weight: 700;
    color: var(--color-text-secondary);
    font-variant-numeric: tabular-nums;
    min-width: 38px;
    text-align: right;
}

/* Einheitlicher leerer Zustand (Kurzform) */
.empty-text {
    text-align: center;
    color: var(--color-text-muted);
    padding: 28px 16px;
    font-size: 0.875rem;
}

/* Kleiner Spinner (KPI-Ladezustand) */
.spinner-small {
    width: 18px;
    height: 18px;
    border: 2px solid var(--color-border);
    border-top-color: var(--color-accent);
    border-radius: 50%;
    animation: spin 0.9s linear infinite;
}
.kpi-card.loading { justify-content: center; }

/* ── Fehlende Formular-Klassen (Rechner) ── */
.form-label {
    display: block;
    font-size: 0.8rem;
    font-weight: 600;
    margin-bottom: 6px;
    color: var(--color-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.form-input,
.form-select {
    width: 100%;
    padding: 10px 14px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: var(--color-bg-page);
    font-size: 0.9rem;
    outline: none;
    transition: all var(--transition-fast);
    color: var(--color-text-primary);
}
.form-input:focus,
.form-select:focus {
    border-color: var(--color-accent);
    background: white;
    box-shadow: 0 0 0 3px var(--color-accent-light);
}

/* ── Fehlende Button-/Badge-/Link-Varianten ── */
.btn-ghost {
    background: transparent;
    color: var(--color-text-secondary);
}
.btn-ghost:hover {
    background: var(--color-bg-page);
    color: var(--color-text-primary);
}
.pill-gold { background: rgba(180, 130, 30, 0.12); color: #9a6b12; }
.upload-link {
    color: var(--color-accent);
    font-weight: 600;
    cursor: pointer;
    text-decoration: underline;
    text-underline-offset: 2px;
}
.upload-link:hover { color: var(--color-accent-hover); }

/* Primärer „+ Neuer Plan"-Tab (Ratenzahler) – statt Inline-Style */
.tab-btn.tab-cta {
    margin-left: auto;
    background: var(--color-accent);
    color: #fff;
    border-radius: var(--radius-md);
    font-weight: 600;
}
.tab-btn.tab-cta:hover { background: var(--color-accent-hover); color: #fff; }

/* ── Tagesplan an die warme Palette angleichen (war kühles Slate-Grau) ── */
.heute-datelabel,
.heute-section-hdr h3,
.he-name { color: var(--color-text-primary); }
.heute-count {
    background: var(--color-bg-secondary);
    color: var(--color-text-secondary);
}
.heute-empty,
.heute-empty-sm { color: var(--color-text-muted); }
.heute-pool-item:hover { background: var(--color-bg-card-hover); }
.heute-pool-item.is-added,
.heute-pool-item.is-added:hover { color: var(--color-success); }
.hpi-add { background: var(--color-bg-secondary); color: var(--color-text-secondary); }
.heute-search:focus {
    border-color: var(--color-accent);
    outline: none;
    box-shadow: 0 0 0 3px var(--color-accent-light);
}
/* Karten & Toolbar: weicher Radius + dezenter Schatten wie im übrigen Portal */
.heute-toolbar,
.heute-plan,
.heute-pool { border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); }
.heute-datepicker,
.heute-search { border-radius: var(--radius-md); }
.heute-entry { border-radius: var(--radius-md); transition: border-color 0.15s, background 0.15s, box-shadow 0.15s; }
.heute-entry:hover { border-color: #c8c2b8; box-shadow: var(--shadow-sm); }

/* Termin direkt aus der Tagesplan-Karte planen */
.he-plan-row {
    display: flex;
    gap: 8px;
    align-items: center;
    margin-top: 8px;
    flex-wrap: wrap;
}
.he-plan-row select {
    padding: 7px 10px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: #fff;
    font-size: 0.82rem;
    color: var(--color-text-primary);
}
.he-plan-row .he-plan-standort { flex: 0 0 auto; max-width: 150px; }
.he-plan-row .he-plan-termin { flex: 1; min-width: 150px; }
.he-plan-btn {
    flex: 0 0 auto;
    background: var(--color-accent);
    color: #fff;
    white-space: nowrap;
}
.he-plan-btn:hover { background: var(--color-accent-hover); }
.he-plan-btn:disabled { opacity: 0.6; cursor: default; }

/* ── Globaler Feinschliff (spürbares Refresh) ── */
/* Sanftes Anheben interaktiver Karten */
.kpi-card,
.detail-card,
.dash-card {
    transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}
.kpi-card:hover,
.detail-card:hover,
.dash-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}

/* KPI-Icon mit dezentem Marken-Akzent */
.kpi-icon { background: var(--color-accent-light); color: var(--color-accent); }

/* Buttons: minimaler Hover-Lift */
.btn-primary:hover { transform: translateY(-1px); }
.btn-outline:hover,
.btn-secondary:hover { transform: translateY(-1px); }

/* Sichtbarer Tastatur-Fokus (Barrierefreiheit) */
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
.nav-item:focus-visible,
.filter-tab:focus-visible {
    outline: 2px solid var(--color-accent);
    outline-offset: 2px;
    border-radius: var(--radius-sm);
}

/* Dashboard & Tabellen auf Tablet/Mobil */
@media (max-width: 900px) {
    .dashboard-grid { grid-template-columns: 1fr; }
    .dash-card.span-2 { grid-column: auto; }
    .app-content { padding: 24px 18px; }
    .data-table { display: block; overflow-x: auto; }
}

