/* ============================================================
   Love Überdachungen GmbH - Internes System
   Corporate Identity Stylesheet – Modern Professional Design
   ============================================================ */

/* ---- Variablen ---- */
:root {
    --farbe-primaer:       #1565c0;   /* Dunkelblau – Primäraktionen */
    --farbe-primaer-hover: #0d47a1;   /* Noch dunkleres Blau */
    --farbe-rot:           #E30613;   /* Love-Rot – nur sparsam */
    --farbe-rot-hover:     #c00510;
    --farbe-sekundaer:     #1C1B1A;   /* Fast Schwarz */
    --farbe-hintergrund:   #f0f2f5;   /* Kühles Helles Grau */
    --farbe-weiss:         #ffffff;
    --farbe-text:          #1C1B1A;
    --farbe-text-schwach:  #6b7280;
    --farbe-rahmen:        #e2e5ea;   /* Kühleres Grau */
    --farbe-fehler:        #E30613;
    --farbe-warnung:       #f59e0b;
    --farbe-erfolg:        #43a047;
    --farbe-info:          #1565c0;
    --farbe-sidebar:       #1C1B1A;
    --farbe-sidebar-hover: #2a2928;
    --farbe-sidebar-text:  #b0b0b0;
    --schatten-klein:  0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);
    --schatten-mittel: 0 4px 6px rgba(0,0,0,.05), 0 2px 4px rgba(0,0,0,.03);
    --schatten-gross:  0 10px 25px rgba(0,0,0,.1);
    --radius-klein:  6px;
    --radius-mittel: 8px;
    --radius-gross:  12px;
    --sidebar-breite: 240px;
}

/* ---- Reset & Basis ---- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { font-size: 15px; scroll-behavior: smooth; }

body {
    font-family: 'Segoe UI', system-ui, -apple-system, sans-serif;
    background: var(--farbe-hintergrund);
    color: var(--farbe-text);
    line-height: 1.5;
}

a { color: var(--farbe-primaer); text-decoration: none; }
a:hover { text-decoration: underline; color: var(--farbe-primaer-hover); }

img { max-width: 100%; }

/* ============================================================
   LOGIN-SEITE
   ============================================================ */
.login-seite {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #1C1B1A 0%, #2a2928 50%, #1C1B1A 100%);
}

.login-box {
    background: var(--farbe-weiss);
    border-radius: var(--radius-gross);
    padding: 2.5rem;
    width: 100%;
    max-width: 400px;
    box-shadow: var(--schatten-gross);
    border-top: 4px solid var(--farbe-rot);
}

.login-logo {
    text-align: center;
    margin-bottom: 2rem;
}

.login-logo img {
    height: 60px;
    margin-bottom: 1rem;
}

.login-logo h1 {
    font-size: 1.4rem;
    color: var(--farbe-sekundaer);
    font-weight: 700;
}

.login-logo p {
    color: var(--farbe-text-schwach);
    font-size: 0.875rem;
}

/* ============================================================
   LAYOUT - Sidebar + Inhalt
   ============================================================ */
.app-layout {
    display: flex;
    min-height: 100vh;
}

/* ---- Sidebar ---- */
.sidebar {
    width: var(--sidebar-breite);
    background: var(--farbe-sidebar);
    color: var(--farbe-sidebar-text);
    display: flex;
    flex-direction: column;
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    z-index: 100;
    overflow-y: auto;
    transition: transform 0.3s ease;
}

.sidebar-logo {
    padding: 1.25rem 1.25rem;
    border-bottom: 1px solid rgba(255,255,255,.08);
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.sidebar-logo img {
    height: 36px;
    width: auto;
    border-radius: 4px;
}

.sidebar-logo-text span {
    display: block;
    font-weight: 700;
    font-size: 0.95rem;
    color: #fff;
    line-height: 1.2;
}

.sidebar-logo-text small {
    font-size: 0.65rem;
    color: rgba(255,255,255,.4);
}

.sidebar-nav {
    flex: 1;
    padding: 1rem 0;
}

.nav-gruppe {
    margin-bottom: 0.5rem;
}

.nav-gruppe-titel {
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: #707070;
    padding: 0.75rem 1.25rem 0.25rem;
    font-weight: 600;
}

.nav-link {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.6rem 1.25rem;
    color: #b0b0b0;
    font-size: 0.875rem;
    border-left: 3px solid transparent;
    transition: background .15s, border-color .15s, color .15s;
    cursor: pointer;
    text-decoration: none;
}

.nav-link:hover {
    background: var(--farbe-sidebar-hover);
    color: #e0e0e0;
    text-decoration: none;
}

.nav-link.aktiv {
    background: var(--farbe-sidebar-hover);
    border-left-color: var(--farbe-rot);
    color: #fff;
}

.nav-link svg {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    opacity: 0.5;
}

.nav-link:hover svg { opacity: 0.8; }
.nav-link.aktiv svg { opacity: 1; }

/* Sidebar Footer - Benutzerinfo */
.sidebar-benutzer {
    padding: 1rem 1.25rem;
    border-top: 1px solid rgba(255,255,255,.08);
    font-size: 0.8rem;
}

.sidebar-benutzer-name {
    font-weight: 600;
    color: #e0e0e0;
    margin-bottom: 0.2rem;
}

.sidebar-benutzer-rolle {
    color: #707070;
    margin-bottom: 0.75rem;
    font-size: 0.75rem;
}

.btn-abmelden {
    width: 100%;
    padding: 0.4rem;
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.1);
    border-radius: var(--radius-klein);
    color: #909090;
    font-size: 0.8rem;
    cursor: pointer;
    transition: background .15s, color .15s;
}

.btn-abmelden:hover {
    background: rgba(255,255,255,.12);
    border-color: rgba(255,255,255,.2);
    color: #d0d0d0;
}

/* ---- Hauptinhalt ---- */
.haupt-inhalt {
    margin-left: var(--sidebar-breite);
    flex: 1;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

/* ---- Kopfzeile ---- */
.kopfzeile {
    background: var(--farbe-weiss);
    padding: 0.75rem 1.5rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    position: sticky;
    top: 0;
    z-index: 50;
    box-shadow: 0 1px 4px rgba(0,0,0,.08);
    border-bottom: 2px solid var(--farbe-rot);
}

.kopfzeile-links {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex: 1;
}

.kopfzeile-logo {
    display: none;
}

.kopfzeile-titel {
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--farbe-text);
    flex: 1;
    text-align: center;
}

.kopfzeile-aktionen {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.kopfzeile-aktionen .text-schwach {
    color: #666;
}

/* ---- Seiteninhalt ---- */
.seiten-inhalt {
    padding: 1.5rem;
    flex: 1;
}

/* ============================================================
   KARTEN
   ============================================================ */
.karte {
    background: var(--farbe-weiss);
    border-radius: var(--radius-mittel);
    box-shadow: var(--schatten-klein);
    border: 1px solid var(--farbe-rahmen);
}

.karte-kopf {
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--farbe-rahmen);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.karte-titel {
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--farbe-text);
}

.karte-inhalt {
    padding: 1.25rem;
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.45rem 1rem;
    border-radius: var(--radius-klein);
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    border: 1px solid transparent;
    transition: background .15s, box-shadow .15s, transform .1s;
    white-space: nowrap;
    text-decoration: none;
    line-height: 1.4;
}

.btn:hover { transform: translateY(-1px); }
.btn:active { transform: translateY(0); }

.btn svg { width: 16px; height: 16px; }

/* Primär-Button: Dunkelblau (Erstellen, Hauptaktion) */
.btn-primaer {
    background: var(--farbe-primaer);
    color: #fff;
    border-color: var(--farbe-primaer);
}
.btn-primaer:hover {
    background: var(--farbe-primaer-hover);
    border-color: var(--farbe-primaer-hover);
    text-decoration: none;
    color: #fff;
}

/* Akzent-Button: Grün */
.btn-akzent {
    background: var(--farbe-erfolg);
    color: #fff;
    border-color: var(--farbe-erfolg);
}
.btn-akzent:hover {
    background: #388e3c;
    border-color: #388e3c;
    text-decoration: none;
    color: #fff;
}

/* Sekundär-Button: Grau-Outline (Abbrechen, Schließen) */
.btn-sekundaer {
    background: var(--farbe-weiss);
    color: var(--farbe-text-schwach);
    border-color: var(--farbe-rahmen);
}
.btn-sekundaer:hover {
    background: var(--farbe-hintergrund);
    color: var(--farbe-text);
    border-color: #ccc;
    text-decoration: none;
}

/* Gefahr-Button: Rot (Deaktivieren etc.) */
.btn-gefahr {
    background: var(--farbe-rot);
    color: #fff;
    border-color: var(--farbe-rot);
}
.btn-gefahr:hover {
    background: var(--farbe-rot-hover);
    border-color: var(--farbe-rot-hover);
    text-decoration: none;
    color: #fff;
}

/* Speichern-Button (Grün) */
.btn-speichern {
    background: #43a047;
    color: #fff;
    border-color: #43a047;
}
.btn-speichern:hover {
    background: #388e3c;
    border-color: #388e3c;
    text-decoration: none;
    color: #fff;
}

/* Löschen-Button (Rot) */
.btn-loeschen {
    background: var(--farbe-rot);
    color: #fff;
    border-color: var(--farbe-rot);
}
.btn-loeschen:hover {
    background: var(--farbe-rot-hover);
    border-color: var(--farbe-rot-hover);
    text-decoration: none;
    color: #fff;
}

/* Bearbeiten-Button (Blau) */
.btn-bearbeiten {
    background: #1565c0;
    color: #fff;
    border-color: #1565c0;
}
.btn-bearbeiten:hover {
    background: #0d47a1;
    border-color: #0d47a1;
    text-decoration: none;
    color: #fff;
}

.btn-klein {
    padding: 0.3rem 0.65rem;
    font-size: 0.8rem;
}

.btn-nur-icon {
    padding: 0.4rem;
    aspect-ratio: 1;
}

/* ============================================================
   FORMULARE
   ============================================================ */
.formular-gruppe {
    margin-bottom: 1rem;
}

.formular-gruppe label {
    display: block;
    font-size: 0.825rem;
    font-weight: 500;
    color: var(--farbe-text);
    margin-bottom: 0.35rem;
}

.formular-gruppe label .pflichtfeld {
    color: var(--farbe-rot);
    margin-left: 2px;
}

.formular-feld {
    width: 100%;
    padding: 0.5rem 0.75rem;
    border: 1px solid var(--farbe-rahmen);
    border-radius: var(--radius-klein);
    font-size: 0.875rem;
    color: var(--farbe-text);
    background: var(--farbe-weiss);
    transition: border-color .15s, box-shadow .15s;
    font-family: inherit;
}

.formular-feld:focus {
    outline: none;
    border-color: var(--farbe-primaer);
    box-shadow: 0 0 0 3px rgba(21,101,192,.1);
}

.formular-feld::placeholder { color: #9ca3af; }

textarea.formular-feld {
    resize: vertical;
    min-height: 80px;
}

select.formular-feld { cursor: pointer; }

.formular-reihe {
    display: grid;
    gap: 1rem;
}

.formular-reihe-2 { grid-template-columns: 1fr 1fr; }
.formular-reihe-3 { grid-template-columns: 1fr 1fr 1fr; }

/* Aliase für .form-* (Schnittliste etc.) */
.form-gruppe { margin-bottom: .75rem; }
.form-label {
    display: block;
    font-size: 0.825rem;
    font-weight: 500;
    color: var(--farbe-text);
    margin-bottom: 0.35rem;
}
.form-feld {
    width: 100%;
    padding: 0.5rem 0.75rem;
    border: 1px solid var(--farbe-rahmen);
    border-radius: var(--radius-klein);
    font-size: 0.875rem;
    color: var(--farbe-text);
    background: var(--farbe-weiss);
    transition: border-color .15s, box-shadow .15s;
    font-family: inherit;
}
.form-feld:focus {
    outline: none;
    border-color: var(--farbe-primaer);
    box-shadow: 0 0 0 3px rgba(21,101,192,.1);
}

.formular-fehler {
    font-size: 0.8rem;
    color: var(--farbe-rot);
    margin-top: 0.25rem;
    display: flex;
    align-items: center;
    gap: 0.25rem;
}

/* ============================================================
   TABELLEN
   ============================================================ */
.tabelle-container {
    overflow-x: auto;
    border-radius: var(--radius-mittel);
    border: 1px solid var(--farbe-rahmen);
}

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

thead {
    background: #f5f7fa;
}

th {
    padding: 0.75rem 1rem;
    text-align: left;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--farbe-text-schwach);
    border-bottom: 2px solid var(--farbe-rahmen);
    white-space: nowrap;
}

td {
    padding: 0.75rem 1rem;
    border-bottom: 1px solid #f0f2f5;
    vertical-align: middle;
}

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

tbody tr:nth-child(even) { background: #f9fafb; }
tbody tr:hover { background: #f0f4ff; }

.tabelle-aktionen {
    display: flex;
    gap: 0.4rem;
    justify-content: flex-end;
}

/* Leere Tabelle */
.tabelle-leer {
    text-align: center;
    padding: 3rem 1rem;
    color: var(--farbe-text-schwach);
}

.tabelle-leer svg {
    width: 48px;
    height: 48px;
    opacity: 0.3;
    margin-bottom: 0.75rem;
}

/* ============================================================
   SUCHE & FILTER
   ============================================================ */
.such-leiste {
    display: flex;
    gap: 0.75rem;
    align-items: center;
    flex-wrap: wrap;
}

.such-eingabe-wrapper {
    position: relative;
    flex: 1;
    min-width: 200px;
}

.such-eingabe-wrapper svg {
    position: absolute;
    left: 0.75rem;
    top: 50%;
    transform: translateY(-50%);
    width: 16px;
    height: 16px;
    color: var(--farbe-text-schwach);
    pointer-events: none;
}

.such-eingabe {
    width: 100%;
    padding: 0.5rem 0.75rem 0.5rem 2.25rem;
    border: 1px solid var(--farbe-rahmen);
    border-radius: var(--radius-klein);
    font-size: 0.875rem;
}

.such-eingabe:focus {
    outline: none;
    border-color: var(--farbe-primaer);
    box-shadow: 0 0 0 3px rgba(21,101,192,.1);
}

/* ============================================================
   BADGES / STATUS-ANZEIGEN
   ============================================================ */
.badge {
    display: inline-flex;
    align-items: center;
    padding: 0.2rem 0.6rem;
    border-radius: 9999px;
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: .02em;
    white-space: nowrap;
}

.badge-gruen   { background: #dcfce7; color: #166534; }
.badge-blau    { background: #dbeafe; color: #1e40af; }
.badge-orange  { background: #ffedd5; color: #9a3412; }
.badge-rot     { background: #fee2e2; color: #991b1b; }
.badge-grau    { background: #f3f4f6; color: #374151; }
.badge-lila    { background: #ede9fe; color: #5b21b6; }

/* Rollen-Badges */
.rolle-admin        { background: #334155; color: #fff; }
.rolle-innendienst  { background: #0e7490; color: #fff; }
.rolle-vertrieb     { background: #0369a1; color: #fff; }
.rolle-versand      { background: #7e22ce; color: #fff; }
.rolle-fertigung    { background: #c2410c; color: #fff; }
.rolle-monteure     { background: #b45309; color: #fff; }
.rolle-aussendienst { background: #1565c0; color: #fff; }

/* ============================================================
   MODAL / DIALOG
   ============================================================ */
.modal-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.4);
    z-index: 200;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}

.modal-overlay.offen {
    display: flex;
}

.modal {
    background: var(--farbe-weiss);
    border-radius: var(--radius-gross);
    box-shadow: var(--schatten-gross);
    width: 100%;
    max-width: 600px;
    max-height: 90vh;
    overflow-y: auto;
    animation: modal-einblenden .2s ease;
}

.modal-gross { max-width: 800px; }

@keyframes modal-einblenden {
    from { opacity: 0; transform: scale(.96) translateY(-10px); }
    to   { opacity: 1; transform: scale(1)  translateY(0); }
}

.modal-kopf {
    padding: 1.25rem 1.5rem;
    border-bottom: 1px solid var(--farbe-rahmen);
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: var(--farbe-weiss);
    color: var(--farbe-text);
    border-radius: var(--radius-gross) var(--radius-gross) 0 0;
}

.modal-titel {
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--farbe-text);
}

.modal-schliessen {
    background: none;
    border: none;
    cursor: pointer;
    padding: 0.25rem;
    color: var(--farbe-text-schwach);
    border-radius: var(--radius-klein);
    line-height: 0;
    transition: background .15s, color .15s;
}

.modal-schliessen:hover {
    background: var(--farbe-hintergrund);
    color: var(--farbe-text);
}
.modal-schliessen svg { width: 20px; height: 20px; }

.modal-koerper { padding: 1.5rem; }

.modal-fusszeile {
    padding: 1rem 1.5rem;
    border-top: 1px solid var(--farbe-rahmen);
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.75rem;
    background: #f9fafb;
    border-radius: 0 0 var(--radius-gross) var(--radius-gross);
}

/* ============================================================
   BENACHRICHTIGUNGEN (Toast)
   ============================================================ */
.toast-container {
    position: fixed;
    bottom: 1.5rem;
    right: 1.5rem;
    z-index: 300;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    max-width: 380px;
}

.toast {
    background: var(--farbe-weiss);
    border-radius: var(--radius-mittel);
    padding: 0.875rem 1rem;
    box-shadow: var(--schatten-gross);
    border-left: 4px solid var(--farbe-info);
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    animation: toast-einblenden .3s ease;
    font-size: 0.875rem;
}

@keyframes toast-einblenden {
    from { opacity: 0; transform: translateX(100%); }
    to   { opacity: 1; transform: translateX(0); }
}

.toast-erfolg  { border-left-color: var(--farbe-erfolg); }
.toast-fehler  { border-left-color: var(--farbe-rot); }
.toast-warnung { border-left-color: var(--farbe-warnung); }

.toast-text { flex: 1; }
.toast-titel { font-weight: 600; margin-bottom: 0.15rem; }
.toast-nachricht { color: var(--farbe-text-schwach); font-size: 0.8rem; }

/* ============================================================
   DASHBOARD - Statistik-Kacheln
   ============================================================ */
.dashboard-kacheln {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.kachel {
    background: var(--farbe-weiss);
    border-radius: var(--radius-mittel);
    padding: 1.25rem;
    box-shadow: var(--schatten-klein);
    border: 1px solid var(--farbe-rahmen);
    border-left: 4px solid var(--farbe-primaer);
}

.kachel-titel {
    font-size: 0.8rem;
    color: var(--farbe-text-schwach);
    text-transform: uppercase;
    letter-spacing: .05em;
    font-weight: 600;
    margin-bottom: 0.5rem;
}

.kachel-wert {
    font-size: 2rem;
    font-weight: 700;
    color: var(--farbe-sekundaer);
    line-height: 1;
}

.kachel-untertitel {
    font-size: 0.75rem;
    color: var(--farbe-text-schwach);
    margin-top: 0.35rem;
}

/* ============================================================
   DOKUMENT-BEREICH
   ============================================================ */
.dokument-typen-tabs {
    display: flex;
    gap: 0.5rem;
    overflow-x: auto;
    padding-bottom: 0.5rem;
    margin-bottom: 1rem;
    border-bottom: 2px solid var(--farbe-rahmen);
}

.dok-tab {
    padding: 0.4rem 0.9rem;
    border-radius: var(--radius-klein);
    font-size: 0.8rem;
    font-weight: 500;
    cursor: pointer;
    white-space: nowrap;
    background: none;
    border: 1px solid var(--farbe-rahmen);
    color: var(--farbe-text-schwach);
    transition: all .15s;
}

.dok-tab:hover { background: var(--farbe-hintergrund); color: var(--farbe-text); }

.dok-tab.aktiv {
    background: var(--farbe-primaer);
    border-color: var(--farbe-primaer);
    color: #fff;
}

.dokument-liste {
    display: grid;
    gap: 0.5rem;
}

.dokument-karte {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.75rem 1rem;
    border: 1px solid var(--farbe-rahmen);
    border-radius: var(--radius-klein);
    background: var(--farbe-weiss);
    transition: box-shadow .15s;
}

.dokument-karte:hover { box-shadow: var(--schatten-klein); }

.dokument-icon {
    width: 36px;
    height: 36px;
    border-radius: var(--radius-klein);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-size: 1.1rem;
}

.dokument-icon.pdf      { background: #fee2e2; color: #dc2626; }
.dokument-icon.bild     { background: #dbeafe; color: #2563eb; }
.dokument-icon.word     { background: #e0f2fe; color: #0369a1; }
.dokument-icon.excel    { background: #dcfce7; color: #16a34a; }
.dokument-icon.sonstig  { background: #f3f4f6; color: #6b7280; }

.dokument-info { flex: 1; min-width: 0; }

.dokument-name {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--farbe-text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.dokument-meta {
    font-size: 0.75rem;
    color: var(--farbe-text-schwach);
    margin-top: 0.15rem;
}

.dokument-aktionen {
    display: flex;
    gap: 0.4rem;
    flex-shrink: 0;
}

/* Upload-Bereich */
.upload-bereich {
    border: 2px dashed var(--farbe-rahmen);
    border-radius: var(--radius-mittel);
    padding: 2rem;
    text-align: center;
    cursor: pointer;
    transition: border-color .15s, background .15s;
}

.upload-bereich:hover, .upload-bereich.drag-over {
    border-color: var(--farbe-primaer);
    background: rgba(21,101,192,.03);
}

.upload-bereich input[type="file"] { display: none; }

.upload-symbol { font-size: 2.5rem; margin-bottom: 0.75rem; }

.upload-text { font-size: 0.875rem; color: var(--farbe-text-schwach); }
.upload-text strong { color: var(--farbe-primaer); }

/* ============================================================
   FREIGABE-PANEL
   ============================================================ */
.freigabe-panel {
    border: 1px solid var(--farbe-rahmen);
    border-radius: var(--radius-mittel);
    overflow: hidden;
}

.freigabe-panel-kopf {
    background: var(--farbe-hintergrund);
    padding: 0.75rem 1rem;
    font-weight: 600;
    font-size: 0.875rem;
    border-bottom: 1px solid var(--farbe-rahmen);
}

.rollen-liste {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    padding: 0.75rem 1rem;
}

.rollen-checkbox {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.4rem 0.75rem;
    border: 1px solid var(--farbe-rahmen);
    border-radius: var(--radius-klein);
    cursor: pointer;
    transition: all .15s;
    font-size: 0.8rem;
    background: var(--farbe-weiss);
}

.rollen-checkbox:has(input:checked) {
    background: var(--farbe-primaer);
    border-color: var(--farbe-primaer);
    color: #fff;
}

.rollen-checkbox input { display: none; }

/* ============================================================
   KALENDER
   ============================================================ */
.kalender-wrapper {
    background: var(--farbe-weiss);
    border-radius: var(--radius-mittel);
    border: 1px solid var(--farbe-rahmen);
    overflow: hidden;
}

.kalender-kopf {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--farbe-rahmen);
    background: var(--farbe-weiss);
}

.kalender-monat {
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--farbe-sekundaer);
}

.kalender-nav {
    display: flex;
    gap: 0.5rem;
}

.kalender-nav-btn {
    background: none;
    border: 1px solid var(--farbe-rahmen);
    border-radius: var(--radius-klein);
    padding: 0.35rem 0.6rem;
    cursor: pointer;
    font-size: 0.875rem;
    transition: background .15s;
}

.kalender-nav-btn:hover { background: var(--farbe-hintergrund); }

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

.kalender-tag-kopf {
    padding: 0.5rem;
    text-align: center;
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--farbe-text-schwach);
    text-transform: uppercase;
    letter-spacing: .05em;
    background: #f5f7fa;
    border-bottom: 1px solid var(--farbe-rahmen);
}

.kalender-tag {
    min-height: 90px;
    border-right: 1px solid #f0f2f5;
    border-bottom: 1px solid #f0f2f5;
    padding: 0.4rem;
    cursor: pointer;
    transition: background .1s;
    position: relative;
}

.kalender-tag:hover { background: #f0f4ff; }

.kalender-tag.anderer-monat { background: #fafafa; }
.kalender-tag.anderer-monat .tag-nummer { color: #d1d5db; }

.kalender-tag.heute { background: #e8f0fe; }
.kalender-tag.heute .tag-nummer {
    background: var(--farbe-primaer);
    color: #fff;
    border-radius: 50%;
    width: 22px;
    height: 22px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.tag-nummer {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--farbe-text);
    margin-bottom: 0.3rem;
    width: 22px;
    height: 22px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.kalender-ereignis {
    font-size: 0.7rem;
    padding: 0.15rem 0.4rem;
    border-radius: 3px;
    margin-bottom: 0.2rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    color: #fff;
    cursor: pointer;
    font-weight: 500;
}

.kalender-ereignis:hover { opacity: .85; }

/* Legende */
.kalender-legende {
    display: flex;
    gap: 1.5rem;
    padding: 0.75rem 1.25rem;
    border-top: 1px solid var(--farbe-rahmen);
    font-size: 0.8rem;
}

.legende-eintrag {
    display: flex;
    align-items: center;
    gap: 0.4rem;
}

.legende-farbe {
    width: 12px;
    height: 12px;
    border-radius: 2px;
}

/* ============================================================
   PAGINATION
   ============================================================ */
.pagination {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    justify-content: center;
    padding: 1rem;
}

.pagination-btn {
    min-width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--farbe-rahmen);
    border-radius: var(--radius-klein);
    background: var(--farbe-weiss);
    cursor: pointer;
    font-size: 0.875rem;
    transition: all .15s;
    padding: 0 0.5rem;
}

.pagination-btn:hover { background: var(--farbe-hintergrund); }
.pagination-btn.aktiv {
    background: var(--farbe-primaer);
    border-color: var(--farbe-primaer);
    color: #fff;
}
.pagination-btn:disabled {
    opacity: .4;
    cursor: default;
}

/* ============================================================
   LADE-ANIMATION
   ============================================================ */
.ladezeichen {
    display: inline-block;
    width: 20px;
    height: 20px;
    border: 2px solid rgba(0,0,0,.08);
    border-top-color: var(--farbe-primaer);
    border-radius: 50%;
    animation: drehen .6s linear infinite;
}

.ladezeichen-gross {
    width: 40px;
    height: 40px;
    border-width: 3px;
}

@keyframes drehen { to { transform: rotate(360deg); } }

.lade-overlay {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 3rem;
    gap: 0.75rem;
    color: var(--farbe-text-schwach);
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 768px) {
    .sidebar {
        transform: translateX(-100%);
    }

    .sidebar.offen {
        transform: translateX(0);
        box-shadow: var(--schatten-gross);
    }

    .haupt-inhalt {
        margin-left: 0;
    }

    .formular-reihe-2,
    .formular-reihe-3 {
        grid-template-columns: 1fr;
    }

    .kalender-tag { min-height: 60px; }
    .kalender-ereignis { display: none; }
    .kalender-tag.hat-ereignisse::after {
        content: '';
        width: 5px;
        height: 5px;
        background: var(--farbe-primaer);
        border-radius: 50%;
        position: absolute;
        bottom: 4px;
        right: 4px;
    }

    .kopfzeile-logo {
        display: none;
    }
}

/* ============================================================
   DIVERSES
   ============================================================ */
.trennlinie { border: none; border-top: 1px solid var(--farbe-rahmen); margin: 1.25rem 0; }

.text-klein    { font-size: 0.8rem; }
.text-schwach  { color: var(--farbe-text-schwach); }
.text-primaer  { color: var(--farbe-primaer); }
.text-fehler   { color: var(--farbe-rot); }
.text-erfolg   { color: var(--farbe-erfolg); }
.text-rechts   { text-align: right; }
.text-mitte    { text-align: center; }

.fett { font-weight: 600; }

.flex          { display: flex; }
.flex-mitte    { display: flex; align-items: center; }
.flex-zwischen { display: flex; align-items: center; justify-content: space-between; }
.luecke-klein  { gap: 0.5rem; }
.luecke-mittel { gap: 1rem; }

.verbergen     { display: none !important; }
.sichtbar      { display: block !important; }

/* Bestätigungs-Dialog */
.bestaetigung-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.4);
    z-index: 400;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}

.bestaetigung-overlay.offen { display: flex; }

.bestaetigung-box {
    background: var(--farbe-weiss);
    border-radius: var(--radius-gross);
    padding: 2rem;
    max-width: 420px;
    width: 100%;
    box-shadow: var(--schatten-gross);
    text-align: center;
}

.bestaetigung-icon {
    font-size: 3rem;
    margin-bottom: 1rem;
}

.bestaetigung-titel {
    font-size: 1.1rem;
    font-weight: 600;
    margin-bottom: 0.5rem;
}

.bestaetigung-text {
    color: var(--farbe-text-schwach);
    margin-bottom: 1.5rem;
    font-size: 0.9rem;
}

.bestaetigung-aktionen {
    display: flex;
    gap: 0.75rem;
    justify-content: center;
}

/* ============================================================
   PROJEKT-STATUS-BADGES
   ============================================================ */
.projekt-status-badge {
    display: inline-block;
    padding: .2rem .55rem;
    border-radius: var(--radius-klein);
    font-size: .72rem;
    font-weight: 600;
    border: 1px solid transparent;
    white-space: nowrap;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
}

.projekt-item {
    border: 1px solid var(--farbe-rahmen);
    border-radius: var(--radius-mittel);
    padding: .875rem 1rem;
    margin-bottom: .5rem;
    background: var(--farbe-weiss);
}

.projekt-item:last-child {
    margin-bottom: 0;
}

.projekt-item-kopf {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .5rem;
    flex-wrap: wrap;
    cursor: pointer;
    user-select: none;
}

.projekt-pfeil {
    color: var(--farbe-text-schwach);
    flex-shrink: 0;
    transition: transform .2s ease;
}

.projekt-item.offen .projekt-pfeil {
    transform: rotate(90deg);
}

.projekt-item-inhalt {
    display: none;
    flex-direction: column;
    gap: .4rem;
    margin-top: .5rem;
}

.projekt-item.offen .projekt-item-inhalt {
    display: flex;
}

.projekt-item-name {
    font-weight: 600;
    font-size: .9rem;
}

.projekt-item-beschreibung {
    font-size: .8rem;
    color: var(--farbe-text-schwach);
}

.projekt-item-aktionen {
    display: flex;
    align-items: center;
    gap: .4rem;
    flex-wrap: wrap;
}

.projekt-status-select {
    font-size: .75rem;
    padding: .2rem .5rem;
    border: 1px solid var(--farbe-rahmen);
    border-radius: var(--radius-klein);
    background: var(--farbe-hintergrund);
    cursor: pointer;
    max-width: 260px;
}

/* ---- Projekt-Notiz-Bereich ---- */
.projekt-notiz-bereich {
    display: flex;
    flex-direction: column;
    gap: .5rem;
    margin-top: .5rem;
    padding-top: .5rem;
    border-top: 1px dashed var(--farbe-rahmen);
}

.projekt-notiz-textarea {
    width: 100%;
    box-sizing: border-box;
    font-size: .8rem;
    font-family: inherit;
    padding: .3rem .5rem;
    border: 1px solid var(--farbe-rahmen);
    border-radius: var(--radius-klein);
    background: var(--farbe-weiss);
    color: var(--farbe-text);
    resize: vertical;
    min-height: 2.4rem;
    max-height: 8rem;
    transition: border-color .15s;
    line-height: 1.4;
}

.projekt-notiz-textarea:focus {
    outline: none;
    border-color: var(--farbe-primaer);
}

/* ---- Status-Kommentar-Bereich (erscheint bei Statuswechsel) ---- */
.projekt-status-kommentar-bereich {
    background: #f0fdf4;
    border: 1px solid #86efac;
    border-radius: var(--radius-klein);
    padding: .6rem .75rem;
    margin-top: .5rem;
}

.projekt-kommentar-input {
    font-size: .8rem !important;
    padding: .3rem .5rem !important;
    height: auto !important;
}

/* ---- Schnittliste: Kunden-Banner ---- */
#kundenBanner {
    background: var(--farbe-primaer) !important;
    border-color: var(--farbe-primaer-hover) !important;
    color: #fff !important;
}

#kundenBanner span,
#kundenBanner strong,
#kundenBanner svg {
    color: #fff !important;
    stroke: #fff !important;
}
