:root{--ink:#1f3a5f;--accent:#b4552d;--line:#d9dee6;--soft:#f4f6f9;--muted:#5b6472;}
*{box-sizing:border-box;}
body{margin:0;font-family:"Segoe UI","Calibri","Helvetica Neue",Arial,sans-serif;
  color:#23272e;background:#fbfcfd;font-size:15px;line-height:1.5;}
.wrap{max-width:1040px;margin:0 auto;padding:0 20px;}

/* Kopfleiste */
.topbar{background:var(--ink);color:#fff;box-shadow:0 1px 4px rgba(0,0,0,.15);}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;height:56px;}
.brand{font-weight:700;font-size:18px;letter-spacing:.02em;}
.brand-sub{font-weight:400;opacity:.8;}
.topbar nav a{color:#dfe6ef;text-decoration:none;margin-left:18px;font-size:14px;padding:4px 0;
  border-bottom:2px solid transparent;}
.topbar nav a.active{color:#fff;border-bottom-color:var(--accent);}
.topbar nav a.disabled{opacity:.45;cursor:default;}
.topright{display:flex;align-items:center;gap:22px;}
.userbox{font-size:12.5px;color:#c3cee0;white-space:nowrap;}
.userbox a{color:#fff;text-decoration:none;border-bottom:1px solid rgba(255,255,255,.4);}

/* Login */
.loginbody{background:linear-gradient(160deg,#1f3a5f,#2a4a73);min-height:100vh;margin:0;
  display:flex;align-items:center;justify-content:center;}
.loginwrap{width:340px;max-width:92vw;}
.logincard{background:#fff;border-radius:12px;padding:28px 26px;box-shadow:0 12px 40px rgba(0,0,0,.28);}
.loginbrand{font-size:20px;font-weight:700;color:var(--ink);margin-bottom:18px;}
.loginbrand span{font-weight:400;color:var(--muted);}
.loginform{display:flex;flex-direction:column;gap:14px;}
.loginform label{display:flex;flex-direction:column;gap:5px;font-size:13px;color:var(--muted);}
.loginform input{padding:10px 12px;font-size:15px;border:1px solid #c6cfdb;border-radius:8px;}
.loginform input:focus{outline:none;border-color:var(--ink);box-shadow:0 0 0 3px rgba(31,58,95,.15);}
.loginform .btn{margin-top:4px;text-align:center;}
.loginfoot{text-align:center;color:#c3cee0;font-size:12px;margin-top:16px;}

h1{color:var(--ink);font-size:26px;margin:22px 0 4px;}
.lead{color:var(--muted);margin:0 0 18px;}
.foot{color:var(--muted);font-size:12px;margin:40px auto 24px;border-top:1px solid var(--line);padding-top:10px;}

/* Suche */
.searchbar{display:flex;align-items:center;gap:12px;margin-bottom:14px;}
.searchbar input[type=search]{flex:1;padding:11px 14px;font-size:15px;border:1px solid #c6cfdb;
  border-radius:8px;background:#fff;}
.searchbar input:focus{outline:none;border-color:var(--ink);box-shadow:0 0 0 3px rgba(31,58,95,.12);}
.htmx-indicator{opacity:0;color:var(--muted);font-size:13px;transition:opacity .2s;}
.htmx-request .htmx-indicator{opacity:1;}
.meta{color:var(--muted);font-size:13px;margin:6px 0 10px;}

/* Tabelle */
table.grid{border-collapse:collapse;width:100%;background:#fff;border:1px solid var(--line);
  border-radius:8px;overflow:hidden;}
table.grid thead th{background:var(--soft);color:var(--ink);text-align:left;font-size:12px;
  text-transform:uppercase;letter-spacing:.05em;padding:9px 12px;border-bottom:1px solid var(--line);}
table.grid td{padding:9px 12px;border-bottom:1px solid #eef1f5;font-size:14px;}
table.grid tbody tr{cursor:pointer;}
table.grid tbody tr:hover{background:#f0f5fb;}
table.grid td.titel{font-weight:600;color:#16202e;}
td.leer{color:var(--muted);text-align:center;padding:22px;}

.tag{display:inline-block;font-size:11px;padding:2px 8px;border-radius:10px;
  background:#e7ebf1;color:#41506a;text-transform:uppercase;letter-spacing:.04em;}
.tag-merged{background:#e3efe4;color:#2f6d3a;}
.tag-oracle{background:#e7edf7;color:#2c4a80;}
.tag-geodb{background:#f6e9df;color:#a4531f;}

/* Detail */
.back{color:var(--ink);text-decoration:none;font-size:14px;}
.detail-titel{font-size:22px;margin-top:6px;}
.cardgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:2px 26px;background:#fff;
  border:1px solid var(--line);border-radius:8px;padding:16px 20px;margin:12px 0 20px;}
.cardgrid>div{display:flex;justify-content:space-between;gap:14px;padding:7px 0;
  border-bottom:1px solid #f0f3f7;}
.cardgrid .k{color:var(--muted);font-size:13px;}
.cardgrid .v{font-weight:500;text-align:right;}
h2{color:var(--ink);font-size:16px;border-bottom:1px solid var(--line);padding-bottom:5px;margin-top:24px;}
.abstract{background:var(--soft);border-left:3px solid var(--accent);padding:10px 14px;border-radius:0 6px 6px 0;}
.prov{color:var(--muted);font-size:14px;}

/* Seitenkopf mit Aktion */
.pagehead,.detailhead{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;}
.detailhead{align-items:center;margin-top:6px;}
.detailhead .btns{display:flex;gap:8px;align-items:center;}
.detailhead form{margin:0;}

/* Buttons */
.btn{display:inline-block;padding:8px 16px;border-radius:7px;font-size:14px;font-weight:600;
  text-decoration:none;border:1px solid transparent;cursor:pointer;line-height:1.2;}
.btn-primary{background:var(--ink);color:#fff;}
.btn-primary:hover{background:#274b78;}
.btn-ghost{background:#fff;color:var(--ink);border-color:#c6cfdb;}
.btn-ghost:hover{background:var(--soft);}
.btn-danger{background:#fff;color:#b02a2a;border-color:#e3b7b7;}
.btn-danger:hover{background:#fbeeee;}

/* Formular */
.formfehler{background:#fbeaea;border-left:3px solid #b02a2a;color:#7d1d1d;padding:9px 14px;border-radius:0 6px 6px 0;}
.form{display:grid;grid-template-columns:1fr 1fr;gap:14px 22px;background:#fff;border:1px solid var(--line);
  border-radius:8px;padding:20px 22px;margin-top:12px;}
.form label{display:flex;flex-direction:column;gap:5px;font-size:13px;color:var(--muted);}
.form label.wide{grid-column:1 / -1;}
.form input,.form select,.form textarea{padding:9px 11px;font-size:14px;color:#23272e;
  border:1px solid #c6cfdb;border-radius:7px;background:#fff;font-family:inherit;}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--ink);
  box-shadow:0 0 0 3px rgba(31,58,95,.12);}
.form .pflicht{color:var(--accent);}
.formaktion{display:flex;gap:10px;align-items:center;margin-top:4px;}

/* ADeX-Export */
.exportcards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:18px 0;}
.expcard{background:#fff;border:1px solid var(--line);border-radius:10px;padding:20px;text-align:center;}
.expcard .expnum{font-size:34px;font-weight:700;color:var(--ink);line-height:1;}
.expcard .expk{color:var(--muted);font-size:13px;margin:6px 0 16px;}
.hinweis{background:var(--soft);border-left:3px solid var(--accent);border-radius:0 6px 6px 0;
  padding:12px 16px;font-size:13px;color:#3a4250;line-height:1.6;}
.hinweis code{background:#e7ebf1;padding:1px 5px;border-radius:3px;font-size:12px;color:#9a3412;}

/* Zahlenspalten & Zeilenaktionen */
table.grid th.num,table.grid td.num{text-align:right;white-space:nowrap;}
td.rowact{white-space:nowrap;text-align:right;}
td.rowact a{color:var(--ink);text-decoration:underline;font-size:13px;margin-right:10px;}
td.rowact form{display:inline;margin:0;}
.linkbtn{background:none;border:none;color:#b02a2a;cursor:pointer;font-size:13px;padding:0;text-decoration:underline;font-family:inherit;}
.linkbtn-ink{color:var(--ink);}

/* Ausleihe */
.ausleihe-status{display:flex;align-items:center;gap:10px;margin:2px 0 16px;}
.ausleihe-status form{margin:0;}
.badge{display:inline-block;font-size:12px;font-weight:600;padding:3px 11px;border-radius:12px;}
.badge-out{background:#f6e9df;color:#a4531f;}
.badge-in{background:#e3efe4;color:#2f6d3a;}
.filterbar{display:flex;gap:8px;margin:12px 0;}
.chip{padding:6px 14px;border-radius:16px;border:1px solid #c6cfdb;color:var(--muted);text-decoration:none;font-size:13px;}
.chip-on{background:var(--ink);color:#fff;border-color:var(--ink);}

/* Karte */
#map{height:560px;border:1px solid var(--line);border-radius:8px;z-index:0;}
.leaflet-control-layers{font-size:13px;}
