/* Auftraggeberportal — helles, ruhiges Layout auf Basis von theme.css */
.plogin { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: var(--sp-6);
  background: linear-gradient(160deg, var(--brand-primary), var(--brand-primary-dark)); }
.plogin__card { width: 100%; max-width: 400px; padding: var(--sp-8); }
.plogin__brand { display: flex; align-items: center; gap: var(--sp-3); font-size: var(--fs-h2); font-weight: 700; margin-bottom: var(--sp-2); }

.ptop { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-4);
  height: var(--topbar-h); padding: 0 var(--sp-6); background: var(--color-surface); border-bottom: 1px solid var(--color-line); }
.ptop__brand { display: flex; align-items: center; gap: var(--sp-3); font-weight: 700; font-size: var(--fs-h3); }
.ptabs { display: flex; gap: var(--sp-1); padding: 0 var(--sp-6); background: var(--color-surface); border-bottom: 2px solid var(--color-line); }
.pmain { max-width: 1040px; margin: 0 auto; padding: var(--sp-6) var(--sp-5); }
/* ---------- Leer- & Ladezustände ---------- */
.empty { padding: var(--sp-8) var(--sp-6); text-align: center; color: var(--color-ink-3); }
.empty__icon { width: 40px; height: 40px; margin: 0 auto var(--sp-3); color: var(--color-line-strong); }
.empty__title { font-weight: 600; color: var(--color-ink-2); }
.skeleton { padding: var(--sp-10); text-align: center; color: var(--color-ink-3); }
.skeleton-list { padding: var(--sp-4) var(--sp-5); display: flex; flex-direction: column; gap: var(--sp-4); }
.sk-bar { display: block; height: 14px; border-radius: 7px; background: var(--color-surface-2);
  background-image: linear-gradient(90deg, var(--color-surface-2) 0%, #e9eef4 50%, var(--color-surface-2) 100%);
  background-size: 200% 100%; animation: sk-shimmer 1.2s ease-in-out infinite; }
.sk-bar.sk-30 { width: 30%; } .sk-bar.sk-60 { width: 60%; } .sk-bar.sk-80 { width: 80%; }
@keyframes sk-shimmer { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }
@media (prefers-reduced-motion: reduce) { .sk-bar { animation: none; } }

/* ---------- Status-Cockpit ---------- */
.ampel { display: flex; align-items: center; gap: var(--sp-4); padding: var(--sp-5);
  border-radius: var(--radius-lg); margin-bottom: var(--sp-5); background: var(--color-surface);
  border: 1px solid var(--color-line); border-left: 5px solid var(--color-ink-3); }
.ampel__dot { width: 16px; height: 16px; border-radius: 50%; background: var(--color-ink-3); flex: 0 0 auto; box-shadow: 0 0 0 4px rgba(0,0,0,.05); }
.ampel__title { font-weight: 700; font-size: var(--fs-h3); }
.ampel__sub { color: var(--color-ink-3); font-size: var(--fs-body); }
.ampel--gruen { border-left-color: var(--color-success); } .ampel--gruen .ampel__dot { background: var(--color-success); }
.ampel--gelb { border-left-color: var(--color-warning); } .ampel--gelb .ampel__dot { background: var(--color-warning); }
.ampel--rot { border-left-color: var(--color-danger); } .ampel--rot .ampel__dot { background: var(--color-danger); }

.kpi-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--sp-4); margin-bottom: var(--sp-5); }
@media (max-width: 720px) { .kpi-grid { grid-template-columns: repeat(2, 1fr); } }
.kpi { background: var(--color-surface); border: 1px solid var(--color-line); border-radius: var(--radius-lg); padding: var(--sp-4) var(--sp-5); }
.kpi__val { font-size: 30px; font-weight: 700; line-height: 1.1; color: var(--color-ink); }
.kpi__label { font-weight: 600; color: var(--color-ink-2); margin-top: 2px; }
.kpi__sub { color: var(--color-ink-3); font-size: var(--fs-small, 13px); margin-top: 4px; }
.kpi--danger .kpi__val { color: var(--color-danger); } .kpi--warning .kpi__val { color: var(--color-warning); }
.cockpit-row { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-4); padding: var(--sp-5); margin-bottom: var(--sp-5); }
.cockpit-due { font-size: var(--fs-h2); font-weight: 700; color: var(--brand-primary); white-space: nowrap; }
.card__head { padding: var(--sp-4) var(--sp-5); border-bottom: 1px solid var(--color-line); }

.toasts { position: fixed; right: var(--sp-5); bottom: var(--sp-5); display: flex; flex-direction: column; gap: var(--sp-2); z-index: 50; }
.toast { background: var(--color-ink); color: #fff; padding: var(--sp-3) var(--sp-4); border-radius: var(--radius-md); box-shadow: var(--shadow-2); font-weight: 600; }
.toast--danger { background: var(--color-danger); }
