:root{
  --bg:#eef1f5; --card:#fff; --ink:#1a2230; --muted:#6b7686; --line:#e0e5ec;
  --brand:#15355f; --brand-d:#0e2545; --accent:#c0392b; --ok:#168a3c; --warn:#b9820a; --bad:#c22;
  --radius:12px; --shadow:0 1px 3px rgba(15,35,70,.08),0 4px 14px rgba(15,35,70,.07);
}
.dpi-badge{display:inline-flex;align-items:center;justify-content:center;font-weight:800;letter-spacing:1px;
  background:#fff;color:var(--brand);border-radius:8px;padding:6px 10px;font-size:18px;border:2px solid var(--accent)}
.dpi-head{text-align:center;margin-bottom:18px}
.dpi-head .full{font-weight:700;color:var(--brand);margin-top:10px;font-size:15px;line-height:1.3}
.dpi-head .claim{color:var(--muted);font-size:12.5px;margin-top:6px;letter-spacing:.3px}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg);color:var(--ink);font-size:15px;line-height:1.45;
  -webkit-tap-highlight-color:transparent;overscroll-behavior-y:none}
a{color:var(--brand);text-decoration:none}
button{font-family:inherit;font-size:14px;cursor:pointer;border:none;border-radius:9px;padding:10px 16px;font-weight:600}
.btn{background:var(--brand);color:#fff}
.btn:hover{background:var(--brand-d)}
.btn.sec{background:#eef2f8;color:var(--brand)}
.btn.ghost{background:transparent;color:var(--muted);padding:6px 10px}
.btn.sm{padding:6px 12px;font-size:13px}
.btn.bad{background:var(--bad)}
input,select,textarea{font-family:inherit;font-size:16px;width:100%;padding:11px 12px;border:1px solid var(--line);
  border-radius:9px;background:#fff;color:var(--ink)}/* 16px = kein Auto-Zoom auf iOS */
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand)}
label{display:block;font-size:13px;font-weight:600;color:var(--muted);margin:10px 0 4px}
.row{display:flex;gap:12px;flex-wrap:wrap}
.row>*{flex:1;min-width:0}

/* Topbar */
header.top{background:var(--brand);color:#fff;padding:12px 16px;padding-top:calc(12px + env(safe-area-inset-top));
  padding-left:calc(16px + env(safe-area-inset-left));padding-right:calc(16px + env(safe-area-inset-right));
  display:flex;align-items:center;gap:10px;position:sticky;top:0;z-index:20;box-shadow:var(--shadow)}
header.top .logo{font-weight:800;font-size:18px;letter-spacing:.3px}
header.top .logo small{font-weight:500;opacity:.85;font-size:12px;display:block;letter-spacing:0}
header.top .spacer{flex:1}
header.top .who{font-size:13px;opacity:.95;text-align:right}
header.top button{background:rgba(255,255,255,.16);color:#fff}
header.top .backbtn{font-size:15px;line-height:1;padding:9px 14px;font-weight:800;
  background:#fff;color:var(--brand);border-radius:9px;white-space:nowrap;flex:0 0 auto}
header.top button:hover{background:rgba(255,255,255,.28)}

#net{display:none;background:var(--warn);color:#fff;text-align:center;padding:6px;font-size:13px;font-weight:600}
#net.show{display:block}

main{max-width:920px;margin:0 auto;padding:18px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);
  padding:18px;margin-bottom:16px}
h1{font-size:22px;margin:4px 0 16px}
h2{font-size:17px;margin:0 0 12px}
.crumb{font-size:13px;color:var(--muted);margin-bottom:10px}
.crumb a{color:var(--muted)}

/* Auth */
.auth-wrap{max-width:400px;margin:8vh auto;padding:18px}
.auth-wrap .logo{text-align:center;font-size:28px;font-weight:800;color:var(--brand);margin-bottom:4px}
.auth-wrap .sub{text-align:center;color:var(--muted);margin-bottom:22px;font-size:14px}
.tabs{display:flex;margin-bottom:16px;border-bottom:1px solid var(--line)}
.tabs button{background:none;color:var(--muted);border-bottom:2px solid transparent;border-radius:0;padding:10px 14px}
.tabs button.active{color:var(--brand);border-bottom-color:var(--brand)}

/* list items */
.item{display:flex;align-items:center;gap:12px;padding:14px 16px;border:1px solid var(--line);border-radius:11px;
  background:#fff;margin-bottom:10px;cursor:pointer;transition:.12s}
.item:hover{border-color:var(--brand);box-shadow:var(--shadow)}
.item.done{background:#eef9f1;border-color:#bfe6cc}
.item .grow{flex:1;min-width:0}
.item .t{font-weight:700}
.item .s{font-size:13px;color:var(--muted)}
.pill{font-size:12px;font-weight:700;padding:4px 10px;border-radius:999px;white-space:nowrap}
.pill.offen{background:#eef0f3;color:#69707d}
.pill.aktuell{background:#e7f6ec;color:var(--ok)}
.pill.faellig{background:#fdf2e0;color:var(--warn)}
.pill.gesperrt{background:#fdeaea;color:var(--bad)}
.empty{color:var(--muted);text-align:center;padding:30px;font-size:14px}
.opill{font-size:12px;font-weight:700;padding:4px 10px;border-radius:999px;white-space:nowrap;display:inline-block;margin-left:4px}
.opill.offen{background:#fdeaea;color:#c22}
.opill.done{background:#e7f6ec;color:#168a3c}
.opill.busy{background:#fff3cd;color:#8a6d00;border:1px solid #f0d98a}
.tpill{display:inline-block;background:#fff;border:2px solid var(--ok);color:var(--ok);border-radius:999px;
  padding:9px 15px;margin:6px 6px 0 0;font-weight:700;font-size:14px;cursor:pointer}
.tpill.sel{background:var(--bad);border-color:var(--bad);color:#fff}
.tpill.sel::before{content:'✓ '}

/* checklist */
.cl-group{font-weight:700;color:var(--brand);margin:18px 0 6px;font-size:14px}
.cl-item{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--line)}
.cl-item .lbl{flex:1;font-size:14px}
.cl-item .lbl small{display:block;color:var(--muted);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.4px}
.seg{display:flex;border:1px solid var(--line);border-radius:8px;overflow:hidden}
.seg button{background:#fff;color:var(--muted);border-radius:0;padding:7px 10px;font-size:13px;border-right:1px solid var(--line);flex:1;line-height:1.15;text-align:center}
.seg button:last-child{border-right:none}
.seg button.on-ok{background:var(--ok);color:#fff}
.seg button.on-mangel{background:var(--bad);color:#fff}
.seg button.on-na{background:#8a93a3;color:#fff}

.dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px}
.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:var(--ink);color:#fff;
  padding:12px 20px;border-radius:10px;box-shadow:var(--shadow);z-index:50;font-size:14px;opacity:0;transition:.2s}
.toast.show{opacity:1}
.muted{color:var(--muted)}
.right{text-align:right}
.flex{display:flex;align-items:center;gap:10px}
.flex .spacer{flex:1}
.statgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}
.stat{background:#fff;border:1px solid var(--line);border-radius:11px;padding:14px;text-align:center}
.stat .n{font-size:26px;font-weight:800}
.stat .l{font-size:12px;color:var(--muted);font-weight:600}
.stat.faellig .n{color:var(--warn)} .stat.gesperrt .n{color:var(--bad)} .stat.aktuell .n{color:var(--ok)}
@media(max-width:620px){.statgrid{grid-template-columns:repeat(2,1fr)}}

/* Modul-Auswahl (Zwischenschritt nach Sync) */
.modgrid{display:flex;flex-direction:column;gap:10px;height:calc(100dvh - 150px);min-height:300px}
.modtile{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;flex:1;min-height:0;
  position:relative;border-radius:18px;border:2px solid var(--line);background:#fff;
  cursor:pointer;padding:14px;text-align:center;box-shadow:var(--shadow);transition:.12s}
.modtile:active{transform:scale(.99)}
.modtile .ico{font-size:40px;line-height:1}
.modtile .ttl{font-size:21px;font-weight:800;color:var(--brand)}
.modtile .sub{font-size:14px;color:var(--muted);font-weight:600}
.modtile.dguv{background:linear-gradient(160deg,#fffaf0,#fff);border-color:#f0d98a}
.modtile.dguv .ttl{color:#8a6d00}
.modtile.tafel{background:linear-gradient(160deg,#eef4fb,#fff)}
.modtile.tafel.locked{background:#f4f6f9;opacity:.85;cursor:not-allowed}
.modtile.tafel.locked .ttl{color:#8a93a3}
.modtile.tafel.locked .sub{color:var(--bad);font-weight:700}
.modtile .soon{position:absolute;top:12px;right:12px;background:var(--warn);color:#fff;
  border-radius:999px;padding:4px 12px;font-size:12px;font-weight:800}

/* Globaler Hub (Admin-Landing): Online-Streifen + Kachel-Zähler */
.hub-online{font-size:13px;padding:9px 13px;background:#fff;border:1px solid var(--line);border-radius:10px;
  margin-bottom:10px;line-height:1.5}
.modgrid.compact{height:calc(100dvh - 250px);min-height:240px}
.modcount{display:flex;gap:6px;margin-top:7px;flex-wrap:wrap;justify-content:center}
.cpill{font-size:12px;font-weight:700;padding:3px 10px;border-radius:999px}
.cpill.f{background:#fdf2e0;color:var(--warn)}
.cpill.z{background:#eef0f3;color:#69707d}
.cpill.g{background:#fdeaea;color:var(--bad)}
.hub-admin-row{margin-top:12px;display:flex;gap:10px;justify-content:center}

/* Stilllegen-Dialog: Grund-Optionen */
.rt-opt{display:flex;align-items:center;gap:10px;padding:12px;border:1px solid var(--line);border-radius:9px;
  margin-bottom:8px;font-weight:600;cursor:pointer}
.rt-opt:hover{border-color:var(--brand)}

/* --- Mobil (iPhone/Android) --- */
main{padding-bottom:calc(18px + env(safe-area-inset-bottom))}
@media(max-width:560px){
  main{padding:14px 12px}
  .card{padding:14px}
  h1{font-size:20px}
  .row{flex-direction:column;gap:0}      /* Formularfelder untereinander */
  .row>*{margin-bottom:2px}
  header.top{gap:8px}
  header.top .logo{font-size:15px;line-height:1.1}
  header.top .logo small{font-size:10.5px}
  header.top .who{font-size:11px;max-width:90px;line-height:1.15;overflow:hidden}
  header.top button{padding:8px 10px;font-size:13px}
  .dpi-badge{padding:5px 8px;font-size:15px}
  /* Checklisten-Zeile: Bewertung darf unter den Text rutschen */
  .cl-item{flex-wrap:wrap}
  .cl-item .lbl{flex:1 1 100%}
  .cl-item .seg{margin-top:6px}
  .seg button{padding:10px 14px}          /* größere Touch-Fläche */
  .item{padding:13px 12px}
  .btn{padding:11px 15px}
}
@media(max-width:520px){
  header.top .who{display:none}           /* Handy: Name oben ausblenden, Header sauber */
  header.top .logo small{display:none}
}
