/* ============================================================
   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; }

/* Modals die über dem Projekt-Popup liegen, ohne doppelten Overlay */
#modal-hoai-wizard,
#modal-contact {
  z-index: 1010;
  background: rgba(0,0,0,0.18);
  backdrop-filter: none;
}
.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; overflow-x: hidden; 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; position: relative; }
.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 {
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
  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;
}

/* ── Bauherr-Karte ────────────────────────────────────────── */
.proj-bauherr-card {
  display:flex; align-items:center; gap:12px;
  padding:12px 14px; border:1px solid var(--border-mid);
  border-radius:10px; background:#fafbfc;
}
.proj-bauherr-avatar {
  width:40px; height:40px; border-radius:10px;
  background:#eff6ff; display:flex; align-items:center; justify-content:center;
  font-size:15px; font-weight:700; color:var(--primary); flex-shrink:0;
}
.proj-bauherr-info { flex:1; min-width:0; }
.proj-bauherr-name { font-weight:600; font-size:13px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.proj-bauherr-detail { font-size:11px; color:var(--muted); margin-top:1px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.proj-bauherr-actions { display:flex; gap:4px; flex-shrink:0; }
.proj-bauherr-action {
  background:none; border:none; cursor:pointer; color:var(--muted);
  padding:4px 6px; border-radius:4px; font-size:12px; display:flex; align-items:center;
}
.proj-bauherr-action:hover { background:#f3f4f6; color:var(--text); }

/* ── Adopt-Button (Vom Bauherrn übernehmen etc.) ──────────── */
.proj-adopt-btn {
  display:inline-flex; align-items:center; gap:4px;
  padding:3px 10px; border-radius:5px; font-size:11px; font-weight:600;
  border:1px solid var(--border-mid); background:#fff; color:var(--muted);
  cursor:pointer; transition:all 0.15s;
}
.proj-adopt-btn:hover { border-color:var(--primary); color:var(--primary); background:#eff6ff; }

/* ── Projektbearbeiter Checkliste ───────────────────────── */
/* ── Projektbearbeiter Chips ──────────────────────────────── */
.proj-members-chips {
  display: flex; flex-wrap: wrap; gap: 6px;
  padding: 8px 10px; min-height: 36px;
  border: 1.5px solid var(--border-mid); border-radius: 8px;
  background: var(--surface1);
}
.proj-member-chip {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 8px; border-radius: 12px;
  background: #f3f4f6; font-size: 11px; font-weight: 500;
  color: var(--text);
}
.proj-member-chip-remove {
  cursor: pointer; color: var(--muted);
  font-size: 13px; line-height: 1;
  margin-left: 2px;
}
.proj-member-chip-remove:hover { color: var(--danger); }

/* + Button neben Label */
.proj-add-btn {
  background: none; border: none;
  color: var(--muted); font-size: 16px; font-weight: 400; line-height: 1;
  cursor: pointer; padding: 0 2px;
  transition: color 0.15s;
}
.proj-add-btn:hover { color: var(--primary); }

/* Dropdown-Liste (Overlay) */
.proj-member-dropdown {
  position: absolute; z-index: 10; left: 0; right: 0;
  border: 1.5px solid var(--border-mid); border-radius: 8px;
  background: #fff; max-height: 140px; overflow-y: auto;
  box-shadow: 0 4px 12px rgba(0,0,0,0.08); margin-top: 4px;
}
.proj-member-dd-item {
  padding: 7px 12px; font-size: 13px; cursor: pointer;
  transition: background 0.1s;
}
.proj-member-dd-item:hover { background: rgba(0,113,227,0.07); }

/* 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 (Custom Dropdown) ───────────────────────── */
.proj-color-dd-wrap { position: relative; }
.proj-color-dd-trigger {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 10px; border: 1.5px solid var(--border-mid); border-radius: 8px;
  background: #fff; cursor: pointer; transition: border-color 0.15s;
  font-size: 0.875rem;
}
.proj-color-dd-trigger:hover { border-color: var(--primary); }
.proj-color-dot {
  width: 14px; height: 14px; border-radius: 50%;
  background: #4A90D9; flex-shrink: 0;
}
.proj-color-dd-label { flex: 1; }
.proj-color-dd-arrow { color: var(--muted); font-size: 10px; }
.proj-color-dd-list {
  position: absolute; bottom: calc(100% + 4px); left: 0; right: 0; z-index: 10;
  border: 1.5px solid var(--border-mid); border-radius: 8px;
  background: #fff; max-height: 180px; overflow-y: auto;
  box-shadow: 0 -4px 12px rgba(0,0,0,0.1);
}
.proj-color-dd-item {
  display: flex; align-items: center; gap: 8px;
  padding: 7px 10px; cursor: pointer; font-size: 13px;
  transition: background 0.1s;
}
.proj-color-dd-item:hover { background: rgba(0,113,227,0.07); }
.proj-color-dd-item-dot {
  width: 12px; height: 12px; border-radius: 50%; flex-shrink: 0;
}

/* ── 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); }

/* ── Angebots-Picker (KG 700) ───────────────────────────── */
.ke-offer-card {
  border:1px solid #e5e7eb; border-radius:10px; padding:14px 18px;
  margin-bottom:10px; cursor:pointer; transition:all 0.15s;
}
.ke-offer-card:hover { border-color:#93c5fd; background:#f0f9ff; box-shadow:0 2px 8px rgba(37,99,235,0.1); }
.ke-offer-linked { border-style:dashed; opacity:0.65; }
.ke-offer-linked:hover { opacity:0.85; }

/* ── 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); }

/* ── Angebot Editor: Positions Redesign ──────────────────── */

/* Position item wrapper */
.ang-pos-item { border-bottom:1px solid #f0f0f0; }

/* Position row (HOAI header, POS/STD/GRP/TXT row) */
.ang-pos-row {
  display:flex; align-items:center; padding:10px 12px; cursor:pointer;
  gap:10px; transition:background 0.15s;
}
.ang-pos-row:hover { background:#fafafa; }

/* Drag handle */
.ang-drag { color:#d2d2d7; cursor:grab; font-size:14px; flex-shrink:0; }

/* Position chevron (16px) */
.ang-pos-chev {
  width:16px; height:16px; color:var(--muted); transition:transform 0.2s; flex-shrink:0;
}
.ang-pos-chev.open { transform:rotate(90deg); }

/* Position title & subtitle */
.ang-pos-title { font-weight:600; font-size:13px; }
.ang-pos-subtitle { font-size:11px; color:var(--muted); margin-top:1px; }

/* Amount column */
.ang-pos-amount {
  font-weight:700; font-size:13px; font-variant-numeric:tabular-nums;
  text-align:right; white-space:nowrap;
}

/* Action buttons */
.ang-pos-actions { display:flex; gap:4px; align-items:center; margin-left:8px; }
.ang-pos-actions button {
  background:none; border:none; cursor:pointer; color:var(--muted);
  padding:4px; border-radius:4px; font-size:13px; line-height:1;
}
.ang-pos-actions button:hover { background:#f3f4f6; color:var(--text); }

/* LP Detail table (inside HOAI) */
.ang-lp-detail { background:#fafbfc; }
.ang-lp-table { width:100%; border-collapse:collapse; font-size:12px; }
.ang-lp-table td { padding:7px 12px; border-bottom:1px solid #f0f0f0; vertical-align:top; }
.ang-lp-table tr:last-child td { border-bottom:none; }

/* LP number column */
.ang-lp-nr {
  font-weight:700; color:var(--primary); width:52px; white-space:nowrap;
  font-size:11px; padding-top:9px !important;
}

/* LP name cell */
.ang-lp-name-cell { /* flex container for name toggle + desc */ }

/* LP name toggle (click to expand desc) */
.ang-lp-name-toggle {
  display:flex; align-items:center; gap:4px; cursor:pointer; user-select:none;
}
.ang-lp-name-toggle:hover { color:var(--primary); }

/* LP name text */
.ang-lp-name { font-weight:600; font-size:12px; }

/* Mini chevron for LP rows (10px) */
.ang-lp-chev {
  width:10px; height:10px; color:var(--muted); transition:transform 0.2s; flex-shrink:0;
}
.ang-lp-chev.open { transform:rotate(90deg); }

/* LP description (hidden by default, contenteditable) */
.ang-lp-desc {
  font-size:11px; color:#555; line-height:1.45; margin-top:4px;
  display:none; padding:6px 8px; border:1px solid transparent; border-radius:4px;
  white-space:pre-wrap;
}
.ang-lp-desc.show { display:block; }
.ang-lp-desc:focus {
  outline:none; border-color:var(--primary); background:#fff;
  box-shadow:0 0 0 2px rgba(0,113,227,0.12);
}

/* LP percentage, unit, base, total columns */
.ang-lp-pct { text-align:center; font-weight:600; width:55px; white-space:nowrap; }
.ang-lp-unit { text-align:center; color:var(--muted); width:75px; font-size:11px; }
.ang-lp-base { text-align:right; color:var(--muted); width:90px; font-variant-numeric:tabular-nums; }
.ang-lp-total { text-align:right; font-weight:600; width:90px; font-variant-numeric:tabular-nums; }

/* Dimmed LP row (unchecked / not commissioned) */
.ang-lp-dim td { opacity:0.4; }

/* HOAI Subtotal row */
.ang-lp-subtotal { background:var(--primary-light); }
.ang-lp-subtotal td { padding:8px 12px; font-weight:700; font-size:12px; }

/* Besondere Leistungen header */
.ang-bes-header-row { background:#f8f9fa; border-top:1px dashed #e0e0e0; }
.ang-bes-header {
  padding:8px 12px 6px 16px; font-size:11px; font-weight:700;
  color:var(--muted); text-transform:uppercase; letter-spacing:0.03em;
}

/* Drag & Drop for positions */
.ang-pos-item[draggable="true"] { cursor:default; }
.ang-drag {
  cursor:grab; user-select:none;
}
.ang-drag:active { cursor:grabbing; }
.ang-pos-drop-above { border-top:2px solid var(--primary) !important; }
.ang-pos-drop-below { border-bottom:2px solid var(--primary) !important; }

/* ═══════════════════════════════════════════════════════════════
   SETTINGS EXTENSIONS — Firmendaten, Briefpapier
   ═══════════════════════════════════════════════════════════════ */

/* Section title inside settings cards */
.settings-section-title {
  font-size: 0.78rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.04em; color: var(--text); margin-bottom: 12px;
}

/* Two-logo upload layout */
.settings-logo-uploads { display: flex; gap: 24px; flex-wrap: wrap; }
.settings-logo-box { display: flex; align-items: center; gap: 16px; }
.settings-logo-area {
  border: 2px dashed var(--border); border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden; background: var(--surface2); position: relative;
}
.settings-logo-area.square { width: 80px; height: 80px; }
.settings-logo-area.wide { width: 200px; height: 80px; }
.settings-logo-area img { width: 100%; height: 100%; object-fit: contain; }
.settings-logo-empty {
  color: var(--muted); font-size: 0.75rem; text-align: center; padding: 8px;
}

/* Toggle button group (Links / Rechts) */
.settings-toggle-group { display: flex; gap: 6px; }
.settings-toggle-btn {
  padding: 6px 14px; border: 1.5px solid var(--border); border-radius: 6px;
  font-size: 0.8rem; cursor: pointer; background: var(--surface);
  color: var(--muted); font-weight: 500; transition: all 0.15s;
}
.settings-toggle-btn.active {
  border-color: var(--primary); color: var(--primary); background: var(--primary-light);
}

/* Switch row (toggle + label) */
.settings-switch-row {
  display: flex; align-items: center; gap: 10px; cursor: pointer;
  font-size: 0.85rem; color: var(--text); font-weight: 500;
}
.settings-switch {
  position: relative; width: 36px; height: 20px; flex-shrink: 0;
}
.settings-switch input { display: none; }
.settings-switch-slider {
  position: absolute; inset: 0; background: #ccc; border-radius: 10px;
  transition: 0.2s;
}
.settings-switch-slider:before {
  content: ''; position: absolute; width: 16px; height: 16px;
  left: 2px; bottom: 2px; background: #fff; border-radius: 50%; transition: 0.2s;
}
.settings-switch input:checked + .settings-switch-slider { background: var(--primary); }
.settings-switch input:checked + .settings-switch-slider:before { transform: translateX(16px); }

/* Info box */
.settings-info-box {
  padding: 12px 14px; background: var(--primary-light); border-radius: 8px;
  border: 1px solid rgba(0,113,227,0.1); font-size: 0.8rem; color: #444; line-height: 1.5;
}

/* Hint box (warning style) */
.settings-hint-box {
  padding: 10px 14px; background: #fefce8; border-radius: 8px;
  border: 1px solid rgba(202,138,4,0.15); font-size: 0.8rem; color: #666; line-height: 1.5;
}

/* Footer preview inside briefpapier settings */
.settings-footer-preview {
  background: var(--surface2); border: 1px solid var(--border); border-radius: 8px;
  padding: 14px 16px;
}
.settings-footer-preview-title {
  font-size: 0.7rem; font-weight: 600; color: var(--muted);
  text-transform: uppercase; letter-spacing: 0.04em; margin-bottom: 10px;
}
.settings-footer-preview-cols {
  display: flex; gap: 16px; font-size: 0.78rem; color: #555; line-height: 1.6;
}
.settings-footer-preview-col { flex: 1; }
.settings-footer-preview-col strong {
  display: block; color: var(--text); font-weight: 600; margin-bottom: 2px;
}

/* ═══════════════════════════════════════════════════════════════
   PRINT PREVIEW — Mehrseitiges DIN A4 Layout (Honorarangebot)
   ═══════════════════════════════════════════════════════════════ */

.print-preview-overlay {
  position: fixed; inset: 0; z-index: 2000;
  background: var(--surface2); overflow-y: auto;
}
.print-preview-toolbar {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 20px; background: var(--surface);
  border-bottom: 1px solid var(--border);
  position: sticky; top: 0; z-index: 10;
}
.print-preview-layout {
  display: flex; min-height: calc(100vh - 52px);
}
.print-preview-wrap {
  flex: 1; display: flex; justify-content: center; padding: 30px 20px 60px;
  background: #e8e8ec; min-height: calc(100vh - 52px); overflow-y: auto;
}

/* ── Sidebar: Druck-Optionen & Editor ─────────────────────── */
.pp-sidebar {
  width: 340px; flex-shrink: 0; background: var(--surface, #fff);
  border-left: 1px solid var(--border, #e5e7eb);
  padding: 18px 18px 30px; overflow-y: auto;
  position: sticky; top: 52px; max-height: calc(100vh - 52px);
  font-size: 13px; box-shadow: -2px 0 8px rgba(0,0,0,0.04);
}
.pp-sidebar h3 {
  margin: 0 0 14px; font-size: 15px; font-weight: 700; color: var(--text, #1a1a1a);
  display: flex; align-items: center; gap: 8px;
}
.pp-sidebar h4 {
  margin: 0 0 6px; font-size: 12px; font-weight: 600; color: var(--muted, #6b7280);
  text-transform: uppercase; letter-spacing: 0.5px;
}
.pp-sidebar h4 small { text-transform: none; color: #aaa; font-weight: 400; }

.pp-status-badge {
  display: inline-block; background: #e0e7ff; color: #2563eb;
  padding: 2px 8px; border-radius: 10px; font-size: 11px; font-weight: 600;
  margin-left: auto;
}
.pp-status-badge.dirty { background: #fef3c7; color: #92400e; }
.pp-status-badge.saved { background: #dcfce7; color: #166534; }

.pp-side-section {
  margin-bottom: 18px; padding-bottom: 14px;
  border-bottom: 1px solid var(--border, #e5e7eb);
}
.pp-side-section:last-child { border-bottom: none; margin-bottom: 0; padding-bottom: 0; }
.pp-side-section-flush { border-bottom: none; padding-bottom: 0; margin-bottom: 12px; }

/* Toggle-Switch */
.pp-toggle {
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  cursor: pointer; padding: 8px 10px; background: var(--surface2, #f7f7f9);
  border-radius: 8px; font-size: 13px; user-select: none;
}
.pp-toggle:hover { background: var(--hover, #f0f0f4); }
.pp-toggle strong { display: block; margin-bottom: 2px; color: var(--text, #1a1a1a); }
.pp-toggle small { color: var(--muted, #888); font-size: 11px; }
.pp-toggle input { display: none; }
.pp-toggle-wrap { display: flex; align-items: center; gap: 6px; flex-shrink: 0; }
.pp-toggle-slider {
  width: 40px; height: 22px; background: #ccc; border-radius: 11px;
  position: relative; flex-shrink: 0; transition: background .2s;
}
.pp-toggle-slider::after {
  content: ''; position: absolute; top: 2px; left: 2px; width: 18px; height: 18px;
  background: #fff; border-radius: 50%; box-shadow: 0 1px 3px rgba(0,0,0,.3);
  transition: left .2s;
}
.pp-toggle input:checked + .pp-toggle-slider { background: var(--primary, #2563eb); }
.pp-toggle input:checked + .pp-toggle-slider::after { left: 20px; }

/* Editor-Toolbar */
.pp-editor-toolbar {
  display: flex; flex-wrap: wrap; gap: 4px; padding: 6px;
  background: var(--surface2, #f7f7f9); border: 1px solid var(--border, #e0e0e0);
  border-radius: 6px 6px 0 0;
}
.pp-editor-toolbar button,
.pp-editor-toolbar select {
  min-width: 28px; height: 28px; padding: 0 8px; background: #fff;
  border: 1px solid var(--border, #d0d0d0); border-radius: 4px; cursor: pointer;
  font-size: 12px; color: var(--text, #333); display: flex; align-items: center;
  justify-content: center;
}
.pp-editor-toolbar button:hover { background: var(--hover, #e8eaf0); border-color: #888; }
.pp-editor-toolbar button.active {
  background: rgba(37,99,235,.15); border-color: var(--primary, #2563eb); color: var(--primary, #2563eb);
}
.pp-editor-toolbar select { padding: 0 4px; }

.pp-editor {
  min-height: 60px; padding: 8px 10px;
  border: 1px solid var(--border, #e0e0e0); border-top: none;
  border-radius: 0 0 6px 6px; background: #fff;
  font-size: 13px; line-height: 1.5; color: var(--text, #1a1a1a);
  outline: none; max-height: 200px; overflow-y: auto;
}
.pp-editor:focus {
  border-color: var(--primary, #2563eb);
  box-shadow: 0 0 0 2px rgba(37,99,235,.1);
}
.pp-editor[data-field="subject"],
.pp-editor[data-field="project-ref"] { min-height: 36px; }
.pp-editor-text { min-height: 110px; }

.pp-save-btn { width: 100%; margin-top: 6px; }
.pp-reset-btn {
  width: 100%; padding: 8px; background: transparent; color: var(--muted, #6b7280);
  border: 1px solid var(--border, #ddd); border-radius: 6px;
  font-size: 12px; cursor: pointer; margin-top: 6px;
}
.pp-reset-btn:hover { background: var(--hover, #f0f0f4); }

/* LP-Beschreibungen ausblenden */
.pp-hide-lp-desc .pp-lp-desc { display: none !important; }
/* LP-Beschreibung aus → Titel + Werte in einer Zeile (spart Platz) */
.pp-hide-lp-desc .pp-lp-section {
  display: flex;
  align-items: center;
  padding: 5px 0;
}
.pp-hide-lp-desc .pp-lp-section > .pp-lp-title {
  flex: 1;
  margin-bottom: 0;
  padding-left: 4px;
}
.pp-hide-lp-desc .pp-lp-section > .pp-lp-summary {
  flex: none;
  border-top: none;
  padding: 0;
}
.pp-hide-lp-desc .pp-lp-section > .pp-lp-summary > .pp-lp-col-name {
  display: none;
}

.print-pages-container {
  display: flex; flex-direction: column; gap: 24px; align-items: center;
}
.print-page {
  width: 595px; height: 842px; background: #fff;
  box-shadow: 0 4px 24px rgba(0,0,0,0.12);
  /* DIN 5008 Form A (Brief mit Briefkopf):
     oben 16,9 mm · links 25 mm · rechts 20 mm · unten 16,9 mm
     (bei PX_PER_MM = 2,8333 → 48 / 71 / 57 / 48 px) */
  padding: 48px 57px 48px 71px;
  font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
  font-size: 10px; color: #1a1a1a; position: relative; line-height: 1.5;
  page-break-after: always;
  box-sizing: border-box;
  overflow: hidden;       /* 1 DOM-Page == 1 PDF-Page: Überlauf wird geclippt */
}

/* ── Seite 1: Anschreiben (Cover) ─────────────────────────── */
.pp-header { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 4px; }
.pp-header-left { flex: 1; }
.pp-header-right { text-align: right; font-size: 9px; color: #1e1e1e; line-height: 1.7; flex-shrink: 0; }
.pp-logo-wrap { margin-bottom: 4px; }
.pp-logo-wrap img { max-height: 80px; max-width: 200px; display: block; }
.pp-company-name { font-size: 16px; font-weight: 300; letter-spacing: 3px; color: #1a1a1a; }
.pp-company-subtitle { font-size: 8.5px; color: #1e1e1e; margin-top: 2px; letter-spacing: 0.2px; }
.pp-company-partners { font-size: 8.5px; color: #1e1e1e; margin-top: 6px; font-weight: 500; font-style: italic; }
.pp-contact-block { font-size: 9px; color: #1e1e1e; line-height: 1.7; text-align: right; margin-top: 4px; }

/* Sender-Line wird im klassischen Pfad nicht mehr gerendert. Fallback: display:none
   falls sie doch irgendwo (z.B. Alt-Inhalt) auftaucht, damit keine Linie erscheint.
   Im Layout-Modus ausserdem pp-header (klassischer Kopf) unterdrücken. */
.pp-sender-line { display: none !important; }
.print-page.has-lh .pp-header { display: none !important; }
.pp-recipient { margin-top: 0; margin-bottom: 10px; font-size: 10px; line-height: 1.6; }
.pp-recipient-name { font-weight: 600; }

.pp-cover-title { font-size: 18px; font-weight: 700; color: #1a1a1a; margin: 30px 0 18px; }

.pp-cover-info {
  display: flex; justify-content: space-between; padding: 12px 0;
  border-top: 1px solid #ddd; border-bottom: 1px solid #ddd; margin-bottom: 20px;
  font-size: 9.5px; line-height: 1.6;
}
.pp-cover-info-left { flex: 1; }
.pp-cover-info-right { text-align: left; }
.pp-cover-info strong { display: block; font-weight: 700; margin-bottom: 2px; }

.pp-text { font-size: 9.5px; line-height: 1.65; margin-bottom: 14px; color: #333; }

.pp-closing { font-size: 9.5px; color: #333; line-height: 1.6; margin-bottom: 28px; }
.pp-signature { font-size: 9.5px; color: #333; margin-bottom: 28px; }

.pp-cover-sums {
  border-top: 1px solid #ddd; padding-top: 14px; margin-bottom: 24px;
}
.pp-cover-sums table { width: 220px; font-size: 9.5px; border-collapse: collapse; }
.pp-cover-sums td { padding: 3px 0; }
.pp-cover-sums td:last-child { text-align: right; font-variant-numeric: tabular-nums; }
.pp-cover-sums .pp-sum-divider td { border-top: 1px solid #ddd; padding-top: 6px; }
.pp-cover-sums .pp-sum-total td { font-weight: 700; font-size: 10.5px; border-top: 1px solid #ddd; padding-top: 6px; }

/* ── Summen + Unterschrift Bauherr nebeneinander ─────────── */
.pp-sums-sig-row { display: flex; gap: 28px; align-items: flex-start; margin-bottom: 24px; }
.pp-sums-sig-row .pp-cover-sums { margin-bottom: 0; flex: 0 0 auto; }
.pp-sums-sig-row .pp-bauherr-sig { flex: 1; }

/* ── Meta-Block rechts (Datum, Angebot-Nr, Projekt-Nr) ───── */
.pp-meta { display: flex; justify-content: flex-end; margin: 14px 0 18px; }
.pp-meta-right { text-align: right; color: #1e1e1e; font-size: 9px; line-height: 1.55; }
.pp-meta-right strong { color: #1a1a1a; font-weight: 600; }

/* ── Betreff + Projekt-Referenz (Block 5a) ───────────────── */
.pp-subject { font-size: 13px; font-weight: 700; margin-bottom: 4px; color: #1a1a1a; }
.pp-project-ref { font-size: 9.5px; color: #1e1e1e; margin-bottom: 14px; }

/* ── Unterschriftsfeld Bauherr (Block 11) ────────────────── */
.pp-sig-block { display: flex; gap: 40px; padding-top: 56px; }
.pp-sig-field { flex: 1; }
.pp-sig-line { border-top: 1px solid #999; padding-top: 4px; font-size: 8px; color: #1e1e1e; }
.pp-hide-bauherr-sig .pp-bauherr-sig { display: none; }

/* ── Alt: pp-cover-payment (deprecated, Fallback) ──────────── */
.pp-cover-payment {
  font-size: 8.5px; color: #1e1e1e; line-height: 1.6;
  border-top: 1px solid #ddd; padding-top: 12px;
}
.pp-cover-payment .pp-pay-label { color: #1e1e1e; font-size: 8px; }

.pp-page-number {
  /* bottom:6px → liegt UNTER der Fußzeile (bottom:22px), kollidiert nicht mit mittlerer Footer-Spalte */
  position: absolute; bottom: 6px; left: 0; right: 0;
  text-align: center; font-size: 8.5px; color: #1e1e1e;
}

/* ── Detail-Seiten: Kopfzeile ────────────────────────────── */
.pp-detail-header {
  display: flex; justify-content: space-between; margin-bottom: 2px;
  font-size: 9px; line-height: 1.4;
}
.pp-detail-header-left { font-weight: 600; color: #1a1a1a; }
.pp-detail-header-right { text-align: right; color: #1a1a1a; }
.pp-detail-header-sub {
  display: flex; justify-content: space-between; margin-bottom: 12px;
  font-size: 8.5px; color: #1e1e1e;
}
.pp-detail-sep { border: none; border-top: 1px solid #ddd; margin: 0 0 16px; }

/* ── HOAI-Abschnitt ──────────────────────────────────────── */
.pp-hoai-title {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-bottom: 14px;
}
.pp-hoai-title h2 { font-size: 14px; font-weight: 700; color: #1a1a1a; margin: 0; }
.pp-hoai-title .pp-hoai-amount { font-size: 14px; font-weight: 700; color: #1a1a1a; }

.pp-hoai-info { margin-bottom: 14px; font-size: 9.5px; line-height: 1.8; }
.pp-hoai-info-row {
  display: flex; justify-content: space-between;
  padding: 0 0 1px;
}
.pp-hoai-info-row .pp-info-label { color: #333; }
.pp-hoai-info-row .pp-info-value { color: #1a1a1a; text-align: right; font-variant-numeric: tabular-nums; }

/* ── LP-Tabelle ──────────────────────────────────────────── */
.pp-lp-table-head {
  display: flex; padding: 7px 0; background: #f5f6f8;
  font-size: 8px; color: #1a1a1a; border-bottom: 1px solid #ddd;
  margin-bottom: 0;
}
.pp-lp-col-name { flex: 1; padding-left: 4px; }
.pp-lp-col-pct { width: 70px; text-align: right; }
.pp-lp-col-ep { width: 90px; text-align: right; }
.pp-lp-col-total { width: 90px; text-align: right; padding-right: 4px; }

.pp-lp-section { padding: 10px 0 4px; border-bottom: 1px solid #eee; }
.pp-lp-title { font-size: 10px; font-weight: 700; color: #1a1a1a; margin-bottom: 8px; }
.pp-lp-desc { margin: 0 0 8px 20px; font-size: 9px; color: #333; line-height: 1.55; }
.pp-lp-desc-item { margin-bottom: 2px; padding-left: 4px; }
.pp-lp-desc-sub { margin-left: 16px; list-style: disc; padding-left: 10px; }
.pp-lp-desc-sub li { margin-bottom: 1px; }

.pp-lp-summary {
  display: flex; padding: 5px 0; font-size: 9.5px;
  border-top: 1px solid #ddd;
}
.pp-lp-summary .pp-lp-col-name { flex: 1; }
.pp-lp-summary .pp-lp-col-total { font-weight: 700; }

/* ── Positions-Beschreibung (Stundenlohn / Freitext / Pauschal) ─ */
.pp-pos-desc {
  padding: 2px 4px 8px 4px; font-size: 9px; color: #444;
  border-bottom: 1px solid #ddd; margin-bottom: 2px; line-height: 1.4;
}
.pp-pos-desc-italic { font-style: italic; }

/* ── Zwischensumme / Zuschlag ────────────────────────────── */
.pp-subtotal-row {
  display: flex; padding: 5px 0; font-size: 9.5px;
  border-bottom: 1px solid #ddd;
}
.pp-subtotal-row .pp-lp-col-name { flex: 1; }
.pp-subtotal-row .pp-lp-col-total { font-weight: 600; }
.pp-subtotal-row.pp-zuschlag { color: #333; font-weight: 600; }

/* ── Endsummen (Detail-Seiten) ───────────────────────────── */
.pp-final-sums { margin-top: 20px; width: 55%; margin-left: auto; }
.pp-final-sums table { width: 100%; border-collapse: collapse; font-size: 10px; }
.pp-final-sums td { padding: 4px 0; }
.pp-final-sums td:last-child { text-align: right; font-variant-numeric: tabular-nums; }
.pp-final-sums .pp-fs-zwischen td { font-weight: 700; border-top: 1px solid #ddd; padding-top: 6px; }
.pp-final-sums .pp-fs-total td { font-weight: 700; font-size: 11px; }

/* ── Kalkulations-Seiten ─────────────────────────────────── */
.pp-kalk-title { font-size: 14px; font-weight: 700; color: #1a1a1a; margin-bottom: 14px; }

.pp-kalk-table { width: 100%; border-collapse: collapse; font-size: 9px; margin-bottom: 16px; }
.pp-kalk-table th {
  padding: 6px 8px; font-size: 8px; color: #888; font-weight: 400;
  text-align: right; border-bottom: 1px solid #ddd; background: #f5f6f8;
}
.pp-kalk-table th:first-child { text-align: left; }
.pp-kalk-table td { padding: 8px 8px; text-align: right; border-bottom: 1px solid #eee; font-variant-numeric: tabular-nums; }
.pp-kalk-table td:first-child { text-align: left; color: #333; }
.pp-kalk-table .pp-kalk-total td { font-weight: 700; border-top: 1.5px solid #333; }

.pp-kalk-formula { font-size: 9px; line-height: 1.8; color: #333; margin-top: 10px; }
.pp-kalk-formula-row { display: flex; justify-content: space-between; padding: 1px 0; }
.pp-kalk-formula-row .pp-kf-label { color: #333; }
.pp-kalk-formula-row .pp-kf-value { text-align: right; font-variant-numeric: tabular-nums; }
.pp-kalk-formula-row.pp-kf-result { font-weight: 700; margin-top: 4px; }
.pp-kalk-formula-row.pp-kf-result .pp-kf-label { font-weight: 700; }

/* ── Footer auf Seite 1 ─────────────────────────────────── */
.pp-footer {
  /* an DIN-5008-Ränder ausgerichtet: links 25 mm / rechts 20 mm */
  position: absolute; bottom: 40px; left: 71px; right: 57px;
  border-top: 0.5px solid #ccc; padding-top: 8px;
  display: flex; gap: 24px; font-size: 7px; color: #1e1e1e; line-height: 1.5;
}
.pp-footer-col { flex: 1; }
.pp-footer-col strong { color: #1e1e1e; font-weight: 600; }

/* ═══════════════════════════════════════════════════════════════
   Letterhead-Layer in Druckvorschau (aus letterhead_layouts)
   — überlagert jede .print-page wenn ein Layout gewählt wurde.
   Koordinaten: 1 mm = 2.8333 px (595px / 210mm)
   ═══════════════════════════════════════════════════════════════ */
.print-page.has-lh { padding: 0; }
.pp-lh-bg {
  position: absolute; inset: 0; pointer-events: none;
  font-family: inherit;
}
.pp-lh-bg .pp-lh-elem {
  position: absolute;
  line-height: 1.25;
}
/* Nur Bild-Elemente clippen — Textelemente (Büroanschrift etc.) dürfen überlaufen */
.pp-lh-bg .pp-lh-elem[data-kind="image"] { overflow: hidden; }
.pp-lh-bg .pp-lh-elem[data-align="left"]    { text-align:left; }
.pp-lh-bg .pp-lh-elem[data-align="right"]   { text-align:right; }
.pp-lh-bg .pp-lh-elem[data-align="center"]  { text-align:center; }
.pp-lh-bg .pp-lh-elem[data-align="justify"] { text-align:justify; }
/* Block: inline-block inner div zentriert im Container — spiegelt justify-content:center des Editors */
.pp-lh-bg .pp-lh-elem[data-align="block"]   { text-align:center; }
.pp-lh-bg .pp-lh-elem img { width:100%; height:100%; object-fit:contain; display:block; }
.pp-lh-bg .pp-lh-footer {
  /* Flex-Fallback — wenn im Editor keine cols-Positionen definiert sind.
     An DIN 5008 ausgerichtet: links 25 mm / rechts 20 mm */
  position:absolute; left:71px; right:57px; bottom:22px;
  display:flex; gap:14px; font-size:7px; color:#1e1e1e; line-height:1.5;
}
.pp-lh-bg .pp-lh-footer-col { flex:1; }
.pp-lh-bg .pp-lh-footer-col strong { color:#1e1e1e; font-weight:600; display:block; margin-bottom:2px; }
/* Absolut-positionierte Footer-Spalten (wenn im Briefpapier-Editor verschoben) */
.pp-lh-bg .pp-lh-footer-col-abs {
  line-height: 1.35;
  color: #1e1e1e;
}
.pp-lh-bg .pp-lh-footer-col-abs strong { color:#1e1e1e; font-weight:600; display:block; margin-bottom:2px; }
.pp-lh-bg .pp-lh-sender {
  font-size: 7px; color:#1e1e1e;
  padding-bottom:2px; letter-spacing:0.3px;
  white-space: pre-line;
  /* keine Trennlinie mehr — auf Userwunsch entfernt */
}
.print-page.has-lh .pp-content-area {
  position: relative; z-index: 2;
  /* padding wird inline pro Seite in mm gesetzt (contentTopMm + contentBottomMm) */
}

/* ═══════════════════════════════════════════════════════════════
   Print media query
   ═══════════════════════════════════════════════════════════════ */
@page { size: A4; margin: 0; }

/* ═══════════════════════════════════════════════════════════════
   Briefpapier-Editor (Einstellungen → Briefpapier)
   ═══════════════════════════════════════════════════════════════ */

/* Inline-Toggle (Fußzeile an/aus in der Card-Header-Leiste) */
.inline-toggle { display:flex; align-items:center; gap:8px; font-size:12.5px; color:var(--text); cursor:pointer; user-select:none; }
.inline-toggle .sw { width:34px; height:20px; background:#ccc; border-radius:10px; position:relative; transition:background .2s; }
.inline-toggle .sw::after { content:''; position:absolute; top:2px; left:2px; width:16px; height:16px; background:#fff; border-radius:50%; box-shadow:0 1px 2px rgba(0,0,0,.3); transition:left .2s; }
.inline-toggle input { display:none; }
.inline-toggle input:checked + .sw { background: var(--primary); }
.inline-toggle input:checked + .sw::after { left:16px; }

/* Seiten-Umschalter (Erste Seite / Folgeseite) in der Action-Bar */
.bp-seg { display:flex; gap:2px; background:#f0f0f2; padding:2px; border-radius:6px; }
.bp-seg button { border:none; background:transparent; padding:5px 10px; border-radius:4px; font-size:12px; cursor:pointer; color:var(--muted); font-weight:500; font-family:var(--font); }
.bp-seg button.active { background:#fff; color:var(--text); box-shadow:0 1px 2px rgba(0,0,0,0.08); }

/* Status-Chip (Live / Ungespeichert / Gespeichert) */
.status-chip { font-size:11px; padding:3px 8px; border-radius:10px; font-weight:500; background:#f0f0f2; color:var(--muted); }
.status-chip.dirty { background:#fff3e0; color:#e65100; }
.status-chip.saved { background:#e8f5e9; color:#2e7d32; }

/* ─── Landing-Ansicht (Kacheln) ─── */
.bp-landing { padding:24px; }
.bp-tiles { display:grid; grid-template-columns:repeat(auto-fill, minmax(240px, 1fr)); gap:16px; }
.bp-tile { background:var(--surface); border:1px solid var(--border); border-radius:12px; overflow:hidden; cursor:pointer; transition:all 0.15s; display:flex; flex-direction:column; }
.bp-tile:hover { border-color:var(--primary); box-shadow:0 4px 16px rgba(0,113,227,0.12); transform:translateY(-2px); }
.bp-tile-thumb { aspect-ratio:210/297; background:#fafafa; border-bottom:1px solid rgba(0,0,0,0.06); position:relative; display:flex; align-items:center; justify-content:center; }
.bp-tile-thumb svg { width:92%; height:92%; }
.bp-tile-body { padding:12px 14px; }
.bp-tile-name { font-weight:600; font-size:14px; margin-bottom:2px; }
.bp-tile-meta { color:var(--muted); font-size:12px; display:flex; justify-content:space-between; align-items:center; gap:6px; }
.bp-tile-badge { background:rgba(0,113,227,0.1); color:var(--primary); padding:2px 7px; border-radius:4px; font-size:11px; font-weight:600; }
.bp-tile-actions { display:flex; gap:4px; margin-top:6px; }
.bp-tile-actions button { border:none; background:rgba(0,0,0,0.05); color:var(--muted); border-radius:5px; padding:3px 8px; font-size:11px; cursor:pointer; font-family:var(--font); }
.bp-tile-actions button:hover { background:rgba(0,0,0,0.1); color:var(--text); }
.bp-tile-actions button.danger:hover { background:rgba(255,59,48,0.1); color:var(--danger); }
.bp-tile.action { border:2px dashed rgba(0,0,0,0.15); background:transparent; align-items:center; justify-content:center; min-height:240px; flex-direction:column; gap:8px; color:var(--muted); }
.bp-tile.action:hover { border-color:var(--primary); color:var(--primary); background:rgba(0,113,227,0.03); }
.bp-tile.action .icon { font-size:32px; line-height:1; }
.bp-tile.action .label { font-weight:600; font-size:14px; }

/* ─── Editor-Layout (Canvas + Properties-Panel) ─── */
.bp-editor { display:flex; min-height:calc(100vh - 200px); }
.bp-canvas-area {
  flex:1; overflow:auto; background:#e8e8ec;
  display:flex; align-items:flex-start; justify-content:center;
  padding:24px; position:relative;
}
/* A4: 210×297mm @ 3px/mm */
.bp-a4 {
  width:630px; height:891px; background:#fff;
  box-shadow:0 4px 24px rgba(0,0,0,0.12); position:relative;
  background-image:radial-gradient(circle, rgba(0,0,0,0.05) 1px, transparent 1px);
  background-size:15px 15px;
}

/* Dummy-Angebot (Vorschau-Schemen im Hintergrund) */
.bp-a4 .dummy { position:absolute; color:#b8b8bc; pointer-events:none; user-select:none; font-family:'Helvetica Neue',Arial,sans-serif; }
.bp-a4 .dummy-thin  { font-size:7pt; }
.bp-a4 .dummy-meta  { font-size:9pt; line-height:1.45; text-align:right; }
.bp-a4 .dummy-recip { font-size:10pt; line-height:1.4; }
.bp-a4 .dummy-subj  { font-size:13px; font-weight:700; color:#b8b8bc; }
.bp-a4 .dummy-ref   { font-size:9pt; }
.bp-a4 .dummy-text  { font-size:10pt; line-height:1.55; }
.bp-a4 .dummy-sum   { font-size:9pt; border-top:1px solid #d9d9dc; border-bottom:1px solid #d9d9dc; padding:4px 0; width:220px; border-collapse:collapse; }
.bp-a4 .dummy-sum tr td:nth-child(2) { text-align:right; }
.bp-a4 .dummy-sum tr.total td { border-top:1px solid #d9d9dc; padding-top:3px; font-weight:700; }
.bp-a4 .dummy-sig { border-top:1px solid #d9d9dc; width:100%; padding-top:4px; font-size:7pt; color:#c5c5c9; }
.bp-a4 .dummy-pagenr { font-size:9pt; color:#b8b8bc; }
.bp-a4 .dummy-footer {
  position:absolute; left:45px; right:45px; bottom:24px;
  display:grid; grid-template-columns:1fr 1.6fr 1fr; gap:18px;
  font-size:7pt; line-height:1.4;
  border-top:1px solid #e5e5e8; padding-top:8px; color:#b8b8bc;
}
.bp-a4 .dummy-footer strong { color:#a5a5a9; font-weight:600; display:block; margin-bottom:2px; }
.bp-a4 .dummy-footer .nowrap { white-space:nowrap; }

/* ── Randlinien-Guides im Briefpapier-Editor ── */
.bp-margin-guide {
  position: absolute; top: 0; bottom: 0; width: 1px;
  background: rgba(0,113,227,0.3);
  pointer-events: none; z-index: 6;
}
.bp-margin-guide::before {
  content: attr(data-label);
  position: absolute; top: 8px;
  font-size: 8px; font-family: 'Helvetica Neue', Arial, sans-serif;
  color: #0071e3; white-space: nowrap;
  background: rgba(255,255,255,0.88); padding: 1px 4px;
  border-radius: 3px; border: 1px solid rgba(0,113,227,0.25);
  line-height: 1.5;
}
.bp-margin-guide-left::before  { left: 3px; }
.bp-margin-guide-right::before { right: 3px; }

/* Editierbare Elemente (liegen über dem Dummy) */
.bp-a4 .elem {
  position:absolute; min-width:25px; min-height:14px;
  cursor:move; user-select:none; padding:0;
  display:flex; align-items:center;
}
.bp-a4 .elem:hover { outline:1px solid rgba(0,113,227,0.5); outline-offset:-1px; background:rgba(0,113,227,0.04); }
.bp-a4 .elem.selected { outline:1.5px solid var(--primary); outline-offset:-1px; background:rgba(0,113,227,0.06); z-index:10; }
.bp-a4 .elem .handle { position:absolute; width:8px; height:8px; background:var(--primary); border:1.5px solid #fff; border-radius:50%; display:none; }
.bp-a4 .elem.selected .handle { display:block; }
.bp-a4 .elem .handle.se { bottom:-4px; right:-4px; cursor:se-resize; }

.bp-a4 .elem-image { background:#f7f7f9; outline:1px dashed rgba(0,0,0,0.22); outline-offset:-1px; color:#8a8a8e; font-size:10px; justify-content:center; text-align:center; flex-direction:column; gap:1px; }
.bp-a4 .elem-image .lbl { font-weight:600; font-size:10px; }
.bp-a4 .elem-image .sub { font-size:8.5px; color:#a8a8ac; }
.bp-a4 .elem-image.has-src { background:none; outline-color:transparent; padding:0; }
.bp-a4 .elem-image.has-src img { width:100%; height:100%; object-fit:contain; display:block; }

.bp-a4 .elem-text { line-height:1.3; color:var(--text); }
.bp-a4 .elem-sender { color:#3a3a3c; white-space:pre-wrap; line-height:1.25; align-items:flex-start; padding-top:1px; }
.bp-a4 .elem-pagenr { color:#3a3a3c; font-size:8pt; }
.bp-a4 .elem-footer-col { color:#3a3a3c; line-height:1.35; align-items:flex-start; padding:2px 3px; }
.bp-a4 .elem-footer-col strong { color:#555; font-weight:600; display:block; margin-bottom:2px; }
.bp-a4 .elem-footer-col .inner { line-height:1.35; }

.bp-a4 .elem .inner { width:100%; outline:none; }
.bp-a4 .elem-text .inner { white-space:pre-wrap; }
.bp-a4 .elem[data-align="left"]   { justify-content:flex-start; }
.bp-a4 .elem[data-align="center"] { justify-content:center; }
.bp-a4 .elem[data-align="right"]  { justify-content:flex-end; }
.bp-a4 .elem[data-align="block"]  { justify-content:center; }
.bp-a4 .elem[data-align="left"]   .inner { text-align:left; }
.bp-a4 .elem[data-align="center"] .inner { text-align:center; }
.bp-a4 .elem[data-align="right"]  .inner { text-align:right; }
.bp-a4 .elem[data-align="block"]  .inner { display:inline-block; width:auto; max-width:100%; text-align:left; }

.bp-a4 .elem.editing { outline:1.5px solid var(--primary) !important; cursor:text; background:#fff; }
.bp-a4 .elem.editing .inner { cursor:text; display:block !important; width:100% !important; }
.bp-a4 .elem.richtext .inner { word-wrap:break-word; }

.bp-a4 .elem-label {
  position:absolute; top:-18px; left:0; font-size:10px; color:var(--primary);
  font-weight:600; background:#fff; padding:1px 6px; border-radius:3px;
  border:1px solid var(--primary); pointer-events:none; white-space:nowrap;
  display:none;
}
.bp-a4 .elem.selected .elem-label { display:block; }
.bp-a4 .elem:hover .elem-label { display:block; color:var(--muted); border-color:#ccc; }

/* ─── Eigenschaften-Panel ─── */
.bp-props {
  width:300px; flex-shrink:0; background:var(--surface);
  border-left:1px solid var(--border);
  padding:16px; overflow-y:auto;
}
.bp-props h4 { margin:0 0 14px; font-size:13px; font-weight:700; display:flex; align-items:center; gap:8px; }
.bp-props .elem-kind { font-size:10px; text-transform:uppercase; letter-spacing:0.4px; color:var(--muted); margin-bottom:4px; font-weight:600; }
.bp-props .empty { color:var(--text3); font-size:12px; padding:14px 0; text-align:center; line-height:1.5; }
.bp-props-group { margin-bottom:14px; }
.bp-props-group > label { display:block; font-size:11px; color:var(--muted); font-weight:600; text-transform:uppercase; letter-spacing:0.4px; margin-bottom:5px; }
.bp-props-row { display:flex; gap:6px; }
.bp-props-row input { flex:1; min-width:0; }
.bp-props input[type="text"], .bp-props input[type="number"], .bp-props textarea, .bp-props select {
  width:100%; padding:6px 8px; border:1px solid rgba(0,0,0,0.15); border-radius:5px;
  font-size:12.5px; font-family:var(--font); background:#fff; color:var(--text);
}
.bp-props input:focus, .bp-props textarea:focus, .bp-props select:focus {
  outline:none; border-color:var(--primary); box-shadow:0 0 0 2px rgba(0,113,227,0.15);
}
.bp-props textarea { min-height:70px; resize:vertical; }
.bp-props .vis-toggle { display:flex; align-items:center; justify-content:space-between; padding:9px 10px; background:#f7f7f9; border-radius:7px; margin-bottom:14px; cursor:pointer; }
.bp-props .seg { display:flex; gap:2px; background:#f0f0f2; padding:2px; border-radius:6px; }
.bp-props .seg button { flex:1; border:none; background:transparent; padding:6px 0; border-radius:4px; font-size:12px; cursor:pointer; color:var(--muted); font-weight:500; font-family:var(--font); }
.bp-props .seg button.active { background:#fff; color:var(--text); box-shadow:0 1px 2px rgba(0,0,0,0.08); }
.bp-props .hint-row { font-size:11px; color:var(--muted); line-height:1.45; padding:8px 10px; background:#f7f7f9; border-radius:6px; }
.bp-props .elem-list { margin-top:6px; }
.bp-props .elem-list .row { display:flex; align-items:center; justify-content:space-between; padding:8px 10px; border-radius:6px; cursor:pointer; background:#f7f7f9; margin-bottom:4px; }
.bp-props .elem-list .row:hover { background:#eef2f7; }
.bp-props .elem-list .row .name { font-size:12.5px; color:var(--text); font-weight:500; }
.bp-props .elem-list .row.is-hidden .name { color:var(--text3); text-decoration:line-through; }
.bp-props .elem-list .row .vis { font-size:11px; padding:2px 8px; border-radius:10px; font-weight:500; background:#e8f5e9; color:#2e7d32; }
.bp-props .elem-list .row.is-hidden .vis { background:#f0f0f2; color:var(--text3); }

/* Rich-Text-Toolbar */
.bp-props .rt-toolbar { display:flex; gap:4px; flex-wrap:wrap; padding:6px; background:#f7f7f9; border-radius:7px; margin-bottom:8px; align-items:center; }
.bp-props .rt-toolbar button { min-width:28px; height:28px; padding:0 7px; border:1px solid rgba(0,0,0,0.1); background:#fff; border-radius:5px; cursor:pointer; font-size:12.5px; color:var(--text); font-family:var(--font); }
.bp-props .rt-toolbar button:hover { background:#eef2f7; border-color:var(--primary); }
.bp-props .rt-toolbar button.active { background:#e3effd; border-color:var(--primary); color:var(--primary); }
.bp-props .rt-toolbar .b { font-weight:700; }
.bp-props .rt-toolbar .i { font-style:italic; }
.bp-props .rt-toolbar .u { text-decoration:underline; }
.bp-props .rt-toolbar input[type="number"] { width:54px; height:28px; padding:0 6px; border:1px solid rgba(0,0,0,0.15); border-radius:5px; font-size:12px; font-family:var(--font); }
.bp-props .rt-toolbar .label { font-size:11px; color:var(--muted); margin:0 2px; }
.bp-props .rt-toolbar .sep { width:1px; height:18px; background:rgba(0,0,0,0.1); margin:0 2px; }

/* Platzhalter-Hilfe im Props-Panel */
.bp-token-help > summary { padding:4px 0; outline:none; }
.bp-token-help > summary::-webkit-details-marker { display:none; }
.bp-token-help > summary::before { content:"▸ "; display:inline-block; transition:transform 0.15s; }
.bp-token-help[open] > summary::before { transform:rotate(90deg); }
.bp-props .bp-token-chip {
  display:inline-block; margin:2px 3px 2px 0; padding:2px 7px;
  background:#eef2f7; color:var(--primary); border:1px solid rgba(0,0,0,0.06);
  border-radius:4px; font-family:ui-monospace,SFMono-Regular,Menlo,monospace;
  font-size:10.5px; cursor:pointer; font-weight:500;
}
.bp-props .bp-token-chip:hover { background:#dce7f5; border-color:var(--primary); }

/* Hint-Bar (Tastatur-Shortcuts) */
.bp-hint-bar {
  position:fixed; bottom:14px; left:50%; transform:translateX(-50%);
  background:#1d1d1f; color:#fff; padding:6px 14px; border-radius:20px;
  font-size:11.5px; box-shadow:0 4px 12px rgba(0,0,0,0.2); z-index:50;
}
.bp-hint-bar kbd { background:rgba(255,255,255,0.15); padding:1px 6px; border-radius:3px; font-family:var(--font); font-size:10.5px; }

/* ============================================================
   BAUZEITPLANUNG
   ============================================================ */

/* ── View-Shell ──────────────────────────────────────────── */
.bzp-view-gantt {
  display: flex; flex-direction: column;
  height: calc(100vh - 56px); /* Topbar-Höhe */
  overflow: hidden;
}

/* ── Toolbar ─────────────────────────────────────────────── */
.bzp-toolbar {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  background: var(--surface); border-bottom: 1px solid var(--border);
  padding: 7px 14px; flex-shrink: 0; z-index: 10;
}
.bzp-sep { color: var(--border); margin: 0 2px; }
.bzp-proj-lbl { font-weight: 700; font-size: 13px; color: var(--text); }
.bzp-plan-sel {
  border: 1px solid var(--border); border-radius: 6px; padding: 4px 9px;
  font-size: 12px; background: var(--surface); cursor: pointer; max-width: 200px;
}
.bzp-today-badge {
  background: rgba(0,113,227,.1); color: var(--primary);
  border-radius: 4px; padding: 2px 7px; font-size: 11px; font-weight: 600;
}
.bzp-year-nav { display: flex; align-items: center; gap: 4px; }
.bzp-year-nav button {
  border: 1px solid var(--border); background: var(--surface);
  width: 24px; height: 24px; border-radius: 5px; cursor: pointer;
  font-size: 14px; display: flex; align-items: center; justify-content: center;
}
.bzp-year-nav span { font-weight: 700; font-size: 13px; min-width: 38px; text-align: center; }
.bzp-view-btns { display: flex; border: 1px solid var(--border); border-radius: 6px; overflow: hidden; }
.bzp-view-btns button {
  border: none; background: var(--surface); padding: 4px 9px;
  font-size: 11px; cursor: pointer; font-family: inherit;
}
.bzp-view-btns button.active { background: var(--primary); color: #fff; }

/* ── Body Layout ─────────────────────────────────────────── */
.bzp-body {
  display: flex; flex: 1; overflow: hidden;
}

/* ── Linke Sidebar ───────────────────────────────────────── */
.bzp-sidebar {
  width: 200px; flex-shrink: 0; background: var(--surface);
  border-right: 1px solid var(--border); overflow-y: auto;
  display: flex; flex-direction: column; font-size: 12px;
}
.bzp-sidebar h4 {
  font-size: 10px; color: var(--muted); text-transform: uppercase;
  letter-spacing: .06em; padding: 10px 12px 5px; font-weight: 600;
}
.bzp-plan-item {
  padding: 7px 12px; cursor: pointer; border-bottom: 1px solid rgba(0,0,0,.04);
  position: relative; transition: background .1s;
}
.bzp-plan-item:hover { background: rgba(0,0,0,.025); }
.bzp-plan-item.active { background: rgba(0,113,227,.07); }
.bzp-plan-item.active::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--primary); border-radius: 0 2px 2px 0; }
.bzp-plan-item.active::before {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0;
  width: 3px; background: var(--primary); border-radius: 0 2px 2px 0;
}
.bzp-plan-item-name { font-weight: 600; font-size: 12px; }
.bzp-plan-item-meta { font-size: 10px; color: var(--muted); margin-top: 1px; }

/* ── Gantt-Zweipane ──────────────────────────────────────── */
.bzp-gantt-main   { flex: 1; display: flex; overflow: hidden; }
.bzp-gantt-fixed  { flex-shrink: 0; width: 458px; overflow: hidden; border-right: 2px solid var(--border); background: var(--surface); z-index: 10; }
.bzp-gantt-scroll { flex: 1; overflow: auto; position: relative; }
.bzp-gantt-inner  { position: relative; min-height: 100%; }

/* Bayern Schulferien-Toggle */
.bzp-schul-toggle { background: #f0fdf4; color: #059669; border-radius: 4px; padding: 2px 7px; font-size: 10px; font-weight: 600; border: 1px solid #d1fae5; cursor: pointer; font-family: inherit; transition: all .15s; }
.bzp-schul-toggle:hover { background: #dcfce7; border-color: #86efac; }
.bzp-schul-toggle.off { background: #f3f4f6; color: #9ca3af; border-color: #e5e7eb; text-decoration: line-through; }

/* ── Gantt-Tabelle ───────────────────────────────────────── */
table.bzp-table { border-collapse: separate; border-spacing: 0; min-width: 100%; }
table.bzp-table th, table.bzp-table td { border-right: 1px solid var(--border); border-bottom: 1px solid var(--border); white-space: nowrap; }
table.bzp-table th {
  background: var(--surface2); font-size: 10px; font-weight: 600; color: var(--muted);
  padding: 5px 7px; position: sticky; top: 0; z-index: 20; border-bottom: 2px solid var(--border);
}
table.bzp-table td { height: 36px; padding: 0 7px; font-size: 12px; vertical-align: middle; }
table.bzp-table tr:hover td { background: rgba(0,0,0,.012); }

/* Info-Spalten (im fixen linken Panel, kein sticky nötig) */
.bzp-st-ctrl  { background: var(--surface); width: 36px; min-width: 36px; max-width: 36px; padding: 0 !important; text-align: center; overflow: hidden; display: flex; align-items: stretch; }
/* Einklapp-Chevron + Plus nebeneinander in ctrl-Zelle */
td.bzp-st-ctrl .bzp-gw-chev-btn { width: 14px; flex-shrink: 0; align-self: center; padding: 0; }
td.bzp-st-ctrl .bzp-row-add-btn { flex: 1; width: auto; }
.bzp-st-name  { background: var(--surface); min-width: 155px; max-width: 155px; width: 155px; position: relative; }
.bzp-st-user  { background: var(--surface); min-width: 95px; max-width: 95px; width: 95px; overflow: hidden; text-overflow: ellipsis; position: relative; }
.bzp-st-start { background: var(--surface); width: 62px; min-width: 62px; text-align: center; position: relative; }
.bzp-st-end   { background: var(--surface); width: 62px; min-width: 62px; text-align: center; position: relative; }
.bzp-st-prog  { background: var(--surface); width: 54px; min-width: 54px; text-align: center; position: relative; }
table.bzp-table th.bzp-st-ctrl,
table.bzp-table th.bzp-st-name, table.bzp-table th.bzp-st-user,
table.bzp-table th.bzp-st-start, table.bzp-table th.bzp-st-end,
table.bzp-table th.bzp-st-prog { background: var(--surface2); }
/* + Hinzufügen-Button in ctrl-Zelle */
.bzp-row-add-btn {
  border: none; background: none; color: #c0c4cc; font-size: 17px; font-weight: 300;
  width: 100%; height: 100%; cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: color .12s, background .12s; border-radius: 0; padding: 0;
}
.bzp-row-add-btn:hover { color: var(--primary); background: rgba(0,113,227,.08); }
tr.bzp-phase-row td.bzp-st-ctrl { background: var(--surface2); padding: 0 !important; }
/* Spalten-Resize-Handle */
.bzp-col-resizer {
  position: absolute; right: 0; top: 0; bottom: 0; width: 5px;
  cursor: col-resize; z-index: 5; border-radius: 0 2px 2px 0;
  transition: background .1s;
}
.bzp-col-resizer:hover, .bzp-col-resizer.resizing { background: var(--primary); opacity: .45; }

/* Kalender-Spalten */
.bzp-col-lbl { text-align: center; font-size: 9px; padding: 4px 1px !important; }
.bzp-col-lbl-m { font-size: 10px; text-transform: uppercase; letter-spacing: .04em; font-weight: 600; }
.bzp-col-span { text-align: center; font-size: 10px; font-weight: 700; text-transform: uppercase; padding: 4px 6px !important; border-right: 1px solid var(--border); }
td.bzp-col-g { padding: 0 !important; vertical-align: middle; overflow: visible; position: relative; }
th.bzp-col-today  { background: rgba(0,113,227,.18) !important; color: var(--primary) !important; }
td.bzp-col-today  { background: rgba(0,113,227,.07) !important; }
th.bzp-col-hol    { background: rgba(239,68,68,.22) !important; color: #b91c1c !important; }
td.bzp-col-hol    { background: rgba(239,68,68,.13) !important; }
th.bzp-col-shol   { background: rgba(16,185,129,.14) !important; color: #065f46 !important; }
td.bzp-col-shol   { background: rgba(16,185,129,.07) !important; }
th.bzp-col-we     { background: #e4e6ea !important; color: #6b7280 !important; }
td.bzp-col-we     { background: rgba(0,0,0,.055) !important; }
.bzp-hd { display: flex; gap: 2px; justify-content: center; margin-top: 2px; }
.bzp-hd span { width: 4px; height: 4px; border-radius: 50%; display: inline-block; }
.bzp-hd-pub { background: #ef4444; }
.bzp-hd-sch { background: #10b981; }

/* Phase-Zeilen */
tr.bzp-phase-row td {
  background: var(--surface2); font-weight: 700; font-size: 10px;
  letter-spacing: .06em; text-transform: uppercase; color: var(--text);
  padding: 0 10px; cursor: pointer; border-top: 2px solid var(--border);
  height: 28px !important; border-right: none;
}
tr.bzp-phase-row td .bzp-phi { display: flex; align-items: center; gap: 6px; }
tr.bzp-phase-row td .bzp-ph-dot { width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0; }
tr.bzp-phase-row td .bzp-ph-cnt { color: var(--muted); font-weight: 400; font-size: 10px; }
tr.bzp-phase-row td .bzp-ph-chev { font-size: 10px; color: var(--muted); transition: .15s; }
tr.bzp-phase-row.collapsed td .bzp-ph-chev { transform: rotate(-90deg); }
tr.bzp-phase-row td .bzp-ph-actions { margin-left: auto; display: flex; align-items: center; gap: 4px; }
.bzp-ph-edit-btn, .bzp-ph-del-btn {
  border: none; background: none; cursor: pointer; font-size: 11px; padding: 2px 5px;
  border-radius: 4px; color: var(--muted); opacity: 0; transition: opacity .12s, background .12s;
}
tr.bzp-phase-row:hover .bzp-ph-edit-btn,
tr.bzp-phase-row:hover .bzp-ph-del-btn { opacity: 1; }
.bzp-ph-edit-btn:hover { background: var(--border); color: var(--text); }
.bzp-ph-del-btn:hover  { background: #fee2e2; color: #ef4444; }

/* Gewerk-Zellen */
.bzp-gw-name { font-weight: 600; display: flex; align-items: center; gap: 5px; }
.bzp-gw-dot  { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }
.bzp-gw-user { font-size: 10px; color: var(--muted); }
.bzp-gw-date { font-size: 10px; }
.bzp-prog-pill { display: inline-block; border-radius: 8px; overflow: hidden; width: 36px; height: 7px; background: #e5e7eb; vertical-align: middle; }
.bzp-prog-fill { height: 100%; border-radius: 8px; }
.bzp-prog-txt  { font-size: 9px; color: var(--muted); margin-left: 3px; }

/* ── Inline-Editing ──────────────────────────────────────── */
.bzp-editable { cursor: text; border-radius: 3px; padding: 1px 2px; transition: background .1s; display: inline-block; }
.bzp-editable:hover { background: rgba(0,113,227,.08); outline: 1px dashed rgba(0,113,227,.35); }
.bzp-inline-inp {
  border: none; border-bottom: 2px solid var(--primary); background: rgba(0,113,227,.05);
  border-radius: 3px 3px 0 0; padding: 2px 4px; font-size: 12px; font-family: inherit; outline: none;
  width: 100%; box-sizing: border-box; color: var(--text);
}
.bzp-inline-inp-month { font-size: 11px; padding: 2px 3px; width: 110px; }
.bzp-inline-inp-prog  { flex: 1; accent-color: var(--primary); cursor: pointer; margin: 0; }
.bzp-ph-name { cursor: pointer; border-radius: 3px; padding: 1px 3px; transition: background .1s; }
.bzp-ph-name:hover { background: rgba(0,0,0,.07); }

/* ── Zeilen-Drag Indikatoren ─────────────────────────────── */
tr.bzp-row-dragging { opacity: .35; pointer-events: none; }
tr.bzp-row-drag-above td { border-top: 2.5px solid var(--primary) !important; }
tr.bzp-row-drag-below td { border-bottom: 2.5px solid var(--primary) !important; }
tr.bzp-phase-row.bzp-phase-drag-over td { background: rgba(0,113,227,.07) !important; outline: 1px dashed var(--primary); }

/* ── Toast-Benachrichtigungen ────────────────────────────── */
.bzp-toast {
  position: fixed; bottom: 18px; right: 18px; z-index: 9999;
  background: #1a1a1a; color: #fff; border-radius: 8px;
  padding: 9px 16px; font-size: 12px; font-family: inherit;
  pointer-events: none; opacity: 0; transform: translateY(6px);
  transition: opacity .2s, transform .2s; max-width: 320px;
}
.bzp-toast.show { opacity: 1; transform: translateY(0); }

/* ── Gewerk: Einklapp-Chevron ────────────────────────────── */
.bzp-gw-chev-btn {
  background: none; border: none; cursor: pointer; padding: 0 2px;
  font-size: 9px; color: var(--muted); line-height: 1;
  opacity: 0; transition: opacity .15s; flex-shrink: 0;
}
tr:hover .bzp-gw-chev-btn { opacity: .7; }
.bzp-gw-chev-btn:hover { opacity: 1 !important; }
/* Berechnetes Datum (kommt aus Leistungen) */
.bzp-date-computed { color: var(--muted); font-style: italic; cursor: default; font-size: 10px; }
/* Parent-Balken (Gewerk mit Leistungen) – leicht transparenter */
.bzp-bar.bzp-bar-parent { opacity: .55; }

/* ── Gewerk-Zeile: Grip + ⋮-Button ──────────────────────── */
.bzp-drag-grip {
  flex-shrink: 0; width: 16px; text-align: center; cursor: grab;
  color: var(--muted); font-size: 14px;
  opacity: 0; transition: opacity .15s; user-select: none; margin-right: 1px;
}
tr:hover .bzp-drag-grip { opacity: .6; }
.bzp-drag-grip:hover { opacity: 1 !important; cursor: grab; }
.bzp-dot-btn {
  margin-left: auto; flex-shrink: 0;
  background: none; border: none; color: var(--muted); cursor: pointer;
  font-size: 15px; line-height: 1; padding: 1px 4px; border-radius: 4px;
  opacity: 0; transition: opacity .15s, background .12s;
}
tr:hover .bzp-dot-btn { opacity: 1; }
.bzp-dot-btn:hover { background: var(--border); color: var(--text); }

/* ── Plan-Sidebar ⋮ ─────────────────────────────────────── */
.bzp-plan-item { position: relative; }
.bzp-plan-dot {
  position: absolute; right: 6px; top: 50%; transform: translateY(-50%);
  background: none; border: none; cursor: pointer;
  font-size: 15px; color: var(--muted); line-height: 1; padding: 2px 5px;
  border-radius: 4px; opacity: 0; transition: opacity .15s, background .12s;
}
.bzp-plan-item:hover .bzp-plan-dot { opacity: 1; }
.bzp-plan-dot:hover { background: rgba(0,0,0,.08); color: var(--text); }

/* ── Gewerk-Kontext-Menü ─────────────────────────────────── */
.bzp-ctx-menu {
  position: fixed; z-index: 20000;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 8px; box-shadow: 0 6px 24px rgba(0,0,0,.18);
  min-width: 175px; padding: 4px 0; font-size: 13px;
  opacity: 0; animation: bzpCtxFadeIn .08s ease forwards;
}
@keyframes bzpCtxFadeIn { from { opacity:0; transform:translateY(-4px); } to { opacity:1; transform:translateY(0); } }
.bzp-ctx-item {
  display: flex; align-items: center; gap: 9px;
  padding: 7px 14px; cursor: pointer; color: var(--text);
  transition: background .1s; font-size: 12px;
}
.bzp-ctx-item:hover { background: var(--surface2); }
.bzp-ctx-item.danger { color: #ef4444; }
.bzp-ctx-item.danger:hover { background: #fff1f2; }
.bzp-ctx-sep { height: 1px; background: var(--border); margin: 3px 0; }
/* Icon-Badge im Kontextmenü (farbiger Hintergrund wie im Mockup) */
.bzp-ctx-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 20px; height: 20px; border-radius: 5px; font-size: 11px;
  flex-shrink: 0; font-weight: 700;
}

/* ── Balken ──────────────────────────────────────────────── */
.bzp-wrap { position: relative; height: 36px; display: flex; align-items: center; overflow: visible; }
.bzp-bar  {
  position: absolute; height: 20px; border-radius: 5px;
  cursor: grab; user-select: none; overflow: visible;
  transition: box-shadow .12s;
}
.bzp-bar:hover { box-shadow: 0 2px 8px rgba(0,0,0,.2); }
.bzp-bar.dragging { cursor: grabbing !important; opacity: .85; box-shadow: 0 4px 14px rgba(0,0,0,.25); z-index: 50; }
.bzp-done { position: absolute; left: 0; top: 0; bottom: 0; opacity: .28; pointer-events: none; background: #000; }
/* Resize-Handles */
.bzp-rh { position: absolute; top: 0; bottom: 0; width: 8px; cursor: ew-resize; z-index: 6; display: flex; align-items: center; justify-content: center; }
.bzp-rh-l { left: 0; border-radius: 5px 0 0 5px; }
.bzp-rh-r { right: 0; border-radius: 0 5px 5px 0; }
.bzp-rh::after { content: ''; width: 2px; height: 10px; background: rgba(255,255,255,.55); border-radius: 2px; }
/* Label vor / Tage nach Balken */
.bzp-bar-pre {
  position: absolute; right: calc(100% + 4px); top: 50%; transform: translateY(-50%);
  font-size: 10px; font-weight: 600; color: var(--text); white-space: nowrap;
  background: rgba(255,255,255,.92); padding: 1px 4px; border-radius: 3px;
  pointer-events: none; z-index: 9;
}
.bzp-bar-post {
  position: absolute; left: calc(100% + 5px); top: 50%; transform: translateY(-50%);
  font-size: 9px; color: var(--muted); white-space: nowrap; font-weight: 600;
  pointer-events: none; z-index: 9;
}
/* Meilenstein-Balken (dünner Streifen) */
.bzp-bar-ms { height: 6px !important; top: 50%; transform: translateY(-50%); }

/* Meilenstein-Raute */
.bzp-ms-wrap {
  position: absolute; right: -2px; top: 0; bottom: 0;
  display: flex; align-items: center; justify-content: flex-end;
  pointer-events: none; overflow: visible; z-index: 10;
}
.bzp-ms-diamond {
  width: 16px; height: 16px;
  background: #e44d26; transform: rotate(45deg);
  border: 2.5px solid #fff;
  box-shadow: 0 2px 6px rgba(0,0,0,.3);
  flex-shrink: 0; cursor: pointer; pointer-events: all;
}
.bzp-ms-label {
  position: absolute; top: calc(50% + 12px); right: -4px;
  transform: translateX(50%);
  font-size: 8px; font-weight: 700; white-space: nowrap;
  background: rgba(255,255,255,.85); padding: 1px 3px;
  border-radius: 3px;
}
/* ── Leistungen (3. Ebene) ───────────────────────────────── */
tr.bzp-lei-row td { background: var(--bg); }
/* Name-Zelle der Leistung: 20px Einrückung via Padding-Links */
td.bzp-lei-name-td { padding-left: 20px !important; }
td.bzp-lei-name-td .bzp-gw-name { padding-left: 0; }
/* Leistung-Balken (etwas flacher als Gewerk-Balken) */
.bzp-bar-lei { height: 12px !important; top: 50%; transform: translateY(-50%); }
/* „+ Leistung" Hinzufügen-Zeile */
tr.bzp-add-lei-row td { background: var(--bg); border-top: none; }
.bzp-add-lei-btn {
  background: none; border: none; cursor: pointer;
  font-size: 10px; color: var(--muted); padding: 2px 8px 2px 32px;
  opacity: 0; transition: opacity .15s;
}
tr.bzp-add-lei-row:hover .bzp-add-lei-btn { opacity: 1; }

/* Heute-Linie */
.bzp-today-line { position: absolute; top: 0; bottom: 0; width: 2px; background: var(--primary); opacity: .55; pointer-events: none; z-index: 25; }
.bzp-today-line::before { content: '▼'; position: absolute; top: -2px; left: -5px; font-size: 9px; color: var(--primary); }
/* SVG-Overlay */
.bzp-dep-svg { position: absolute; top: 0; left: 0; width: 100%; height: 100%; pointer-events: none; z-index: 8; overflow: visible; }

/* ── Rechtes Detail-Panel ────────────────────────────────── */
.bzp-detail { width: 248px; flex-shrink: 0; background: var(--surface); border-left: 1px solid var(--border); display: none; flex-direction: column; overflow-y: auto; }
.bzp-detail.open { display: flex; }
.bzp-dp-head { padding: 12px 14px 9px; border-bottom: 1px solid var(--border); display: flex; align-items: center; gap: 7px; }
.bzp-dp-head h4 { font-size: 13px; font-weight: 700; flex: 1; }
.bzp-dp-dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }
.bzp-dp-close { border: none; background: none; cursor: pointer; font-size: 16px; color: var(--muted); }
.bzp-dp-body { padding: 12px 14px; display: flex; flex-direction: column; gap: 10px; }
.bzp-dp-field label { display: block; font-size: 9px; color: var(--muted); font-weight: 600; text-transform: uppercase; letter-spacing: .05em; margin-bottom: 3px; }
.bzp-dp-field input, .bzp-dp-field select { width: 100%; border: 1px solid var(--border); border-radius: 6px; padding: 5px 8px; font-size: 12px; font-family: inherit; }
.bzp-dp-field input[type=color] { width: 34px; height: 28px; border-radius: 4px; padding: 2px; }
.bzp-dp-actions { padding: 9px 14px 12px; border-top: 1px solid var(--border); display: flex; gap: 7px; align-items: center; }

/* ── Legende ─────────────────────────────────────────────── */
.bzp-legend {
  padding: 5px 14px; background: var(--surface); border-top: 1px solid var(--border);
  display: flex; gap: 12px; flex-wrap: wrap; align-items: center;
  font-size: 10px; color: var(--muted); flex-shrink: 0;
}
.bzp-leg-item { display: flex; align-items: center; gap: 4px; }
.bzp-leg-bar  { width: 18px; height: 9px; border-radius: 3px; }
