:root{
  --primary:#003b7c; --primary2:#002d5f; --accent:#ec4a70; --accent2:#f97316;
  --bg:#eef2f8; --card:#fff; --text:#12213a; --muted:#5b6b86; --line:#e2e8f3;
  --ok:#1a8a4d; --warn:#b8860b; --bad:#c0392b;
  --shadow:0 1px 3px rgba(18,33,58,.06),0 6px 18px rgba(18,33,58,.06);
}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  background:var(--bg);color:var(--text);font-size:15px;line-height:1.45}
h1,h3,h4{margin:0}
a{color:var(--primary)}
button{font:inherit}

/* Topbar – hell, WissenLebtOnline-Branding */
.topbar{display:flex;justify-content:space-between;align-items:center;gap:1rem;
  background:#fff;color:var(--text);border-bottom:3px solid transparent;
  border-image:linear-gradient(90deg,var(--primary),var(--accent)) 1;
  padding:.7rem 1.2rem;position:sticky;top:0;z-index:30}
.brand{display:flex;align-items:center;gap:.8rem;min-width:0}
.brand-logo{height:34px;width:auto;display:block}
.brand-app{font-size:.95rem;font-weight:600;color:var(--muted);border-left:2px solid var(--line);padding-left:.8rem;white-space:nowrap}
.topbar-actions{display:flex;gap:.6rem;align-items:center}
#search{padding:.55rem .85rem;border:1px solid var(--line);border-radius:9px;width:min(36vw,340px);font-size:.9rem;background:var(--bg)}
.topbar .btn-ghost{color:#fff;background:var(--primary);border-color:var(--primary);font-weight:600}
.topbar .btn-ghost:hover{background:var(--primary2);border-color:var(--primary2)}
.tabbar{top:64px}.selbar{top:110px}.filters{top:124px}

/* Tabbar */
.tabbar{display:flex;justify-content:space-between;align-items:center;background:var(--card);
  border-bottom:1px solid var(--line);padding:.35rem 1.2rem;position:sticky;top:58px;z-index:25}
.tabs{display:flex;gap:.3rem}
.tab{background:none;border:none;padding:.55rem .9rem;border-radius:8px;cursor:pointer;color:var(--muted);font-weight:600}
.tab:hover{background:var(--bg)}
.tab.active{background:var(--primary);color:#fff}
.tabbar-export{display:flex;gap:.4rem;align-items:center}

/* Auswahl-Leiste */
.selbar{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;
  background:#fff6f8;border-bottom:1px solid #ffd6e0;padding:.5rem 1.2rem;position:sticky;top:104px;z-index:24}
.selbar-actions{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}

/* Layout */
.layout{display:grid;grid-template-columns:235px 1fr;gap:1.2rem;padding:1.1rem 1.2rem 3rem}
.filters{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:1rem;align-self:start;
  position:sticky;top:118px;box-shadow:var(--shadow)}
.filters h3{margin-bottom:.5rem;font-size:.95rem}
.filters label{display:block;font-size:.8rem;color:var(--muted);margin:.7rem 0 .15rem}
.filters select,.filters input[type=range]{width:100%}
.filters select{padding:.45rem;border:1px solid var(--line);border-radius:8px;background:#fff}
.chk{display:flex!important;align-items:center;gap:.45rem;color:var(--text)!important;font-size:.85rem!important;margin-top:.55rem!important;cursor:pointer}
.selectall{margin-top:.9rem!important;padding-top:.7rem;border-top:1px solid var(--line)}
.statuskey{display:flex;flex-wrap:wrap;gap:.2rem .6rem;font-size:.7rem;color:var(--muted);margin-top:.55rem}
.statuskey span{display:flex;align-items:center;gap:.25rem}
.sk{width:9px;height:9px;border-radius:50%;display:inline-block;border:1px solid rgba(0,0,0,.12)}
.sk.ok{background:#2aa35a}.sk.warn{background:#e0a400}.sk.miss{background:#d6493b}.sk.unk{background:#aeb8c7}
.hint{font-size:.75rem;color:var(--muted);margin-top:.8rem}
.err{color:var(--bad);font-size:.8rem}

/* Cards – WissenLebtOnline-Stil (Referenz-Layout) */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(335px,1fr));gap:1rem}
.card{background:var(--card);border:1px solid var(--line);border-radius:14px;cursor:pointer;
  transition:.14s;display:flex;flex-direction:column;box-shadow:var(--shadow);position:relative}
.card:hover{border-color:var(--accent);box-shadow:0 8px 24px rgba(0,59,124,.12);transform:translateY(-2px)}
.card.sel{outline:2px solid var(--primary);outline-offset:-1px;border-color:var(--primary)}
.card-head{display:flex;align-items:center;gap:.5rem;padding:.6rem .85rem 0}
.card-head .card-check{flex:0 0 auto;width:17px;height:17px;cursor:pointer;accent-color:var(--accent);margin:0}
.ctype{flex:1;min-width:0;font-size:.7rem;color:var(--muted);font-weight:700;display:flex;align-items:center;gap:.32rem;text-transform:uppercase;letter-spacing:.4px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.card-menu-btn{background:none;border:none;font-size:1.35rem;line-height:.5;color:var(--muted);cursor:pointer;padding:.1rem .35rem .25rem;border-radius:7px;flex:0 0 auto}
.card-menu-btn:hover{background:var(--bg);color:var(--primary)}
.card h4{font-size:1.04rem;line-height:1.25;padding:.2rem .85rem .35rem}
.card-body{display:flex;gap:.7rem;padding:0 .85rem .55rem;flex:1}
.card-body .desc{flex:1;font-size:.8rem;color:#46566f;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;margin:0}
.thumb{position:relative;width:96px;height:68px;border-radius:9px;overflow:hidden;flex:0 0 auto;background:#0a1a2f}
.thumb img{width:100%;height:100%;object-fit:cover;display:block}
.thumb-badges{position:absolute;bottom:4px;right:4px;display:flex;gap:3px;align-items:center}
.b-oer{background:var(--primary);color:#fff;font-size:.57rem;font-weight:800;padding:.07rem .32rem;border-radius:4px;letter-spacing:.3px}
.card-foot{display:flex;gap:.35rem .45rem;align-items:center;flex-wrap:wrap;padding:.5rem .85rem .7rem;border-top:1px solid var(--line);font-size:.74rem;color:var(--muted)}
.fcount{background:var(--primary);color:#fff;border-radius:20px;padding:.1rem .55rem;font-weight:600;font-size:.72rem;flex:0 0 auto}
.foot-badges{display:flex;gap:.3rem;flex-wrap:wrap;margin-left:auto;justify-content:flex-end}
.badge{font-size:.66rem;padding:.1rem .45rem;border-radius:6px;border:1px solid var(--line);color:var(--muted);background:#fafcff;white-space:nowrap}
/* einheitliche Status-Pillen (Kachel-Fußzeile): Farbe = Status */
.badge.st-ok{background:#e7f6ec;color:#1a7a44;border-color:#bfe5cd}
.badge.st-warn{background:#fff6e5;color:#9a6700;border-color:#ffe0a8}
.badge.st-miss{background:#fdecec;color:#c0392b;border-color:#f3c6c1}
.badge.st-unk{background:#eef1f5;color:#73809a;border-color:#dde3ec}
.badge.st-count{background:#fff;color:var(--muted);border-color:var(--line)}

/* Karten-Aktionsmenü */
.cardmenu{position:absolute;z-index:60;background:#fff;border:1px solid var(--line);border-radius:11px;box-shadow:0 12px 34px rgba(10,20,40,.2);padding:.3rem;min-width:210px}
.cardmenu button{display:flex;align-items:center;gap:.6rem;width:100%;text-align:left;background:none;border:none;padding:.55rem .7rem;border-radius:8px;cursor:pointer;font-size:.88rem;color:var(--text)}
.cardmenu button:hover{background:var(--bg)}

.pager{display:flex;gap:.5rem;justify-content:center;margin-top:1.5rem;align-items:center}
.btn,.btn-ghost{border-radius:9px;padding:.5rem .9rem;cursor:pointer;border:1px solid var(--primary)}
.btn{background:var(--primary);color:#fff}.btn:hover{background:var(--primary2)}
.btn-ghost{background:#fff;color:var(--primary)}
.btn-ghost:hover{background:var(--bg)}
.btn.small,.btn-ghost.small{padding:.32rem .65rem;font-size:.82rem}
.btn:disabled{opacity:.45;cursor:default}

/* Overlay / Drawer */
.overlay{position:fixed;inset:0;background:rgba(10,20,40,.45);display:flex;justify-content:flex-end;z-index:50}
.overlay.hidden,.hidden{display:none!important}
.drawer{background:var(--bg);width:min(700px,96vw);height:100%;overflow:auto;box-shadow:-8px 0 30px rgba(0,0,0,.2)}
.dialog{background:#fff;margin:auto;border-radius:14px;padding:1.4rem;width:min(380px,92vw);align-self:center}
.dialog input{width:100%;padding:.6rem;border:1px solid var(--line);border-radius:8px;margin:.5rem 0}
.dialog-actions{display:flex;justify-content:flex-end;gap:.6rem;margin-top:.5rem}

/* Steckbrief */
.sb-head{background:linear-gradient(100deg,var(--primary),var(--primary2));color:#fff;padding:1.2rem 1.4rem;position:sticky;top:0;z-index:2}
.sb-head h2{margin:0 0 .2rem;font-size:1.4rem}
.sb-head .sb-sub{opacity:.85;font-size:.85rem}
.sb-head .close{position:absolute;top:1rem;right:1.2rem;background:none;border:none;color:#fff;font-size:1.6rem;cursor:pointer}
.sb-markers{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.6rem}
.mk{font-size:.72rem;font-weight:600;padding:.14rem .55rem;border-radius:6px;color:#fff;border:1px solid rgba(255,255,255,.4);background:rgba(255,255,255,.18)}
.mk-mis{background:#c0392b;border-color:#e58b80}
.mk-oer{background:#1a8a4d;border-color:#5bbd84}
.mk-leg{background:rgba(255,210,150,.3)}
.sb-body{padding:1.2rem 1.4rem}
.sb-section{background:#fff;border:1px solid var(--line);border-radius:12px;padding:1rem 1.1rem;margin-bottom:1rem;box-shadow:var(--shadow)}
.sb-section h3{font-size:.95rem;margin-bottom:.7rem;color:var(--primary);display:flex;align-items:center;gap:.4rem}
.kv{display:grid;grid-template-columns:175px 1fr;gap:.35rem .8rem;font-size:.88rem}
.kv .k{color:var(--muted)}
.kv .v{word-break:break-word}
.ki-section .kv .v{max-height:150px;overflow:auto;background:#fafcff;border:1px solid var(--line);border-radius:6px;padding:.3rem .5rem;white-space:pre-wrap}
.sb-sub2{font-size:.82rem;color:var(--muted);margin:.85rem 0 .35rem;padding-top:.6rem;border-top:1px dashed var(--line)}
.kv-remarks .v{white-space:pre-wrap}
.prov{font-size:.66rem;margin-left:.4rem;background:#eef3fb;border-radius:5px;padding:.02rem .35rem;color:#46a;white-space:nowrap}
.prov.api{color:#1a6;background:#e7f7ee}.prov.csv{color:#a60;background:#fff3e6}.prov.facet{color:#46a;background:#eef3fb}
.fieldtable{width:100%;border-collapse:collapse;font-size:.8rem}
.fieldtable th,.fieldtable td{text-align:left;padding:.3rem .5rem;border-bottom:1px solid var(--line);vertical-align:top}
.fieldtable th{color:var(--muted);font-weight:600}
.how{color:var(--accent2)}
.internal{border:1px dashed var(--accent);background:#fff8f1}
.internal h3{color:#a85b00}
.locked{text-align:center;color:var(--muted);padding:1rem;border:1px dashed var(--line);border-radius:10px;background:#fff}
.tag-oer{color:var(--ok);font-weight:600}
.print-actions{display:flex;gap:.6rem;margin-bottom:1rem;flex-wrap:wrap}

/* Statistik-View */
.stats-view{padding:1.2rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:1.1rem;align-content:start;max-width:1500px;margin-inline:auto}
.stats-head{grid-column:1/-1;margin:.6rem 0 -.2rem;font-size:1.05rem;color:var(--primary);font-weight:700;border-bottom:2px solid var(--line);padding-bottom:.35rem}
.stats-head span{font-weight:400;font-size:.82rem;color:var(--muted)}
.stats-head.team{color:#a85b00;border-bottom-color:#ffd9ad}
.team-note{grid-column:1/-1;background:#fff8f1;border:1px solid #ffd9ad;border-radius:8px;padding:.55rem .9rem;color:#7a5200;font-size:.8rem;margin:.2rem 0}
/* je Abschnitt ein eigenes Karten-Grid (volle Breite, saubere Gruppierung) */
.chart-grid{grid-column:1/-1;display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:1.1rem;align-items:start;margin-bottom:.3rem}
.chart-card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:1rem;box-shadow:var(--shadow);min-height:120px}
.chart-card.wide{grid-column:1/-1}
.chart-card h3{font-size:.95rem;margin-bottom:.6rem;color:var(--text)}
.chart-card canvas{max-height:260px}
/* Herkunfts-Überschneidung: segmentierte Balken */
.segbar{display:flex;height:22px;border-radius:6px;overflow:hidden;background:var(--bg);border:1px solid var(--line)}
.seg{height:100%}
.seglegend{display:flex;flex-wrap:wrap;gap:.35rem 1.1rem;margin-top:.7rem;font-size:.76rem;color:var(--muted)}
.seglegend span{display:flex;align-items:center;gap:.4rem}
.seglegend i{width:11px;height:11px;border-radius:3px;display:inline-block;flex:none}
.barlist{display:flex;flex-direction:column;gap:.35rem;font-size:.82rem}
.barrow{display:grid;grid-template-columns:140px 1fr 44px;align-items:center;gap:.5rem}
.barrow .bl{color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bar{height:14px;background:var(--primary);border-radius:4px;min-width:2px}
.barrow .bv{text-align:right;color:var(--muted)}

/* Top-Listen-Reihe: füllt die Breite und bricht um — KEIN horizontales Scrollen */
.chart-grid.lists{grid-template-columns:repeat(auto-fit,minmax(238px,1fr))}
.chart-grid.lists .barrow{grid-template-columns:96px 1fr 42px}
/* größere vertikale Charts (Inhaltsmengen je Quelldatensatz / Bezugsquelle) */
.chart-grid.cols2{grid-template-columns:repeat(auto-fit,minmax(440px,1fr))}
.chart-grid.cols3{grid-template-columns:repeat(auto-fit,minmax(340px,1fr))}
.chart-card.tall canvas{max-height:380px}

.toast{position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%);background:var(--primary);color:#fff;
  padding:.7rem 1.2rem;border-radius:10px;z-index:80;box-shadow:0 6px 20px rgba(0,0,0,.25);font-size:.9rem}

/* PDF-Optionen in der Auswahl-Leiste */
.mini-sel{padding:.3rem .5rem;border:1px solid var(--line);border-radius:8px;background:#fff;font-size:.82rem;color:var(--text);cursor:pointer}
.selbar-actions .sep{color:var(--muted);opacity:.55}

/* Footer (Impressum / Datenschutz) */
.appfoot{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;
  padding:1rem 1.4rem;border-top:1px solid var(--line);background:var(--card);color:var(--muted);font-size:.82rem}
.appfoot .foot-links{display:flex;gap:1.1rem;flex-wrap:wrap}
.appfoot .foot-links a{color:var(--muted);text-decoration:none;cursor:pointer}
.appfoot .foot-links a:hover{color:var(--primary);text-decoration:underline}

/* Rechtsseiten-Overlay (Impressum / Datenschutz) */
.legal-panel{position:relative;background:#fff;margin:auto;align-self:center;width:min(800px,94vw);max-height:90vh;overflow:auto;border-radius:14px;box-shadow:0 12px 44px rgba(10,20,40,.32)}
.legal-close{position:sticky;top:.7rem;float:right;margin:.7rem .9rem 0 0;background:var(--bg);border:1px solid var(--line);border-radius:8px;width:2rem;height:2rem;font-size:1.25rem;line-height:1;cursor:pointer;z-index:2}
.legal-body{padding:1.6rem 2rem 2.2rem}
.legal-body h2{font-size:1.55rem;color:var(--primary);margin-bottom:.4rem}
.legal-body h3{font-size:1.02rem;color:var(--primary);margin:1.2rem 0 .35rem}
.legal-body p{margin:.45rem 0;font-size:.9rem;line-height:1.55}
.legal-body ul{margin:.3rem 0 .7rem 1.3rem;font-size:.9rem;line-height:1.5}
.legal-body li{margin:.12rem 0}
.legal-body a{word-break:break-word}
.legal-intro{color:var(--muted);font-size:.86rem;background:var(--bg);border-radius:8px;padding:.7rem .9rem}
.legal-src{margin-top:1.5rem;padding-top:.85rem;border-top:1px solid var(--line);color:var(--muted);font-size:.8rem}

@media(max-width:760px){.layout{grid-template-columns:1fr}.filters{position:static}}

@media print{
  body *{visibility:hidden}
  #drawer,#drawer *{visibility:visible}
  .overlay{position:static;background:none}
  #drawer{width:100%;box-shadow:none}
  .sb-head{color:#000;background:#fff;border-bottom:2px solid var(--primary)}
  .sb-head .close,.print-actions{display:none}
  .internal{display:none!important}
}
