/* Dokumente / DMS (Mockup 05) — viewspezifische Klassen 1:1 aus dem Mockup.
   Meta-Panel läuft als Drawer über der Liste (Meridian behält die rechte Spalte). */

/* Facetten-Rail */
.facets{display:flex;flex-direction:column;min-height:0;border-right:1px solid var(--border);background:linear-gradient(180deg,var(--bg-2),transparent 40%)}
.facets .fh{height:var(--topbar-h);display:flex;align-items:center;gap:9px;padding:0 16px;border-bottom:1px solid var(--border);font-family:var(--font-display);font-weight:600;font-size:15px;flex:0 0 auto}
.facets .fscroll{flex:1 1 auto;overflow-y:auto;padding:14px 12px}
.fgrp{margin-bottom:16px}
.fgrp .gl{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--mist-dim);font-weight:700;margin:0 8px 7px}
.fitem{display:flex;align-items:center;gap:9px;width:100%;text-align:left;background:transparent;border:0;border-radius:9px;padding:8px 10px;color:var(--mist);font-size:13px;transition:.14s}
.fitem:hover{background:var(--surface);color:var(--text)}
.fitem.on{background:linear-gradient(90deg,rgba(201,162,75,.16),rgba(201,162,75,.02));color:var(--text);box-shadow:inset 2px 0 0 var(--gold)}
.fitem .fi{width:16px;height:16px;flex:0 0 auto;color:var(--gold-soft)}
.fitem .fn{flex:1 1 auto;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fitem .fc{font-size:11px;color:var(--mist-dim);font-variant-numeric:tabular-nums}
.fitem.alert.on,.fitem.alert:hover{box-shadow:inset 2px 0 0 var(--warn)}
.fitem.alert .fc{color:var(--warn)}
.facsearch{display:flex;align-items:center;gap:7px;background:var(--bg);border:1px solid var(--border-2);border-radius:8px;padding:6px 10px;margin:0 2px 8px}
.facsearch svg{width:13px;height:13px;color:var(--mist-dim);flex:0 0 auto}
.facsearch input{flex:1 1 auto;border:0;background:transparent;color:var(--text);font-family:var(--font-ui);font-size:12.5px;outline:none;min-width:0}

/* Center: Liste */
.dmscenter{display:flex;flex-direction:column;min-height:0;border-right:1px solid var(--border);position:relative}
.ctop{height:var(--topbar-h);display:flex;align-items:center;gap:12px;padding:0 16px;border-bottom:1px solid var(--border);background:var(--topbar-bg);backdrop-filter:blur(10px);flex:0 0 auto}
.dmssearch{display:flex;align-items:center;gap:9px;flex:1 1 auto;background:var(--surface);border:1px solid var(--border-2);border-radius:999px;padding:8px 14px;color:var(--mist-dim);font-size:13px}
.dmssearch svg{width:15px;height:15px;flex:0 0 auto}
.dmssearch input{flex:1 1 auto;border:0;background:transparent;color:var(--text);font-family:var(--font-ui);font-size:13px;outline:none}
.ctop .up{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:600;padding:8px 14px;border-radius:10px;border:0;background:linear-gradient(180deg,var(--gold-soft),var(--bronze));color:var(--on-gold,#fff);text-shadow:0 1px 2px rgba(0,0,0,.28)}
.ctop .up svg{width:15px;height:15px}
.cbar{display:flex;align-items:center;gap:9px;padding:10px 16px;border-bottom:1px solid var(--border);flex:0 0 auto;font-size:12px;color:var(--mist-dim)}
.cbar .actf{margin-left:auto;display:flex;gap:7px;flex-wrap:wrap}
.tag{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:600;padding:4px 9px;border-radius:999px;background:var(--surface-2);border:1px solid var(--border-2);color:var(--mist)}
.tag .x{cursor:pointer;color:var(--mist-dim)}
.dscroll{flex:1 1 auto;overflow-y:auto;padding:10px 12px}

.drow{display:flex;align-items:center;gap:13px;width:100%;text-align:left;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:12px 14px;margin-bottom:8px;color:inherit;transition:.14s}
.drow:hover{border-color:var(--border-2);background:var(--surface-2)}
.drow.sel{border-color:color-mix(in srgb,var(--gold) 60%,transparent);box-shadow:var(--shadow)}
.dic{width:38px;height:46px;border-radius:8px;flex:0 0 auto;display:grid;place-items:end center;padding-bottom:5px;font-size:9px;font-weight:800;letter-spacing:.02em;color:#fff;position:relative;background:linear-gradient(160deg,#3a4756,#222d39);border:1px solid var(--border-2)}
/* Falz-Ecke folgt dem Zeilen-Hintergrund — sonst „überlappt" der Hover-Effekt das Icon (UI-Scan 2.1). */
.dic::before{content:"";position:absolute;right:0;top:0;border-width:0 9px 9px 0;border-style:solid;border-color:transparent var(--surface) transparent transparent;transition:border-color .14s}
.drow:hover .dic::before{border-color:transparent var(--surface-2) transparent transparent}
.dic.pdf{background:linear-gradient(160deg,#7a3b3b,#542828)}
.dic.img{background:linear-gradient(160deg,#3d6b54,#274736)}
.dic.zip{background:linear-gradient(160deg,#6e5a2e,#473a1d)}
.dmain{flex:1 1 auto;min-width:0}
.dn{font-weight:600;font-size:13.5px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dchips{display:flex;gap:6px;margin-top:5px;flex-wrap:wrap}
.kl{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;padding:2px 7px;border-radius:999px}
.kl.vertrag{color:#9cc0e0;background:color-mix(in srgb,var(--info) 14%,transparent)}
.kl.beleg{color:var(--champagne);background:color-mix(in srgb,var(--gold) 13%,transparent)}
.kl.schriftstueck{color:var(--gold-soft);background:color-mix(in srgb,var(--gold) 10%,transparent)}
.kl.nachweis,.kl.selbstauskunft,.kl.protokoll{color:var(--ok);background:color-mix(in srgb,var(--ok) 14%,transparent)}
.kl.foto,.kl.schadenfoto{color:#b9a0d6;background:color-mix(in srgb,#8b6db5 16%,transparent)}
.kl.korrespondenz,.kl.sonstiges,.kl.mietvertrag{color:var(--mist);background:var(--surface-2);border:1px solid var(--border-2)}
.lnk{font-size:10.5px;color:var(--mist-dim);display:inline-flex;align-items:center;gap:5px}
.lnk b{color:var(--mist);font-weight:600}
.dright{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex:0 0 auto}
.dsrc{width:24px;height:24px;border-radius:7px;display:grid;place-items:center;color:#fff;font-size:11px}
.dsrc.mail{background:linear-gradient(180deg,var(--gold-soft),var(--bronze))}.dsrc.whatsapp{background:var(--wa,#4f9d7a)}.dsrc.scan{background:linear-gradient(180deg,#6e93b5,#3d5d80)}.dsrc.upload{background:var(--surface-2);color:var(--mist);border:1px solid var(--border-2)}.dsrc.impower{background:linear-gradient(180deg,#6e93b5,#3d5d80)}
.dst{font-size:9.5px;font-weight:700;padding:3px 8px;border-radius:999px;white-space:nowrap}
.dst.ok{color:var(--ok);background:color-mix(in srgb,var(--ok) 13%,transparent)}
.dst.review{color:var(--warn);background:color-mix(in srgb,var(--warn) 13%,transparent);border:1px solid color-mix(in srgb,var(--warn) 35%,transparent)}
.dst.exp{color:var(--red);background:color-mix(in srgb,var(--red) 12%,transparent);border:1px solid color-mix(in srgb,var(--red) 35%,transparent)}
.ddate{font-size:10.5px;color:var(--mist-dim)}

/* Meta-Panel als Drawer ueber der Liste */
.dmeta{position:absolute;right:0;top:0;bottom:0;width:min(440px,94%);z-index:60;display:flex;flex-direction:column;min-height:0;background:linear-gradient(180deg,var(--surface),var(--grad-card));border-left:1px solid var(--border);box-shadow:var(--shadow);transform:translateX(105%);transition:transform .26s ease}
.dmeta.open{transform:translateX(0)}
.mprev{min-height:200px;flex:0 0 auto;display:grid;place-items:center;gap:9px;padding:18px;background:repeating-linear-gradient(45deg,var(--bg) 0 10px,var(--bg-2) 10px 20px);border-bottom:1px solid var(--border);position:relative}
.mprev img{max-width:90%;max-height:230px;border-radius:7px;box-shadow:0 14px 36px -10px rgba(0,0,0,.6)}
.mprev iframe{width:92%;height:240px;border:0;border-radius:7px;background:#fff;box-shadow:0 14px 36px -10px rgba(0,0,0,.6)}
.mprev .pvhint{font-size:10.5px;color:var(--mist-dim)}
.mprev .close{position:absolute;right:12px;top:12px;width:30px;height:30px;border-radius:8px;border:1px solid var(--border-2);background:rgba(11,16,22,.6);color:var(--mist);font-size:17px}
.mprev .close:hover{color:var(--text);border-color:var(--gold)}
.mbody{flex:1 1 auto;overflow-y:auto;padding:18px}
.mbody h2{font-family:var(--font-display);font-weight:600;font-size:17px;margin:0;word-break:break-word}
.msub{font-size:12px;color:var(--mist-dim);margin-top:3px}
.msec{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-soft);font-weight:700;margin:18px 0 10px}
.klass{display:flex;align-items:center;gap:10px}
.conf{flex:1 1 auto}
.conf .bt{height:6px;border-radius:999px;background:var(--bg);border:1px solid var(--border-2);overflow:hidden}
.conf .bt span{display:block;height:100%;background:linear-gradient(90deg,var(--bronze),var(--gold-soft))}
.conf .l{font-size:10.5px;color:var(--mist-dim);margin-top:4px}
.lent{display:flex;align-items:center;gap:9px;padding:8px 0;border-bottom:1px solid var(--border);font-size:13px;color:var(--text)}
.lent:last-child{border-bottom:0}
.lent .le{font-size:9.5px;font-weight:700;text-transform:uppercase;color:var(--mist-dim);width:64px;flex:0 0 auto}
.lent a{color:var(--gold-soft);text-decoration:none}
.kv2{display:flex;justify-content:space-between;gap:10px;font-size:12.5px;color:var(--mist);padding:7px 0;border-bottom:1px solid var(--border)}
.kv2:last-child{border-bottom:0}.kv2 b{color:var(--text);font-weight:600;text-align:right}
.ver{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--mist);padding:6px 0}
.ver .vb{font-size:9.5px;font-weight:700;padding:2px 7px;border-radius:999px;background:var(--surface-2);border:1px solid var(--border-2);color:var(--champagne)}
.ver.cur .vb{background:linear-gradient(180deg,var(--gold-soft),var(--bronze));color:var(--on-gold,#fff);border-color:transparent}
.mfoot{flex:0 0 auto;padding:14px 18px;border-top:1px solid var(--border);display:flex;gap:9px}
.mfoot .btn{flex:1 1 0}
.rev-note{display:flex;gap:10px;border:1px solid color-mix(in srgb,var(--warn) 35%,transparent);background:color-mix(in srgb,var(--warn) 9%,transparent);border-radius:11px;padding:12px 14px;margin-top:8px}
.rev-note .t{font-size:12px;color:var(--mist);line-height:1.5}.rev-note .t b{color:var(--champagne)}
.dmsempty{flex:1 1 auto;display:grid;place-items:center;text-align:center;color:var(--mist-dim);font-size:13px;padding:30px}
