/* QM-Pilot – Oberflaeche (Stufe 0). Farben kommen aus der Mandanten-Konfiguration. */
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  color:#1f2937;background:#f5f6f8;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}

/* ---------- Login ---------- */
body.auth{display:flex;align-items:center;justify-content:center;min-height:100vh}
.auth-wrap{width:100%;max-width:380px;text-align:center}
.auth-card{background:#fff;border:1px solid #e6e8ec;border-radius:14px;padding:32px 28px}
.auth-logo{max-width:210px;height:auto;margin:4px auto 14px;display:block}
.auth-sub{font-size:14px;color:#6b7280;margin-bottom:20px}
.auth-card form{text-align:left}
.auth-card label{display:block;font-size:13px;color:#374151;margin:12px 0 5px;font-weight:500}
.auth-card input{width:100%;height:42px;padding:0 12px;border:1px solid #d1d5db;border-radius:9px;
  font-size:15px;outline:none}
.auth-card input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(56,176,152,.18)}
.btn-primary{width:100%;height:44px;margin-top:20px;border:0;border-radius:9px;
  background:var(--primary);color:#fff;font-size:15px;font-weight:500;cursor:pointer}
.btn-primary:hover{filter:brightness(.95)}
.auth-error{background:#fdecea;color:#a3261c;border-radius:8px;padding:9px 12px;font-size:13px;margin-bottom:6px}
.auth-hint{font-size:12px;color:#9ca3af;margin-top:16px}
.auth-foot{margin-top:18px;font-size:12px;color:#9ca3af}

/* ---------- App-Layout ---------- */
.layout{display:flex;min-height:100vh}
.sidebar{width:230px;flex-shrink:0;background:#fff;border-right:1px solid #e6e8ec;
  display:flex;flex-direction:column;padding:16px 12px}
.brand{display:flex;align-items:center;gap:9px;padding:6px 8px 18px}
.brand img{height:26px;width:auto}
.brand span{font-weight:600;letter-spacing:.02em;color:#0f6e56}
.nav{display:flex;flex-direction:column;gap:2px}
.nav-item{display:block;padding:9px 12px;border-radius:9px;font-size:14px;color:#4b5563}
.nav-item.active{background:#e1f5ee;color:#0f6e56;font-weight:500;border-left:3px solid var(--primary)}
.nav-item.disabled{color:#b6bcc6}
.side-user{margin-top:auto;display:flex;gap:10px;align-items:center;
  border-top:1px solid #eef0f3;padding-top:12px}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--primary);color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:600;text-transform:uppercase}
.su-name{font-size:13px;font-weight:500}
.su-logout{background:none;border:0;padding:0;color:#9ca3af;font-size:12px;cursor:pointer}
.su-logout:hover{color:var(--akzent)}

.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{background:#fff;border-bottom:1px solid #e6e8ec;padding:16px 24px}
.page-title{font-size:18px;font-weight:600}
.content{padding:22px 24px}
.welcome{font-size:15px;color:#374151;margin-bottom:10px}
.rollen{font-size:13px;color:#6b7280;margin-bottom:6px}
.chip{display:inline-block;background:#eef0f3;border-radius:20px;padding:3px 11px;margin:2px 4px 2px 0;
  font-size:12px;color:#374151}
.muted{color:#9ca3af}
.sec{font-size:14px;font-weight:600;color:#374151;margin:22px 0 12px}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:12px}
.card{background:#fff;border:1px solid #e6e8ec;border-radius:12px;padding:14px 16px;position:relative}
.card-active{border-color:var(--primary);box-shadow:0 0 0 1px var(--primary) inset}
.card-stage{font-size:12px;color:#9ca3af}
.card-name{font-size:14px;font-weight:500;margin:3px 0 12px}
.badge{font-size:11px;font-weight:500;padding:3px 9px;border-radius:7px}
.badge-aktiv{background:#e1f5ee;color:#0f6e56}
.badge-geplant{background:#eef0f3;color:#6b7280}

/* ---------- Audit-Trail ---------- */
.filterbar{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:12px}
.filterbar input[type=text]{flex:1;min-width:200px;height:38px;padding:0 12px;border:1px solid #d1d5db;border-radius:9px;font-size:14px}
.filterbar select{height:38px;border:1px solid #d1d5db;border-radius:9px;padding:0 10px;font-size:14px;background:#fff}
.filterbar input:focus,.filterbar select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(56,176,152,.18)}
.btn-primary.sm{width:auto;height:38px;margin:0;padding:0 16px}
.btn-ghost{height:38px;display:inline-flex;align-items:center;padding:0 14px;border:1px solid #d1d5db;border-radius:9px;background:#fff;color:#374151;font-size:14px}
.btn-ghost:hover{border-color:var(--primary);color:var(--primary)}
.treffer{font-size:12px;color:#9ca3af;margin-bottom:8px}
.tbl{width:100%;border-collapse:collapse;background:#fff;border:1px solid #e6e8ec;border-radius:12px;overflow:hidden;font-size:13px}
.tbl th{text-align:left;background:#f3f5f7;color:#6b7280;font-weight:600;padding:10px 12px;border-bottom:1px solid #e6e8ec}
.tbl td{padding:10px 12px;border-bottom:1px solid #eef0f3;vertical-align:top}
.tbl tr:last-child td{border-bottom:0}
.nowrap{white-space:nowrap;color:#6b7280}
.tag{display:inline-block;background:#e1f5ee;color:#0f6e56;border-radius:7px;padding:2px 9px;font-size:12px;font-weight:500}
.pager{display:flex;gap:14px;align-items:center;justify-content:center;margin-top:14px;font-size:13px;color:#6b7280}
.pager a{color:var(--primary);font-weight:500}

/* ---------- Kiosk / PIN / Reinigung (niederschwellig, große Flächen) ---------- */
body.kiosk{display:flex;align-items:flex-start;justify-content:center;min-height:100vh;background:#f5f6f8}
.kiosk-wrap{width:100%;max-width:440px;text-align:center;padding:34px 18px}
.kiosk-logo{max-width:200px;height:auto;margin:0 auto 18px;display:block}
.kiosk-h{font-size:26px;margin:6px 0 2px;color:#1f2937}
.kiosk-sub{font-size:16px;color:#6b7280;margin-bottom:18px}
.kiosk-error{background:#fdecea;color:#a3261c;border-radius:10px;padding:12px 14px;font-size:15px;margin-bottom:14px}
.kiosk-back{display:inline-block;margin-top:22px;color:#6b7280;font-size:15px}
.tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-top:8px}
.tile{display:flex;flex-direction:column;align-items:center;gap:10px;background:#fff;border:1px solid #e6e8ec;
  border-radius:16px;padding:22px 12px;color:#1f2937}
.tile:hover{border-color:var(--primary);box-shadow:0 0 0 2px rgba(56,176,152,.2)}
.tile-ini{width:60px;height:60px;border-radius:50%;background:var(--primary);color:#fff;display:flex;
  align-items:center;justify-content:center;font-size:26px;font-weight:600;text-transform:uppercase}
.tile-ini.big{width:84px;height:84px;font-size:36px;margin:0 auto 4px}
.tile-name{font-size:17px;font-weight:500}
.pin-dots{height:30px;font-size:34px;letter-spacing:10px;color:var(--primary);margin:6px 0 16px;min-height:34px}
.keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;max-width:300px;margin:0 auto}
.keypad button{height:66px;font-size:26px;border:1px solid #d8dce2;background:#fff;border-radius:14px;cursor:pointer;color:#1f2937}
.keypad button:active{transform:scale(.97)}
.keypad button.ok{background:var(--primary);color:#fff;border:0}
.keypad button.aux{color:#6b7280}
.r-tasks{margin-top:8px}
.r-empty{background:#fff;border:1px dashed #cfd4db;border-radius:16px;padding:34px 16px;color:#374151;font-size:17px}
.r-logout{margin-top:22px;height:60px;width:100%;max-width:300px;border:0;border-radius:14px;
  background:var(--primary);color:#fff;font-size:18px;font-weight:500;cursor:pointer}
.auth-pin-link{display:inline-block;margin-top:14px;color:var(--primary);font-size:13px;font-weight:500}

/* ---------- Benutzerverwaltung ---------- */
.tag-off{background:#fbeae7;color:#a3261c}
.linkbtn{background:none;border:0;padding:0;color:var(--akzent);cursor:pointer;font-size:13px}
.linkbtn:hover{text-decoration:underline}
.formcard{max-width:560px;background:#fff;border:1px solid #e6e8ec;border-radius:12px;padding:20px 22px}
.formcard > div{margin-bottom:14px}
.formcard label{display:block;font-size:13px;color:#374151;font-weight:500;margin-bottom:5px}
.formcard input[type=text],.formcard input[type=email],.formcard input[type=password],.formcard select{
  width:100%;height:38px;padding:0 12px;border:1px solid #d1d5db;border-radius:9px;font-size:14px;background:#fff}
.formcard input:focus,.formcard select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(56,176,152,.18)}
.formcard input[type=checkbox]{width:auto;height:auto;margin-right:7px}
.formcard ul{list-style:none;padding:0;margin:0}
.formcard ul li label{display:flex;align-items:center;font-weight:400;margin:0 0 4px}
.form-actions{display:flex;gap:10px;margin-top:6px}

/* ---------- Aufgaben ---------- */
.kpi{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:12px;margin:6px 0 8px}
.kpi-card{background:var(--color-background-secondary,#f3f5f7);background:#f3f5f7;border-radius:10px;padding:12px 14px}
.kpi-l{font-size:12px;color:#6b7280}
.kpi-n{font-size:26px;font-weight:600;color:#1f2937}
.kpi-n.rot{color:var(--akzent)}
.tasklist{margin-top:8px}
.taskrow{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid #e6e8ec;border-radius:10px;padding:10px 14px;margin-bottom:8px}
.tinfo{flex:1;min-width:0}
.ttitle{font-size:14px;font-weight:500;color:#1f2937}
.tmeta{font-size:12px;color:#9ca3af}
.badge.bad{background:#fbeae7;color:#a3261c}
.badge.today{background:#fff3d6;color:#854f0b}
.badge.soon{background:#eef0f3;color:#6b7280}
.empty{padding:18px;text-align:center}
/* Reinigungs-Kacheln */
.r-tasks{display:grid;grid-template-columns:1fr;gap:12px;margin-top:8px}
.r-tile{background:#fff;border:1px solid #e6e8ec;border-radius:16px;padding:16px;display:flex;flex-direction:column;gap:12px}
.r-tile-title{font-size:18px;font-weight:500;color:#1f2937}
.r-done{height:54px;border:0;border-radius:12px;background:var(--primary);color:#fff;font-size:18px;font-weight:500;cursor:pointer}

/* ---------- Dokumente / Schulungs-Donut ---------- */
.donut{width:56px;height:56px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.donut-i{width:40px;height:40px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:#374151}

/* ===================== Cockpit-Redesign & Marke ===================== */
.brand{align-items:center;gap:11px}
.brand img{height:44px;width:auto}
.brand-txt{display:flex;flex-direction:column;line-height:1.15}
.brand-txt b{font-weight:700;font-size:14px;color:#0f6e56;letter-spacing:.01em}
.brand-txt small{font-size:12px;color:#6b7280;letter-spacing:.06em;text-transform:uppercase}

/* Sidebar-Avatar als Foto */
.side-user .avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}

/* Cockpit-Kopf: Begrüßung links, Crew-Karte rechts (nicht zentral) */
.cockpit-top{display:flex;gap:18px;align-items:stretch;flex-wrap:wrap;margin-bottom:16px}
.cockpit-hello{flex:1 1 320px;display:flex;flex-direction:column;justify-content:center;
  background:linear-gradient(135deg,var(--primary),#0f6e56);color:#fff;border-radius:14px;padding:22px 24px}
.hello-line{font-size:22px;font-weight:700;letter-spacing:.01em}
.hello-tag{margin-top:6px;font-size:14px;opacity:.92}

.crew-card{flex:0 0 240px;background:#fff;border:1px solid #e6e8ec;border-radius:14px;
  padding:16px;display:flex;flex-direction:column;align-items:center;text-align:center}
.crew-ava-form{margin:0}
.crew-ava{position:relative;width:78px;height:78px;border-radius:50%;overflow:hidden;cursor:pointer;
  display:flex;align-items:center;justify-content:center;background:var(--primary);color:#fff}
.crew-ava img{width:100%;height:100%;object-fit:cover}
.crew-ini{font-size:30px;font-weight:600}
.crew-ava-edit{position:absolute;left:0;right:0;bottom:0;font-size:10px;background:rgba(0,0,0,.55);
  color:#fff;padding:2px 0;opacity:0;transition:opacity .15s}
.crew-ava:hover .crew-ava-edit{opacity:1}
.crew-name{margin-top:10px;font-weight:600;color:#1f2937}
.crew-role{font-size:12px;color:#6b7280;margin-top:2px}
.crew-clock{font-size:12px;color:#374151;margin-top:8px;font-variant-numeric:tabular-nums}

/* KPI-Kacheln klickbar */
.kpi-link{display:block;text-decoration:none;color:inherit;border:1px solid transparent;transition:.15s}
.kpi-link:hover{border-color:var(--primary);transform:translateY(-1px);box-shadow:0 2px 8px rgba(0,0,0,.06)}

/* Motivierender Leer-Zustand */
.allclear{display:flex;gap:16px;align-items:center;background:#eafaf4;border:1px solid #bfe9da;
  border-radius:14px;padding:18px 20px;margin-top:6px}
.allclear-badge{width:46px;height:46px;border-radius:50%;background:var(--primary);color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.allclear-h{font-weight:700;color:#0f6e56;font-size:16px}
