:root {
  --c-bg: #f4f6fa;
  --c-panel: #fff;
  --c-text: #1f2937;
  --c-muted: #6b7280;
  --c-border: #e2e8f0;
  --c-brand: #2b6cb0;       /* Wappen-Blau */
  --c-brand-2: #3b82c4;
  --c-accent: #c49a1e;      /* Wappen-Gelb */
  --c-hover: #eff6ff;
  --radius: 6px;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body { font: 14px/1.45 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
       color: var(--c-text); background: var(--c-bg); }

/* Header */
.site-header { background: var(--c-brand); color: #fff; }
.site-header .inner { max-width: 1100px; margin: 0 auto; padding: 10px 16px;
                      display: flex; align-items: center; gap: 24px; }
.brand { color: #fff; text-decoration: none; font-size: 1.05rem;
         display: flex; align-items: center; gap: 12px; }
.brand-logo { height: 40px; width: auto; display: block;
              background: #fff; border-radius: 4px; padding: 2px; }
.brand-text { display: flex; flex-direction: column; line-height: 1.15; }
.brand-text strong { font-size: 1.05rem; }
.brand-text small { opacity: .85; font-weight: normal; font-size: .78rem; }
.nav { display: flex; align-items: center; gap: 16px; flex: 1; }
.nav a { color: #fff; text-decoration: none; opacity: .85; padding: 4px 8px; border-radius: 4px; }
.nav a:hover, .nav a.active { opacity: 1; background: rgba(255,255,255,0.12); }
.nav .spacer { flex: 1; }
.nav .user { opacity: .75; font-size: .85rem; }
.nav a.logout { font-size: .85rem; opacity: .75; }
.nav a.logout:hover { opacity: 1; }

th a { color: inherit; text-decoration: none; }
th a:hover { text-decoration: underline; }

/* Main + Footer */
main { max-width: 1100px; margin: 20px auto; padding: 0 16px; }
.site-footer { max-width: 1100px; margin: 40px auto 20px; padding: 12px 16px;
               color: var(--c-muted); font-size: .85rem; text-align: center; }

/* Panels */
.panel { background: var(--c-panel); border: 1px solid var(--c-border);
         border-radius: var(--radius); padding: 20px 24px; margin-bottom: 20px; }
.panel h1 { margin: 0 0 14px; font-size: 1.4rem; }
.panel h2 { margin: 20px 0 12px; font-size: 1.1rem; border-bottom: 1px solid var(--c-border); padding-bottom: 6px; }
.panel h3 { margin: 18px 0 8px; font-size: .95rem; color: var(--c-muted); text-transform: uppercase; letter-spacing: .04em; }

.muted { color: var(--c-muted); }
.crumbs { font-size: .9rem; margin: 0 0 8px; }
.crumbs a { color: var(--c-muted); text-decoration: none; }
.crumbs a:hover { color: var(--c-brand); }

/* Forms & Buttons */
button, .btn-primary, .btn-secondary, .btn-small, .btn-danger {
  font: inherit; padding: 6px 12px; border-radius: var(--radius);
  border: 1px solid var(--c-border); background: #fff; cursor: pointer;
  color: var(--c-text);
}
button:hover { background: var(--c-hover); border-color: var(--c-brand); }
.btn-primary, button[type="submit"]:not(.btn-danger):not(.btn-small) {
  background: var(--c-brand); color: #fff; border-color: var(--c-brand);
}
.btn-primary:hover, button[type="submit"]:not(.btn-danger):not(.btn-small):hover {
  background: var(--c-brand-2); border-color: var(--c-brand-2); color: #fff;
}
.btn-danger { background: #fff; color: var(--c-accent); border-color: #fecaca; }
.btn-danger:hover { background: var(--c-accent); color: #fff; border-color: var(--c-accent); }
.btn-small { padding: 3px 8px; font-size: .85rem; }

input[type="text"], input[type="search"], input[type="number"],
input[type="date"], select, textarea {
  font: inherit; padding: 5px 8px; border: 1px solid var(--c-border);
  border-radius: var(--radius); background: #fff;
}
input:focus, select:focus, textarea:focus {
  outline: 2px solid var(--c-brand); outline-offset: -1px;
}

.toolbar { display: flex; gap: 8px; align-items: center; margin-bottom: 14px; flex-wrap: wrap; }
.toolbar .spacer { flex: 1; }

.form-inline { display: inline-flex; gap: 8px; align-items: center; margin-top: 8px; flex-wrap: wrap; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px 14px; margin-top: 10px; }
.form-grid .full { grid-column: 1 / -1; }
.form-grid label { display: flex; flex-direction: column; font-size: .88rem; color: var(--c-muted); gap: 2px; }
.form-grid input, .form-grid textarea { font-size: 1rem; color: var(--c-text); }
.form-grid .actions { display: flex; gap: 8px; }

.engagement-form { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 8px 12px;
                   background: #fafaf7; padding: 14px; border-radius: var(--radius);
                   border: 1px dashed var(--c-border); }
.engagement-form label { display: flex; flex-direction: column; font-size: .82rem; color: var(--c-muted); }
.engagement-form label input, .engagement-form label select { font-size: .95rem; }
.engagement-form label.wide { grid-column: 1 / -1; }
.engagement-form button { align-self: end; grid-column: 4; }
.engagement-form .hint { grid-column: 1 / -1; margin: 0; font-size: .8rem; color: var(--c-muted); }

.form-edit-engagement .row { display: flex; flex-wrap: wrap; gap: 8px; align-items: end; margin-bottom: 6px; }
.form-edit-engagement label { display: flex; flex-direction: column; font-size: .8rem; color: var(--c-muted); }
.form-edit-engagement .wide { flex: 1; }

/* Tables */
table.grid { width: 100%; border-collapse: collapse; margin-top: 8px; background: #fff; }
table.grid th, table.grid td { padding: 7px 10px; border-bottom: 1px solid var(--c-border); text-align: left; vertical-align: top; }
table.grid thead th { background: #fafaf7; font-weight: 600; font-size: .88rem; color: var(--c-muted); text-transform: uppercase; letter-spacing: .03em; }
table.grid tbody tr:hover { background: var(--c-hover); }
table.grid .num { text-align: right; font-variant-numeric: tabular-nums; }
table.grid .actions { text-align: right; white-space: nowrap; }
table.grid a { color: var(--c-brand); text-decoration: none; font-weight: 500; }
table.grid a:hover { text-decoration: underline; }

.engagements tr.editing td { background: #fffbea; }

.pill { display: inline-block; padding: 1px 7px; border-radius: 10px; font-size: .78rem;
        font-weight: 500; }
.pill:not([style]):not(.muted):not([class*="klasse-"]):not([class*="verband-"]) {
  background: #eef2ff; color: #3730a3;
}
.pill.muted { background: #f3f4f6; color: var(--c-muted); }
.pill.klasse-V { background: #dbeafe; color: #1e40af; }
.pill.klasse-S { background: #dcfce7; color: #166534; }
.pill.klasse-P { background: #fef3c7; color: #92400e; }
.pill.klasse-X { background: #f3f4f6; color: var(--c-muted); }
.pill.verband-djk  { background: #dbeafe; color: #1e40af; }
.pill.verband-blsv { background: #e0e7ff; color: #3730a3; }
.pill.verband-bfv  { background: #dcfce7; color: #166534; }
.pill.verband-btv  { background: #fef3c7; color: #92400e; }
.pill-aktiv { display: inline-block; margin-left: 6px; padding: 1px 7px; border-radius: 10px;
  font-size: .72rem; background: #dcfce7; color: #166534; font-weight: 600; }
label.checkbox { display: inline-flex; align-items: center; gap: 6px; font-weight: normal; white-space: nowrap; }
label.checkbox input { width: auto; margin: 0; }

details.inline { display: inline; }
details.inline > summary { list-style: none; cursor: pointer; display: inline-block; }
details.inline > summary::-webkit-details-marker { display: none; }
details.edit-person { margin: 10px 0 20px; }
details.edit-person > summary { cursor: pointer; color: var(--c-muted); padding: 4px 0; }
