:root{
  --bg:#f1f5f9; --card:#fff; --ink:#0f172a; --muted:#64748b; --line:#e2e8f0;
  --brand:#1d4ed8; --brand-d:#1e3a8a; --accent:#eff6ff;
  --ok:#16a34a; --warn:#d97706; --bad:#dc2626; --violet:#7c3aed;
}
*{box-sizing:border-box}
body{margin:0;font:14px/1.5 system-ui,Segoe UI,Roboto,Arial,sans-serif;color:var(--ink);background:var(--bg)}
a{color:inherit;text-decoration:none}

/* layout */
.app{display:flex;min-height:100vh}
.sidebar{width:240px;background:var(--card);border-right:1px solid var(--line);flex-shrink:0;position:sticky;top:0;height:100vh;overflow-y:auto}
.brand{display:flex;align-items:center;gap:10px;padding:16px 18px;border-bottom:1px solid var(--line)}
.brand .logo{font-weight:800;color:var(--brand);font-size:18px;letter-spacing:.5px}
.brand small{color:var(--muted);font-size:11px;display:block}
.nav{padding:10px 0}
.nav .sec{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);padding:12px 18px 4px}
.nav a{display:flex;align-items:center;gap:10px;padding:9px 18px;color:#334155;font-size:13.5px;border-left:3px solid transparent}
.nav a:hover{background:var(--accent)}
.nav a.active{background:var(--accent);border-left-color:var(--brand);color:var(--brand);font-weight:600}
.nav .geb{display:flex;flex-direction:column;gap:1px;padding:7px 18px;border-left:3px solid transparent}
.nav .geb:hover{background:var(--accent)}
.nav .geb b{font-size:13px;display:flex;align-items:center;gap:7px}
.nav .geb span{font-size:11px;color:var(--muted);padding-left:15px}
.dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;display:inline-block}
.dot.offen{background:var(--bad)} .dot.in_arbeit{background:var(--warn)} .dot.fertig{background:var(--ok)}

.main{flex:1;min-width:0}
.topbar{background:var(--card);border-bottom:1px solid var(--line);padding:12px 26px;display:flex;justify-content:space-between;align-items:center}
.crumbs{font-size:13px;color:var(--muted)}
.crumbs a:hover{color:var(--brand)} .crumbs b{color:var(--ink)}
.content{padding:24px 26px;max-width:1180px}

/* cards & kpi */
h1{font-size:22px;margin:0 0 4px} h2{font-size:16px;margin:22px 0 10px}
.sub{color:var(--muted);font-size:13px;margin:0 0 18px}
.card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:18px}
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin:6px 0 4px}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px 16px}
.kpi .l{font-size:12px;color:var(--muted)}
.kpi .v{font-size:24px;font-weight:700;margin-top:4px}
.kpi.accent{background:var(--accent);border-color:#dbeafe}
.kpi.warn{background:#fffbeb;border-color:#fde68a}.kpi.warn .v{color:var(--warn)}
.kpi.bad .v{color:var(--bad)} .kpi.ok .v{color:var(--ok)} .kpi.violet .v{color:var(--violet)}

/* building grid */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}
.gcard{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:16px;display:block;transition:.12s}
.gcard:hover{border-color:var(--brand);box-shadow:0 4px 14px rgba(29,78,216,.08)}
.gcard .badge{font-size:11px;font-weight:600;padding:2px 9px;border-radius:20px;display:inline-block}
.badge.beladestelle{background:#fef2f2;color:var(--bad)} .badge.entladestelle{background:#f0fdf4;color:var(--ok)} .badge.zwischenlager{background:#f5f3ff;color:var(--violet)}
.gcard h3{margin:8px 0 2px;font-size:16px} .gcard .adr{color:var(--muted);font-size:12.5px}
.gcard .mini{display:flex;gap:16px;margin-top:12px;font-size:12px;color:var(--muted)}
.gcard .mini b{display:block;color:var(--ink);font-size:16px}

/* tables */
table{width:100%;border-collapse:collapse;font-size:13.5px}
th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);padding:10px 12px;border-bottom:1px solid var(--line)}
td{padding:10px 12px;border-bottom:1px solid #f1f5f9;vertical-align:middle}
tr:hover td{background:#fafcff}
.num{text-align:right;font-variant-numeric:tabular-nums}
.tablecard{background:var(--card);border:1px solid var(--line);border-radius:12px;overflow:hidden}
tfoot td{font-weight:700;background:#f8fafc}

/* chips */
.chip{font-size:11px;font-weight:600;padding:2px 9px;border-radius:20px;white-space:nowrap}
.chip.kat{background:#f1f5f9;color:#475569}
.chip.umziehen{background:#f0fdf4;color:var(--ok)} .chip.entsorgen{background:#fef2f2;color:var(--bad)} .chip.einlagern{background:#eff6ff;color:var(--brand)}
.chip.bestaetigt{background:#f0fdf4;color:var(--ok)} .chip.ungeklaert{background:#fef2f2;color:var(--bad)} .chip.abgeleitet{background:#fffbeb;color:var(--warn)}

/* map */
#map{height:420px;border-radius:12px;border:1px solid var(--line);z-index:1}

/* progress */
.bar{height:9px;background:#e2e8f0;border-radius:6px;overflow:hidden}
.bar>span{display:block;height:100%;background:var(--brand)}
.bar.ok>span{background:var(--ok)} .bar.warn>span{background:var(--warn)}

.grp-head{display:flex;justify-content:space-between;align-items:center;background:var(--accent);padding:8px 14px;font-weight:700;color:var(--brand);border-bottom:1px solid var(--line)}
.muted{color:var(--muted)}
.toolbar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.btn{background:var(--brand);color:#fff;border:0;border-radius:8px;padding:8px 14px;font-size:13px;cursor:pointer}
.btn.ghost{background:#fff;border:1px solid var(--line);color:#334155}
