:root{
  --yellow:#ffed00; --yellow-d:#b3a600; --yellow-sub:#fffbe0;
  --black:#16170f; --g900:#1c1d17; --g800:#2e2f27; --g700:#46473d; --g600:#62635a;
  --g500:#8a8b80; --g400:#aeafa4; --g300:#d2d3c8; --g200:#e7e8df; --g100:#f3f4ec; --g50:#fafbf4;
  --surf:#ffffff; --surf2:#f6f7ef; --border:#e2e3d8; --border-s:#eceee3;
  --info:#1f6feb; --info-sub:#e8f0fe; --ok:#1a7f4b; --ok-sub:#e4f5ec;
  --warn:#b56a00; --warn-sub:#fcefdc; --err:#c0362c; --err-sub:#fbe9e7;
  --purple:#7e2a73; --purple-sub:#f6e9f3; --teal:#0f7d77; --teal-sub:#e0f3f1;
  --radius:12px; --radius-sm:7px; --shadow:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.04);
  --sans:'PT Sans',system-ui,-apple-system,'Helvetica Neue',Arial,sans-serif;
  --mono:'SF Mono','Fira Code',ui-monospace,Consolas,monospace;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--sans);background:var(--surf2);color:var(--g800);font-size:15px;line-height:1.55;-webkit-font-smoothing:antialiased}
a{color:var(--info);text-decoration:none}
button{font:inherit;cursor:pointer}

.mockbar{background:var(--g900);color:#fff;text-align:center;font-size:12.5px;letter-spacing:.2px;padding:5px 16px}
.mockbar b{color:var(--yellow)}
.confbar{background:var(--err-sub);color:var(--err);text-align:center;font-size:12.5px;font-weight:700;letter-spacing:.3px;padding:5px;border-bottom:1px solid var(--border)}
.brandbar{position:sticky;top:0;z-index:70;background:var(--surf);border-bottom:1px solid var(--border);box-shadow:var(--shadow);display:flex;align-items:center;gap:18px;padding:0 28px;height:54px}
nav.tabs.tabbar{position:sticky;top:54px;z-index:60;background:var(--surf);border-bottom:1px solid var(--border);box-shadow:var(--shadow);margin:0;align-items:center;padding:5px 28px;height:44px}
.wordmark{font-size:21px;color:var(--black);position:relative;white-space:nowrap}
.wordmark .appname{font-weight:700;position:relative}
.wordmark .appname::after{content:"";position:absolute;left:0;bottom:-7px;width:100%;height:3px;background:var(--yellow)}
.wordmark .by{font-size:inherit;color:var(--g600);margin-left:12px;font-weight:400}
nav.tabs{display:flex;gap:4px;margin-left:6px}
nav.tabs button{background:none;border:0;padding:8px 14px;border-radius:8px;color:var(--g600);font-weight:700;font-size:14px}
nav.tabs button:hover{background:var(--g100);color:var(--g900)}
nav.tabs button.active{background:var(--black);color:#fff}
.brandbar .spacer{margin-left:auto}
.brandbar .stand{font-size:12.5px;color:var(--g500)}
/* Infozeile unter der Titelleiste (Stand · Vorgänge · Aktenseiten · GB · Zeitraum) */
.infobar{padding:7px 28px;background:var(--surf);border-bottom:1px solid var(--border)}
.infobar .stand{font-size:12.5px;font-weight:400;color:var(--g600);padding:0;border-radius:0;background:none;white-space:nowrap}
.hdr-actions{display:inline-flex;align-items:center;gap:12px}
.channelbar{position:sticky;top:54px;z-index:65;background:var(--g900);display:flex;align-items:center;gap:14px;padding:6px 28px;box-shadow:var(--shadow)}
.segctl{display:inline-flex;background:var(--g100);border:1px solid var(--border);border-radius:9px;padding:3px;margin-left:6px}
.channelbar .cblabel{color:var(--g400);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;margin-right:6px}
.chan{background:transparent;border:0;color:var(--g600);font-weight:700;font-size:14px;letter-spacing:.8px;padding:6px 20px;border-radius:7px;display:inline-flex;align-items:center;gap:8px;cursor:pointer}
.chan:hover{color:var(--g900)}
.chan.active{background:var(--yellow);color:#1c1d17}
.chan.active .cnt{background:rgba(0,0,0,.14);color:#1c1d17}
.chan .cnt{font-size:11.5px;background:var(--g200);color:var(--g700);padding:1px 8px;border-radius:999px;font-variant-numeric:tabular-nums}
.cbhint{margin-left:auto;color:var(--g500);font-size:11.5px;max-width:46%;text-align:right;line-height:1.3}
.langsw{display:inline-flex;gap:2px;margin-left:14px;border:1px solid var(--border);border-radius:8px;padding:2px;background:var(--surf)}
.lng{background:transparent;border:0;font-weight:700;font-size:12px;letter-spacing:.5px;color:var(--g500);padding:5px 9px;border-radius:6px;cursor:pointer;font-variant-numeric:tabular-nums}
.lng:hover{background:var(--g100);color:var(--g900)}
.lng.active{background:var(--black);color:#fff}

main{max-width:1500px;margin:0 auto;padding:22px 28px 80px}
.view{display:none}.view.active{display:block}
h2.vt{font-size:19px;margin:4px 0 2px;color:var(--g900)}
.sub{color:var(--g600);font-size:13.5px;margin:0 0 18px;max-width:880px}

.badge{display:inline-flex;align-items:center;gap:4px;font-size:11.5px;font-weight:700;padding:2px 8px;border-radius:999px;letter-spacing:.2px;white-space:nowrap;line-height:1.4}
.b-de{background:#fdf6d8;color:#7a6a00;border:1px solid #ecd96a}
.b-ch{background:var(--g100);color:var(--g600);border:1px solid var(--border)}
.rg{font-size:11px;font-weight:700;padding:2px 7px;border-radius:5px;white-space:nowrap}
.rg-strafrecht{background:var(--err-sub);color:var(--err)}
.rg-verwaltungsrecht{background:var(--info-sub);color:var(--info)}
.rg-zivilrecht{background:var(--purple-sub);color:var(--purple)}
.rg-berufsrecht{background:var(--teal-sub);color:var(--teal)}
.rg-owi{background:var(--g100);color:var(--g600)}
.role{font-size:11px;font-weight:700;padding:2px 8px;border-radius:5px;white-space:nowrap}
.role-def{background:#eef0f5;color:#3f4a63;border:1px solid #d3d9e6}
.role-off{background:var(--yellow-sub);color:#8a7500;border:1px solid #ecd96a}
.chip{display:inline-block;font-family:var(--mono);font-size:11px;font-weight:600;background:var(--g100);color:var(--g700);border:1px solid var(--border);border-radius:5px;padding:1px 6px;margin:1px 2px 1px 0}
.chip.norm{background:#eef4ff;color:#234e9e;border-color:#cfe0ff}
.chip.ch{background:var(--g100);color:var(--g700);border-color:var(--border)}
.stand{font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px;white-space:nowrap}
.s-ermittlung{background:var(--g100);color:var(--g700)}
.s-haupt{background:#eae6fb;color:#5a3fb0}
.s-strafbefehl{background:var(--warn-sub);color:var(--warn)}
.s-rechtsmittel{background:#e6eefb;color:#2b5fb3}
.s-abgeschlossen{background:var(--g200);color:var(--g600)}
.aus{font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px;white-space:nowrap}
.aus-offen{background:var(--info-sub);color:var(--info)}
.aus-eingestellt{background:var(--ok-sub);color:var(--ok)}
.aus-freispruch{background:var(--ok-sub);color:var(--ok)}
.aus-verurteilung{background:var(--err-sub);color:var(--err)}
.aus-verloren{background:var(--err-sub);color:var(--err)}
.aus-strafbefehl{background:var(--warn-sub);color:var(--warn)}
.aus-teil{background:#f1ecdb;color:#84691a}
.aus-zurueckgenommen{background:var(--g200);color:var(--g600)}
.tag-illus{font-size:9.5px;color:var(--g500);border:1px dashed var(--g300);border-radius:4px;padding:0 4px;margin-left:5px;font-weight:700;letter-spacing:.3px;vertical-align:middle}

.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:18px}
.kpi{background:var(--surf);border:1px solid var(--border);border-radius:var(--radius);padding:15px 16px;box-shadow:var(--shadow)}
.kpi .n{font-size:28px;font-weight:700;color:var(--g900);line-height:1}
.kpi .lab{font-size:12px;color:var(--g600);margin-top:6px}
.kpi .lab span{color:var(--g500)}
.total-row{display:flex;gap:16px;margin-bottom:16px}
.total-kpi{flex:1;display:flex;align-items:center;gap:18px;background:var(--surf);border:1px solid var(--border);border-left:4px solid var(--yellow);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px 22px}
.total-kpi .tn{font-size:34px;font-weight:700;color:var(--g900);line-height:1;font-variant-numeric:tabular-nums}
.total-kpi .tl{font-size:14px;font-weight:700;color:var(--g800);display:flex;flex-direction:column;gap:2px}
.total-kpi .tl small{font-weight:400;font-size:12px;color:var(--g500)}
.statline{font-size:13px;color:var(--g600);margin:2px 0 16px}.sb-verlauf{margin-top:13px;padding-top:13px;border-top:1px solid var(--border-s);font-size:13px;color:var(--g700);line-height:1.55}.statline b{color:var(--g900);font-variant-numeric:tabular-nums}
.card .sublabel{font-size:11px;font-weight:700;color:var(--g500);text-transform:uppercase;letter-spacing:.4px;margin:12px 0 5px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.card{background:var(--surf);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px 18px;margin-bottom:16px}
.card h3{margin:0 0 13px;font-size:14px;color:var(--g900);display:flex;align-items:center;gap:8px}
.card h3 .hint{font-weight:400;color:var(--g500);font-size:11.5px;margin-left:auto}
.bar{display:flex;align-items:center;gap:12px;margin:5px 0;font-size:13px}
.bar.click{cursor:pointer;border-radius:7px;padding:4px 6px;margin-left:-6px}
.bar.click:hover{background:var(--yellow-sub)}
.bar .lab{flex:0 0 250px;color:var(--g700);white-space:nowrap;display:flex;align-items:center;gap:7px}
.bar .meter{flex:1;display:flex;align-items:center;gap:10px;min-width:0}
.bar .fill{height:19px;border-radius:5px;min-width:6px;max-width:calc(100% - 46px)}
.bar .val{font-weight:700;color:var(--g800);font-variant-numeric:tabular-nums;white-space:nowrap}
.years{display:flex;align-items:flex-end;gap:14px;height:130px;padding:6px 4px 0}
.years .yr{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%}
.years .yr .yb{width:100%;max-width:54px;background:var(--yellow-d);border-radius:4px 4px 0 0}
.years .yr .yn{font-size:12px;font-weight:700;color:var(--g800);margin-bottom:3px}
.years .yr .yl{font-size:11px;color:var(--g600);margin-top:5px}
.dq{background:var(--warn-sub);border:1px solid #ecd96a;border-radius:var(--radius);padding:13px 16px;font-size:13px;color:#6e5300}
.dq b{color:#5a4400}

.reg{background:var(--surf);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;margin-bottom:18px}
.reg .rh{padding:12px 16px;border-bottom:1px solid var(--border);font-weight:700;font-size:14px;color:var(--g900);display:flex;align-items:center;gap:8px;background:var(--surf2)}
.reg .rh .c{margin-left:auto;font-weight:400;font-size:12px;color:var(--g500)}
table{width:100%;border-collapse:collapse;font-size:13px}
.reg table tr{cursor:pointer}
.reg table tr:hover td{background:var(--yellow-sub)}
.reg td{padding:9px 16px;border-bottom:1px solid var(--border-s);vertical-align:middle}
.reg td:last-child{text-align:right}
.reg tr:last-child td{border-bottom:0}
.pname{font-weight:700;color:var(--g900)}
.pmeta{font-size:11.5px;color:var(--g600)}
.pcount{font-family:var(--mono);font-weight:700;color:var(--g800);background:var(--g100);border:1px solid var(--border);border-radius:999px;padding:2px 10px;font-size:12px;white-space:nowrap}

.toolbar{display:flex;flex-wrap:wrap;gap:9px;align-items:center;background:var(--surf);border:1px solid var(--border);border-radius:var(--radius);padding:11px 13px;margin-bottom:14px;box-shadow:var(--shadow);position:sticky;top:98px;z-index:30}
.toolbar input[type=search]{flex:1;min-width:230px;font:inherit;font-size:14px;padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius-sm)}
.toolbar select{font:inherit;font-size:13px;padding:7px 9px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surf);color:var(--g700)}
.toolbar input:focus,.toolbar select:focus{outline:none;border-color:var(--yellow-d);box-shadow:0 0 0 3px rgba(255,237,0,.3)}
.seg{display:inline-flex;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}
/* Checkbox-Filtergruppen (Status / Rechtsgebiete) */
.fchk{display:inline-flex;align-items:center;gap:11px;border:1px solid var(--border);border-radius:var(--radius-sm);padding:4px 12px 6px;margin:0}
.fchk legend{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;color:var(--g500);padding:0 4px}
.fchk label{display:inline-flex;align-items:center;gap:5px;font-size:12.5px;color:var(--g700);white-space:nowrap;cursor:pointer}
.fchk input[type=checkbox]{accent-color:var(--yellow-d);cursor:pointer;margin:0}
.seg button{background:var(--surf);border:0;padding:7px 13px;font-size:13px;font-weight:700;color:var(--g600)}
.seg button.on{background:var(--black);color:#fff}
.count{font-size:12.5px;color:var(--g600)}
.count-line{margin:0 0 8px;text-align:left}
.table-wrap{background:var(--surf);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:auto;max-height:calc(100vh - 240px)}
table.cases{width:100%;min-width:0;table-layout:fixed}
table.cases thead th{position:sticky;top:0;z-index:5;background:var(--surf2);color:var(--g700);text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.3px;padding:9px 4px;border-bottom:1px solid var(--border);white-space:nowrap}
table.cases thead th.sortable{cursor:pointer;user-select:none}
table.cases thead th.sortable:hover{background:var(--yellow-sub);color:var(--g900)}
table.cases thead th.sorted{color:var(--g900);background:var(--yellow-sub)}
.sortind{font-size:10px;color:var(--g600);font-weight:700}
table.cases tbody td{padding:9px 4px;border-bottom:1px solid var(--border-s);vertical-align:top;overflow:hidden}
table.cases .role,table.cases .stand{white-space:normal}
table.cases .nowrap{white-space:nowrap}
table.cases tbody tr{cursor:pointer}
table.cases tbody tr:hover{background:var(--yellow-sub)}
.pid{font-family:var(--mono);font-size:11.5px;color:var(--g500);font-weight:700;white-space:nowrap}
.ttl-cell{max-width:320px}
.ttl-cell .t{font-weight:700;color:var(--g900);line-height:1.35}
.ttl-cell .k{color:var(--g600);font-size:12px;margin-top:3px}
.bet-cell{max-width:200px;font-size:12.5px}
.row-meta{margin-top:6px;font-size:11px;color:var(--g500);display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.row-meta .chip{margin:0}
.beginn-cell{font-size:12px;color:var(--g600);font-variant-numeric:tabular-nums}
.beginn-cell .bdate{display:block;white-space:nowrap}
.beginn-cell .jurbadge{margin-top:5px}
.sdate{display:block;font-size:11px;color:var(--g500);margin-top:2px;font-variant-numeric:tabular-nums}
.bet-cell .who{font-weight:600;color:var(--g800)}
.bet-cell .wr{font-size:11px;color:var(--g500)}
.beh-cell{max-width:210px;font-size:11.5px;color:var(--g800);line-height:1.45}
.id-cell .pid{cursor:help;display:block}
.id-cell .jurbadge{margin-top:5px;margin-right:4px}
.id-cell .rgtag{display:inline-block;margin-top:5px;font-size:11px;font-weight:700;letter-spacing:.02em;color:var(--g600);background:var(--g100);border:1px solid var(--border);border-radius:4px;padding:0 5px;cursor:help}
.norm-stack .chip{display:block;width:fit-content;margin:2px 0;white-space:nowrap}
td.kurz-cell{max-width:none}
.beh-stack>div{padding:1px 0;word-break:break-word}
.beh-stack .az{color:var(--g600)}
.akten-cell{max-width:230px}
.akten-stack a.filelink{display:block;padding:2px 0;font-size:11.5px;color:var(--info);text-decoration:none;word-break:break-word}
.akten-stack a.filelink:hover{text-decoration:underline}
.akten-stack .akten-sum{display:inline-block;font-size:11.5px;color:var(--g600);background:var(--g100);border:1px solid var(--border);border-radius:5px;padding:2px 8px;white-space:nowrap}
.akten-stack .pg{color:var(--g500);white-space:nowrap}
.az-cell{font-family:var(--mono);font-size:11.5px;color:var(--g700);white-space:nowrap}
.az-cell .auth{font-family:var(--sans);font-size:11.5px;color:var(--g600);display:block}
.docs-cell{white-space:nowrap;font-variant-numeric:tabular-nums;color:var(--g700)}
.nowrap{white-space:nowrap}

.back{background:none;border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px 12px;font-size:13px;font-weight:700;color:var(--g700);margin-bottom:14px}
.rubrum{background:var(--surf);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px 20px;margin-bottom:16px}
.rubrum .pid{margin-bottom:6px;display:inline-block}
.rubrum h1{font-size:21px;margin:2px 0 12px;color:var(--g900);line-height:1.3}
.rubrum .meta{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:14px}
.statusline{display:flex;flex-wrap:wrap;gap:26px;padding-top:13px;border-top:1px solid var(--border-s)}
.statusline .it{font-size:12px}
.statusline .it .lab{color:var(--g500);text-transform:uppercase;letter-spacing:.4px;font-size:10.5px;font-weight:700;margin-bottom:4px}
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.detail-grid .full{grid-column:1/3}
.sec-row{display:flex;gap:16px;align-items:stretch}
.sec-row>.sec{flex:1 1 0;min-width:0;width:50%}
.sec{background:var(--surf);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px 18px}
.sec h3{margin:0 0 13px;font-size:13px;text-transform:uppercase;letter-spacing:.5px;color:var(--g600);display:flex;align-items:center;gap:8px}
.sec h3 .su{font-size:14px}
.kv{display:grid;grid-template-columns:150px 1fr;gap:6px 14px;font-size:13.5px}
.kv dt{color:var(--g600)}.kv dd{margin:0;color:var(--g900);font-weight:600}
.party{display:flex;gap:10px;padding:8px 0;border-bottom:1px solid var(--border-s)}
.party:last-child{border-bottom:0}
.party .pr{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;color:var(--g500);width:128px;flex:none;padding-top:2px}
.party .pv{font-weight:600;color:var(--g900)}
.party .pv small{display:block;font-weight:400;color:var(--g600);font-size:12px}
.timeline{position:relative;margin-left:6px;padding-left:22px}
.timeline::before{content:"";position:absolute;left:5px;top:4px;bottom:8px;width:2px;background:var(--g200)}
.station{position:relative;padding:0 0 16px}
.station:last-child{padding-bottom:0}
.station::before{content:"";position:absolute;left:-21px;top:3px;width:11px;height:11px;border-radius:50%;background:var(--g300);border:2px solid var(--surf);box-shadow:0 0 0 2px var(--g200)}
.station.aktuell::before{background:var(--yellow);box-shadow:0 0 0 2px var(--yellow-d)}
.station .sh{font-weight:700;color:var(--g900);font-size:13.5px}
.station .sh .now{font-size:10px;background:var(--yellow);color:#6e5d00;font-weight:700;padding:1px 6px;border-radius:999px;margin-left:7px;letter-spacing:.3px}
.station .sd{font-size:12.5px;color:var(--g600);margin-top:2px}
.station .saz{font-family:var(--mono);font-size:12px;color:var(--g800);font-weight:600;margin-top:3px}
.station .saz .cp{cursor:pointer;color:var(--g400);margin-left:6px;font-family:var(--sans);font-size:11px}
.narr{font-size:13.5px;color:var(--g700);line-height:1.6}
.narr details summary{cursor:pointer;color:var(--info);font-weight:700;font-size:13px;margin-top:6px}
.lab-mini{font-size:10.5px;font-weight:700;color:var(--g500);text-transform:uppercase;letter-spacing:.4px;margin-bottom:4px}
.quote{border-left:3px solid var(--yellow);background:var(--yellow-sub);padding:8px 12px;border-radius:0 6px 6px 0;font-style:italic;color:var(--g800);margin:6px 0 0}
table.docs th{position:static;background:var(--surf2);color:var(--g700);text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.4px;padding:9px 12px;border-bottom:1px solid var(--border);white-space:nowrap}
table.docs td{padding:10px 12px;border-bottom:1px solid var(--border-s);vertical-align:middle}
.dk{font-size:10.5px;font-weight:700;padding:1px 7px;border-radius:5px;white-space:nowrap;background:var(--g100);color:var(--g600)}
.dk.key{background:var(--yellow-sub);color:#8a7500;border:1px solid #ecd96a}
.dl{display:inline-flex;align-items:center;gap:5px;background:var(--black);color:#fff;border:0;border-radius:6px;padding:5px 11px;font-size:12px;font-weight:700}
.dl.sec2{background:var(--surf);color:var(--g700);border:1px solid var(--border)}
.enc{font-size:11px;color:var(--err);font-weight:700}
.linkcard{display:block;border:1px solid var(--border);border-radius:8px;padding:9px 12px;margin-bottom:8px}
.linkcard:hover{background:var(--g50)}
.linkcard .rel{font-size:10.5px;font-weight:700;color:var(--g500);text-transform:uppercase;letter-spacing:.3px}
.persons{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:12px}
.pcard{border:1px solid var(--border);border-radius:10px;padding:12px 14px;background:var(--surf2)}
.pcard .pn{font-weight:700;color:var(--g900);font-size:14px}
.pcard .pn .nn-unk{font-weight:400;color:var(--g500);font-size:11.5px}
.pcard .pr2{font-size:11.5px;color:var(--g600);margin:2px 0 9px;line-height:1.35}
.pdl{display:grid;grid-template-columns:96px 1fr;gap:3px 10px;font-size:12.5px;margin:0}
.pdl dt{color:var(--g500)}
.pdl dd{margin:0;color:var(--g800);font-weight:600;word-break:break-word}
.pdl .xref{color:#1c4e8a;font-weight:700}
.pnote{margin-top:11px;font-size:11.5px;color:var(--g500);line-height:1.45}
.foot{margin-top:30px;padding-top:16px;border-top:1px solid var(--border);font-size:12px;color:var(--g500)}
/* ===== Verfahren-Detail: Arbeitsplatz ===== */
.vk{background:var(--surf);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px 20px 0;margin-bottom:16px}
.vkrole{font-weight:700;letter-spacing:.2px;font-size:11.5px;padding:2px 9px;border-radius:999px}
.vkrole.role-def{background:#e7f0fb;color:#1c4e8a}.vkrole.role-off{background:#eaf7ec;color:#1f7a37}
.vkid{background:var(--g100);border:1px solid var(--border);color:var(--g600);font-size:11px}
.vk2{font-size:23px;line-height:1.2;margin:9px 0 6px;color:var(--g900)}
.vk2 .vknorm{color:var(--g500);font-weight:600;font-size:17px}.vk2 .kurzn{color:#1c1d17;background:var(--yellow);padding:0 7px;border-radius:5px;font-size:18px}
.vk3{display:flex;align-items:center;gap:12px;flex-wrap:wrap;font-family:ui-monospace,Menlo,monospace;font-size:12.5px;color:var(--g700);padding-bottom:12px;border-bottom:1px solid var(--border-s)}
.vk3 .vkaz{font-size:15px;font-weight:800;color:var(--g900);background:var(--g100);padding:2px 9px;border-radius:6px;cursor:copy}
.vk3 .vkaz-wrap{display:inline-flex;flex-direction:column;align-items:flex-start;gap:3px}
.vk3 .vkaz-more{font-family:inherit;font-size:12px;font-weight:600;color:var(--g600);background:var(--surf2);border:1px solid var(--border);padding:1px 8px;border-radius:6px}
.vk .meta{padding:11px 0 0;border:0}
.vk .meta>span{font-size:11.5px}.vart-b{font-size:12px;color:var(--g600)}.polb{background:var(--yellow-sub);color:#8a7500;border:1px solid #ecd96a}.sigb{font-size:12px;color:var(--g500)}
.secnav{position:sticky;top:98px;z-index:40;display:flex;gap:6px;flex-wrap:wrap;margin:0 0 16px;padding:10px 14px;background:var(--surf);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}
.secnav a{font-size:12.5px;font-weight:700;color:var(--g700);text-decoration:none;padding:6px 12px;border-radius:7px;background:var(--surf2);border:1px solid var(--border);transition:background .12s,color .12s,border-color .12s}
.secnav a:hover{background:var(--yellow);color:#1c1d17;border-color:var(--yellow)}
.akten-meta{display:inline-flex;align-items:center;font-size:12px;font-weight:600;color:var(--g600);background:var(--surf2);border:1px solid var(--border);border-radius:6px;padding:3px 9px}
.vk3 .akten-meta{margin-left:auto}
.sv-summary{margin:0 0 16px;padding:13px 15px;background:var(--surf2);border:1px solid var(--border);border-left:3px solid var(--yellow);border-radius:var(--radius);font-size:14px;line-height:1.6;color:var(--g800)}
.sec .secnote{font-weight:400;color:var(--g500);font-size:11px;margin-left:auto;display:inline-flex;align-items:center;gap:6px}
.sec.full h3{display:flex;align-items:center}
.ex{background:#fff4cc;color:#8a6d00;border:1px solid #ecd96a;font-size:9.5px;font-weight:700;padding:1px 6px;border-radius:10px;letter-spacing:.3px;text-transform:uppercase}
.muted{color:var(--g500)}.empty,.empty-sec{color:var(--g500);font-size:13px}.empty-sec{padding:14px;background:var(--surf2);border:1px dashed var(--border);border-radius:8px;display:flex;gap:8px;align-items:center}
.flash{outline:3px solid var(--yellow);outline-offset:2px;transition:outline .3s}
.fst{font-size:11px;font-weight:600;color:#1c4e8a;background:#eef3fb;border:1px solid #cfe0f5;border-radius:5px;padding:1px 7px;text-decoration:none;white-space:nowrap}.fst:hover{background:#1c4e8a;color:#fff}.nofst{font-size:11px;color:var(--g400)}
/* generische Tabelle */
.gtab{width:100%;border-collapse:collapse;font-size:12.5px}
.gtab th{background:var(--surf2);text-align:left;font-size:10.5px;text-transform:uppercase;letter-spacing:.4px;color:var(--g600);padding:8px 10px;border-bottom:1px solid var(--border);position:static}
.gtab td{padding:8px 10px;border-bottom:1px solid var(--border-s);vertical-align:top}
/* Chronik */
/* Aktenbefunde (faktisch) */
.befund{border:1px solid var(--border);border-left:3px solid var(--g500);border-radius:9px;padding:11px 13px;margin-bottom:10px;background:var(--surf2)}
.befund .btyp{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.4px;color:var(--g700);margin-bottom:8px}
.befund .bpair{display:grid;grid-template-columns:1fr auto 1fr;gap:10px;align-items:start;font-size:12.5px}
.befund .ba,.befund .bb{background:var(--surf);border:1px solid var(--border);border-radius:8px;padding:9px}
.befund .bvs{font-size:16px;color:var(--g400);align-self:center;text-align:center}
.befund .blab{display:block;font-size:10px;font-weight:700;color:var(--g500);text-transform:uppercase;margin-bottom:3px}
.befund .bf{margin-top:9px;font-size:12.5px;color:var(--g800)}.befund .bf b{color:var(--g900)}
/* Fristen (rein deskriptiv, kein Countdown) */
.frist-tab{width:100%;border-collapse:collapse;font-size:12.5px}
.frist-tab th{background:var(--surf2);text-align:left;font-size:10.5px;text-transform:uppercase;letter-spacing:.4px;color:var(--g600);padding:8px 10px;border-bottom:1px solid var(--border)}
.frist-tab td{padding:8px 10px;border-bottom:1px solid var(--border-s);vertical-align:top}
@media(max-width:1080px){.befund .bpair{grid-template-columns:1fr}.befund .bvs{display:none}}
/* Verbund */
.vblist{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:10px}
.vbcard{border:1px solid var(--border);border-radius:9px;padding:10px 12px;background:var(--surf2)}
.vbcard .rel{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:#8a6d00;background:var(--yellow-sub);padding:1px 7px;border-radius:10px}
.vbt{font-weight:700;color:var(--g800);margin:6px 0 3px;font-size:13px}.vbg,.vbs{font-size:11.5px;color:var(--g500)}

@media(max-width:1080px){.kpis{grid-template-columns:repeat(2,1fr)}.grid2,.detail-grid{grid-template-columns:1fr}.detail-grid .full{grid-column:auto}.sec-row{flex-direction:column}.sec-row>.sec{width:auto}.total-row{flex-direction:column}}
.hdr-actions{display:inline-flex;gap:8px;align-items:center}
.hbtn{font-size:12.5px;font-weight:700;color:var(--g800);background:var(--surf);border:1px solid var(--border);border-radius:8px;padding:6px 12px;cursor:pointer;white-space:nowrap;display:inline-flex;align-items:center;gap:6px}
/* Admin-only Aktionen: nur für eingeloggte Admins sichtbar */
.adminbtn{display:none}
body.is-admin .adminbtn{display:inline-flex}
.adminonly{display:none}
body.is-admin .adminonly{display:inline-flex}
/* 'Privat'-Markierung */
.privbadge{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:700;color:#7a5b00;background:#fde68a;border:1px solid #e9c349;border-radius:6px;padding:1px 7px;letter-spacing:.2px;white-space:nowrap}
.privbadge.sm{font-size:10px;padding:0 4px;margin-left:4px;background:#fff7d6;color:#8a6d00}
/* Privat-Toggle: eigenständiger schwarzer Button links oben, vor der Sektions-Navigation */
.privtoggle{display:inline-flex;align-items:center;gap:6px;font:inherit;font-size:12.5px;font-weight:700;color:#fff;background:#111;border:1px solid #111;border-radius:8px;padding:8px 15px;cursor:pointer;margin:0 0 12px;box-shadow:var(--shadow)}
.privtoggle:hover{background:#000;border-color:#000}
.privtoggle:focus-visible{outline:2px solid var(--yellow-d);outline-offset:2px}
/* private Verfahren in der Verfahrensliste: deutlich dunkle Zeile + 'privat'-Tag links */
tr.priv-row td{background:#22252e;border-bottom-color:#3a3e49}
tr.priv-row:hover td{background:#2d313d}
tr.priv-row .pid,tr.priv-row .t,tr.priv-row .bdate,tr.priv-row .sdate,
tr.priv-row .beh-cell,tr.priv-row .beh-cell *,tr.priv-row .akten-cell,tr.priv-row .akten-cell *,
tr.priv-row .row-meta,tr.priv-row .row-meta *{color:#ededf0 !important}
.priv-tag{display:inline-block;background:#fde68a;color:#161616;font-size:9.5px;font-weight:800;text-transform:uppercase;letter-spacing:.7px;border-radius:4px;padding:1px 6px;margin-right:7px;vertical-align:middle}
/* Sprachumschalter vorerst ausgeblendet */
.langsw{display:none}
/* System-Schalter (admin-only) mit Dropdown */
.sysmenu{position:relative}
.sysmenu-pop{position:absolute;right:0;top:calc(100% + 6px);background:var(--surf);border:1px solid var(--border);border-radius:9px;box-shadow:var(--shadow);padding:6px;min-width:215px;z-index:90;display:flex;flex-direction:column;gap:2px}
.sysmenu-pop[hidden]{display:none}
.sysmenu-pop button{display:flex;align-items:center;gap:8px;width:100%;text-align:left;background:none;border:0;border-radius:6px;padding:8px 10px;font:inherit;font-size:13px;font-weight:600;color:var(--g800);cursor:pointer;white-space:nowrap}
.sysmenu-pop button:hover{background:var(--yellow-sub)}
.hbtn:hover{background:var(--g100)}
.hbtn.primary{background:var(--black);color:#fff;border-color:var(--black)}
.hbtn.primary:hover{filter:brightness(1.15)}
.hbtn.wide{width:100%;justify-content:center;margin-top:12px}
.modal-ov{position:fixed;inset:0;z-index:200;background:rgba(20,21,17,.55);display:none;align-items:flex-start;justify-content:center;padding:60px 16px;overflow:auto}
.modal-ov.open{display:flex}
.modal{background:var(--surf);border:1px solid var(--border);border-radius:14px;box-shadow:0 24px 60px rgba(0,0,0,.3);width:100%;max-width:560px}
.modal-h{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--border);font-size:16px}
.modal-x{background:none;border:0;font-size:22px;line-height:1;color:var(--g500);cursor:pointer;padding:0 4px}
.modal-x:hover{color:var(--g900)}
.modal-b{padding:18px}
.dropzone{border:2px dashed var(--border);border-radius:12px;padding:28px 18px;text-align:center;color:var(--g600);cursor:pointer;background:var(--surf2);display:flex;flex-direction:column;align-items:center;gap:8px}
.dropzone:hover{border-color:var(--g400);background:var(--g100)}
.dz-ic{font-size:30px}
.mock-note{font-size:12px;color:var(--g500);background:var(--warn-sub);border:1px solid #f0d9a8;border-radius:8px;padding:8px 10px;margin:12px 0;line-height:1.5}
.intake-result{margin-top:14px;border-top:1px solid var(--border);padding-top:14px}
.ir-h{font-weight:800;font-size:14px;margin-bottom:6px}
.ir-meta{font-size:12.5px;color:var(--g700);background:var(--surf2);border:1px solid var(--border);border-radius:8px;padding:8px 10px;margin-bottom:12px}
.ir-q{font-size:12.5px;font-weight:700;color:var(--g700);margin-bottom:8px}
.ir-opt{display:flex;align-items:flex-start;gap:8px;font-size:13px;padding:9px 11px;border:1px solid var(--border);border-radius:8px;margin-bottom:7px;cursor:pointer}
.ir-opt:hover{background:var(--g100)}
.ir-btns{display:flex;gap:8px;margin-top:12px}
.ir-out{margin-top:12px;font-size:13px;line-height:1.5;color:var(--g800)}
.ir-out .ok,.scanrows .ok{color:var(--ok);font-weight:700}
.scanrows{list-style:none;margin:0 0 14px;padding:0;font-size:13px}
.scanrows li{padding:6px 0;border-bottom:1px solid var(--border-s);display:flex;gap:8px;align-items:center}
.mock-report{border:1px solid var(--border);border-radius:10px;overflow:hidden;margin-bottom:12px}
.rep-row{padding:10px 12px;font-size:13px;border-bottom:1px solid var(--border-s)}
.rep-row:last-child{border-bottom:0}
.rep-row b{font-size:15px;margin-right:6px}
.rep-row.new{background:#eef5ff}.rep-row.add{background:var(--ok-sub)}.rep-row.case{background:var(--warn-sub)}
.chron .cev{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;padding:1px 6px;border-radius:4px;background:#e7f0fb;color:#1c4e8a;margin-right:7px;white-space:nowrap}
.chron .cev.anwalt{background:#eaf7ec;color:#1f7a37}.chron .cev.rechtsmittel{background:var(--warn-sub);color:#8a5a00}
.docs td.toc-cell{min-width:260px;max-width:380px}
ol.toc{margin:0;padding:0;list-style:none}
ol.toc li{margin:0 0 4px;font-size:12px;line-height:1.4}
ol.toc li:last-child{margin-bottom:0}
ol.toc a.fst{display:flex;gap:8px;align-items:baseline}
.toc-p{display:inline-block;min-width:40px;font-variant-numeric:tabular-nums;color:var(--g500);font-weight:700;flex:none}
.toc-empty{font-size:11.5px}
ol.toc a.fst:hover{text-decoration:underline}
.toc-wrap{position:relative}
.toc-wrap.long:not(.open) ol.toc li:nth-child(n+5){display:none}
.toc-more{display:inline-block;margin-top:4px;font-size:11px;font-weight:700;color:var(--info);cursor:pointer}
.toc-prov{display:inline-block;margin-top:5px;font-size:9px;font-weight:700;letter-spacing:.3px;text-transform:uppercase;color:var(--g500);background:var(--g100);border:1px solid var(--border);border-radius:4px;padding:0 5px}
.toc-open{font-size:12px;font-weight:700;color:var(--info)}
a.dfile{color:var(--g900);text-decoration:none;font-weight:600}
a.dfile:hover{text-decoration:underline}
@media print{.toc-wrap.long:not(.open) ol.toc li{display:block}.toc-more,.toc-prov{display:none}}
.vorwurf-q{margin:0;padding:12px 16px;border-left:3px solid var(--g800);background:var(--surf2);border-radius:0 8px 8px 0;font-size:15px;line-height:1.6;color:var(--g900)}
.vorwurf-src{margin-top:10px;font-size:12.5px;color:var(--g600)}
.sv-sub{margin:18px 0 8px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--g600)}
/* Beweismittel-Block in der linken Spalte des Vorwurf-Kastens */
.bm-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:7px}
.bm-list li{font-size:13px;line-height:1.4;color:var(--g800);padding-left:14px;position:relative}
.bm-list li::before{content:"▪";position:absolute;left:0;color:var(--g400)}
.bm-bm{font-weight:600;color:var(--g900)}
.bm-typ{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;color:var(--g600);background:var(--g100);border-radius:4px;padding:1px 5px;margin-left:3px}
/* Personen: zurückhaltende Seiten-Einfärbung — rot = Gegner, grün = Verteidigung/Entlastung */
.pcard.pside-gegner{background:#fcf2f2;border-color:#e6c8c8}
.pcard.pside-vert{background:#eff7f1;border-color:#cde4d4}
/* Datenstand-/Integritätsprüfung */
#rcResult .rc-sec{border:1px solid var(--border);border-radius:9px;padding:9px 12px;margin:8px 0;background:var(--surf2)}
#rcResult .rc-sec.rc-ok{border-color:#cde4d4;background:#f3f9f4}
#rcResult .rc-sec.rc-bad{border-color:#e6c8c8;background:#fcf2f2}
#rcResult .rc-sec.rc-review{border-color:#ecdca6;background:#fdf8e9}
#rcResult .rc-h{font-size:13px;font-weight:600;color:var(--g800)}
#rcResult .rc-list{list-style:none;margin:7px 0 0;padding:0;display:flex;flex-direction:column;gap:4px;font-size:12.5px}
#rcResult .rc-list a{font-weight:600}
#rcResult .rc-tot{margin-top:10px;font-size:11.5px}
.vorwurf-art{margin:0 0 8px;font-size:13px;font-weight:700;color:var(--g800)}
.vorwurf-bild{margin:0;padding:18px 16px;border:1px dashed var(--border);border-radius:8px;background:var(--surf2);color:var(--g700);font-size:13px;display:flex;align-items:center;gap:8px}
.vph-ic{font-size:20px;flex:none}
/* Kombi-Kasten „Vorwurf": links Chronologie, rechts Behaupteter Sachverhalt */
.vorwurf-2col{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:start}
.vw-col{min-width:0;overflow-x:auto}
.vw-colh{font-size:13px;font-weight:700;color:var(--g800);margin:0 0 11px;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--border-s);padding-bottom:7px}
.vw-note{margin-left:auto;font-size:10.5px;font-weight:400;color:var(--g500);text-transform:uppercase;letter-spacing:.3px}
@media(max-width:980px){.vorwurf-2col{grid-template-columns:1fr}}

/* ===== Dokument-Viewer + In-Akten-Suche (Phase 2) ===== */
.viewer{display:grid;grid-template-columns:300px 1fr;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:var(--surf);min-height:460px}
.viewer-side{border-right:1px solid var(--border);background:var(--surf2);display:flex;flex-direction:column;max-height:660px}
.vsearch{padding:10px;border-bottom:1px solid var(--border)}
.vsearch input{width:100%;padding:7px 10px;border:1px solid var(--border);border-radius:7px;font:inherit;font-size:13px}
.vsearch input:focus{outline:none;border-color:var(--yellow-d);box-shadow:0 0 0 3px rgba(255,237,0,.3)}
.vdocs{overflow:auto;flex:1}
.vdoc{padding:8px 11px;border-bottom:1px solid var(--border-s);cursor:pointer;font-size:12.5px;color:var(--g800)}
.vdoc:hover{background:var(--yellow-sub)}
.vdoc.active{background:var(--yellow-sub);font-weight:700}
.vdoc .vpc{color:var(--g500);font-size:11px;font-weight:400;margin-top:2px}
.vhit{padding:8px 11px;border-bottom:1px solid var(--border-s);cursor:pointer;font-size:12px;line-height:1.4}
.vhit:hover{background:var(--yellow-sub)}
.vhit .vhh{font-weight:700;color:var(--g700);margin-bottom:2px}
/* Viewer-Rail: kompakter Dokument-Umschalter + Inhaltsverzeichnis des aktiven Dokuments */
.vdocsel{width:calc(100% - 20px);margin:10px;padding:6px 8px;border:1px solid var(--border);border-radius:7px;font:inherit;font-size:12px;background:var(--surf);color:var(--g800)}
.vtoc{list-style:none;margin:0;padding:0 6px 8px}
.vtoc li{margin:0}
.vtoc a{display:flex;gap:8px;align-items:baseline;padding:6px 8px;border-radius:6px;font-size:12px;color:var(--g800);text-decoration:none;line-height:1.4}
.vtoc a:hover{background:var(--yellow-sub)}
.vtoc li.toc-active a{background:var(--yellow-sub);font-weight:700;box-shadow:inset 3px 0 0 var(--yellow-d)}
.vtoc-prov{padding:6px 10px;font-size:10px;color:var(--g500);border-top:1px solid var(--border-s)}
.vrail-note{padding:12px;font-size:12px;color:var(--g600);line-height:1.5}
.vhit mark{background:var(--yellow);color:#1c1d17;padding:0 1px;border-radius:2px}
.viewer-main{display:flex;flex-direction:column;min-width:0}
.vbar{display:flex;align-items:center;gap:10px;padding:8px 12px;border-bottom:1px solid var(--border);background:var(--surf2);font-size:12.5px;flex-wrap:wrap}
.vbar b{color:var(--g900);max-width:46%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.vbar button{border:1px solid var(--border);background:var(--surf);border-radius:6px;padding:4px 10px;cursor:pointer;font-weight:700;color:var(--g800)}
.vbar button:hover{background:var(--g100)}
.vnav{display:inline-flex;align-items:center;gap:8px;font-variant-numeric:tabular-nums}
.vstage{overflow:auto;flex:1;background:var(--g200);display:flex;justify-content:center;padding:14px;max-height:660px}
.vstage img{max-width:100%;height:auto;box-shadow:var(--shadow);background:#fff;align-self:flex-start}
.vstage .vtext{white-space:pre-wrap;word-break:break-word;font:12.5px/1.6 var(--mono,ui-monospace,monospace);color:var(--g800);background:#fff;padding:18px 20px;margin:0;align-self:flex-start;max-width:82ch;box-shadow:var(--shadow);border-radius:6px;text-align:left}
/* === Zweispaltiges „Akten & Dokumente"-Panel: links Datei-Karten, rechts Viewer === */
.akten-hint{font-size:12px;color:var(--g600);margin:0 0 12px}
.akten-actions{margin-top:12px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.akten-2col{display:grid;grid-template-columns:minmax(340px,42%) 1fr;gap:16px;align-items:start}
.akten-list{max-height:760px;overflow:auto;display:flex;flex-direction:column;gap:10px;padding-right:4px}
.filecard{border:1px solid var(--border);border-radius:8px;padding:10px 12px;background:var(--surf);cursor:pointer}
.filecard:hover{border-color:var(--yellow-d);background:var(--yellow-sub)}
.filecard.active{border-color:var(--yellow-d);background:var(--yellow-sub);box-shadow:inset 3px 0 0 var(--yellow-d)}
.fc-name{font-weight:700;color:var(--g900);font-size:13px;line-height:1.35;word-break:break-word}
.fc-mail{color:var(--info);font-weight:800}
.filecard.keydoc .fc-name{color:#7a6800}
.fc-key{margin-left:6px;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;color:#8a7500;background:var(--yellow-sub);border:1px solid #ecd96a;border-radius:4px;padding:0 5px;vertical-align:middle}
.fc-meta{font-size:11.5px;color:var(--g600);margin:3px 0 7px;font-variant-numeric:tabular-nums}
.filecard ol.toc{margin:0 0 7px;padding:0;list-style:none}
.filecard ol.toc li{margin:0 0 3px}
.filecard ol.toc a.fst{display:flex;gap:8px;align-items:baseline;font-size:12px;color:var(--g800);text-decoration:none;line-height:1.4}
.filecard ol.toc a.fst:hover{text-decoration:underline}
.filecard:not(.open) ol.toc.long li:nth-child(n+7){display:none}
.fc-pdf{display:inline-block;font-size:11.5px;font-weight:700;color:var(--info);text-decoration:none}
.fc-pdf:hover{text-decoration:underline}
#s-akten li.toc-active a{background:var(--yellow-sub);border-radius:4px;font-weight:700;box-shadow:inset 2px 0 0 var(--yellow-d)}
.akten-reader{position:sticky;top:108px;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:var(--surf);box-shadow:var(--shadow)}
.reader{display:flex;flex-direction:column;min-height:420px}
.rbar{display:flex;align-items:center;gap:8px 14px;padding:9px 14px;border-bottom:1px solid var(--border);background:var(--yellow-sub);font-size:13px;flex-wrap:wrap}
.rbar .ropen{font-weight:700;color:#8a7500;white-space:nowrap}
.rbar .rname{color:var(--g900);font-weight:700;max-width:42%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rbar .vnav{display:inline-flex;align-items:center;gap:8px;font-variant-numeric:tabular-nums}
.rbar button{border:1px solid var(--border);background:var(--surf);border-radius:6px;padding:4px 10px;cursor:pointer;font-weight:700;color:var(--g800)}
.rbar button:hover{background:var(--g100)}
.rbar .rorig{margin-left:auto}
.rtools{padding:8px 14px;border-bottom:1px solid var(--border-s);background:var(--surf2)}
.rtools input{width:100%;max-width:420px;padding:7px 10px;border:1px solid var(--border);border-radius:7px;font:inherit;font-size:13px}
.rtools input:focus{outline:none;border-color:var(--yellow-d);box-shadow:0 0 0 3px rgba(255,237,0,.3)}
.rhits{max-height:230px;overflow:auto;border-bottom:1px solid var(--border);background:var(--surf)}
.rhits-h{padding:7px 14px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;color:var(--g600);background:var(--surf2);position:sticky;top:0}
.rhits .vhit{padding:8px 14px;border-bottom:1px solid var(--border-s);cursor:pointer;font-size:12px;line-height:1.45}
.rhits .vhit:hover{background:var(--yellow-sub)}
.rhits .vhh{font-weight:700;color:var(--g700);margin-bottom:2px}
@media print{.akten-2col{display:block}.akten-reader{display:none}.akten-list{max-height:none;overflow:visible}.filecard:not(.open) ol.toc.long li{display:block}}
@media(max-width:1080px){.akten-2col{grid-template-columns:1fr}.akten-reader{position:static}}
.vempty{color:var(--g600);padding:40px 20px;text-align:center;font-size:13px}
@media(max-width:900px){.viewer{grid-template-columns:1fr}.viewer-side{max-height:280px}}
@media print{.viewer-side,.vbar button{display:none}.viewer{grid-template-columns:1fr}.vstage{max-height:none;background:#fff}}

/* ===== Login-Overlay + User-Chip ===== */
/* Diskreter Login: bis zur Authentifizierung ist NICHTS von der App sichtbar (kein Name,
   keine Kennzahlen, kein Zweck-Hinweis) — nur das blickdichte Login-Overlay. */
body.preauth>*:not(#loginOv):not(script){display:none!important}
.login-ov{position:fixed;inset:0;z-index:300;background:#14150f;display:flex;align-items:center;justify-content:center;padding:20px}
.login-card{background:var(--surf);border:1px solid var(--border);border-radius:14px;box-shadow:0 24px 60px rgba(0,0,0,.35);width:100%;max-width:380px;padding:26px}
.login-card h2{margin:0;font-size:20px;color:var(--g900)}
.login-card h2::after{content:"";display:block;width:42px;height:3px;background:var(--yellow);margin-top:6px;border-radius:2px}
.login-sub{margin:12px 0 18px;font-size:12.5px;color:var(--g600)}
.login-card label{display:block;font-size:12px;font-weight:700;color:var(--g700);margin-bottom:12px}
.login-card input{display:block;width:100%;margin-top:5px;padding:9px 11px;border:1px solid var(--border);border-radius:8px;font:inherit;font-size:14px}
.login-card input:focus{outline:none;border-color:var(--yellow-d);box-shadow:0 0 0 3px rgba(255,237,0,.3)}
.login-err{color:var(--err);font-size:12.5px;margin:2px 0 12px;min-height:16px}
.userchip{display:inline-flex;align-items:center;gap:8px;font-size:12px;color:var(--g600);margin-right:14px}
.userchip b{color:var(--g900)}
.userchip button{font-size:12px;font-weight:700;color:var(--g700);background:var(--surf);border:1px solid var(--border);border-radius:7px;padding:4px 10px;cursor:pointer}
.userchip button:hover{background:var(--g100)}
/* Nutzerverwaltung (Admin-Modal) */
.modal-wide{max-width:760px;width:92vw}
.um-note{margin:0 0 12px;font-size:12.5px}
.um-new{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}
.um-new input[type=email]{flex:1;min-width:220px;padding:8px 11px;border:1px solid var(--border);border-radius:7px;font:inherit;font-size:13px}
.um-new select{padding:8px 10px;border:1px solid var(--border);border-radius:7px;font:inherit;font-size:13px;background:var(--surf)}
.um-creds{margin:0 0 14px;padding:12px 14px;border:1px solid #ecd96a;background:var(--yellow-sub);border-radius:8px;font-size:13px}
.um-creds .cred{margin-top:8px;display:flex;flex-direction:column;gap:4px}
.um-creds code{font-family:var(--mono,monospace);background:var(--surf);border:1px solid var(--border);border-radius:4px;padding:1px 6px}
.um-creds .um-otp{font-size:11px;color:var(--g600);word-break:break-all}
.um-creds .err{color:var(--err);font-weight:600}
.um-list{max-height:52vh;overflow:auto}
.um-tab{width:100%;border-collapse:collapse;font-size:13px}
.um-tab th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.3px;color:var(--g600);padding:6px 8px;border-bottom:1px solid var(--border)}
.um-tab td{padding:8px;border-bottom:1px solid var(--border-s);vertical-align:middle}
.um-tab tr.um-off{opacity:.55}
.um-mail{font-weight:600;color:var(--g900);word-break:break-all}
.um-tab select{padding:4px 8px;border:1px solid var(--border);border-radius:6px;font:inherit;font-size:12px;background:var(--surf)}
.um-act{color:#1c7c3a;font-weight:700;font-size:12px}
.um-ina{color:var(--g500);font-weight:700;font-size:12px}
.um-actions{white-space:nowrap}
.um-actions button{font-size:12px;font-weight:600;color:var(--g700);background:var(--surf);border:1px solid var(--border);border-radius:6px;padding:5px 9px;cursor:pointer;margin-right:4px}
.um-actions button:hover{background:var(--g100)}
.um-list .err{color:var(--err);font-weight:600;padding:10px 2px}

/* ===== Druckausgabe (saubere Akten-Übersicht) ===== */
@media print{
  .mockbar,.confbar,.channelbar,.brandbar,.infobar,nav.tabs.tabbar,.toolbar,.secnav,.foot,.userchip,.login-ov,.hdr-actions,.langsw,.segctl{display:none!important}
  body{background:#fff;color:#000;font-size:11pt;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  main{max-width:none;margin:0;padding:0}
  .view{display:block!important}
  .card,.sec,.reg,.table-wrap,.rubrum,.vk,.viewer{box-shadow:none;border-color:#bbb;break-inside:avoid}
  .table-wrap{max-height:none;overflow:visible}
  a{color:#000;text-decoration:none}
}

/* ===== Tablet & darunter: Kopfzeile umbrechen, Sticky-Stapel entkoppeln ===== */
@media(max-width:960px){
  .brandbar{flex-wrap:wrap;height:auto;min-height:54px;align-content:center;gap:8px 14px;padding:8px 18px}
  .brandbar .spacer{display:none}
  .hdr-actions{margin-left:auto}
  nav.tabs.tabbar{position:static;height:auto;padding:6px 18px;overflow-x:auto;white-space:nowrap}
  .toolbar{position:static;top:auto}
  .infobar .stand{white-space:normal}
}
/* ===== Phones ===== */
@media(max-width:680px){
  .brandbar{padding:8px 14px}
  .wordmark{font-size:17px;white-space:normal;line-height:1.2}
  .wordmark .by{display:none}
  .segctl{margin-left:0}
  .hdr-actions{flex-wrap:wrap;row-gap:6px;margin-left:0}
  .userchip{font-size:11px}
  .userchip b{word-break:break-all}
  nav.tabs.tabbar{padding:6px 12px}
  .infobar{padding:6px 14px}
  .infobar .stand{font-size:11px;line-height:1.35}
  main{padding:14px 12px 64px}
  .sub{font-size:12.5px}
  /* Filter/Suche: gestapelt, volle Breite */
  .toolbar{flex-direction:column;align-items:stretch;gap:8px}
  .toolbar input[type=search]{min-width:0;width:100%}
  .fchk{display:flex;flex-wrap:wrap;width:100%}
  /* Dichte Liste: horizontal scrollbar INNERHALB der Box, kein Seiten-Overflow */
  .table-wrap{max-height:none;overflow-x:auto;-webkit-overflow-scrolling:touch}
  table.cases{table-layout:fixed;min-width:760px}
  /* Detail-Ansicht */
  .rubrum h1{font-size:19px}
  .kv{grid-template-columns:110px 1fr}
  .party .pr{width:96px}
  .statusline{gap:14px}
  /* breite Detail-Tabellen (Chronik, Dokumente, Beweis, Fristen) scrollbar machen */
  .vorwurf-2col table,table.docs,.detail-grid table,.sec table{display:block;overflow-x:auto;white-space:nowrap}
  /* Login-Dialog auf kleinen Screens */
  .login-card{width:calc(100vw - 28px);max-width:none}
}
@media(max-width:430px){
  .wordmark{font-size:15px}
  nav.tabs.tabbar button{font-size:12.5px}
}
