:root{
  --bg:#eef1f5; --panel:#fff; --ink:#1f2933; --muted:#6b7280; --line:#e3e7ec;
  --brand-lr:#ea6a1e; --brand-mdl:#1f6feb;   /* LagerRent=Orange, MieteDeinLager=Blau */
  --ok:#16a34a; --ok-bg:#e7f6ec; --warn:#d97706; --warn-bg:#fcf2e0;
  --danger:#dc2626; --danger-bg:#fdecec; --info:#2563eb; --info-bg:#e8f0fe;
  --reserved:#7c3aed; --reserved-bg:#f1ebfd;
  --radius:12px; --shadow:0 1px 3px rgba(16,24,40,.08),0 1px 2px rgba(16,24,40,.04);
}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;background:var(--bg);color:var(--ink);font-size:14px;line-height:1.45}
h1,h2,h3{margin:0}
.appbar{display:flex;align-items:center;gap:14px;background:var(--panel);border-bottom:1px solid var(--line);padding:11px 20px;position:sticky;top:0;z-index:20;flex-wrap:wrap}
.logo{font-weight:800;font-size:17px;letter-spacing:-.2px}
.logo b{color:var(--brand-lr)}
.spacer{flex:1}
.updated{color:var(--muted);font-size:12.5px}
.who{font-size:12.5px;color:var(--muted)}
.btn{border:1px solid var(--line);background:var(--panel);color:var(--ink);border-radius:8px;padding:8px 13px;font-size:13px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:7px}
.btn.primary{background:#334155;border-color:#334155;color:#fff}
.btn:disabled{opacity:.5;cursor:default}
.btn:hover:not(:disabled){filter:brightness(.97)}
.wrap{max-width:1180px;margin:0 auto;padding:18px 20px 70px}

.kpis{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-bottom:16px}
@media(max-width:900px){.kpis{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.kpis{grid-template-columns:repeat(2,1fr)}}
.kpi{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:13px 14px;position:relative;overflow:hidden}
.kpi .v{font-size:25px;font-weight:800;line-height:1;font-variant-numeric:tabular-nums}
.kpi .l{font-size:11.5px;color:var(--muted);margin-top:6px;font-weight:600;line-height:1.25}
.kpi .strip{position:absolute;left:0;top:0;bottom:0;width:4px}
.kpi.ok .strip{background:var(--ok)} .kpi.danger .strip{background:var(--danger)}
.kpi.warn .strip{background:var(--warn)} .kpi.info .strip{background:var(--info)}
.kpi.reserved .strip{background:var(--reserved)} .kpi.muted .strip{background:var(--muted)}
.kpi{cursor:pointer;transition:box-shadow .1s}
.kpi:hover{box-shadow:0 2px 10px rgba(16,24,40,.14)}
.kpi.active{outline:2px solid #334155;outline-offset:-1px}

/* Eintrag = Datenzeile + Namenszeile darunter (Name de-emphasized, ganz unten) */
tr.e-main td{border-bottom:none;padding-bottom:3px}
tr.e-name td{padding-top:0;padding-bottom:11px;border-bottom:1px solid var(--line);color:var(--muted);font-size:12px}
tbody tr.e-main:hover, tbody tr.e-main:hover + tr.e-name{background:#f8fafc}
#clear{white-space:nowrap}
tr.e-name .note{margin-top:3px;color:#475569;font-size:12px;font-style:italic}

.filters{display:flex;gap:10px;flex-wrap:wrap;align-items:center;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:10px 14px;margin-bottom:6px;box-shadow:var(--shadow)}
.filters select{font:inherit;padding:7px 10px;border:1px solid var(--line);border-radius:8px;background:#fff}
.filters label{font-size:12px;color:var(--muted);font-weight:600;display:flex;gap:6px;align-items:center}

.alertband{background:#fffaf2;border:1px solid #f3dcae;border-left:4px solid var(--warn);border-radius:var(--radius);padding:12px 16px;margin:16px 0 4px}
.alertband b{color:#92400e}
.alertband .row{display:flex;gap:9px;align-items:center;padding:5px 0;flex-wrap:wrap;border-top:1px dashed #f0ddb8}
.alertband .row:first-of-type{border-top:none}

.section-title{display:flex;align-items:center;gap:10px;margin:24px 0 11px;font-size:15px;font-weight:700;flex-wrap:wrap}
.section-title .count{color:var(--muted);font-weight:600;font-size:13px}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.panel.scroll{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:13px}
th{text-align:left;color:var(--muted);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.04em;padding:9px 12px;border-bottom:1px solid var(--line);white-space:nowrap}
td{padding:10px 12px;border-bottom:1px solid var(--line);vertical-align:middle}
tr:last-child td{border-bottom:none}
tbody tr:hover{background:#f8fafc}
.muted{color:var(--muted)} .num{font-variant-numeric:tabular-nums}
.no{color:var(--danger);font-weight:600}

.badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;padding:3px 8px;border-radius:999px;white-space:nowrap}
.b-ok{background:var(--ok-bg);color:var(--ok)} .b-warn{background:var(--warn-bg);color:var(--warn)}
.b-danger{background:var(--danger-bg);color:var(--danger)} .b-info{background:var(--info-bg);color:var(--info)}
.b-reserved{background:var(--reserved-bg);color:var(--reserved)}
.b-brand-LR{background:#fdeee2;color:var(--brand-lr)} .b-brand-MDL{background:#e8f0fe;color:var(--brand-mdl)}
.lc{display:inline-block;font-weight:800;font-size:11px;background:#eef2f7;color:#475569;border:1px solid #dde3ea;border-radius:6px;padding:1px 6px;margin-right:6px;font-variant-numeric:tabular-nums}
.opt{padding:2px 0}
.contact{font-size:11.5px;color:var(--muted)}

.intro{background:var(--info-bg);border:1px solid #cfe0fd;color:#1e40af;border-radius:var(--radius);padding:11px 15px;margin-bottom:16px;font-size:13px}
#err{display:none;background:var(--danger-bg);border:1px solid #f3c0c0;color:#991b1b;border-radius:var(--radius);padding:11px 15px;margin-bottom:14px}

/* Login */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}
.login-card{background:var(--panel);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:28px;width:340px;max-width:100%}
.login-card h1{font-size:20px;margin-bottom:4px}
.login-card .sub{color:var(--muted);font-size:13px;margin-bottom:18px}
.login-card label{display:block;font-size:12px;font-weight:600;color:var(--muted);margin:12px 0 5px}
.login-card input{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:9px;font:inherit}
.login-card button{width:100%;margin-top:18px;padding:11px;border:none;border-radius:9px;background:#334155;color:#fff;font-weight:700;font-size:14px;cursor:pointer}
.login-card .msg{color:var(--danger);font-size:12.5px;margin-top:12px;min-height:16px}

/* ============================ Mobil ============================ */
@media(max-width:680px){
  body{font-size:13.5px}

  /* Appbar gestapelt: Logo, Status, dann Buttons */
  .appbar{padding:10px 13px;gap:7px}
  .appbar .spacer{display:none}
  .logo{order:0;width:100%;font-size:16px}
  .updated{order:1;width:100%;font-size:11.5px}
  .who{order:2;width:100%;font-size:11.5px}
  .appbar .btn{order:3;flex:1;justify-content:center;min-height:42px;font-size:14px}

  .wrap{padding:14px 12px 60px}

  /* KPIs: 2 Spalten, gut tippbar */
  .kpis{grid-template-columns:repeat(2,1fr);gap:9px;margin-bottom:14px}
  .kpi{padding:11px 12px}
  .kpi .v{font-size:22px}
  .kpi .l{font-size:11px}

  /* Filter: volle Breite, größere Touch-Ziele */
  .filters{gap:8px;padding:10px 12px}
  .filters label{font-size:11.5px;flex:1 1 46%}
  .filters select{flex:1;min-height:40px}
  #clear{flex:1 1 100%;justify-content:center;min-height:42px}
  #finfo{width:100%}

  .section-title{font-size:14px;margin:18px 0 9px}

  /* Dichte Tabellen: horizontal wischbar, Spalten bleiben lesbar */
  .panel.scroll{-webkit-overflow-scrolling:touch}
  .panel.scroll table{min-width:600px}
  th{font-size:10.5px;padding:8px 10px}
  td{padding:9px 10px}

  /* Login */
  .login-card{padding:22px 20px}
}
