/* ============================================================
   WorkSpace – Hauptstylesheet  (Modern Design als Standard)
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; }

:root {
  --bg:        #f5f5f7;
  --surface:   #ffffff;
  --surface2:  #f5f5f7;
  --border:    rgba(0,0,0,0.08);
  --border-mid:rgba(0,0,0,0.13);
  --primary:   #0071e3;
  --primary-d: #0064cc;
  --text:      #1d1d1f;
  --muted:     #6e6e73;
  --text3:     #aeaeb2;
  --danger:    #ff3b30;
  --success:   #34c759;
  --warn:      #ff9500;
  --header-h:  52px;
  --sidebar-w: 220px;
  --row-h:     46px;
  --month-w:   88px;
  --radius-sm: 8px;
  --radius:    12px;
  --radius-lg: 18px;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.08), 0 1px 2px rgba(0,0,0,0.04);
  --shadow:    0 4px 16px rgba(0,0,0,0.08), 0 1px 4px rgba(0,0,0,0.05);
  --shadow-lg: 0 12px 40px rgba(0,0,0,0.12), 0 2px 8px rgba(0,0,0,0.06);
  --font: -apple-system, BlinkMacSystemFont, 'SF Pro Display', 'Helvetica Neue', sans-serif;
}

body {
  margin: 0;
  font-family: var(--font);
  font-size: 13px;
  color: var(--text);
  background: var(--bg);
  overflow-x: hidden;
}

/* ── Top-Navigation ──────────────────────────────────────── */
#topbar {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: var(--header-h);
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  padding: 0 20px;
  gap: 16px;
  z-index: 200;
  box-shadow: 0 1px 0 rgba(0,0,0,0.08);
}
#topbar .logo {
  display: flex; align-items: center; gap: 10px;
  color: var(--text); font-weight: 700; font-size: 1rem;
  text-decoration: none; letter-spacing: -0.3px;
}
#topbar .logo svg { width: 28px; height: 28px; }
#topbar nav { display: flex; gap: 2px; margin-left: 20px; }
#topbar nav button {
  background: none; border: none; color: var(--muted);
  padding: 6px 14px; border-radius: var(--radius-sm); cursor: pointer;
  font-size: 0.875rem; font-weight: 500; transition: all 0.15s;
  font-family: var(--font);
}
#topbar nav button:hover  { background: rgba(0,0,0,0.05); color: var(--text); }
#topbar nav button.active { background: rgba(0,113,227,0.1); color: var(--primary); font-weight: 600; }
/* Bauleitung-Link im Topbar-Nav */
#topbar nav .nav-bauleitung-btn {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--primary); color: #fff !important; text-decoration: none;
  padding: 6px 14px; border-radius: var(--radius-sm);
  font-size: 0.875rem; font-weight: 600; transition: background 0.15s;
  margin-left: 6px;
}
#topbar nav .nav-bauleitung-btn:hover { background: #0064cc; }
#topbar .spacer { flex: 1; }
#topbar .user-info {
  color: var(--muted); font-size: 0.8rem;
  display: flex; align-items: center; gap: 12px;
}
#topbar .user-info strong { color: var(--text); }
#topbar .btn-logout {
  background: rgba(0,0,0,0.05); border: 1px solid var(--border-mid);
  color: var(--text); padding: 5px 12px; border-radius: var(--radius-sm);
  cursor: pointer; font-size: 0.8rem; transition: background 0.15s;
  font-family: var(--font);
}
#topbar .btn-logout:hover { background: rgba(0,0,0,0.09); }
#topbar .btn-settings {
  background: rgba(0,0,0,0.05); border: none; color: var(--muted);
  padding: 6px 9px; border-radius: var(--radius-sm); cursor: pointer;
  display: flex; align-items: center; transition: background 0.15s;
}
#topbar .btn-settings:hover,
#topbar .btn-settings.active { background: rgba(0,0,0,0.09); color: var(--text); }

/* Avatar */
.topbar-avatar {
  width: 30px; height: 30px; border-radius: 50%;
  background: linear-gradient(135deg, #0071e3, #34aadc);
  display: flex; align-items: center; justify-content: center;
  font-size: 0.75rem; font-weight: 700; color: #fff;
  cursor: pointer; flex-shrink: 0;
}

/* ── Einstellungen-Seite ─────────────────────────────────── */
.settings-nav-btn {
  display: block; width: 100%; text-align: left; padding: 9px 14px;
  border: none; background: none; cursor: pointer; border-radius: var(--radius-sm);
  font-size: 0.875rem; color: var(--muted); transition: all 0.15s;
  margin-bottom: 2px; font-family: var(--font);
}
.settings-nav-btn:hover  { background: rgba(0,0,0,0.04); color: var(--text); }
.settings-nav-btn.active { background: rgba(0,113,227,0.1); color: var(--primary); font-weight: 600; }
.settings-tab { padding: 0; }
.settings-tab .card-header { padding: 16px 24px; border-bottom: 1px solid var(--border); }

/* ── Hauptinhalt ─────────────────────────────────────────── */
#app {
  margin-top: var(--header-h);
  padding: 24px;
  min-height: calc(100vh - var(--header-h));
}

/* ── Seiten ──────────────────────────────────────────────── */
.page { display: none; }
.page.active { display: block; }

/* ── Karten ──────────────────────────────────────────────── */
.card {
  background: var(--surface);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
  overflow: hidden;
  margin-bottom: 20px;
}
.card-header {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 20px;
  border-bottom: 1px solid var(--border);
  background: rgba(0,0,0,0.015);
}
.card-header h2 { margin: 0; font-size: 1rem; font-weight: 600; letter-spacing: -0.2px; }
.card-header .spacer { flex: 1; }

/* ── Buttons ─────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 16px; border-radius: var(--radius-sm);
  font-size: 0.875rem; font-weight: 500;
  border: none; cursor: pointer; transition: all 0.15s;
  text-decoration: none; font-family: var(--font);
}
.btn-primary   { background: var(--primary); color: #fff; }
.btn-primary:hover { background: var(--primary-d); }
.btn-secondary {
  background: rgba(0,0,0,0.05); color: var(--text);
  border: 1px solid var(--border-mid);
}
.btn-secondary:hover { background: rgba(0,0,0,0.09); }
.btn-danger    { background: rgba(255,59,48,0.08); color: var(--danger); border: 1px solid rgba(255,59,48,0.2); }
.btn-danger:hover { background: rgba(255,59,48,0.15); }
.btn-warning   { background: rgba(255,149,0,0.08); color: #b36200; border: 1px solid rgba(255,149,0,0.2); }
.btn-warning:hover { background: rgba(255,149,0,0.14); }
.btn-success   { background: rgba(52,199,89,0.08); color: #1a8a3a; border: 1px solid rgba(52,199,89,0.2); }
.btn-success:hover { background: rgba(52,199,89,0.15); }
.btn-sm { padding: 5px 12px; font-size: 0.8rem; }
.btn-icon {
  padding: 6px; border-radius: var(--radius-sm);
  background: rgba(0,0,0,0.05); border: 1px solid var(--border-mid);
  cursor: pointer; color: var(--muted); transition: all 0.15s;
}
.btn-icon:hover { background: rgba(0,0,0,0.09); color: var(--text); }

/* ── Year-Nav ────────────────────────────────────────────── */
.year-nav {
  display: flex; align-items: center; gap: 8px;
  background: rgba(0,0,0,0.05); border-radius: var(--radius-sm);
  padding: 3px 5px;
}
.year-nav button {
  background: none; border: none; width: 28px; height: 28px;
  border-radius: 6px; font-size: 1rem; cursor: pointer;
  color: var(--muted); transition: all 0.15s;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font);
}
.year-nav button:hover { background: rgba(0,0,0,0.07); color: var(--text); }
.year-nav span { font-size: 0.9rem; font-weight: 600; min-width: 38px; text-align: center; }

/* ── Gantt-Tabelle ───────────────────────────────────────── */
#gantt-container {
  overflow-x: auto;
  overflow-y: auto;
  border-radius: 0 0 var(--radius-lg) var(--radius-lg);
  scrollbar-width: thin;
  scrollbar-color: rgba(0,0,0,0.2) transparent;
}
#gantt-container::-webkit-scrollbar { height: 8px; width: 8px; }
#gantt-container::-webkit-scrollbar-track { background: transparent; }
#gantt-container::-webkit-scrollbar-thumb {
  background: rgba(0,0,0,0.18); border-radius: 4px;
}
#gantt-container::-webkit-scrollbar-thumb:hover { background: rgba(0,0,0,0.28); }

.gantt-table {
  border-collapse: collapse;
  min-width: 100%;
  font-size: 13px;
}
/* Keine vertikalen Trennlinien */
.gantt-table th, .gantt-table td {
  border: none;
  border-bottom: 1px solid var(--border);
  padding: 0;
  white-space: nowrap;
}
.gantt-table thead th {
  background: var(--surface2);
  color: var(--muted);
  font-weight: 600;
  text-align: center;
  padding: 9px 8px;
  position: sticky;
  top: 0;
  z-index: 10;
  font-size: 13px;
  letter-spacing: 0;
  border-bottom: 1px solid var(--border-mid);
}
/* Monatsspalten-Header bleiben kompakter */
.gantt-table thead th.col-month { font-size: 11px; text-transform: uppercase; letter-spacing: 0.04em; padding: 9px 4px; }

/* Fixe Spalten links */
.col-fix {
  position: sticky;
  left: 0;
  z-index: 5;
  /* Kein eigenes background – erbt von tr für korrekten Hover */
  background: inherit;
}
.gantt-table thead th.col-fix {
  background: var(--surface2);
  z-index: 15;
}

.col-nr    { width: 70px;  min-width: 70px; }
.col-name  { width: 200px; min-width: 160px; }
.col-mgr   { width: 130px; min-width: 100px; }
.col-bh    { width: 130px; min-width: 100px; }
.col-start { width: 70px;  min-width: 60px; }
.col-dur   { width: 55px;  min-width: 50px; }
.col-end   { width: 70px;  min-width: 60px; }
.col-fee   { width: 100px; min-width: 90px;  text-align: right; }
.col-yr    { width: 90px;  min-width: 80px;  text-align: right; }
.col-month { width: var(--month-w); min-width: var(--month-w); text-align: right; }
/* Heute-Spalte: td bekommt direkt background (Ausnahme vom inherit-Prinzip) */
td.col-month-today { background-color: rgba(0,113,227,0.05) !important; }
th.col-month-today {
  background-color: rgba(0,113,227,0.12) !important;
  color: var(--primary) !important;
  font-weight: 700;
}
/* Aktuelles Jahr – gleiche Hervorhebung wie aktueller Monat */
td.col-yr-today { background-color: rgba(0,113,227,0.05) !important; }
th.col-yr-today {
  background-color: rgba(0,113,227,0.12) !important;
  color: var(--primary) !important;
  font-weight: 700;
}

/* ── Zeilen – Background auf TR, td erbt → Hover funktioniert für sticky cols ── */
.gantt-table tbody tr          { height: var(--row-h); background-color: var(--surface); }
.gantt-table tbody tr:hover    { background-color: #f2f2f4 !important; }
.gantt-table tbody td {
  padding: 0 8px;
  vertical-align: middle;
  color: var(--text);
  background-color: transparent; /* tr-Farbe durchscheinen lassen */
}
/* sticky cols: background inherit vom tr → Hover zieht durch */
.gantt-table tbody td.col-fix  { background-color: inherit; }

/* Gantt-Balken-Zelle */
.gantt-cell {
  padding: 0 !important;
  position: relative;
}
.gantt-bar-wrapper {
  width: 100%; height: 24px;
  display: flex; flex-direction: column;
  align-items: stretch; justify-content: center;
  cursor: pointer;
  position: relative;
}
.gantt-bar {
  height: 20px;
  border-radius: 5px;
  margin: 0 2px;
  opacity: 0.85;
  transition: opacity 0.15s;
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: 10px; font-weight: 700;
  overflow: hidden;
}
.gantt-bar:hover { opacity: 1; }
.gantt-bar-past  { opacity: 0.5; }
.gantt-fee-label {
  font-size: 10px;
  color: var(--muted);
  text-align: center;
  line-height: 1;
  padding: 2px 2px 0;
  white-space: nowrap;
  overflow: hidden;
  cursor: pointer;
  border-radius: 3px;
  transition: background 0.15s, color 0.15s;
}
.gantt-fee-label:hover {
  background: rgba(0,113,227,0.1);
  color: var(--primary);
}
.gantt-fee-label.fee-overridden {
  color: var(--primary);
  font-weight: 700;
}
.gantt-fee-label.fee-overridden::after {
  content: ' ✎';
  font-size: 8px;
}

/* Ausgaben-Zeilen – background auf tr */
.gantt-table tbody tr.expense-row { background-color: var(--surface) !important; }
/* Kein Hover-Effekt auf expense-rows nötig – erbt von allgemeinem tr:hover */

/* Drag & Drop */
.gantt-table tbody tr[draggable="true"] { cursor: grab; }
.gantt-table tbody tr[draggable="true"]:active { cursor: grabbing; }
.gantt-table tbody tr.dragging { opacity: 0.4; }
.gantt-table tbody tr.drag-over td { border-top: 2px solid var(--primary) !important; }

/* Fee-Popover */
.fee-popover {
  position: fixed;
  z-index: 499;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-lg);
  padding: 16px;
  width: 260px;
}
.fee-popover-header {
  display: flex;
  align-items: center;
  margin-bottom: 12px;
}
.fee-popover-header strong {
  font-size: 0.875rem;
  flex: 1;
}

/* Zusammenfassung – background auf tr, schmäler als Datenzeilen */
.gantt-table tbody tr.summary-row {
  height: 34px;
  background-color: #f6f6f8 !important; /* opakes rgba(0,0,0,0.025) auf weiß */
}
.gantt-table tbody tr.summary-row:hover { background-color: #f6f6f8 !important; }
.summary-row td { font-weight: 700; border-top: 1px solid var(--border-mid); }
.summary-row.deficit td { color: var(--danger); }

/* Abschnitt-Header – schmal, background auf tr */
.gantt-table tbody tr.section-header {
  height: 26px !important;
  background-color: var(--surface2) !important;
}
.gantt-table tbody tr.section-header:hover { background-color: var(--surface2) !important; cursor: default; }
.gantt-table tbody tr.section-header.collapsible { cursor: pointer !important; }
.gantt-table tbody tr.section-header.collapsible:hover { filter: brightness(0.96); }
.section-header td {
  color: var(--muted) !important;
  font-weight: 700;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  padding: 0 10px !important;
  border-bottom: 1px solid var(--border-mid) !important;
}
.sh-inner { display: flex; align-items: center; gap: 6px; }
/* Chevron */
.section-chevron {
  display: inline-flex; align-items: center; justify-content: center;
  width: 16px; height: 16px; border-radius: 4px;
  background: rgba(0,0,0,0.06); flex-shrink: 0;
  transition: transform 0.2s, background 0.15s;
}
.section-chevron svg { width: 9px; height: 9px; display: block; }
.collapsible:hover .section-chevron { background: rgba(0,0,0,0.11); }
.section-header.collapsed .section-chevron { transform: rotate(-90deg); }
/* Zähler-Badge */
.section-count-badge {
  font-size: 9px; font-weight: 700; letter-spacing: 0; text-transform: none;
  background: rgba(0,0,0,0.07); color: var(--muted);
  border-radius: 9px; padding: 1px 6px;
  transition: background 0.2s, color 0.2s;
}
.section-header.collapsed .section-count-badge {
  background: rgba(0,113,227,0.12); color: var(--primary);
}
/* Eingeklappte Zeilen */
.gantt-row-hidden { display: none !important; }

/* ── Adressbuch Karten ───────────────────────────────────── */
.contact-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  margin-bottom: 10px;
}
.contact-card-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 11px 18px;
  background: rgba(0,0,0,0.025);
  border-bottom: 1px solid var(--border);
}
.contact-card-name { font-weight: 700; font-size: 0.94rem; letter-spacing: -0.1px; }
.contact-card-data {
  display: grid;
  grid-template-columns: minmax(140px,2fr) minmax(120px,1fr) minmax(120px,1fr) minmax(160px,2fr) minmax(150px,2fr);
  gap: 0; padding: 9px 18px;
  font-size: 0.84rem; color: var(--muted);
  align-items: center;
}
.contact-card-data a { color: var(--primary); text-decoration: none; }
.contact-card-data a:hover { text-decoration: underline; }
.contact-person-row {
  display: grid;
  grid-template-columns: minmax(140px,2fr) minmax(120px,1fr) minmax(120px,1fr) minmax(160px,2fr) minmax(150px,2fr);
  gap: 0; padding: 7px 18px 7px 32px;
  font-size: 0.83rem; color: var(--muted);
  border-top: 1px solid var(--border);
  align-items: center;
}
.contact-person-row .person-name { font-weight: 600; color: var(--text); }
.contact-person-row a { color: var(--primary); text-decoration: none; }
.contact-person-row a:hover { text-decoration: underline; }

/* Search & Filter Bar */
.search-bar {
  display: flex; gap: 10px;
  padding: 14px 20px;
  border-bottom: 1px solid var(--border);
}
.search-input {
  flex: 1; padding: 8px 14px;
  border: 1.5px solid var(--border-mid);
  border-radius: var(--radius-sm);
  font-size: 0.875rem; font-family: var(--font);
  background: var(--surface2); outline: none; color: var(--text);
  transition: border-color 0.15s, box-shadow 0.15s;
}
.search-input:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(0,113,227,0.15);
  background: var(--surface);
}
.role-select {
  padding: 8px 14px;
  border: 1.5px solid var(--border-mid);
  border-radius: var(--radius-sm);
  font-size: 0.875rem; font-family: var(--font);
  background: var(--surface2); color: var(--text);
  min-width: 160px; outline: none;
  transition: border-color 0.15s;
}
.role-select:focus { border-color: var(--primary); }

/* ── Status-Toggle (Angebot / Beauftragt) ────────────────── */
.status-toggle-wrap { display:flex; align-items:center; gap:7px; }
.status-lbl { font-size:0.8rem; color:var(--muted); white-space:nowrap; transition:color 0.2s; }
.status-toggle { position:relative; display:inline-block; width:40px; height:22px; cursor:pointer; }
.status-toggle input { opacity:0; width:0; height:0; }
.status-track { position:absolute; inset:0; background:#ddd; border-radius:11px; transition:background 0.2s; }
.status-track .status-knob { position:absolute; top:3px; left:3px; width:16px; height:16px; background:#fff; border-radius:50%; transition:transform 0.2s; box-shadow:0 1px 3px rgba(0,0,0,0.25); }
.status-toggle input:checked + .status-track { background:var(--primary); }
.status-toggle input:checked + .status-track .status-knob { transform:translateX(18px); }
.proj-status-btn { display:inline-flex; align-items:center; justify-content:center;
  width:18px; height:18px; border-radius:50%; font-size:9px; font-weight:800; cursor:pointer;
  border:none; margin-left:4px; vertical-align:middle; transition:all 0.15s; flex-shrink:0; }
.proj-status-btn.beauftragt { background:#dcfce7; color:#16a34a; }
.proj-status-btn.beauftragt:hover { background:#16a34a; color:#fff; }
.proj-status-btn.angebot    { background:#fff7ed; color:#ea580c; }
.proj-status-btn.angebot:hover { background:#ea580c; color:#fff; }
.section-header-angebot td { background:var(--surface2) !important; color:var(--muted) !important; }
[data-theme="clean"] .section-header-angebot td { background:#334155 !important; color:#fff !important; }

/* ── Modal ───────────────────────────────────────────────── */
.modal-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.35);
  backdrop-filter: blur(4px);
  z-index: 1000;
  display: flex; align-items: center; justify-content: center;
  padding: 20px;
  opacity: 0; pointer-events: none;
  transition: opacity 0.2s;
}
.modal-overlay.open { opacity: 1; pointer-events: all; }
.modal {
  background: var(--surface);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  width: 100%;
  max-width: 600px;
  max-height: 90vh;
  /* Flex-Spalte: Header + Body(scrollbar) + Footer bleiben immer sichtbar */
  display: flex; flex-direction: column;
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  transform: translateY(8px) scale(0.99);
  transition: transform 0.2s;
}
.modal-overlay.open .modal { transform: translateY(0) scale(1); }
.modal-header {
  display: flex; align-items: center; flex-shrink: 0;
  padding: 18px 22px;
  border-bottom: 1px solid var(--border);
  background: rgba(0,0,0,0.015);
}
.modal-header h3 { margin: 0; font-size: 1rem; font-weight: 700; letter-spacing: -0.2px; flex: 1; }
.modal-header .spacer { flex: 1; }
.modal-close {
  width: 28px; height: 28px; border-radius: 50%; border: none;
  background: rgba(0,0,0,0.07); font-size: 1.1rem;
  cursor: pointer; color: var(--muted);
  display: flex; align-items: center; justify-content: center;
  transition: background 0.15s;
}
.modal-close:hover { background: rgba(0,0,0,0.12); color: var(--text); }
/* Body scrollt, Header und Footer bleiben fest */
.modal-body { padding: 22px; overflow-y: auto; flex: 1; }
.modal-footer {
  padding: 14px 22px; flex-shrink: 0;
  border-top: 1px solid var(--border);
  display: flex; gap: 10px; justify-content: flex-end;
  background: rgba(0,0,0,0.015);
  border-radius: 0 0 var(--radius-lg) var(--radius-lg);
}

/* ── Formular ────────────────────────────────────────────── */
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.form-grid .span2 { grid-column: 1 / -1; }
.form-group { display: flex; flex-direction: column; gap: 5px; }
.form-group label {
  font-size: 0.78rem; font-weight: 600; color: var(--muted);
  text-transform: uppercase; letter-spacing: 0.05em;
}
.form-group input,
.form-group select,
.form-group textarea {
  padding: 9px 13px;
  border: 1.5px solid var(--border-mid);
  border-radius: var(--radius-sm);
  font-size: 0.875rem;
  background: var(--surface);
  color: var(--text);
  transition: border-color 0.15s, box-shadow 0.15s;
  font-family: var(--font);
  outline: none;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(0,113,227,0.15);
}
.form-group textarea { resize: vertical; min-height: 70px; }

/* ── Projekt-Popup Sektionen ────────────────────────────── */
.proj-section { margin-bottom:22px; padding-bottom:18px; border-bottom:1px solid var(--border); }
.proj-section-last { margin-bottom:0; padding-bottom:0; border-bottom:none; }
.proj-section-title {
  font-size:12px; font-weight:700; color:var(--text); margin-bottom:12px;
  text-transform:uppercase; letter-spacing:0.5px;
  display:flex; align-items:center; gap:8px;
}
.proj-section-icon {
  width:26px; height:26px; border-radius:8px; display:inline-flex;
  align-items:center; justify-content:center; flex-shrink:0;
}

/* ── Projektbearbeiter Checkliste ───────────────────────── */
.proj-members-wrap {
  border: 1.5px solid var(--border-mid);
  border-radius: 10px;
  max-height: 148px;
  overflow-y: auto;
  background: var(--surface1);
}
.proj-members-list {
  display: flex;
  flex-direction: column;
}
.proj-members-list label {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 6px 13px;
  cursor: pointer;
  font-size: 0.875rem;
  color: var(--text);
  transition: background 0.1s;
  font-weight: 400;
  text-transform: none;
  letter-spacing: 0;
}
.proj-members-list label:hover { background: rgba(0,113,227,0.07); }
.proj-members-list input[type="checkbox"] {
  width: 15px; height: 15px;
  accent-color: var(--primary);
  flex-shrink: 0;
  cursor: pointer;
}
.proj-members-placeholder {
  padding: 8px 13px;
  color: var(--muted);
  font-size: 0.8rem;
  font-style: italic;
}

/* Toggle-Gruppe (Person / Firma) */
.toggle-group {
  display: flex;
  background: rgba(0,0,0,0.06);
  border-radius: var(--radius-sm);
  padding: 3px;
}
.toggle-btn {
  flex: 1; padding: 5px 14px; border: none;
  border-radius: 7px; font-size: 0.82rem; font-weight: 500;
  cursor: pointer; font-family: var(--font);
  transition: all 0.15s; background: none; color: var(--muted);
}
.toggle-btn.active {
  background: var(--surface); color: var(--text);
  box-shadow: var(--shadow-sm); font-weight: 600;
}

/* ── Expense-Items Inline-Inputs ─────────────────────────── */
.exp-input {
  padding: 7px 10px;
  border: 1.5px solid var(--border-mid);
  border-radius: var(--radius-sm);
  font-size: 0.875rem;
  background: var(--surface);
  color: var(--text);
  width: 100%;
  box-sizing: border-box;
  font-family: var(--font);
  transition: border-color 0.15s;
  outline: none;
}
.exp-input:focus { border-color: var(--primary); box-shadow: 0 0 0 3px rgba(0,113,227,0.15); }

/* ── Info-Badges ─────────────────────────────────────────── */
.badge {
  display: inline-block;
  padding: 2px 9px;
  border-radius: 20px;
  font-size: 0.72rem;
  font-weight: 600;
}
.badge-blue   { background: rgba(0,113,227,0.1);  color: #0071e3; }
.badge-green  { background: rgba(52,199,89,0.12); color: #1a8a3a; }
.badge-purple { background: rgba(124,58,237,0.1); color: #7c3aed; }
.badge-orange { background: rgba(255,149,0,0.12); color: #b36200; }
.badge-gray   { background: rgba(0,0,0,0.06);     color: var(--muted); }

/* ── Zahlen & Beträge ────────────────────────────────────── */
.amount     { text-align: right; font-variant-numeric: tabular-nums; }
.amount-neg { color: var(--danger); }
.amount-pos { color: var(--success); }

/* ── Tabs ────────────────────────────────────────────────── */
.tab-bar {
  display: flex; gap: 0;
  border-bottom: 1px solid var(--border);
}
.tab-btn {
  padding: 10px 20px;
  border: none; background: none;
  font-size: 0.875rem; font-weight: 500;
  color: var(--muted); cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  transition: all 0.15s;
  font-family: var(--font);
}
.tab-btn:hover  { color: var(--text); }
.tab-btn.active { color: var(--primary); border-bottom-color: var(--primary); font-weight: 600; }

/* ── Loader ──────────────────────────────────────────────── */
.loader {
  display: flex; align-items: center; justify-content: center;
  padding: 40px; color: var(--muted);
}

/* ── Farb-Auswahl ────────────────────────────────────────── */
.color-options { display: flex; gap: 8px; flex-wrap: wrap; }
.color-swatch {
  width: 28px; height: 28px; border-radius: 6px;
  cursor: pointer; border: 3px solid transparent;
  transition: border-color 0.15s, transform 0.15s;
}
.color-swatch:hover { transform: scale(1.1); }
.color-swatch.selected { border-color: var(--text); }

/* ── Tooltip ─────────────────────────────────────────────── */
[data-tip] { position: relative; }
[data-tip]:hover::after {
  content: attr(data-tip);
  position: absolute;
  bottom: calc(100% + 6px);
  left: 50%;
  transform: translateX(-50%);
  background: #1d1d1f;
  color: #fff;
  padding: 4px 10px;
  border-radius: 6px;
  font-size: 11px;
  white-space: nowrap;
  pointer-events: none;
  z-index: 500;
}

/* ── Data-Table (Projekte-Liste) ─────────────────────────── */
.data-table {
  width: 100%;
  border-collapse: collapse;
}
.data-table th {
  background: var(--surface2);
  border-bottom: 1px solid var(--border-mid);
  padding: 9px 14px;
  text-align: left;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--muted);
}
.data-table td {
  padding: 10px 14px;
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
  color: var(--text);
}
.data-table tr:last-child td { border-bottom: none; }
.data-table tr:hover td { background: rgba(0,0,0,0.018); }

/* ── Responsive ──────────────────────────────────────────── */
@media (max-width: 768px) {
  .form-grid { grid-template-columns: 1fr; }
  .form-grid .span2 { grid-column: 1; }
  #app { padding: 16px; }
}

/* ── Hilfklassen ─────────────────────────────────────────── */
.flex { display: flex; }
.items-center { align-items: center; }
.gap-2 { gap: 8px; }
.mt-4 { margin-top: 16px; }
.mb-4 { margin-bottom: 16px; }
.text-muted { color: var(--muted); }
.text-right { text-align: right; }
.font-bold { font-weight: 700; }

/* ============================================================
   THEME: clean  (altes dunkles Design)
   Aktiviert via <html data-theme="clean">
   ============================================================ */

[data-theme="clean"] {
  --bg:        #f0f2f5;
  --surface:   #ffffff;
  --surface2:  #f8fafc;
  --border:    #e2e8f0;
  --border-mid:#cbd5e1;
  --primary:   #4A90D9;
  --primary-d: #357abd;
  --text:      #1e293b;
  --muted:     #64748b;
  --text3:     #94a3b8;
  --danger:    #dc2626;
  --success:   #16a34a;
  --warn:      #d97706;
  --radius-sm: 7px;
  --radius:    10px;
  --radius-lg: 12px;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.05);
  --shadow:    0 1px 3px rgba(0,0,0,0.05);
  --shadow-lg: 0 20px 60px rgba(0,0,0,0.3);
}

[data-theme="clean"] #topbar {
  background: #1a2332;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  box-shadow: 0 2px 8px rgba(0,0,0,0.3);
  border-bottom: none;
}
[data-theme="clean"] #topbar .logo { color: #fff; }
[data-theme="clean"] #topbar nav button { color: #94a3b8; }
[data-theme="clean"] #topbar nav button:hover { background: rgba(255,255,255,0.08); color: #fff; }
[data-theme="clean"] #topbar nav button.active { background: var(--primary); color: #fff; }
[data-theme="clean"] #topbar nav .nav-bauleitung-btn { background: var(--primary); color: #fff !important; }
[data-theme="clean"] #topbar nav .nav-bauleitung-btn:hover { background: #0064cc; }
[data-theme="clean"] #topbar .user-info { color: #94a3b8; }
[data-theme="clean"] #topbar .user-info strong { color: #fff; }
[data-theme="clean"] #topbar .btn-logout { background: rgba(255,255,255,0.1); border: none; color: #fff; }
[data-theme="clean"] #topbar .btn-logout:hover { background: rgba(255,255,255,0.2); }
[data-theme="clean"] #topbar .btn-settings { background: rgba(255,255,255,0.1); color: #94a3b8; }
[data-theme="clean"] #topbar .btn-settings:hover,
[data-theme="clean"] #topbar .btn-settings.active { background: rgba(255,255,255,0.2); color: #fff; }

[data-theme="clean"] .gantt-table thead th {
  background: #1e293b;
  color: #fff;
}
[data-theme="clean"] .gantt-table thead th.col-fix { background: #1e293b; }
[data-theme="clean"] .col-month-today { background: #eef6ff !important; }
[data-theme="clean"] th.col-month-today { background: #dbeafe !important; color: #1d4ed8 !important; }
[data-theme="clean"] .col-yr-today { background: #eef6ff !important; }
[data-theme="clean"] th.col-yr-today { background: #dbeafe !important; color: #1d4ed8 !important; }

[data-theme="clean"] .section-header td,
[data-theme="clean"] .section-header td.col-fix { background: #334155 !important; color: #fff !important; }

[data-theme="clean"] .gantt-table tbody tr:hover    { background-color: #f0f4f8 !important; }
[data-theme="clean"] .gantt-table tbody tr.section-header,
[data-theme="clean"] .gantt-table tbody tr.section-header:hover { background-color: #334155 !important; }
[data-theme="clean"] .gantt-table tbody tr.section-header td { color: #fff !important; }

[data-theme="clean"] .settings-nav-btn.active { background: var(--primary); color: #fff; }
[data-theme="clean"] .tab-btn.active { color: var(--primary); border-bottom-color: var(--primary); }

[data-theme="clean"] .modal {
  border-radius: 12px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.3);
}
[data-theme="clean"] .modal-header,
[data-theme="clean"] .modal-footer { background: #f8fafc; }
[data-theme="clean"] .card-header { background: #f8fafc; }
[data-theme="clean"] .summary-row td { background: #f8fafc; }

[data-theme="clean"] .gantt-fee-label:hover { background: #dbeafe; color: var(--primary); }
[data-theme="clean"] .badge-blue   { background: #dbeafe; color: #1d4ed8; }
[data-theme="clean"] .badge-green  { background: #dcfce7; color: #15803d; }
[data-theme="clean"] .badge-orange { background: #fed7aa; color: #c2410c; }
[data-theme="clean"] .badge-purple { background: #f3e8ff; color: #7c3aed; }
[data-theme="clean"] .btn-secondary { background: #f1f5f9; border-color: var(--border); }
[data-theme="clean"] .btn-secondary:hover { background: #e2e8f0; }
[data-theme="clean"] .btn-danger  { background: #fef2f2; border-color: #fca5a5; }
[data-theme="clean"] .btn-warning { background: #fffbeb; border-color: #fcd34d; }
[data-theme="clean"] .btn-success { background: #f0fdf4; border-color: #86efac; }

/* ── Theme Switcher in Einstellungen ── */
.theme-switcher { display: flex; gap: 14px; margin-bottom: 24px; }
.theme-option {
  flex: 1; max-width: 200px;
  border: 2px solid var(--border); border-radius: var(--radius);
  padding: 14px; cursor: pointer; transition: all 0.2s;
  background: var(--surface); text-align: center;
}
.theme-option:hover { border-color: var(--primary); }
.theme-option.active {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(0,113,227,0.18);
}
.theme-option-preview {
  width: 100%; height: 80px; border-radius: 8px;
  margin-bottom: 10px; overflow: hidden; position: relative;
}
.theme-option-name { font-size: 0.875rem; font-weight: 600; }
.theme-option-desc { font-size: 0.78rem; color: var(--muted); margin-top: 3px; }

/* Preview: Modern */
.preview-modern { background: #f5f5f7; }
.preview-modern .p-topbar { height: 18px; background: rgba(255,255,255,0.85); border-bottom: 1px solid rgba(0,0,0,0.08); display: flex; align-items: center; padding: 0 8px; gap: 4px; }
.preview-modern .p-dot { width: 22px; height: 5px; border-radius: 3px; background: rgba(0,0,0,0.1); }
.preview-modern .p-dot.a { background: #0071e3; opacity: 0.7; }
.preview-modern .p-body { padding: 5px; display: flex; flex-direction: column; gap: 3px; }
.preview-modern .p-card { background: #fff; border-radius: 8px; height: 12px; box-shadow: 0 1px 4px rgba(0,0,0,0.08); }
.preview-modern .p-bar { background: #0071e3; border-radius: 4px; height: 6px; width: 60%; margin-top: 3px; opacity: 0.65; }

/* Preview: Clean */
.preview-clean { background: #1a2332; }
.preview-clean .p-topbar { height: 18px; background: #1a2332; display: flex; align-items: center; padding: 0 8px; gap: 4px; }
.preview-clean .p-dot { width: 22px; height: 5px; border-radius: 3px; background: rgba(255,255,255,0.15); }
.preview-clean .p-dot.a { background: #4A90D9; }
.preview-clean .p-body { padding: 5px; display: flex; flex-direction: column; gap: 3px; }
.preview-clean .p-card { background: #fff; border-radius: 5px; height: 12px; }
.preview-clean .p-bar { background: #4A90D9; border-radius: 3px; height: 6px; width: 60%; margin-top: 3px; opacity: 0.7; }

/* ═══════════════════════════════════════════════════════
   Projektplanung
   ═══════════════════════════════════════════════════════ */

/* Meine / Alle – Toggle */
.pp-filter-btn {
  background:none; border:none; cursor:pointer;
  padding:4px 12px; font-size:12px; font-weight:500; color:var(--muted);
  border-radius:5px; transition:background .12s,color .12s; white-space:nowrap;
}
.pp-filter-btn.pp-filter-active {
  background:#fff; color:#1d1d1f; font-weight:600;
  box-shadow:0 1px 3px rgba(0,0,0,.12);
}
:root {
  --pp-cell:    38px;
  --pp-label-w: 240px;
  --pp-lph14:   #4f8ef7;
  --pp-lph5:    #f0a030;
  --pp-lph67:   #a84ff7;
  --pp-lph8:    #8e8e93;
}

/* Outer scroll wrapper – feste Höhe damit Header sticky korrekt wirkt und Scrollbar
   immer unten sichtbar ist */
.pp-gantt-outer {
  overflow-x:auto;
  overflow-y:auto;
  height: calc(100vh - var(--header-h) - 100px);
}
.pp-gantt-outer::-webkit-scrollbar { height:7px; width:7px; }
.pp-gantt-outer::-webkit-scrollbar-track { background:#f0f0f5; }
.pp-gantt-outer::-webkit-scrollbar-thumb { background:#ccc; border-radius:4px; }

/* Header-Wrapper (sticky vertikal – relativ zu pp-gantt-outer als Scroll-Container) */
.pp-header-wrap { position:sticky; top:0; z-index:50; background:#fff; }
.pp-header-row { display:flex; background:#fff; }
.pp-header-top  { border-bottom:1px solid var(--border-mid); min-height:20px; }
.pp-header-bottom { border-bottom:2px solid var(--border); align-items:center; }

/* Eck-Zelle (leer, oben links) – sticky horizontal */
.pp-header-label-corner {
  width:var(--pp-label-w, 240px); flex-shrink:0;
  position:sticky; left:0; z-index:20; background:#fff;
  padding:3px 14px; display:flex; align-items:center;
  border-right:1px solid var(--border);
}

/* Label-Kopfzelle (untere Header-Zeile) – sticky horizontal */
.pp-header-label {
  width:var(--pp-label-w, 240px); flex-shrink:0;
  position:sticky; left:0; z-index:20; background:#fff;
  padding:4px 14px;
  font-size:11px; font-weight:700; color:var(--muted);
  text-transform:uppercase; letter-spacing:.04em;
  border-right:1px solid var(--border);
  display:flex; align-items:center;
  align-self:stretch; /* volle Höhe für Resize-Handle */
}

/* Resize-Handle an der rechten Kante der Label-Spalte */
.pp-label-resize {
  position:absolute; right:0; top:0; bottom:0; width:5px;
  cursor:ew-resize; z-index:5; background:transparent; transition:background .15s;
}
.pp-label-resize:hover { background:rgba(0,113,227,.35); }

/* Gruppen-Zelle (Jahr / Monat in oberer Header-Zeile) */
.pp-group-cell {
  flex-shrink:0; text-align:center;
  font-size:11px; font-weight:600; color:var(--muted);
  padding:3px 6px; border-left:1px solid var(--border-mid);
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
  line-height:1.3;
}

/* Monats-/Wochen-/Tages-Zellen */
.pp-month-cell { flex-shrink:0; text-align:center; font-size:10px; color:#aaa; padding:4px 0; border-left:1px solid #eee; width:var(--pp-cell); }
.pp-month-cell.pp-jan     { border-left-color:#bbb; color:#555; font-weight:700; }
.pp-month-cell.pp-now     { background:rgba(0,113,227,.10); color:var(--primary); font-weight:700; }
.pp-month-cell.pp-weekend { background:rgba(0,0,0,.04); color:#bbb; }

/* Projektzeilen */
.pp-project-row { border-bottom:1px solid var(--border); }
.pp-proj-header { display:flex; align-items:stretch; cursor:pointer; background:#fff; transition:background .12s; }
.pp-proj-header:hover { background:#f7f7fa; }
.pp-proj-label {
  width:var(--pp-label-w, 240px); flex-shrink:0; padding:10px 14px;
  display:flex; align-items:center; gap:8px;
  border-right:1px solid var(--border); font-weight:600; font-size:13px;
  position:sticky; left:0; z-index:5; background:#fff;
}
.pp-proj-header:hover .pp-proj-label { background:#f7f7fa; }
.pp-expand-arrow { font-size:10px; color:#bbb; transition:transform .2s; flex-shrink:0; }
.pp-project-row.pp-expanded .pp-expand-arrow { transform:rotate(90deg); }
.pp-proj-name { flex:1; min-width:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.pp-proj-settings-btn { background:none; border:none; color:#bbb; cursor:pointer; font-size:14px; padding:2px 4px; border-radius:4px; transition:color .15s; flex-shrink:0; }
.pp-proj-settings-btn:hover { color:var(--primary); }
.pp-summary-track { flex:1; position:relative; display:flex; align-items:center; min-height:42px; overflow:hidden; }

/* Dünne Summary-Balken (zugeklappt) */
.pp-summary-bar { position:absolute; top:11px; height:18px; border-radius:4px; opacity:.55; pointer-events:none; }

/* Phasenzeilen */
.pp-phase-rows { display:none; }
.pp-project-row.pp-expanded .pp-phase-rows { display:block; }
.pp-phase-row { display:flex; align-items:stretch; border-top:1px solid rgba(0,0,0,.04); }
.pp-phase-label {
  width:var(--pp-label-w, 240px); flex-shrink:0;
  padding:5px 14px 5px calc(63px + var(--pp-num-w, 40px));
  display:flex; align-items:center; gap:7px;
  border-right:1px solid var(--border); font-size:11px; color:#666; font-weight:500; min-height:34px;
  position:sticky; left:0; z-index:4; background:#fff;
}
.pp-phase-tag { width:8px; height:8px; border-radius:2px; flex-shrink:0; }
.pp-phase-track {
  flex:1; position:relative; min-height:34px; overflow:hidden;
  background:repeating-linear-gradient(90deg,transparent,transparent calc(var(--pp-cell) - 1px),#f0f0f5 calc(var(--pp-cell) - 1px),#f0f0f5 var(--pp-cell));
}

/* Meilenstein-Zeile */
.pp-milestone-row { display:flex; align-items:stretch; border-top:1px solid rgba(0,0,0,.04); }
.pp-milestone-label {
  width:var(--pp-label-w, 240px); flex-shrink:0;
  padding:4px 14px 4px calc(63px + var(--pp-num-w, 40px));
  display:flex; align-items:center; gap:6px;
  border-right:1px solid var(--border); font-size:11px; color:#aaa; font-style:italic;
  position:sticky; left:0; z-index:4; background:#fff;
}
.pp-milestone-track { flex:1; position:relative; min-height:48px; }

/* Phase-Balken */
.pp-bar {
  position:absolute; top:5px; height:24px; border-radius:5px;
  display:flex; align-items:center; padding:0 8px;
  font-size:10px; font-weight:700; color:#fff; white-space:nowrap;
  overflow:hidden; cursor:grab; box-shadow:0 1px 4px rgba(0,0,0,.18);
  transition:box-shadow .12s; z-index:2;
}
.pp-bar:hover { box-shadow:0 2px 8px rgba(0,0,0,.28); }
.pp-bar.pp-dragging { cursor:grabbing; box-shadow:0 4px 16px rgba(0,0,0,.3); z-index:10; opacity:.88; }
.pp-bar.pp-not-contracted { opacity:.22; cursor:default; pointer-events:none; }
.pp-bar-handle { position:absolute; top:0; width:7px; height:100%; cursor:ew-resize; background:rgba(255,255,255,.28); z-index:3; }
.pp-bar-handle.left  { left:0;  border-radius:5px 0 0 5px; }
.pp-bar-handle.right { right:0; border-radius:0 5px 5px 0; }

/* Heute-Spalte (blauer Hintergrund, wie in der Budgetplanung) */
.pp-today-col { position:absolute; top:0; bottom:0; background:rgba(0,113,227,.08); z-index:1; pointer-events:none; border-left:1.5px solid rgba(0,113,227,.25); }

/* Meilenstein-Raute (verschiebbar) */
.pp-ms-marker {
  position:absolute; top:8px; transform:none;
  width:12px; height:12px; background:#f59e0b; border:2px solid #fff;
  border-radius:2px; rotate:45deg; z-index:4; cursor:grab;
  box-shadow:0 1px 3px rgba(0,0,0,.2); transition:box-shadow .12s;
}
.pp-ms-marker:hover { box-shadow:0 0 0 3px rgba(245,158,11,.3); }
.pp-ms-label {
  position:absolute; top:0; transform:translateX(-50%);
  font-size:11px; font-weight:700; color:#92400e; white-space:nowrap;
  background:rgba(255,248,230,.92); padding:1px 5px; border-radius:3px; pointer-events:none;
}

/* Popup-Inhalte */
.pp-popup-section-title { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.05em; color:var(--muted); margin-bottom:8px; }
.pp-lph-check-row { display:flex; align-items:center; gap:10px; padding:8px 0; border-bottom:1px solid rgba(0,0,0,.05); }
.pp-lph-check-row:last-child { border-bottom:none; }
.pp-lph-check-row input[type=checkbox] { width:16px; height:16px; accent-color:var(--primary); cursor:pointer; }
.pp-lph-check-row label { font-size:13px; font-weight:600; cursor:pointer; flex:1; }
.pp-lph-phase-tag { font-size:10px; padding:2px 7px; border-radius:5px; color:#fff; font-weight:700; }
.pp-milestone-entry { display:flex; align-items:center; gap:8px; padding:6px 8px; background:#f7f7fa; border-radius:7px; margin-bottom:6px; }
.pp-milestone-entry input[type=text] { flex:1; border:1.5px solid #e0e0e5; border-radius:5px; padding:4px 8px; font-size:12px; outline:none; }
.pp-milestone-entry input[type=text]:focus { border-color:var(--primary); }
.pp-milestone-entry input[type=date] { border:1.5px solid #e0e0e5; border-radius:5px; padding:4px 8px; font-size:12px; outline:none; }
.pp-milestone-entry input[type=date]:focus { border-color:var(--primary); }
.pp-del-ms-btn { background:none; border:none; color:#ff3b30; cursor:pointer; font-size:16px; padding:0 4px; }
.btn-add-pp-milestone { background:none; border:1.5px dashed rgba(0,113,227,.4); color:var(--primary); border-radius:7px; padding:7px 12px; font-size:12px; font-weight:600; cursor:pointer; width:100%; margin-top:4px; transition:background .15s; }
.btn-add-pp-milestone:hover { background:rgba(0,113,227,.06); }

/* Drag-Handle Projektzeilen-Reihenfolge */
.pp-row-drag-handle { cursor:grab; color:#ccc; font-size:13px; padding:0 5px 0 2px; flex-shrink:0; user-select:none; line-height:1; }
.pp-row-drag-handle:hover { color:#999; }
.pp-row-drag-handle:active { cursor:grabbing; }

/* Projektnummer – feste Breite (längste Nummer) → alle Namen auf gleicher Vorderkante */
.pp-proj-number {
  font-size:10px; font-weight:700; color:var(--muted);
  flex-shrink:0; white-space:nowrap; opacity:.7;
  min-width:var(--pp-num-w, 40px);
  text-align:right;
}

/* Zoom-Buttons */
.pp-zoom-btn.pp-zoom-active { background:var(--primary) !important; color:#fff !important; }

/* Projektlaufzeit-Linie im Summary-Track (blau, über den Balken) */
.pp-proj-duration-line {
  position:absolute; top:3px; /* oben – liegt über den Balken */
  height:3px; border-radius:2px;
  background:rgba(0,100,210,.6); z-index:4; pointer-events:none;
  box-shadow:0 1px 4px rgba(0,113,227,.3);
}

/* Editierbare LPH-Bezeichnungen im Projekt-Popup */
.pp-lph-edit-group { display:flex; gap:5px; flex:1; }
.pp-lph-label-inp {
  width:68px; flex-shrink:0; border:1.5px solid #e0e0e5; border-radius:5px;
  padding:3px 6px; font-size:11px; font-weight:700; outline:none; color:var(--text);
  background:#fafafa;
}
.pp-lph-label-inp:focus { border-color:var(--primary); background:#fff; }
.pp-lph-desc-inp {
  flex:1; border:1.5px solid #e0e0e5; border-radius:5px;
  padding:3px 6px; font-size:12px; outline:none; color:var(--text); background:#fafafa;
}
.pp-lph-desc-inp:focus { border-color:var(--primary); background:#fff; }

/* ══════════════════════════════════════════════════════════════
   KOSTENERMITTLUNG – Tabellarische Ansicht
   ══════════════════════════════════════════════════════════════ */

/* ── Toolbar ─────────────────────────────────────────────── */
.ke-toolbar {
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 16px; border-bottom:1px solid var(--border);
  background:var(--surface); position:sticky; top:0; z-index:15;
  flex-wrap:wrap; gap:8px;
}
.ke-toolbar-left, .ke-toolbar-right { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.ke-title { font-size:1.05rem; font-weight:700; color:var(--text); margin:0; white-space:nowrap; }
.ke-select {
  padding:5px 10px; border:1.5px solid var(--border-mid); border-radius:7px;
  font-size:0.82rem; min-width:180px; background:#fff; color:var(--text); outline:none;
}
.ke-select:focus { border-color:var(--primary); }
.ke-toolbar-btn {
  display:flex; align-items:center; gap:5px; padding:5px 12px;
  font-size:0.82rem; border:1px solid var(--border-mid); border-radius:7px;
  cursor:pointer; background:#fff; color:var(--text); white-space:nowrap;
}
.ke-toolbar-btn:hover { background:#f3f4f6; }
.ke-toolbar-icon {
  display:flex; align-items:center; justify-content:center;
  width:30px; height:30px; border:1px solid var(--border-mid); border-radius:7px;
  cursor:pointer; background:#fff; color:var(--muted);
}
.ke-toolbar-icon:hover { background:#f3f4f6; color:var(--text); }
.ke-btn-export {
  background:var(--text) !important; color:#fff !important; border-color:var(--text) !important;
  font-weight:600;
}
.ke-btn-export:hover { opacity:0.88; }
.ke-btn-danger {
  color:#dc2626 !important; border-color:#fca5a5 !important;
}
.ke-btn-danger:hover { background:#fef2f2 !important; }
.ke-chevron { font-size:10px; margin-left:2px; }

/* ── Dropdown ────────────────────────────────────────────── */
.ke-dropdown-wrap { position:relative; }
.ke-dropdown-menu {
  position:absolute; top:100%; left:0; margin-top:4px; background:#fff;
  border:1px solid var(--border-mid); border-radius:8px;
  box-shadow:0 4px 12px rgba(0,0,0,0.1); z-index:50;
  min-width:130px; padding:4px 0; overflow:hidden;
}
.ke-dropdown-item {
  padding:7px 16px; cursor:pointer; font-size:0.82rem; color:var(--text);
}
.ke-dropdown-item:hover { background:#f3f4f6; }
.ke-dropdown-item.active { background:rgba(0,113,227,0.08); color:var(--primary); font-weight:600; }

/* ── Tabs ────────────────────────────────────────────────── */
.ke-tabs { display:flex; gap:4px; }
.ke-tabs .ke-tab {
  padding:4px 12px; font-size:0.78rem; border-radius:6px;
  cursor:pointer; border:1px solid var(--border); background:#fff; color:var(--muted);
}
.ke-tabs .ke-tab:hover { background:#f3f4f6; }
.ke-tabs .ke-tab.active { background:var(--primary); color:#fff; border-color:var(--primary); font-weight:600; }

/* ── Suche ───────────────────────────────────────────────── */
.ke-search-wrap { display:flex; align-items:center; gap:4px; }
.ke-search-input {
  border:1px solid var(--border-mid); border-radius:7px; padding:5px 10px;
  font-size:0.82rem; width:150px; outline:none; transition:width 0.2s;
}
.ke-search-input:focus { border-color:var(--primary); width:200px; }

/* ── Tabelle ─────────────────────────────────────────────── */
.ke-table-wrap { overflow-x:auto; flex:1; }
.ke-table { width:100%; border-collapse:collapse; font-size:0.82rem; }
.ke-th {
  padding:7px 10px; font-size:0.7rem; font-weight:600; color:var(--muted);
  text-transform:uppercase; letter-spacing:0.04em;
  border-bottom:2px solid var(--border-mid); background:#fafbfc;
  white-space:nowrap;
}
.ke-th-text { text-align:left; }
.ke-th-num { text-align:right; }
.ke-th-center { text-align:center; }

/* Zeilen */
.ke-row { transition:background 0.1s; }
.ke-row:hover { background:#f0f4ff !important; }

.ke-row-l1 { background:#fff; font-weight:600; }
.ke-row-l1-open { background:#fafafa; font-weight:600; }
.ke-row-l2 { background:#f8f9fb; font-weight:500; }
.ke-row-l3 { background:#fff; font-weight:400; color:#4b5563; }
.ke-row-eventual { opacity:0.5; font-style:italic; }

/* Inline-Eingabezeile */
.ke-row-inline { background:#fffde7; }
.ke-row-inline td { padding:4px 6px; border-bottom:1px solid #eef0f3; }
.ke-inline-input {
  border:1px solid var(--border); border-radius:2px; padding:4px 6px;
  font-size:0.82rem; outline:none; width:100%; box-sizing:border-box;
  background:#fff; color:var(--text); font-family:inherit;
}
.ke-inline-input:focus { border-color:var(--primary); background:#f8faff; }
/* Nummer-Felder: rechts ausgerichtet, ohne Spinner */
.ke-inline-num { width:80px; text-align:right; }
.ke-inline-num::-webkit-outer-spin-button,
.ke-inline-num::-webkit-inner-spin-button { -webkit-appearance:none; margin:0; }
.ke-inline-num[type=number] { -moz-appearance:textfield; }
.ke-inline-select {
  border:1px solid var(--border); border-radius:2px; padding:4px 6px;
  font-size:0.82rem; outline:none; background:#fff; color:var(--text); font-family:inherit;
}

/* Zellen */
.ke-td { padding:8px 10px; border-bottom:1px solid #eef0f3; white-space:nowrap; line-height:1.3; height:34px; box-sizing:border-box; }
.ke-td-num { text-align:right; font-variant-numeric:tabular-nums; }
.ke-td-center { text-align:center; }

.ke-td-name { min-width:280px; position:relative; }
.ke-td-name .ke-toggle {
  cursor:pointer; display:inline-flex; align-items:center;
  color:var(--muted); margin-right:4px; vertical-align:middle;
}
.ke-td-name .ke-kg { color:var(--muted); margin-right:6px; font-weight:500; font-size:0.75rem; }

/* + Position Button */
.ke-td-name .ke-pos-btn {
  display:inline-flex; align-items:center; gap:4px;
  padding:2px 10px; border-radius:5px; border:1px solid var(--border-mid);
  cursor:pointer; opacity:0; transition:opacity 0.15s; color:var(--text);
  background:#fff; font-size:0.78rem; margin-left:10px; vertical-align:middle;
  font-weight:500;
}
.ke-row:hover .ke-pos-btn { opacity:1; }
.ke-pos-btn:hover { background:#f3f4f6; border-color:var(--border-mid); }

/* Drei-Punkte-Menü */
.ke-td-name .ke-more-btn {
  display:inline-flex; align-items:center; justify-content:center;
  width:22px; height:22px; border-radius:4px; border:1px solid transparent;
  cursor:pointer; opacity:0; transition:opacity 0.15s; color:var(--muted);
  background:transparent; font-size:14px; margin-left:4px; vertical-align:middle;
}
.ke-row:hover .ke-more-btn { opacity:0.6; }
.ke-more-btn:hover { opacity:1 !important; background:#f0f0f5; border-color:var(--border); }

/* Context-Menü */
.ke-context-menu {
  position:absolute; top:100%; left:0; margin-top:2px;
  background:#fff; border:1px solid var(--border-mid); border-radius:8px;
  box-shadow:0 4px 12px rgba(0,0,0,0.12); z-index:60;
  min-width:170px; padding:4px 0; font-weight:400;
}
.ke-context-item {
  padding:7px 14px; cursor:pointer; font-size:0.82rem; color:var(--text);
  display:flex; align-items:center; gap:8px;
}
.ke-context-item:hover { background:#f3f4f6; }
.ke-context-item.danger { color:#dc2626; }
.ke-context-item.danger:hover { background:#fef2f2; }
.ke-context-sep { height:1px; background:var(--border); margin:4px 0; }
.ke-context-has-sub { position:relative; }
.ke-color-sub {
  position:absolute; left:100%; top:0; margin-left:2px;
  background:#fff; border:1px solid var(--border-mid); border-radius:8px;
  box-shadow:0 4px 12px rgba(0,0,0,0.12); z-index:61;
  min-width:130px; padding:4px 0;
}
.ke-color-dot {
  display:inline-block; width:14px; height:14px; border-radius:4px;
  font-size:9px; line-height:14px; text-align:center;
}

/* Alte add-btn (für Subgroups-Ebene) */
.ke-td-name .ke-add-btn {
  display:inline-flex; align-items:center; justify-content:center;
  width:20px; height:20px; border-radius:4px; border:1px solid transparent;
  cursor:pointer; opacity:0; transition:opacity 0.15s; color:var(--muted);
  background:transparent; font-size:14px; margin-left:6px; vertical-align:middle;
}
.ke-row:hover .ke-add-btn { opacity:0.5; }
.ke-add-btn:hover { opacity:1 !important; background:#f0f0f5; border-color:var(--border); }

/* Summenzeilen */
.ke-row-sum { font-weight:600; background:#f9fafb; }
.ke-row-sum-bold { font-weight:700; background:#f3f4f6; }
.ke-row-sum td { border-top:2px solid var(--text); }

/* Leerer Zustand */
.ke-empty { text-align:center; padding:60px 20px !important; color:var(--muted); font-size:0.9rem; }

/* ── Footer ──────────────────────────────────────────────── */
.ke-footer {
  display:flex; justify-content:flex-end; align-items:center; gap:20px;
  padding:10px 16px; border-top:1px solid var(--border);
  background:var(--surface); font-size:0.78rem; color:var(--muted);
}
.ke-footer strong { color:var(--text); font-weight:700; }

/* ── Views / Navigation ─────────────────────────────────── */
.ke-view { }
.ke-view-header {
  display:flex; align-items:flex-start; justify-content:space-between;
  flex-wrap:wrap; gap:12px; padding:32px 24px 0;
}
.ke-subtitle { color:var(--muted); font-size:0.88rem; margin:6px 0 0; padding:0 24px; }
.ke-view-nav { padding:16px 24px 0; }

/* Zurück-Button */
.ke-back-btn {
  background:none; border:none; color:var(--primary); cursor:pointer;
  font-size:0.84rem; padding:0; display:flex; align-items:center; gap:4px;
}
.ke-back-btn:hover { text-decoration:underline; }

/* Breadcrumb in Toolbar */
.ke-breadcrumb { font-size:0.82rem; display:flex; align-items:center; gap:6px; }
.ke-breadcrumb-nr { color:var(--muted); font-weight:500; }
.ke-breadcrumb-pname { color:var(--text); }
.ke-breadcrumb-arrow { color:var(--muted); }
.ke-breadcrumb-name { color:var(--text); font-weight:600; cursor:pointer; padding:2px 6px; border-radius:4px; transition:background 0.15s; }
.ke-breadcrumb-name:hover { background:var(--surface); }
.ke-toolbar-sep { color:var(--border); margin:0 4px; }

/* Meine/Alle Toggle */
.ke-toggle-wrap {
  display:flex; align-items:center; gap:0;
  background:var(--border); border-radius:8px; padding:3px; flex-shrink:0;
}
.ke-toggle-btn {
  padding:6px 18px; border-radius:6px; border:none; cursor:pointer;
  font-size:0.82rem; font-weight:400;
  background:transparent; color:var(--muted);
  transition:all 0.15s;
}
.ke-toggle-btn.active {
  background:var(--surface); color:var(--text); font-weight:600;
  box-shadow:0 1px 3px rgba(0,0,0,0.08);
}

/* Card Grid */
.ke-card-grid {
  display:grid; grid-template-columns:repeat(auto-fill, minmax(270px, 1fr));
  gap:16px; padding:20px 24px;
}

/* Projekt-Karte */
.ke-card {
  background:var(--surface); border-radius:10px; padding:20px 22px;
  cursor:pointer; border:1.5px solid var(--border);
  transition:all 0.15s; box-shadow:0 1px 3px rgba(0,0,0,0.04);
}
.ke-card:hover {
  border-color:var(--primary); box-shadow:0 2px 12px rgba(108,140,255,0.15);
}
.ke-card-nr { font-size:0.75rem; color:var(--muted); margin-bottom:6px; }
.ke-card-name { font-weight:600; font-size:0.95rem; color:var(--text); margin-bottom:12px; }
.ke-card-meta {
  display:flex; align-items:center; gap:8px;
  font-size:0.8rem; color:var(--muted);
}
.ke-card-meta svg { flex-shrink:0; }

/* Schätzungs-Karte */
.ke-est-card {
  background:var(--surface); border-radius:10px; padding:20px 22px;
  cursor:pointer; border:1.5px solid var(--border);
  transition:all 0.15s; box-shadow:0 1px 3px rgba(0,0,0,0.04);
}
.ke-est-card:hover {
  border-color:var(--primary); box-shadow:0 2px 12px rgba(108,140,255,0.15);
}
.ke-est-card-head { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:10px; }
.ke-est-card-name { font-weight:600; font-size:0.95rem; color:var(--text); }
.ke-est-card-date { font-size:0.78rem; color:var(--muted); margin-top:3px; }
.ke-est-card-badge {
  font-size:0.7rem; font-weight:600; padding:3px 10px; border-radius:20px;
  text-transform:uppercase; letter-spacing:0.03em;
}
.ke-est-card-badge.aktiv { background:#e8f5e9; color:#2e7d32; }
.ke-est-card-badge.entwurf { background:#fff3e0; color:#e65100; }
.ke-est-card-badge.freigegeben { background:#e3f2fd; color:#1565c0; }
.ke-est-card-badge.archiviert { background:#f5f5f5; color:#757575; }
.ke-est-card-total { font-size:1.25rem; font-weight:700; color:var(--text); margin-top:12px; letter-spacing:-0.01em; }
.ke-est-card-type { font-size:0.78rem; color:var(--muted); margin-top:4px; }

/* Neue Schätzung Karte */
.ke-new-card {
  background:rgba(108,140,255,0.03); border-radius:10px; padding:20px 22px;
  cursor:pointer; border:1.5px dashed rgba(108,140,255,0.35);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  min-height:140px; transition:all 0.15s;
}
.ke-new-card:hover { border-color:var(--primary); background:rgba(108,140,255,0.06); }
.ke-new-card-icon {
  width:44px; height:44px; border-radius:50%;
  background:rgba(108,140,255,0.1); display:flex; align-items:center; justify-content:center;
  margin-bottom:12px;
}
.ke-new-card-label { font-weight:600; font-size:0.9rem; color:var(--primary); }
.ke-new-card-sub { font-size:0.78rem; color:var(--muted); margin-top:4px; }

/* ── Netto/Brutto Toggle ─────────────────────────────────── */
.ke-netto-brutto-toggle {
  display:inline-flex; border:1.5px solid var(--border-mid); border-radius:6px; overflow:hidden;
}
.ke-nb-btn {
  padding:4px 12px; font-size:12px; font-weight:600; cursor:pointer;
  border:none; background:#fff; color:var(--muted); font-family:inherit;
  transition:all 0.15s;
}
.ke-nb-btn:first-child { border-right:1.5px solid var(--border-mid); }
.ke-nb-btn:hover { color:var(--text); background:var(--surface2); }
.ke-nb-btn.active { background:var(--primary); color:#fff; }

/* Projekt-Nr über Titel */
.ke-project-nr { display:block; font-size:0.82rem; color:var(--muted); margin:0 0 2px; }

/* ── Viewmode-Buttons (DIN 276 Level + Gewerke) ─────────── */
.ke-viewmode-wrap {
  display:flex; align-items:center; gap:4px;
}
.ke-viewmode-label {
  font-size:11px; color:var(--muted); margin-right:4px; font-weight:500;
}
.ke-level-btn, .ke-gewerke-btn {
  background:none; border:1px solid var(--border); border-radius:4px;
  padding:3px 10px; font-size:12px; cursor:pointer; color:var(--muted);
  transition:all 0.15s; font-weight:500;
}
.ke-level-btn:hover, .ke-gewerke-btn:hover {
  background:var(--surface2); color:var(--text);
}
.ke-level-btn.active {
  background:var(--primary); color:#fff; border-color:var(--primary);
}
.ke-gewerke-btn {
  margin-left:8px; padding:3px 14px;
}
.ke-gewerke-btn.active {
  background:var(--primary); color:#fff; border-color:var(--primary);
}

/* Bauteil-Toggle */
.ke-bauteil-btn {
  background:none; border:1px solid var(--border); border-radius:4px;
  padding:3px 12px; font-size:12px; cursor:pointer; color:var(--muted);
  transition:all 0.15s; font-weight:600; display:inline-flex; align-items:center; gap:5px;
}
.ke-bauteil-btn:hover { background:#ecfdf5; color:#059669; border-color:#6ee7b7; }
.ke-bauteil-btn.active { background:#ecfdf5; color:#059669; border-color:#6ee7b7; }

/* Bauteil-Gruppen-Header */
.ke-row-bauteil-header { background:#f0fdf4; border-bottom:1px solid #d1fae5; border-left:3px solid #6ee7b7; }
.ke-row-bauteil-header:hover { background:#ecfdf5; }

/* ── Steuerelemente (+ / Dreiecke / Drag) ────────────────── */
.ke-td-ctrl { padding:4px 2px !important; width:44px; }
.ke-ctrl-wrap {
  display:flex; align-items:center; justify-content:center; gap:4px;
}
.ke-add-btn {
  background:none; border:1px solid var(--border); border-radius:4px;
  width:20px; height:20px; font-size:14px; line-height:18px;
  cursor:pointer; color:var(--muted); transition:opacity 0.15s;
  flex-shrink:0; display:flex; align-items:center; justify-content:center;
  opacity:0;
}
.ke-row:hover .ke-add-btn, .ke-row-hover .ke-add-btn { opacity:1; }
.ke-add-btn:hover { border-color:var(--primary); color:var(--primary); }

.ke-collapse-btn {
  width:16px; text-align:center; cursor:pointer; flex-shrink:0;
  user-select:none; color:var(--muted);
}
.ke-collapse-btn:hover { color:var(--text); }

.ke-drag-handle {
  width:16px; text-align:center; cursor:grab; flex-shrink:0;
  color:var(--muted); font-size:14px; opacity:0;
  transition:opacity 0.15s; user-select:none;
}
.ke-row:hover .ke-drag-handle, .ke-row-hover .ke-drag-handle { opacity:0.6; }
.ke-drag-handle:hover { opacity:1 !important; }

/* ── Lösch-Button ────────────────────────────────────────── */
.ke-del-btn {
  background:none; border:none; cursor:pointer;
  color:var(--muted); font-size:16px; font-weight:700;
  opacity:0; transition:opacity 0.15s; padding:2px 6px;
}
.ke-row:hover .ke-del-btn, .ke-row-hover .ke-del-btn { opacity:0.7; }
.ke-del-btn:hover { color:var(--danger); opacity:1 !important; }

/* ── Kontextmenü-Button (⋮) ─────────────────────────────── */
.ke-ctx-btn {
  background:none; border:1px solid transparent; border-radius:4px; cursor:pointer;
  width:20px; height:20px; display:flex; align-items:center; justify-content:center;
  color:var(--muted); font-size:14px; font-weight:700; padding:0;
  opacity:0; transition:all 0.15s;
}
.ke-row:hover .ke-ctx-btn, .ke-row-hover .ke-ctx-btn { opacity:0.6; }
.ke-ctx-btn:hover { opacity:1 !important; background:var(--surface2); border-color:var(--border); color:var(--text); }

/* ── Kontextmenü ─────────────────────────────────────────── */
.ke-context-menu {
  position:fixed; z-index:1000;
  background:#fff; border-radius:12px;
  box-shadow:0 4px 24px rgba(0,0,0,0.15), 0 0 0 1px rgba(0,0,0,0.05);
  padding:6px 0; min-width:240px; font-size:14px;
  font-family:-apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}
.ke-ctx-item {
  display:flex; align-items:center; gap:10px; padding:9px 16px; cursor:pointer;
  color:#1a1a1a; transition:background 0.1s; position:relative;
}
.ke-ctx-item svg { flex-shrink:0; color:#6b7280; }
.ke-ctx-item:hover { background:#f3f4f6; }
.ke-ctx-item-danger { color:#ef4444; }
.ke-ctx-item-danger svg { color:#ef4444; }
.ke-ctx-item-danger:hover { background:#fef2f2; }
.ke-ctx-sep { border-top:1px solid #e5e7eb; margin:4px 0; }

/* Farb-Submenu */
.ke-ctx-item-color { position:relative; }
.ke-ctx-color-panel {
  position:absolute; left:100%; top:-4px; margin-left:4px;
  background:#fff; border-radius:10px;
  box-shadow:0 4px 16px rgba(0,0,0,0.12), 0 0 0 1px rgba(0,0,0,0.05);
  padding:10px 12px; min-width:180; z-index:1001;
}
.ke-ctx-color-label {
  font-size:11px; color:#9ca3af; font-weight:500; margin-bottom:8px;
  text-transform:uppercase; letter-spacing:0.5px;
}
.ke-ctx-color-dots { display:flex; gap:6px; flex-wrap:wrap; }
.ke-ctx-color-dot {
  width:26px; height:26px; border-radius:50%; cursor:pointer;
  display:inline-flex; align-items:center; justify-content:center;
  transition:transform 0.1s, border-color 0.15s;
}
.ke-ctx-color-dot:hover { transform:scale(1.15); }

/* ── Eventualposition (EP) ───────────────────────────────── */
.ke-ep-badge {
  display:inline-flex; align-items:center; justify-content:center;
  background:#f3f4f6; color:#6b7280; font-size:9px; font-weight:700;
  padding:1px 5px; border-radius:3px; letter-spacing:0.5px;
  border:1px solid #d1d5db; flex-shrink:0; vertical-align:middle;
}
.ke-row-ep { opacity:0.7; }
.ke-row-ep:hover { opacity:0.85; }

/* ── Bezugswert-Popup (%-Positionen) ─────────────────────── */
.ke-bw-info-btn {
  background:none; border:none; cursor:pointer; color:#6366f1;
  padding:1px; border-radius:3px; display:inline-flex; align-items:center;
  vertical-align:middle; margin-left:3px; transition:background 0.15s;
}
.ke-bw-info-btn:hover { background:#eef2ff; }
.ke-td-ep-pct .ke-ep-pct-wrap {
  display:flex; align-items:center; gap:4px;
  justify-content:flex-end;
}
.ke-bw-ref-badge {
  display:inline-flex; align-items:center; gap:4px; margin-top:2px;
  font-size:10px; color:#6366f1; background:#eef2ff;
  padding:1px 7px; border-radius:3px; border:1px solid #c7d2fe;
  line-height:1.3;
}
.ke-bw-popup {
  background:#fff; border-radius:14px;
  box-shadow:0 20px 60px rgba(0,0,0,0.18), 0 4px 16px rgba(0,0,0,0.08);
  border:1px solid #e5e7eb; width:360px; overflow:hidden;
  animation:ke-bw-popup-in 0.15s ease-out;
}
@keyframes ke-bw-popup-in {
  from { opacity:0; transform:translateY(-6px); }
  to { opacity:1; transform:translateY(0); }
}
.ke-bw-popup-title {
  padding:14px 16px 2px; font-size:13px; font-weight:700; color:#1f2937;
}
.ke-bw-popup-subtitle {
  padding:0 16px 10px; font-size:11px; color:#9ca3af;
}
.ke-bw-popup-list {
  max-height:380px; overflow-y:auto; padding:0 6px 6px;
}
.ke-bw-popup-divider {
  border-top:1px solid #e5e7eb; margin:4px 10px;
}
.ke-bw-popup-item {
  display:flex; align-items:center; justify-content:space-between; gap:8px;
  width:100%; padding:9px 12px; border:none; background:none; cursor:pointer;
  border-radius:8px; text-align:left; font-size:13px; color:#374151;
  transition:background 0.1s;
}
.ke-bw-popup-item:hover { background:#f3f4f6; }
.ke-bw-popup-item.active { background:#eef2ff; color:#4338ca; }
.ke-bw-popup-item-left { flex:1; min-width:0; }
.ke-bw-popup-item-label { font-weight:500; }
.ke-bw-popup-item-desc { font-size:11px; color:#9ca3af; margin-top:1px; }
.ke-bw-popup-item.active .ke-bw-popup-item-desc { color:#818cf8; }
.ke-bw-popup-item-right {
  display:flex; align-items:center; gap:6px; flex-shrink:0;
}
.ke-bw-popup-item-sum {
  font-size:12px; font-weight:500; color:#6b7280;
  font-variant-numeric:tabular-nums;
}
.ke-bw-popup-item.active .ke-bw-popup-item-sum { color:#6366f1; }

/* ── PDF-Export-Dialog ───────────────────────────────────── */
.ke-pdf-section { margin-bottom:20px; }
.ke-pdf-section-title {
  font-size:12px; font-weight:700; color:var(--text); margin-bottom:8px;
  text-transform:uppercase; letter-spacing:0.5px;
}
.ke-pdf-sublabel { font-size:11px; color:var(--muted); margin-bottom:6px; font-weight:500; }
.ke-pdf-chips { display:flex; gap:6px; flex-wrap:wrap; }
.ke-pdf-chip {
  padding:6px 14px; border-radius:6px; font-size:12px; font-weight:600; cursor:pointer;
  border:1.5px solid var(--border); background:#fff; color:var(--text);
  transition:all 0.15s;
}
.ke-pdf-chip:hover { border-color:var(--primary); color:var(--primary); }
.ke-pdf-chip.active { background:var(--primary); color:#fff; border-color:var(--primary); }
.ke-pdf-check {
  display:flex; align-items:center; gap:8px; padding:5px 0; font-size:13px;
  color:var(--text); cursor:pointer; user-select:none;
}
.ke-pdf-check input[type="checkbox"],
.ke-pdf-check input[type="radio"] { accent-color:var(--primary); margin:0; }
.ke-pdf-pflicht { font-size:10px; color:var(--muted); margin-left:auto; }
.ke-pdf-hint { font-size:11px; color:var(--muted); }

/* ── Inline-Editing ──────────────────────────────────────── */
.ke-td:has(.ke-edit-input) { padding:3px 4px; }
.ke-edit-input {
  width:100%; height:100%; min-height:26px; padding:2px 6px;
  border:2px solid var(--primary); border-radius:2px;
  font-size:13px; outline:none; background:#eff6ff;
  box-sizing:border-box; font-family:inherit;
}
.ke-edit-input:focus { box-shadow:0 0 0 2px rgba(59,130,246,0.15); }

select.ke-edit-input { padding:2px 2px; }

/* ── KG-Spalte fixiert ──────────────────────────────────── */
.ke-td-kg { max-width:150px; overflow:hidden; text-overflow:ellipsis; }
select.ke-select-kg { max-width:142px; }

/* ── Row-Hover & Drag-Drop ───────────────────────────────── */
.ke-row-hover { background:var(--surface) !important; }
.ke-row-l1 { background:#f8f9fa; border-bottom:1px solid #e5e7eb; }
.ke-row-l2 { background:#fcfcfd; border-bottom:1px solid #f0f0f0; }
.ke-row-l3 { border-bottom:1px solid #f3f4f6; }
.ke-row-l3-header { background:#f9fafb; border-bottom:1px solid #f0f0f0; }
.ke-row-gw-header { background:#f8f9fa; border-bottom:1px solid #e5e7eb; }
.ke-drop-target { background:#dbeafe !important; }
.ke-drop-above { border-top:2px solid var(--primary) !important; }
.ke-drop-below { border-bottom:2px solid var(--primary) !important; }

/* ── Gewerke-Ansicht Header ──────────────────────────────── */
.ke-row-gw-header td { padding:10px 8px; }

/* ── Responsive ──────────────────────────────────────────── */
@media (max-width:900px) {
  .ke-toolbar { padding:8px 10px; }
  .ke-title { font-size:0.95rem; }
  .ke-select { min-width:140px; }
  .ke-view-header { padding:20px 16px 0; }
  .ke-card-grid { padding:16px; }
  .ke-subtitle { padding:0 16px; }
}


/* ═══════════════════════════════════════════════════════════ */
/* Angebote & Rechnungen                                       */
/* ═══════════════════════════════════════════════════════════ */

/* Summary Cards */
.ang-summary-cards {
  display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:20px;
}
.ang-summary-card {
  background:#fff; border-radius:12px; padding:14px 18px;
  border:1px solid var(--border); display:flex; align-items:center; gap:12px;
}
.ang-summary-icon {
  width:38px; height:38px; border-radius:10px; display:flex;
  align-items:center; justify-content:center; font-size:17px; flex-shrink:0;
}
.ang-summary-label {
  font-size:11px; color:var(--muted); font-weight:600;
  text-transform:uppercase; letter-spacing:0.04em;
}
.ang-summary-value {
  font-size:16px; font-weight:700; color:var(--text); margin-top:1px;
  font-variant-numeric:tabular-nums;
}

/* Tabs */
.ang-tabs { display:flex; gap:0; }
.ang-tab {
  padding:8px 16px; font-size:13px; font-weight:600; cursor:pointer;
  border:none; border-bottom:2px solid transparent;
  background:none; color:var(--muted); transition:all 0.15s;
}
.ang-tab.active { color:var(--primary); border-bottom-color:var(--primary); }
.ang-tab-count {
  margin-left:5px; padding:1px 7px; border-radius:10px; font-size:11px;
  background:#f3f4f6; color:var(--muted);
}
.ang-tab.active .ang-tab-count { background:#eff6ff; color:var(--primary); }

/* Filters */
.ang-filters { display:flex; gap:5px; }
.ang-filter-btn {
  padding:4px 11px; border-radius:6px; font-size:12px; font-weight:500;
  cursor:pointer; border:1.5px solid var(--border); background:#fff; color:#6b7280;
  transition:all 0.15s;
}
.ang-filter-btn.active { border-color:var(--primary); background:#eff6ff; color:var(--primary); }

/* Status Badges */
.ang-status { display:inline-flex; align-items:center; gap:4px; padding:3px 9px; border-radius:20px; font-size:11px; font-weight:600; }
.ang-status-dot { width:6px; height:6px; border-radius:3px; }

.ang-status-entwurf    { background:#f3f4f6; color:#6b7280; }
.ang-status-entwurf .ang-status-dot { background:#9ca3af; }
.ang-status-offen      { background:#eff6ff; color:#2563eb; }
.ang-status-offen .ang-status-dot { background:#3b82f6; }
.ang-status-beauftragt { background:#f0fdf4; color:#16a34a; }
.ang-status-beauftragt .ang-status-dot { background:#22c55e; }
.ang-status-abgelehnt  { background:#fef2f2; color:#dc2626; }
.ang-status-abgelehnt .ang-status-dot { background:#ef4444; }
.ang-status-abgeschlossen { background:#f5f3ff; color:#7c3aed; }
.ang-status-abgeschlossen .ang-status-dot { background:#8b5cf6; }
.ang-status-bezahlt    { background:#f0fdf4; color:#16a34a; }
.ang-status-bezahlt .ang-status-dot { background:#22c55e; }
.ang-status-ueberfaellig { background:#fef2f2; color:#dc2626; }
.ang-status-ueberfaellig .ang-status-dot { background:#ef4444; }
.ang-status-storniert  { background:#f3f4f6; color:#6b7280; }
.ang-status-storniert .ang-status-dot { background:#9ca3af; }

/* Progress Bar */
.ang-progress { display:flex; align-items:center; gap:8px; }
.ang-progress-bar { flex:1; height:6px; border-radius:3px; background:#f0f0f2; overflow:hidden; }
.ang-progress-fill { height:100%; border-radius:3px; background:var(--primary); transition:width 0.3s; }
.ang-progress-fill.full { background:#22c55e; }
.ang-progress-pct { font-size:11px; color:var(--muted); white-space:nowrap; }

/* Table */
.ang-table { width:100%; border-collapse:collapse; font-size:13px; }
.ang-table th {
  padding:9px 14px; text-align:left; font-size:11px; font-weight:600;
  color:var(--muted); text-transform:uppercase; letter-spacing:0.04em;
  border-bottom:2px solid var(--border); background:#fafbfc;
}
.ang-table th.right { text-align:right; }
.ang-table td { padding:11px 14px; border-bottom:1px solid #f0f0f2; }
.ang-table td.right { text-align:right; }
.ang-table td.num { font-variant-numeric:tabular-nums; font-weight:600; }
.ang-table tbody tr { cursor:pointer; transition:background 0.1s; }
.ang-table tbody tr:hover { background:#f8fafc; }
.ang-table .ang-link { font-weight:600; color:var(--primary); }
.ang-table .ang-sub { font-size:11px; color:var(--muted); }

/* Editor Header (sticky) */
.ang-editor-header {
  background:#fff; border-bottom:1px solid var(--border); padding:12px 28px;
  display:flex; align-items:center; gap:14px; position:sticky; top:0; z-index:20;
}
.ang-back-btn {
  display:flex; align-items:center; gap:5px; padding:5px 13px; border-radius:8px;
  border:1.5px solid var(--border); background:#fff; font-size:13px; font-weight:600;
  cursor:pointer; color:var(--text);
}

/* Positions Table in Editor */
.ang-pos-table { width:100%; border-collapse:collapse; font-size:13px; }
.ang-pos-table th {
  padding:8px 14px; text-align:left; font-size:11px; font-weight:600;
  color:var(--muted); text-transform:uppercase; letter-spacing:0.04em;
  border-bottom:2px solid var(--border); background:#fafbfc;
}
.ang-pos-table td { padding:10px 14px; border-bottom:1px solid #f0f0f2; }
.ang-pos-type {
  padding:2px 6px; border-radius:4px; font-size:10px; font-weight:700; text-transform:uppercase;
}
.ang-pos-type-hoai { background:#eff6ff; color:var(--primary); }
.ang-pos-type-pos  { background:#f3f4f6; color:#6b7280; }
.ang-pos-type-std  { background:#fef3c7; color:#d97706; }
.ang-pos-type-gruppe  { background:#f0fdf4; color:#16a34a; }
.ang-pos-type-freitext { background:#f5f3ff; color:#7c3aed; }

/* Summenbereich */
.ang-sums { background:#fafbfc; border-top:2px solid var(--text); }
.ang-sum-row { display:flex; align-items:center; justify-content:space-between; padding:9px 20px; }
.ang-sum-row + .ang-sum-row { border-top:1px solid var(--border); }
.ang-sum-row.bold { border-top:2px solid var(--text); }
.ang-sum-label { font-size:13px; color:var(--text); }
.ang-sum-label-bold { font-size:14px; font-weight:700; color:var(--text); }
.ang-sum-value { font-size:13px; font-weight:600; color:var(--text); font-variant-numeric:tabular-nums; min-width:130px; text-align:right; }
.ang-sum-value-bold { font-size:15px; font-weight:700; }
.ang-sum-value-big  { font-size:17px; font-weight:700; }
.ang-sum-input { width:60px; padding:4px 8px; border:1.5px solid var(--border); border-radius:6px; text-align:center; font-size:13px; }

/* Add Menu */
.ang-add-menu {
  position:absolute; top:100%; right:0; margin-top:6px; background:#fff;
  border-radius:12px; border:1px solid var(--border); box-shadow:0 8px 30px rgba(0,0,0,0.12);
  width:280px; z-index:30; overflow:hidden;
}
.ang-add-item {
  display:flex; align-items:center; gap:10px; padding:11px 14px; cursor:pointer;
  border-bottom:1px solid #f0f0f2; transition:background 0.1s;
}
.ang-add-item:last-child { border-bottom:none; }
.ang-add-item:hover { background:#f8fafc; }
.ang-add-icon { font-size:17px; width:30px; text-align:center; }
.ang-add-label { font-size:13px; font-weight:600; color:var(--text); }
.ang-add-desc { font-size:11px; color:var(--muted); }

/* HOAI Wizard Stepper */
/* ── HOAI Wizard Slide Viewport ───────────────────────────── */
.hoai-wiz-viewport {
  height:800px; overflow:hidden; position:relative;
}
.hoai-wiz-track {
  display:flex; width:400%; height:100%;
  transition:transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}
.hoai-wiz-page {
  width:25%; height:100%; overflow-y:auto; padding:20px; flex-shrink:0;
}

.hoai-stepper {
  display:flex; padding:16px 20px; border-bottom:1px solid var(--border); gap:4px;
}
.hoai-step {
  flex:1; text-align:center; cursor:pointer; padding-bottom:8px;
  border-bottom:2px solid transparent; transition:all 0.15s;
}
.hoai-step.active { border-bottom-color:var(--primary); }
.hoai-step.done   { border-bottom-color:var(--primary); opacity:0.5; }
.hoai-step-label { font-size:11px; font-weight:600; color:var(--muted); }
.hoai-step.active .hoai-step-label { color:var(--primary); }
.hoai-step.done .hoai-step-label   { color:var(--primary); }

/* HOAI Wizard content */
.hoai-lb-card {
  display:flex; align-items:flex-start; gap:12px; padding:11px 14px;
  border-radius:10px; cursor:pointer; transition:all 0.15s;
  border:1.5px solid var(--border); background:#fff; margin-bottom:6px;
}
.hoai-lb-card.selected { border-color:var(--primary); background:#eff6ff; }
.hoai-lb-radio {
  width:16px; height:16px; border-radius:8px; margin-top:3px; flex-shrink:0;
  box-sizing:border-box; border:2px solid #d2d2d7; background:#fff;
}
.hoai-lb-card.selected .hoai-lb-radio { border:5px solid var(--primary); }
.hoai-lb-par { font-size:13px; font-weight:700; color:var(--primary); }
.hoai-lb-name { font-size:13px; font-weight:600; color:var(--text); }
.hoai-lb-info { font-size:12px; color:#6b7280; margin-top:3px; line-height:1.5; }

.hoai-hz-card {
  flex:1; padding:12px; border-radius:10px; cursor:pointer; text-align:center;
  border:1.5px solid var(--border); background:#fff; transition:all 0.15s;
}
.hoai-hz-card.selected { border-color:var(--primary); background:#eff6ff; }
.hoai-hz-nr { font-size:18px; font-weight:800; color:var(--text); }
.hoai-hz-card.selected .hoai-hz-nr { color:var(--primary); }
.hoai-hz-label { font-size:10px; color:var(--muted); margin-top:4px; }

/* ── HOAI Info-Icon (Mouseover-Tooltip) ──────────────────── */
.hoai-info-icon {
  display:inline-flex; align-items:center; justify-content:center;
  width:16px; height:16px; border-radius:50%;
  border:1.5px solid #9ca3af;
  background:none;
  font-size:10px; font-weight:700; font-style:italic; font-family:Georgia,serif;
  color:#6b7280; cursor:help; flex-shrink:0;
  transition:all 0.15s;
}
.hoai-info-icon:hover { background:#eff6ff; border-color:var(--primary); color:var(--primary); }

/* Legacy: .hoai-info-btn bleibt für Rückwärtskompatibilität */
.hoai-info-btn {
  display:inline-flex; align-items:center; justify-content:center;
  width:16px; height:16px; border-radius:8px; border:1.5px solid #d2d2d7;
  background:none; font-size:10px; color:#86868b; cursor:help; flex-shrink:0; padding:0;
}
.hoai-info-btn:hover { background:#f0f0f2; }

/* ── HOAI Mouseover-Tooltip ──────────────────────────────── */
.hoai-tooltip {
  position:fixed;
  z-index:1300;
  background:#1d1d1f;
  color:#e5e5ea;
  border-radius:10px;
  padding:12px 16px;
  font-size:12px;
  line-height:1.6;
  max-width:380px;
  box-shadow:0 8px 30px rgba(0,0,0,0.3), 0 2px 8px rgba(0,0,0,0.2);
  pointer-events:auto;
  animation:hoai-tip-in 0.12s ease;
}
@keyframes hoai-tip-in { from { opacity:0; transform:translateY(4px); } to { opacity:1; transform:translateY(0); } }
.hoai-tooltip b { color:#fff; font-weight:700; }
.hoai-tooltip a.hoai-tooltip-link {
  display:inline-block;
  margin-top:6px;
  color:#60a5fa;
  font-size:11px;
  font-weight:600;
  text-decoration:none;
  border-top:1px solid rgba(255,255,255,0.1);
  padding-top:6px;
}
.hoai-tooltip a.hoai-tooltip-link:hover { color:#93c5fd; text-decoration:underline; }

/* HOAI Info Overlay (Legacy Fallback) */
.hoai-info-overlay {
  position:fixed; inset:0; background:rgba(0,0,0,0.6); z-index:1100;
  display:flex; align-items:center; justify-content:center;
}
.hoai-info-box {
  background:#1d1d1f; color:#fff; border-radius:14px; padding:24px 28px;
  max-width:560px; max-height:80vh; overflow-y:auto;
}
.hoai-info-box h4 { margin:0 0 10px; font-size:15px; }
.hoai-info-box p  { margin:0; font-size:13px; line-height:1.7; color:#d2d2d7; }

/* HOAI Zuschläge/Nachlass Tabelle */
.hoai-sums-table {
  margin-top:16px; border-top:1px solid var(--border); padding-top:6px;
}
.hoai-sum-row {
  display:grid; grid-template-columns:1fr 140px 110px; align-items:center;
  padding:8px 4px; border-bottom:1px solid #f0f0f2; font-size:13px; gap:8px;
}
.hoai-sum-row.hoai-sum-bold { font-weight:700; border-bottom:1px solid #d4d4d8; }
.hoai-sum-val { text-align:right; font-variant-numeric:tabular-nums; color:#6b7280; }
.hoai-sum-val-bold { text-align:right; font-variant-numeric:tabular-nums; font-weight:700; }

/* ── KG-Dialog (Anrechenbare Kosten Detail) ────────────────── */
.hoai-kg-overlay {
  position:fixed; inset:0;
  background:rgba(0,0,0,0.45);
  backdrop-filter:blur(4px);
  z-index:1200;
  display:flex; align-items:center; justify-content:center;
  padding:20px;
  animation:hoai-kg-fadein 0.15s ease;
}
@keyframes hoai-kg-fadein { from { opacity:0; } to { opacity:1; } }
.hoai-kg-modal {
  background:var(--surface);
  border-radius:var(--radius-lg);
  border:1px solid var(--border);
  width:100%;
  max-width:720px;
  max-height:88vh;
  display:flex; flex-direction:column;
  overflow:hidden;
  box-shadow:0 20px 60px rgba(0,0,0,0.18), 0 2px 8px rgba(0,0,0,0.08);
  animation:hoai-kg-slidein 0.18s ease;
}
@keyframes hoai-kg-slidein { from { transform:translateY(12px) scale(0.98); opacity:0; } to { transform:translateY(0) scale(1); opacity:1; } }
.hoai-kg-header {
  display:flex; align-items:center; gap:12px;
  padding:16px 20px;
  border-bottom:1px solid var(--border);
  background:rgba(0,0,0,0.015);
}
.hoai-kg-input {
  border:1px solid var(--border-mid);
  border-radius:6px;
  padding:4px 6px;
  font-size:12px;
  font-family:var(--font);
  background:#fff;
  outline:none;
  transition:border-color 0.15s;
}
.hoai-kg-input:focus {
  border-color:var(--primary);
  box-shadow:0 0 0 2px rgba(0,113,227,0.12);
}
.hoai-kg-technik-badge {
  display:inline-flex; align-items:center; gap:3px;
  padding:3px 8px;
  border-radius:12px;
  background:#dbeafe;
  color:#1d4ed8;
  font-size:11px;
  font-weight:600;
  cursor:pointer;
  transition:background 0.15s;
}
.hoai-kg-technik-badge:hover { background:#bfdbfe; }

/* ── KG Inline (Step 2) ───────────────────────────────────── */
.hoai-kg-estimate-bar {
  display:flex; align-items:center; gap:8px;
  padding:10px 14px;
  background:#fafbfc;
  border:1px solid var(--border);
  border-radius:10px 10px 0 0;
  border-bottom:none;
}
.hoai-kg-estimate-bar label {
  font-size:12px; font-weight:600; color:var(--muted); white-space:nowrap;
}
.hoai-kg-estimate-bar select {
  flex:1; font-size:12px; padding:5px 8px;
  border:1px solid var(--border); border-radius:6px; background:#fff;
  font-family:var(--font);
}
.hoai-kg-table-wrap {
  border:1px solid var(--border);
  border-radius:0 0 10px 10px;
  overflow:hidden;
  margin-bottom:0;
}
.hoai-kg-table-wrap.no-estimate {
  border-radius:10px;
}
.hoai-kg-table {
  width:100%; border-collapse:collapse; font-size:12px;
}
.hoai-kg-table thead th {
  padding:7px 8px; text-align:left;
  font-size:10px; font-weight:600; color:var(--muted);
  text-transform:uppercase; background:#fafbfc;
  border-bottom:2px solid var(--border);
}
.hoai-kg-table tfoot td {
  padding:8px; border-top:2px solid var(--text);
}
.hoai-kg-technik-hint {
  padding:10px 14px; border-radius:8px;
  background:#fffbeb; border:1px solid #fcd34d;
  font-size:12px; color:#92400e; margin-top:10px;
}

/* Invoice mini-cards in editor */
.ang-inv-card {
  display:flex; align-items:center; gap:14px; padding:9px 13px;
  border-radius:8px; border:1px solid var(--border); cursor:pointer;
  transition:background 0.1s; margin-bottom:6px;
}
.ang-inv-card:hover { background:#f8fafc; }

/* Section Title (reused pattern) */
.ang-section-title {
  font-size:12px; font-weight:700; color:var(--text); margin-bottom:10px;
  text-transform:uppercase; letter-spacing:0.5px; display:flex; align-items:center; gap:8px;
}
.ang-section-icon {
  width:26px; height:26px; border-radius:8px; display:inline-flex;
  align-items:center; justify-content:center; flex-shrink:0;
}

/* Nachtrag rows */
.ang-nachtrag-row { background:#fffbeb; }
.ang-nachtrag-row:hover { background:#fef3c7 !important; }

/* Collapsible details in Summenbereich */
.ang-sums details summary {
  padding:10px 20px; font-size:13px; font-weight:600; color:var(--muted);
  cursor:pointer; user-select:none; display:flex; align-items:center; gap:5px;
  border-top:1px solid var(--border); list-style:none;
}
.ang-sums details summary::-webkit-details-marker { display:none; }
.ang-sums details[open] summary svg { transform:rotate(180deg); }
