/* 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}

/* Aufklappbarer Beta-Bereich der Nav (Wave 2.1: Fokus auf die Mockup-Module) */
.nav-morebtn{opacity:.75}
.nav-morebtn.open{color:var(--text);background:var(--surface)}
.nav-more{display:flex;flex-direction:column;gap:6px;align-items:center;
  border-top:1px dashed var(--border-2);border-bottom:1px dashed var(--border-2);padding:6px 0;width:100%}
.nav-more[hidden]{display:none}
.nav-more .nav-beta{position:relative;opacity:.85}
.nav-more .nav-beta::after{content:"β";position:absolute;right:3px;top:2px;font-size:8.5px;font-weight:700;
  color:var(--warn);background:color-mix(in srgb,var(--warn) 14%,transparent);
  border-radius:999px;padding:0 4px;line-height:1.4}

/* Overlap-Fix (UI-Scan 2.1): Filter-Chips in Listen-Spalten umbrechen statt schrumpfen. */
.col .filterwrap .frow{flex-wrap:wrap;overflow:visible;row-gap:6px}
.col .filterwrap .fchip,.col .filterwrap .flabel,.col .filterbar .fchip{flex:0 0 auto}

/* Meridian-Panel: Breite per Drag verstellbar (persistiert in localStorage). */
.asst{position:relative}
.asst-resizer{position:absolute;left:-3px;top:0;bottom:0;width:7px;cursor:col-resize;z-index:30}
.asst-resizer:hover,.asst-resizer.active{background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--gold) 35%,transparent))}
body.asst-resizing{cursor:col-resize;user-select:none}
/* 12 Module: auf kleinen Hoehen darf die Navbar scrollen statt abzuschneiden. */
.nav{overflow-y:auto;overflow-x:hidden;scrollbar-width:none}
.nav::-webkit-scrollbar{display:none}

/* Impersonation-Banner (SS15.1): unübersehbar, drückt die App nach unten. */
.imp-banner{position:sticky;top:0;z-index:900;display:flex;align-items:center;justify-content:center;gap:14px;
  padding:8px 16px;font-size:12.5px;font-weight:600;color:var(--on-gold,#fff);
  background:repeating-linear-gradient(45deg,var(--warn) 0 14px,color-mix(in srgb,var(--warn) 75%,#000) 14px 28px)}
body.imp-active .app{height:calc(100dvh - 40px)}

/* Agenten-Live (Mockup 07): eine Hauptfläche, Meridian bleibt rechts. */
.app.app-live{grid-template-columns:var(--nav) minmax(0,1fr) var(--asst-w)}
.app.app-live.asst-min{grid-template-columns:var(--nav) minmax(0,1fr) 0}
@media(max-width:1400px){.app.app-live{grid-template-columns:var(--nav) minmax(0,1fr) 0}
  .app.app-live .asst{display:none}}

/* 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)}

/* ===== Ausklappbare Navigation (Marc 2026-06-15) =====
   Default = breit mit Text-Labels neben den Icons; html.nav-collapsed = schmale
   Icon-Rail (74px, bisheriges Verhalten). Zustand persistiert in localStorage. */
:root{--nav-wide:212px}
html:not(.nav-collapsed){--nav:var(--nav-wide)}
html.nav-collapsed{--nav:74px}
.nav-label{font-size:13.5px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:.01em}
.nav-toggle{color:var(--mist);cursor:pointer}
.nav-toggle svg{width:20px;height:20px}
.nav-toggle:hover{color:var(--text);background:var(--surface)}
/* --- breit (Default): Buttons als Zeile Icon+Label, linksbuendig --- */
html:not(.nav-collapsed) .nav{align-items:stretch;padding:16px 12px}
html:not(.nav-collapsed) .nav .crest{margin:0 0 6px 2px}
html:not(.nav-collapsed) .nav>button:not(.nav-toggle):not(.acct),
html:not(.nav-collapsed) .nav-fly>#settingsBtn{
  width:100%;height:42px;display:flex;align-items:center;justify-content:flex-start;gap:12px;padding:0 12px}
html:not(.nav-collapsed) .nav .nav-fly{align-items:stretch;width:100%}
html:not(.nav-collapsed) .nav-toggle{align-self:flex-end;width:42px;height:38px;border-radius:10px;display:grid;place-items:center;border:1px solid transparent;background:transparent;margin-bottom:4px}
html:not(.nav-collapsed) .nav .acct{align-self:flex-start}
/* --- schmal (collapsed): Labels weg, Toggle als Icon-Button --- */
html.nav-collapsed .nav-label{display:none}
html.nav-collapsed .nav-toggle{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;border:1px solid transparent;background:transparent}
