:root{
  --ink:#1d2433; --muted:#6b7480; --line:#e3e7ef; --bg:#f3f4f6; --card:#fff;
  --blue:#2563eb; --blued:#1e40af; --green:#15803d; --amber:#b45309; --red:#b91c1c;
  --respbg:#eef2ff; --respink:#1e40af; --revbg:#f1f5f9; --revink:#475569;
  --ok:#15803d; --okbg:#e9f7ef; --warn:#b45309; --warnbg:#fdf3e7; --off:#6b7480; --offbg:#eceef2;
  --radius:12px; --shadow:0 1px 3px rgba(20,30,55,.08),0 6px 18px rgba(20,30,55,.06);
}
*{box-sizing:border-box}
html,body{margin:0;background:var(--bg);color:var(--ink);font-family:"Segoe UI",-apple-system,system-ui,Arial,sans-serif;font-size:15px;line-height:1.4}
.app-root{min-height:100vh}
.muted{color:var(--muted)} .small{font-size:12.5px} .xsmall{font-size:12px}

/* Buttons / inputs */
.btn{appearance:none;border:1px solid var(--line);background:#fff;color:var(--ink);border-radius:10px;padding:10px 14px;font-size:14px;cursor:pointer;font-weight:600}
.btn:hover{border-color:#c9cfdb}
.btn.primary{background:var(--blue);border-color:var(--blue);color:#fff}
.btn.primary:hover{background:var(--blued)}
.btn.small{padding:7px 11px;font-size:13px;border-radius:9px}
.btn.xsmall{padding:5px 9px;font-size:12px;border-radius:8px}
.btn[disabled]{opacity:.5;cursor:not-allowed}
input,select{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:10px;font-size:15px;background:#fff;margin:6px 0}
select{width:auto;min-width:160px}

/* Gate */
.gate{max-width:460px;margin:0 auto;padding:28px 16px;display:flex;flex-direction:column;gap:16px}
.gate .brand{display:flex;align-items:center;gap:12px;margin-bottom:4px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px}
.card h3{margin:0 0 10px;font-size:16px}
.banner{background:var(--warnbg);color:var(--warn);border:1px solid #f0d8b3;border-radius:10px;padding:10px 12px;font-size:13.5px}

/* Topbar */
.topbar{position:sticky;top:0;z-index:5;background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;flex-wrap:wrap}
.hrow{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.tabs{display:flex;gap:4px;margin-left:8px}
.tab{background:transparent;border:none;padding:8px 12px;border-radius:8px;font-weight:600;color:var(--muted);cursor:pointer}
.tab.active{background:var(--bg);color:var(--ink)}
.pill{font-size:12px;font-weight:700;padding:4px 10px;border-radius:999px;background:var(--offbg);color:var(--off)}
.pill.ok{background:var(--okbg);color:var(--ok)} .pill.warn{background:var(--warnbg);color:var(--warn)} .pill.off{background:#fdeaea;color:var(--red)}

/* Main */
.main{max-width:920px;margin:0 auto;padding:14px}
.projbar{display:flex;align-items:center;gap:10px;margin:6px 0 14px}

/* Phases */
.phases{display:flex;flex-direction:column;gap:10px}
.phase{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.phase-h{width:100%;display:flex;align-items:center;gap:14px;padding:14px 16px;background:#fff;border:none;cursor:pointer;text-align:left}
.phase-title{font-weight:700;font-size:15.5px;flex:0 0 auto}
.phase-h .bar{flex:1}
.phase-body{display:none;padding:6px 14px 14px;border-top:1px solid var(--line)}
.phase-body.open{display:block}
.note{background:#fbf7ff;border:1px solid #ecdcff;color:#5b4a78;border-radius:8px;padding:8px 10px;font-size:12.5px;margin:8px 0}
.ut-h{font-weight:700;color:var(--blued);margin:12px 0 4px;font-size:14px}
.unt{margin:4px 0 10px}
.unt-h{color:var(--muted);font-weight:600;font-size:12.5px;text-transform:uppercase;letter-spacing:.03em;margin:8px 0 2px}

/* Step row */
.step{display:flex;align-items:flex-start;gap:11px;padding:8px 4px;border-bottom:1px dotted var(--line)}
.step:last-child{border-bottom:none}
.check{flex:0 0 auto;width:26px;height:26px;border:2px solid #b3bccb;border-radius:7px;background:#fff;color:#fff;font-size:15px;font-weight:800;line-height:1;cursor:pointer;margin-top:1px}
.check.done{background:var(--green);border-color:var(--green)}
.check.pending{box-shadow:0 0 0 3px #fde9c8}
.check[disabled]{opacity:.45;cursor:not-allowed}
.step-main{flex:1;min-width:0}
.step-title{font-size:14.5px}
.badges{display:flex;flex-wrap:wrap;gap:5px;margin-top:4px}
.badge{font-size:11.5px;font-weight:700;padding:2px 8px;border-radius:999px}
.badge.resp{background:var(--respbg);color:var(--respink)}
.badge.rev{background:var(--revbg);color:var(--revink);font-weight:600}
.badge.rev::before{content:"beteiligt: ";font-weight:600;opacity:.7}
.badge.resp::before{content:"zuständig: ";font-weight:600;opacity:.7}
.step-right{display:flex;flex-direction:column;align-items:flex-end;gap:5px}
.flag{font-size:11.5px;font-weight:700;color:var(--amber);background:var(--warnbg);border-radius:999px;padding:2px 8px}

/* Progress bar */
.bar{display:inline-block;height:8px;min-width:90px;width:100%;background:#eef1f6;border-radius:999px;overflow:hidden;vertical-align:middle}
.fill{display:block;height:100%;background:linear-gradient(90deg,var(--blue),var(--green));border-radius:999px}

/* Dashboard */
.dash{display:flex;flex-direction:column;gap:12px}
.progrow{display:grid;grid-template-columns:160px 1fr 60px;align-items:center;gap:10px;padding:6px 0;border-bottom:1px dotted var(--line)}
.confrow{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:8px 0;border-bottom:1px dotted var(--line)}

/* Filters + table */
.filters{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:10px}
.tablebox{overflow:auto}
table.log{width:100%;border-collapse:collapse;font-size:12.5px}
table.log th,table.log td{border-bottom:1px solid var(--line);padding:6px 8px;text-align:left;white-space:nowrap}
table.log th{color:var(--muted);font-weight:700}

/* Toasts */
.toasts{position:fixed;left:0;right:0;bottom:14px;display:flex;flex-direction:column;align-items:center;gap:8px;z-index:50;pointer-events:none}
.toast{pointer-events:auto;max-width:90%;background:var(--ink);color:#fff;padding:10px 14px;border-radius:10px;font-size:13.5px;box-shadow:var(--shadow);opacity:0;transform:translateY(8px);transition:.25s}
.toast.show{opacity:1;transform:none}
.toast-ok{background:#14532d}.toast-warn{background:#7c4a07}.toast-err{background:#7f1d1d}

@media(max-width:560px){
  .progrow{grid-template-columns:110px 1fr 48px}
  .badge.resp::before,.badge.rev::before{content:""}
}
