:root {
  --c-bg: #f4f5f7;
  --c-surface: #ffffff;
  --c-text: #1f2933;
  --c-text-muted: #5a6b7b;
  --c-primary: #1f4e79;      /* gedecktes Gutachter-Blau */
  --c-primary-dark: #163a5a;
  --c-accent: #2f7d4f;       /* dezentes Grün für Status/OK */
  --c-danger: #b3261e;
  --c-warn: #c98a00;         /* Bernstein für „in Arbeit/unklar" */
  --c-border: #dde2e8;
  --radius: 10px;
  --shadow: 0 1px 3px rgba(31, 41, 51, 0.08), 0 4px 12px rgba(31, 41, 51, 0.05);
  --font: "Segoe UI", system-ui, -apple-system, Roboto, Helvetica, Arial, sans-serif;
}

* { box-sizing: border-box; }

html, body { margin: 0; padding: 0; min-height: 100vh; }

body {
  font-family: var(--font);
  color: var(--c-text);
  background: var(--c-bg);
  display: flex;
  flex-direction: column;
  line-height: 1.55;
}

/* Kopfzeile */
.app-header {
  background: var(--c-surface);
  border-bottom: 1px solid var(--c-border);
  box-shadow: var(--shadow);
}
.app-header__inner {
  max-width: 1500px;
  margin: 0 auto;
  padding: 0.85rem 1.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
.brand { display: flex; align-items: center; gap: 0.75rem; }
.brand__logo { display: block; height: 52px; width: auto; flex-shrink: 0; }
.brand__text { display: flex; flex-direction: column; line-height: 1.25; }
.brand__text strong { font-size: 0.98rem; }
.brand__text span { font-size: 0.82rem; color: var(--c-text-muted); }

.header-right { display: flex; flex-direction: column; align-items: flex-end; gap: 0.35rem; }
.user-box { display: flex; align-items: center; gap: 0.6rem; }
.user-box__name { font-size: 0.9rem; font-weight: 600; }
.user-box__badge {
  font-size: 0.7rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.03em;
  color: #fff; background: var(--c-primary); padding: 0.1rem 0.45rem; border-radius: 999px;
}
.status { display: flex; align-items: center; gap: 0.5rem; font-size: 0.85rem; color: var(--c-text-muted); }
.status__dot { width: 10px; height: 10px; border-radius: 50%; background: #c9ced6; transition: background-color 0.3s ease; }
.status__dot--ok { background: var(--c-accent); }
.status__dot--error { background: var(--c-danger); }

/* Hauptbereich – Dashboard nutzt die volle Breite */
.app-main {
  flex: 1; width: 100%; max-width: 1500px;
  margin: 0 auto; padding: 1.75rem 1.5rem 3rem;
}

/* Buttons */
.btn {
  font-family: inherit; font-size: 0.9rem; border-radius: 8px;
  border: 1px solid transparent; padding: 0.5rem 1rem; cursor: pointer;
  transition: background-color 0.15s ease, border-color 0.15s ease;
}
.btn--primary { background: var(--c-primary); color: #fff; width: 100%; padding: 0.7rem 1rem; font-weight: 600; }
.btn--primary:hover { background: var(--c-primary-dark); }
.btn--primary:disabled { opacity: 0.6; cursor: default; }
.btn--ghost { background: transparent; border-color: var(--c-border); color: var(--c-text-muted); }
.btn--ghost:hover { border-color: var(--c-primary); color: var(--c-primary); }
.btn--inline { width: auto; }
.btn--sm { padding: 0.35rem 0.7rem; font-size: 0.82rem; }
.btn--danger { color: var(--c-danger); }
.btn--danger:hover { border-color: var(--c-danger); color: var(--c-danger); }

/* Login-Seite */
.login-body { align-items: center; justify-content: center; padding: 1.5rem; }
.login-brand { display: flex; flex-direction: column; align-items: center; gap: 0.5rem; margin-bottom: 1.5rem; }
.login-logo { width: 130px; height: auto; display: block; }
.login-brand__sub { font-size: 0.85rem; color: var(--c-text-muted); letter-spacing: 0.02em; }
.login-card {
  background: var(--c-surface); border: 1px solid var(--c-border); border-radius: var(--radius);
  box-shadow: var(--shadow); padding: 2rem 2rem 2.25rem; width: 100%; max-width: 380px;
}
.login-title { font-size: 1.3rem; text-align: center; margin: 0 0 1.5rem; color: var(--c-primary-dark); }
.login-form { display: flex; flex-direction: column; gap: 1rem; }

/* Formularfelder */
.field { display: flex; flex-direction: column; gap: 0.35rem; }
.field__label { font-size: 0.85rem; font-weight: 600; color: var(--c-text); }
.field input, .field select, .field textarea {
  font-family: inherit; font-size: 0.95rem; padding: 0.6rem 0.7rem;
  border: 1px solid var(--c-border); border-radius: 8px; background: #fff; color: var(--c-text);
}
.field textarea { resize: vertical; }
.field input:focus, .field select:focus, .field textarea:focus {
  outline: none; border-color: var(--c-primary); box-shadow: 0 0 0 3px rgba(31, 78, 121, 0.12);
}
.login-error {
  margin: 0; font-size: 0.85rem; color: var(--c-danger);
  background: #fdecea; border: 1px solid #f5c6c2; border-radius: 8px; padding: 0.5rem 0.7rem;
}

/* Toolbar über dem Dashboard */
.toolbar {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 1rem; flex-wrap: wrap; margin-bottom: 1rem;
}
.toolbar__filters { display: flex; gap: 1rem; flex-wrap: wrap; align-items: flex-end; }
.toolbar__actions { display: flex; gap: 0.6rem; align-items: flex-end; }
.toolbar__filter { display: flex; flex-direction: column; gap: 0.3rem; }
.toolbar__filter label { font-size: 0.8rem; font-weight: 600; color: var(--c-text-muted); }
.toolbar__filter select, .toolbar__filter input {
  font-family: inherit; font-size: 0.95rem; padding: 0.5rem 0.7rem;
  border: 1px solid var(--c-border); border-radius: 8px; background: #fff; color: var(--c-text);
}
.toolbar__filter--search input { min-width: 280px; }

.list-info { font-size: 0.85rem; color: var(--c-text-muted); margin: 0 0 0.75rem; }

/* Dashboard-Tabelle */
.table-wrap {
  background: var(--c-surface); border: 1px solid var(--c-border);
  border-radius: var(--radius); box-shadow: var(--shadow); overflow-x: auto;
}
table.dash { border-collapse: collapse; width: 100%; font-size: 0.86rem; }
table.dash th, table.dash td {
  padding: 0.5rem 0.6rem; text-align: left; border-bottom: 1px solid var(--c-border);
  white-space: nowrap;
}
table.dash thead th {
  position: sticky; top: 0; background: #eef1f5; color: var(--c-primary-dark);
  font-weight: 700; font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.02em;
  border-bottom: 2px solid var(--c-border); z-index: 1;
}
table.dash tbody tr:hover { background: #f7f9fb; }
table.dash th.sortable { cursor: pointer; user-select: none; }
table.dash th.sortable:hover { color: var(--c-primary); }
table.dash th.col-pos, table.dash td.col-pos { text-align: center; }
table.dash th.col-pos {
  font-size: 0.68rem; letter-spacing: 0; text-transform: none;
  writing-mode: vertical-rl; transform: rotate(180deg); vertical-align: bottom;
  padding: 0.5rem 0.25rem; height: 120px;
}
.col-az { font-weight: 700; color: var(--c-primary-dark); }
.col-az button { font: inherit; color: inherit; background: none; border: none; cursor: pointer; padding: 0; text-decoration: underline transparent; }
.col-az button:hover { text-decoration-color: currentColor; }
.dash__adresse { color: var(--c-text); }
.dash__ort { color: var(--c-text-muted); font-size: 0.82rem; }
.row-actions { display: flex; gap: 0.3rem; }

/* Status-Ampel (eine Zelle je Position) */
.ampel {
  display: inline-flex; align-items: center; justify-content: center;
  width: 26px; height: 26px; border-radius: 50%; border: 1px solid transparent;
  cursor: pointer; font-size: 0.95rem; line-height: 1; background: transparent;
}
.ampel:hover { box-shadow: 0 0 0 2px rgba(31, 78, 121, 0.18); }
.ampel--offen      { color: var(--c-danger);  background: #fdecea; border-color: #f5c6c2; }
.ampel--angefragt  { color: var(--c-warn);    background: #fdf4e0; border-color: #f0dca8; }
.ampel--unklar     { color: var(--c-warn);    background: #fdf4e0; border-color: #f0dca8; }
.ampel--vorhanden  { color: var(--c-accent);  background: #ecf6f0; border-color: #bfe0cc; }
.ampel--entfaellt  { color: #aab2bd;          background: transparent; border-color: transparent; }
.ampel--ueberfaellig { color: #fff; background: var(--c-danger); border-color: var(--c-danger); font-weight: 700; }
.frist--faellig { color: var(--c-danger); font-weight: 600; }
.frist--bald { color: var(--c-warn); font-weight: 600; }

/* Erinnerungen */
.reminder-filter {
  display: flex; align-items: center; gap: 0.4rem; font-size: 0.9rem;
  cursor: pointer; align-self: flex-end; padding-bottom: 0.55rem; white-space: nowrap;
}
.reminders {
  background: #fdf4e0; border: 1px solid #f0dca8; border-radius: var(--radius);
  padding: 0.6rem 0.9rem; margin-bottom: 0.9rem; font-size: 0.9rem;
  display: flex; flex-wrap: wrap; gap: 0.5rem; align-items: center;
}
.rem-title { font-weight: 700; color: var(--c-warn); }
.rem-chip { border-radius: 999px; padding: 0.15rem 0.6rem; font-size: 0.82rem; border: 1px solid transparent; }
.rem-chip--rot { background: #fdecea; border-color: #f5c6c2; color: var(--c-danger); }
.rem-chip--gelb { background: #fff; border-color: #f0dca8; color: var(--c-warn); }

/* Badges für Objektart/Auftragsart */
.badge {
  font-size: 0.74rem; border-radius: 999px; padding: 0.1rem 0.55rem;
  background: var(--c-bg); border: 1px solid var(--c-border); color: var(--c-text-muted);
}

.empty-state { text-align: center; color: var(--c-text-muted); padding: 3rem 1rem; }
.empty-state p { margin: 0.25rem 0; }
.empty-state__hint { font-size: 0.9rem; }

/* Dialoge */
.editor {
  border: none; border-radius: var(--radius);
  box-shadow: 0 10px 40px rgba(31, 41, 51, 0.25);
  padding: 0; width: min(680px, 94vw); color: var(--c-text);
}
.editor--wide { width: min(960px, 96vw); }
.editor::backdrop { background: rgba(31, 41, 51, 0.45); }
.editor__form { display: flex; flex-direction: column; gap: 1rem; padding: 1.5rem 1.75rem 1.75rem; max-height: 88vh; overflow-y: auto; }
.editor__form h2 { margin: 0; font-size: 1.2rem; color: var(--c-primary-dark); }
.editor__actions { display: flex; justify-content: flex-end; gap: 0.6rem; margin-top: 0.5rem; }
.editor__hint { font-weight: 400; color: var(--c-text-muted); font-size: 0.88rem; margin: 0; }

/* Raster für Stammfelder im Auftrags-Dialog */
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0.85rem 1rem; }
.form-grid .field--full { grid-column: 1 / -1; }
@media (max-width: 620px) { .form-grid { grid-template-columns: 1fr; } }

/* Wiederholbare Zeilen (Beteiligte, Flurstücke) */
.repeat { display: flex; flex-direction: column; gap: 0.6rem; }
.repeat__row {
  display: grid; gap: 0.5rem; align-items: end;
  border: 1px solid var(--c-border); border-radius: 8px; padding: 0.6rem 0.7rem; background: var(--c-bg);
}
.repeat__row--flurstueck { grid-template-columns: 1.2fr 0.6fr 0.7fr 1.3fr 0.9fr 0.7fr 0.8fr auto; }

/* Beteiligten-Karte (mit ausklappbarem Bevollmächtigten-Block) */
.repeat__bet { display: flex; flex-direction: column; gap: 0.55rem; }
.bet-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.4rem 0.6rem; }
.bet-grid label { display: flex; flex-direction: column; }
.bet-grid__wide { grid-column: 1 / -1; }
.bet-vertreter { border-top: 1px dashed var(--c-border); padding-top: 0.5rem; }
.bet-vertreter > summary { cursor: pointer; font-size: 0.8rem; font-weight: 600; color: var(--c-text-muted); user-select: none; }
.bet-vertreter[open] > summary { color: var(--c-primary); margin-bottom: 0.5rem; }
.bet-body { display: flex; flex-direction: column; gap: 0.55rem; }
.repeat__bet .repeat__del { align-self: flex-end; }
@media (max-width: 620px) { .bet-grid { grid-template-columns: 1fr 1fr; } }

/* Beteiligte: Kompaktansicht (Liste) */
.bet-head { display: none; }
#beteiligte-list.is-compact .repeat__bet { padding: 0.5rem 0.7rem; }
#beteiligte-list.is-compact .bet-head {
  display: block; width: 100%; text-align: left; background: transparent; border: none;
  font: inherit; font-weight: 600; color: var(--c-primary-dark); cursor: pointer; padding: 0.2rem 0;
}
#beteiligte-list.is-compact .bet-head::before { content: "▸ "; color: var(--c-text-muted); }
#beteiligte-list.is-compact .repeat__bet.is-open .bet-head::before { content: "▾ "; }
#beteiligte-list.is-compact .bet-body { display: none; }
#beteiligte-list.is-compact .repeat__bet.is-open .bet-body { display: flex; margin-top: 0.5rem; }

/* Aktionsgruppe in Abschnitts-Überschriften */
.section-head__actions { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.repeat__row input { font-family: inherit; font-size: 0.88rem; padding: 0.45rem 0.55rem; border: 1px solid var(--c-border); border-radius: 6px; width: 100%; }
.repeat__row .field__label { font-size: 0.74rem; font-weight: 600; color: var(--c-text-muted); margin-bottom: 0.15rem; display: block; }
.repeat__del { align-self: end; }
@media (max-width: 760px) {
  .repeat__row--beteiligter, .repeat__row--flurstueck { grid-template-columns: 1fr 1fr; }
}

.section-head { display: flex; align-items: center; justify-content: space-between; margin-top: 0.4rem; }
.section-head h3 { margin: 0; font-size: 0.95rem; color: var(--c-primary-dark); }

/* Stellen-Verwaltung */
.stelle-new { border: 1px solid var(--c-border); border-radius: 8px; padding: 0.75rem 0.9rem; }
.stelle-new__row { display: flex; flex-wrap: wrap; gap: 0.5rem; align-items: center; margin-top: 0.4rem; }
.stelle-new__row input, .stelle-new__row select {
  font-family: inherit; font-size: 0.9rem; padding: 0.45rem 0.6rem;
  border: 1px solid var(--c-border); border-radius: 8px; flex: 1 1 150px; color: var(--c-text);
}
.stelle-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 0.5rem; max-height: 50vh; overflow-y: auto; }
.stelle-row {
  display: flex; align-items: center; justify-content: space-between; gap: 0.75rem; flex-wrap: wrap;
  border: 1px solid var(--c-border); border-radius: 8px; padding: 0.6rem 0.8rem;
}
.stelle-row__info { display: flex; flex-direction: column; gap: 0.15rem; min-width: 0; }
.stelle-row__sub { font-size: 0.82rem; color: var(--c-text-muted); }

/* Dokument- und Korrespondenzlisten */
.doku-list, .korr-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 0.4rem; }
.doku-row, .korr-row {
  display: flex; align-items: center; justify-content: space-between; gap: 0.6rem;
  border: 1px solid var(--c-border); border-radius: 8px; padding: 0.5rem 0.7rem;
}
.doku-row__info, .korr-row__info { display: flex; flex-direction: column; gap: 0.1rem; min-width: 0; }
.doku-row__sub, .korr-row__sub { font-size: 0.8rem; color: var(--c-text-muted); }
.badge--dup { background: #fdf4e0; border-color: #f0dca8; color: var(--c-warn); }
.badge--ok { background: #ecf6f0; border-color: #bfe0cc; color: var(--c-accent); }

/* Positions-Dialog (Ampel pflegen) */
.pos-legend { display: flex; flex-wrap: wrap; gap: 0.5rem 1rem; font-size: 0.82rem; color: var(--c-text-muted); }
.pos-legend span { display: inline-flex; align-items: center; gap: 0.35rem; }

/* Fußzeile */
.app-footer {
  border-top: 1px solid var(--c-border); background: var(--c-surface); text-align: center;
  padding: 1rem 1.5rem; font-size: 0.82rem; color: var(--c-text-muted);
}
