/* App-Shell-Ergänzungen über design-system.css hinaus:
   (1) Default-Raster MIT persistenter Meridian-Spalte (Handbuch SS5.1 — in den
       Mockups 03/06 noch nicht enthalten, im Zielbild aber überall),
   (2) Login-/2FA-Screen, (3) Kleinigkeiten (nav-soon, asst-eingeklappt). */

.app.with-asst{grid-template-columns:var(--nav) var(--list) minmax(0,1fr) var(--asst-w)}
.app.with-asst.asst-min{grid-template-columns:var(--nav) var(--list) minmax(0,1fr) 0}
@media(max-width:1400px){.app.with-asst{grid-template-columns:var(--nav) var(--list) minmax(0,1fr) 0}
  .app.with-asst .asst{display:none}}

.nav .nav-soon{opacity:.38;cursor:not-allowed}

/* DMS (Mockup 05): Facetten-Rail + Liste, Meridian bleibt rechts; Meta-Panel als Drawer. */
.app.app-dms{grid-template-columns:var(--nav) 228px minmax(0,1fr) var(--asst-w)}
.app.app-dms.asst-min{grid-template-columns:var(--nav) 228px minmax(0,1fr) 0}
@media(max-width:1400px){.app.app-dms{grid-template-columns:var(--nav) 228px minmax(0,1fr) 0}
  .app.app-dms .asst{display:none}}

/* Karte (Mockup 02): Vollflächen-Stage ohne Listen-Spalte, Meridian bleibt rechts. */
.app.app-karte{grid-template-columns:var(--nav) minmax(0,1fr) var(--asst-w)}
.app.app-karte.asst-min{grid-template-columns:var(--nav) minmax(0,1fr) 0}
@media(max-width:1400px){.app.app-karte{grid-template-columns:var(--nav) minmax(0,1fr) 0}
  .app.app-karte .asst{display:none}}

/* Vorgangs-Filter: in der schmalen Spalte umbrechen statt horizontal scrollen/überlappen. */
.vorgaenge-col .frow{flex-wrap:wrap;overflow:visible;row-gap:6px}
.vorgaenge-col .fchip{flex:0 0 auto}

/* Auth */
/* hidden-Attribut gewinnt IMMER — display:flex/grid auf Komponenten darf es nie übersteuern. */
[hidden]{display:none !important}
.auth-screen{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(1200px 800px at 70% -10%, rgba(201,162,75,.14), transparent 60%), var(--bg);z-index:50}
.auth-card{width:380px;max-width:92vw;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:28px;box-shadow:var(--shadow-lg)}
.auth-brand{display:flex;align-items:center;gap:14px;margin-bottom:22px}
.auth-brand .crest{margin:0}
.auth-title{font-family:var(--font-display);font-size:22px;font-weight:600}
.auth-title span{color:var(--gold)}
.auth-sub{font-size:12.5px;color:var(--muted)}
.auth-form{display:flex;flex-direction:column;gap:14px}
.auth-form label{display:flex;flex-direction:column;gap:6px;font-size:12.5px;color:var(--muted);font-weight:600}
.auth-err{color:var(--red,#e5484d);font-size:12.5px}
/* QR quadratisch ohne weiße Seitenbalken: weißer Rahmen nur so breit wie der Code selbst. */
.totp-qr{display:flex;justify-content:center;padding:8px;background:#fff;border-radius:var(--r-md);
  width:fit-content;margin:0 auto}
.totp-qr img{width:200px;height:200px;display:block}

/* Meridian-Kontextkarte */
.asst-kpis{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.asst-kpi{border:1px solid var(--border);border-radius:var(--r-md);padding:6px 10px;font-size:12px}
.asst-kpi b{display:block;font-size:16px;color:var(--gold)}
