/* Schlicht, hoher Kontrast, große Klickflächen. Kein Schnickschnack.
   Farbschema: Cremeblau (Molotow Premium #113, #6bb8c4). */

:root {
  --cb:         #6bb8c4;   /* Cremeblau – Markenfarbe */
  --cb-dunkel:  #34727d;   /* dunklere Variante – Header, Links, Text auf Weiß */
  --cb-hell:    #84c8d2;   /* hellere Variante – Hover */
  --cb-bg:      #e7f3f5;   /* heller Cremeblau-Ton – Tabellenkopf, Banner */
  --cb-bg2:     #f4fafb;   /* noch heller – alternierende Zeilen, Aktionsleiste */
  --rand:       #b3ccd0;   /* getönter Rahmen */
  --gelb-hover: #fff3cd;   /* Zeilen-Hover */
}

* { box-sizing: border-box; }

body {
  font-family: Arial, Helvetica, sans-serif;
  font-size: 17px;
  line-height: 1.5;
  color: #1a1a1a;
  background: #f3f1f1;
  margin: 0;
  padding: 0;
}

header {
  background: var(--cb-dunkel);
  color: #fff;
  padding: 12px 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 8px;
}
header .brand { font-size: 20px; font-weight: bold; }
header nav a {
  color: #fff;
  text-decoration: none;
  margin-left: 16px;
  padding: 6px 10px;
  border: 1px solid transparent;
}
header nav a:hover, header nav a.active { border-color: #fff; }
header nav button {
  margin-left: 16px;
  font-size: 16px;
  padding: 6px 12px;
  cursor: pointer;
}

main { padding: 20px; max-width: 1400px; margin: 0 auto; }

h1 { font-size: 24px; margin: 0 0 16px; }
h2 { font-size: 20px; margin: 24px 0 10px; border-bottom: 2px solid var(--cb); padding-bottom: 4px; }
h3 { font-size: 18px; margin: 16px 0 6px; }

a { color: var(--cb-dunkel); }

/* --- Buttons --- */
button, .btn {
  font-size: 17px;
  padding: 10px 18px;
  background: var(--cb);
  color: #163b41;
  border: none;
  cursor: pointer;
  border-radius: 0;
}
button:hover, .btn:hover { background: var(--cb-hell); }
button.secondary { background: #777; color: #fff; }
button.secondary:hover { background: #888; }
button.big { font-size: 19px; padding: 12px 26px; }

/* --- Formulare --- */
input[type=text], input[type=number], input[type=password], input[type=date], select {
  font-size: 17px;
  padding: 8px 10px;
  border: 1px solid #999;
  background: #fff;
  border-radius: 0;
}
label { display: inline-block; }

.login-box {
  max-width: 420px;
  margin: 80px auto;
  background: #fff;
  padding: 32px;
  border: 1px solid var(--rand);
  border-top: 5px solid var(--cb);
}
.login-box h1 { text-align: center; }
.login-box input[type=password] { width: 100%; margin: 12px 0; }
.login-box button { width: 100%; }
.login-error { color: var(--cb-dunkel); margin-top: 10px; font-weight: bold; }

/* --- Dashboard --- */
.cards { display: flex; gap: 16px; flex-wrap: wrap; margin-bottom: 24px; }
.card {
  background: #fff;
  border: 1px solid var(--rand);
  border-top: 4px solid var(--cb);
  padding: 18px 24px;
  min-width: 160px;
}
.card .num { font-size: 32px; font-weight: bold; color: var(--cb-dunkel); }
.card .lbl { font-size: 15px; color: #555; }

.big-links a {
  display: inline-block;
  background: var(--cb);
  color: #163b41;
  text-decoration: none;
  padding: 18px 28px;
  font-size: 19px;
  margin-right: 16px;
  margin-bottom: 12px;
}
.big-links a:hover { background: var(--cb-hell); }

/* --- Filterbereich (gruppiertes Layout) --- */
.searchpanel { margin-bottom: 18px; }

.quickbar {
  background: #fff;
  border: 1px solid var(--rand);
  padding: 14px 16px;
  display: flex;
  flex-wrap: wrap;
  gap: 12px 18px;
  align-items: flex-end;
}
.quickbar .f { display: flex; flex-direction: column; }
.quickbar .f label { font-size: 13px; color: #555; margin-bottom: 3px; }
.quickbar .f.grow { flex: 1 1 260px; }

.filter-groups {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 14px;
  margin-top: 14px;
}
.filter-group {
  background: #fff;
  border: 1px solid var(--rand);
  padding: 10px 14px 14px;
}
.filter-group > h4 {
  margin: 0 0 8px;
  font-size: 15px;
  color: var(--cb-dunkel);
  border-bottom: 1px solid var(--cb-bg);
  padding-bottom: 4px;
  text-transform: uppercase;
  letter-spacing: .03em;
}
.filter-group .f { display: flex; flex-direction: column; margin-bottom: 8px; min-width: 0; }
.filter-group .f label { font-size: 13px; color: #555; margin-bottom: 3px; }
.filter-group .f input, .filter-group .f select { width: 100%; }
.filter-group .f small { font-size: 12px; line-height: 1.3; margin-top: 3px; }
.filter-group .pair { display: flex; gap: 10px; }
.filter-group .pair .f { flex: 1 1 0; min-width: 0; margin-bottom: 8px; }

.checkbox-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
  gap: 4px 14px;
}
.checkbox-grid label { font-size: 15px; white-space: nowrap; }

.searchactions {
  margin-top: 14px;
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  align-items: center;
  background: var(--cb-bg2);
  border: 1px solid var(--cb-bg);
  padding: 12px 14px;
}

/* --- Ergebnistabelle --- */
.result-meta { margin: 12px 0; font-size: 16px; }
.result-meta strong { font-size: 18px; color: var(--cb-dunkel); }

.pager { display: flex; align-items: center; gap: 12px; margin: 16px 0; }
.pager button { padding: 8px 16px; }
.pager button:disabled { opacity: 0.4; cursor: not-allowed; }
.pager #pageinfo { flex: 1; text-align: center; }

table.results {
  width: 100%;
  border-collapse: collapse;
  background: #fff;
  font-size: 16px;
}
table.results th, table.results td {
  border: 1px solid var(--rand);
  padding: 7px 9px;
  text-align: left;
  vertical-align: top;
}
table.results th {
  background: var(--cb-bg);
  color: var(--cb-dunkel);
  cursor: pointer;
  user-select: none;
  white-space: nowrap;
}
table.results th:hover { background: #d3eaee; }
table.results th .arrow { font-size: 13px; }
table.results tbody tr:nth-child(even) { background: var(--cb-bg2); }
table.results tbody tr:hover { background: var(--gelb-hover); cursor: pointer; }

.muted { color: #888; }
.nowrap { white-space: nowrap; }

/* --- Detailansicht --- */
.detail-section {
  background: #fff;
  border: 1px solid var(--rand);
  border-top: 4px solid var(--cb);
  padding: 16px 20px;
  margin-bottom: 16px;
}
.detail-grid { display: grid; grid-template-columns: max-content 1fr; gap: 4px 18px; }
.detail-grid dt { font-weight: bold; color: #444; }
.detail-grid dd { margin: 0; }
ul.flags { columns: 3; -webkit-columns: 3; margin: 6px 0; padding-left: 20px; }

.notice { background: #fff8e1; border: 1px solid #f0d98a; padding: 10px 14px; margin: 10px 0; }
.mockup-banner {
  background: var(--cb-bg);
  border: 1px solid var(--cb);
  color: var(--cb-dunkel);
  padding: 10px 14px;
  margin-bottom: 14px;
  font-size: 15px;
}
