:root {
  /* Petrol – Marke / Interaktiv */
  --primary: #0d6e74; --primary-dk: #0a565b; --primary-bg: #e1f0f0;
  /* Text */
  --ink: #16201f; --ink2: #5b6968;
  /* Flächen & Linien */
  --surface: #ffffff; --bg: #eef3f2; --line: #e2e8e7;
  /* Status-Ampel */
  --success: #1f8a5b; --success-bg: #e4f3ea;
  --warn: #9a6700; --warn-bg: #fbf0d4;
  --danger: #bf3a2f; --danger-bg: #fbe9e6;
  /* Form */
  --radius: 16px;
  --shadow: 0 1px 2px rgba(20,30,40,0.05), 0 18px 40px -26px rgba(20,30,40,0.30);

  /* Legacy-Aliase: bestehende Templates referenzieren diese Namen → Petrol */
  --blau: var(--primary); --blau-hell: var(--primary-bg);
  --tinte: var(--ink); --grau: var(--ink2);
  --linie: var(--line); --weiss: var(--surface);
  --gruen: var(--success); --gruen-bg: var(--success-bg);
  --amber: var(--warn); --amber-bg: var(--warn-bg);
  --rot: var(--danger); --rot-bg: var(--danger-bg);
  --violett: #5b4ba0; --violett-bg: #eceaf8;
}
* { box-sizing: border-box; }
body { margin: 0; font-family: 'Hanken Grotesk', system-ui, -apple-system, "Segoe UI", sans-serif; -webkit-font-smoothing: antialiased; background: var(--bg); color: var(--ink); font-size: 15px; }
a { color: var(--primary); text-decoration: none; }
a:hover { text-decoration: underline; }

header { background: var(--surface); border-bottom: 1px solid var(--line); }
.nav { max-width: 1200px; margin: 0 auto; padding: 0 22px; display: flex; align-items: center; gap: 4px; flex-wrap: wrap; min-height: 54px; }
.brand { font-weight: 800; font-size: 18px; color: var(--primary); margin-right: 14px; letter-spacing: -0.015em; }
.brand span { color: var(--ink); font-weight: 600; }
.nav a.item { padding: 16px 11px; color: var(--ink2); border-bottom: 2px solid transparent; font-weight: 600; font-size: 14px; }
.nav a.item.aktiv, .nav a.item:hover { color: var(--primary); border-bottom-color: var(--primary); text-decoration: none; }
.nav .spacer { flex: 1; }
.nav .wer { background: var(--primary-bg); color: var(--primary-dk); font-size: 13px; font-weight: 600; padding: 6px 14px; border-radius: 999px; margin-left: 8px; }
.nav .wer:hover { text-decoration: none; }

main { max-width: 1200px; margin: 0 auto; padding: 24px 22px 60px; }
h1 { font-size: 24px; font-weight: 800; margin: 4px 0 18px; letter-spacing: -0.015em; }
h2 { font-size: 17px; font-weight: 700; margin: 24px 0 12px; }
.hinweis { background: var(--primary-bg); border: 1px solid #c4dede; border-radius: 12px; padding: 11px 15px; margin: 0 0 16px; }
.flash { background: var(--success-bg); border: 1px solid #bce3cd; color: var(--success); border-radius: 12px; padding: 10px 15px; margin: 0 0 16px; }
.fehler { background: var(--danger-bg); border: 1px solid #efc4bf; color: var(--danger); border-radius: 12px; padding: 10px 15px; margin: 0 0 16px; }

.karten { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 12px; margin-bottom: 20px; }
.karte { background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); padding: 15px 17px; box-shadow: var(--shadow); }
.karte .zahl { font-size: 27px; font-weight: 800; }
.karte .label { color: var(--ink2); font-size: 13px; }

.box { background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); padding: 16px; margin-bottom: 18px; box-shadow: var(--shadow); }
table { width: 100%; border-collapse: collapse; background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow); }
th { text-align: left; font-size: 12px; text-transform: uppercase; letter-spacing: .05em; color: var(--ink2); padding: 10px 13px; background: #f6faf9; border-bottom: 1px solid var(--line); }
td { padding: 10px 13px; border-bottom: 1px solid var(--line); vertical-align: top; }
tr:last-child td { border-bottom: none; }
tr:hover td { background: #f7fbfa; }

.badge { display: inline-block; padding: 2px 10px; border-radius: 999px; font-size: 12px; font-weight: 600; white-space: nowrap; }
.b-aktiv { background: var(--success-bg); color: var(--success); }
.b-pausiert { background: var(--warn-bg); color: var(--warn); }
.b-beendet { background: #e7edec; color: var(--ink2); }
.b-anreichern { background: var(--primary-bg); color: var(--primary-dk); }
.b-automat { background: var(--violett-bg); color: var(--violett); }
.b-produzieren { background: var(--warn-bg); color: var(--warn); }
.b-erledigt { background: var(--success-bg); color: var(--success); }
.b-offen { background: var(--danger-bg); color: var(--danger); }
.b-quittiert { background: var(--success-bg); color: var(--success); }
.b-quelle { background: #e7edec; color: var(--ink2); font-weight: 500; }

form.inline { display: inline; }
label { display: block; font-size: 13px; color: var(--ink2); margin: 10px 0 4px; }
input[type=text], input[type=password], input[type=date], select, textarea {
  width: 100%; padding: 9px 11px; border: 1px solid #c9d6d4; border-radius: 10px; font: inherit; background: var(--surface); color: var(--ink);
}
textarea { min-height: 90px; resize: vertical; }
input:focus, select:focus, textarea:focus { outline: 2px solid var(--primary); outline-offset: 0; border-color: var(--primary); }
.zeile { display: flex; gap: 12px; flex-wrap: wrap; }
.zeile > div { flex: 1; min-width: 160px; }

button, .btn { background: var(--primary); color: #fff; border: none; border-radius: 11px; padding: 10px 18px; font: inherit; font-weight: 600; cursor: pointer; }
button:hover, .btn:hover { background: var(--primary-dk); text-decoration: none; }
.btn { color: #fff !important; display: inline-block; }
button.leise, .btn.leise { background: var(--surface); color: var(--ink) !important; border: 1px solid var(--line); font-weight: 600; padding: 9px 16px; }
button.leise:hover, .btn.leise:hover { background: #f0f5f4; }
button.klein, .btn.klein { padding: 6px 13px; font-size: 13px; }
.btn-link { background: none; border: none; color: var(--primary); font: inherit; font-weight: 600; cursor: pointer; padding: 0; }
.btn-link:hover { text-decoration: underline; }

.filter { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; margin-bottom: 14px; }
.filter input, .filter select { width: auto; }
.muted { color: var(--ink2); font-size: 13px; }
.mono { font-family: ui-monospace, Consolas, monospace; font-size: 13px; }
.pwbox { background: var(--warn-bg); border: 1px solid #ecd9a0; border-radius: 12px; padding: 12px 16px; margin-bottom: 16px; }
.pwbox .mono { font-size: 16px; font-weight: 700; }

.login-wrap { max-width: 390px; margin: 8vh auto 0; }
.login-wrap .box { padding: 28px; }
.login-logo { text-align: center; font-size: 28px; font-weight: 800; color: var(--primary); margin-bottom: 4px; letter-spacing: -0.015em; }
.login-sub { text-align: center; color: var(--ink2); font-size: 13px; margin-bottom: 14px; }

/* ===== Lage + Korb (Übersicht) ===== */
.uebertitel { font-size: 12px; font-weight: 700; letter-spacing: 0.05em; text-transform: uppercase; color: var(--ink2); margin: 0 0 9px; }
.lage { display: flex; gap: 11px; flex-wrap: wrap; margin-bottom: 18px; }
.lage-card { flex: 1; min-width: 150px; background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); padding: 11px 14px; display: flex; flex-direction: column; gap: 7px; cursor: pointer; text-decoration: none; color: inherit; box-shadow: var(--shadow); }
.lage-card:hover { text-decoration: none; border-color: #c9d6d4; }
.lage-card.alle { flex: none; width: 104px; }
.lage-card.aktiv { border: 2px solid var(--primary); padding: 10px 13px; }
.lage-name { display: flex; align-items: center; gap: 8px; font-weight: 700; font-size: 15px; color: var(--ink); }
.lage-meta { display: flex; gap: 8px; align-items: center; font-size: 12px; color: var(--ink2); flex-wrap: wrap; }
.ampel { width: 9px; height: 9px; border-radius: 50%; flex: none; }
.ampel.danger { background: var(--danger); } .ampel.warn { background: var(--warn); } .ampel.success { background: var(--success); }
.chip { font-weight: 600; padding: 1px 9px; border-radius: 999px; font-size: 12px; }
.chip.danger { background: var(--danger-bg); color: var(--danger); }
.chip.warn { background: var(--warn-bg); color: var(--warn); }
.chip.success { background: var(--success-bg); color: var(--success); }

.dash-cols { display: flex; gap: 16px; align-items: flex-start; }
.navi { width: 212px; flex: none; background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); padding: 13px; display: flex; flex-direction: column; gap: 3px; box-shadow: var(--shadow); }
.navi-h { font-size: 11px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink2); padding: 0 9px 5px; }
.navi-item { display: flex; justify-content: space-between; gap: 8px; color: var(--ink2); padding: 8px 12px; font-size: 14px; border-radius: 10px; text-decoration: none; }
.navi-item:hover { background: #f0f5f4; text-decoration: none; }
.navi-item .z { font-weight: 600; color: var(--ink); }
.navi-item.aktiv { background: var(--primary-bg); color: var(--primary-dk); font-weight: 700; }
.navi-item.aktiv .z { color: var(--primary-dk); }
.navi-sep { height: 1px; background: var(--line); margin: 8px 5px; }

.korb { flex: 1; min-width: 0; }
.korb-h { display: flex; align-items: center; gap: 10px; margin: 0 0 12px; flex-wrap: wrap; }
.korb-h h2 { margin: 0; font-size: 18px; }
.meld-card { background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); padding: 13px 16px; margin-bottom: 10px; box-shadow: var(--shadow); }
.meld-card.akz-danger { border-left: 3px solid var(--danger); }
.meld-card.akz-warn { border-left: 3px solid var(--warn); }
.meld-card.akz-success { border-left: 3px solid var(--success); }
.meld-card.snooze { opacity: 0.7; }
.meld-top { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.meld-titel { font-weight: 700; font-size: 16px; color: var(--ink); }
.meld-actions { display: flex; gap: 9px; flex-wrap: wrap; margin-top: 11px; align-items: center; }

.seg-wrap { display: inline-flex; gap: 3px; background: var(--surface); border: 1px solid var(--line); border-radius: 999px; padding: 3px; }
.seg { color: var(--ink2); font-weight: 600; font-size: 13px; padding: 7px 17px; border-radius: 999px; text-decoration: none; }
.seg:hover { text-decoration: none; color: var(--ink); }
.seg.aktiv { background: var(--primary); color: #fff; }
.seg.aktiv:hover { color: #fff; }

/* Einrichtung luftiger */
.luftig .lage-card { padding: 16px 19px; }
.luftig .lage-card.aktiv { padding: 15px 18px; }
.luftig .lage-name { font-size: 17px; }
.luftig .lage-meta { font-size: 14px; }
.luftig .dash-cols { gap: 26px; }
.luftig .navi { width: 224px; border: none; box-shadow: none; background: none; padding: 0; }
.luftig .navi-item { font-size: 15px; padding: 10px 14px; }
.luftig .korb-h h2 { font-size: 20px; }
.luftig .meld-card { padding: 17px 19px; }

@media (max-width: 760px) {
  .dash-cols { flex-direction: column; }
  .navi, .luftig .navi { width: 100%; }
}
@media (max-width: 640px) {
  td, th { padding: 8px 9px; }
  .versteckbar { display: none; }
}

/* Dokument-Upload: Drag-and-Drop-Zone */
.dropzone { display: flex; align-items: center; justify-content: center; text-align: center;
  min-height: 96px; padding: 16px; border: 2px dashed #b7cbc9; border-radius: 14px;
  background: #f6faf9; color: var(--ink2); cursor: pointer; transition: background .12s, border-color .12s; }
.dropzone:hover { border-color: var(--primary); background: var(--primary-bg); }
.dropzone.over { border-color: var(--primary); background: var(--primary-bg); color: var(--primary-dk); }
.dropzone strong { color: var(--ink); }

/* Hinweis-Chips in der Bewohnerliste (blisterrelevant) */
.chip-h { display: inline-flex; align-items: center; justify-content: center; width: 18px; height: 18px;
  margin-left: 4px; border-radius: 6px; font-size: 11px; font-weight: 800; vertical-align: middle; cursor: help; }
.chip-m { background: var(--warn-bg); color: var(--warn); }
.chip-s { background: var(--primary-bg); color: var(--primary-dk); }
.chip-a { background: var(--danger-bg); color: var(--danger); }

/* QR-Code-Anzeige */
.qr { display: inline-block; padding: 12px; background: #fff; border: 1px solid var(--line); border-radius: 12px; }
.qr svg { width: 200px; height: 200px; display: block; }
