:root {
  --rot: #e30613; --rot-dunkel: #b30510; --grau: #f4f4f6; --rand: #d9d9de;
  --text: #1c1c22; --gruen: #1a7f37; --warn: #b45309;
}
* { box-sizing: border-box; }
body { margin: 0; font-family: system-ui, "Segoe UI", Arial, sans-serif; color: var(--text); background: var(--grau); }
nav { display: flex; align-items: center; gap: 4px; background: var(--rot); padding: 8px 14px; flex-wrap: wrap; }
nav a { color: #fff; text-decoration: none; padding: 6px 10px; border-radius: 6px; font-size: 15px; }
nav a:hover { background: var(--rot-dunkel); }
nav .brand { font-weight: 700; font-size: 16px; }
nav .spacer { flex: 1; }
nav .userinfo { color: #ffd7da; font-size: 13px; padding: 6px 4px; }
main { max-width: 1180px; margin: 18px auto; padding: 0 14px; }
footer { text-align: center; color: #8a8a92; font-size: 12px; padding: 24px 0; }
h1 { font-size: 22px; margin: 6px 0 14px; }
h2 { font-size: 17px; margin: 4px 0 10px; }
.card { background: #fff; border: 1px solid var(--rand); border-radius: 10px; padding: 16px; margin-bottom: 16px; }
.login-card { max-width: 380px; margin: 8vh auto; text-align: center; }
.login-card .sub { color: #777; margin-top: -8px; }
label { display: block; margin: 10px 0; text-align: left; font-size: 14px; }
label.inline { display: inline-block; margin-right: 12px; }
input, select { padding: 7px 9px; border: 1px solid var(--rand); border-radius: 6px; font-size: 14px; width: auto; max-width: 100%; }
.login-card input { width: 100%; margin-top: 4px; }
button, .button { display: inline-block; padding: 8px 14px; border: 1px solid var(--rand); border-radius: 7px;
  background: #fff; color: var(--text); font-size: 14px; cursor: pointer; text-decoration: none; }
button:hover, .button:hover { background: var(--grau); }
button.primary, .button.primary { background: var(--rot); border-color: var(--rot); color: #fff; }
button.primary:hover, .button.primary:hover { background: var(--rot-dunkel); }
button.klein, .button.klein { padding: 3px 8px; font-size: 12.5px; }
.fehler { color: var(--rot); font-weight: 600; }
.warnung { color: var(--warn); }
.hinweis { background: #fff8e6; border: 1px solid #f0d890; border-radius: 7px; padding: 8px 12px; font-size: 13.5px; }
.leer { color: #999; }
.klein-text { font-size: 12.5px; color: #666; }
table { border-collapse: collapse; width: 100%; background: #fff; font-size: 14px; }
th, td { border: 1px solid var(--rand); padding: 5px 8px; text-align: left; }
th { background: #f0f0f3; font-size: 13px; }
.kpi-reihe { display: flex; gap: 10px; flex-wrap: wrap; margin: 12px 0; }
.kpi { background: #fff; border: 1px solid var(--rand); border-radius: 9px; padding: 8px 14px; min-width: 110px; }
.kpi span { display: block; font-size: 11.5px; color: #777; }
.kpi b { font-size: 17px; }
.kpi.neg b { color: var(--rot); }
.kpi.pos b { color: var(--gruen); }
.neg { color: var(--rot); }
.status { padding: 2px 8px; border-radius: 10px; font-size: 12.5px; font-weight: 600; }
.status-entwurf { background: #eee; }
.status-eingereicht { background: #fff3cd; color: #8a6d00; }
.status-freigegeben { background: #d9f2e2; color: var(--gruen); }
.status-abgeschlossen { background: #e2e6f7; color: #2b3d8f; }
.badge { background: #eef; border-radius: 8px; padding: 2px 8px; font-size: 12px; }
.badge.lock { background: #fde8e8; }
.zettel input.zeit { width: 62px; text-align: center; }
.zettel input.grund { width: 100%; min-width: 120px; }
.zettel select { max-width: 140px; }
.zettel .tag { white-space: nowrap; font-weight: 600; }
.zettel .dauer { text-align: center; font-variant-numeric: tabular-nums; }
tr.we { background: #f2f3f8; }
tr.ft { background: #fdf3f3; }
tr.kat-urlaub td.tag::after { content: " 🌴"; }
tr.kat-krank td.tag::after { content: " 🤒"; }
tr.inaktiv { opacity: .5; }
.warn { color: var(--warn); cursor: help; }
.zettel-kopf { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 8px; }
.aktionen { margin: 16px 0; display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }
form.inline { display: inline; }
.filter { display: flex; gap: 8px; align-items: center; margin-bottom: 12px; flex-wrap: wrap; }
.status-zeile { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.dropzone { border: 2px dashed var(--rand); border-radius: 10px; padding: 34px; text-align: center;
  color: #888; cursor: pointer; margin-bottom: 10px; }
.dropzone.drag { border-color: var(--rot); background: #fff5f5; color: var(--rot); }
.dropzone input { display: none; }
.abgleich { max-width: 560px; margin: 10px 0; }
.abgleich tr.diff td { background: #fdecec; font-weight: 600; }
.scrollbox { overflow-x: auto; }
.jahres { font-size: 12px; }
.jahres td.sym { width: 26px; text-align: center; padding: 3px 2px; }
.jahres td.we { background: #eceef5; }
.jahres td.ft, .jahres td.feiertag { background: #fde8e8; }
.jahres td.urlaub, .jahres td.urlaub_halb { background: #d9f2e2; font-weight: 700; }
.jahres td.krank { background: #fff3cd; font-weight: 700; }
.jahres td.fortbildung, .jahres td.sonderurlaub { background: #e2ecf7; }
.jahres td.alt { color: #999; }
.jahres td.aus { background: #f7f7f9; }
.jahres .monat { font-weight: 700; white-space: nowrap; }
.jahres .summe { text-align: center; font-weight: 600; }
details summary { cursor: pointer; font-weight: 600; }
.muster input.zeit { width: 66px; text-align: center; }
@media (max-width: 720px) {
  .zettel select { max-width: 105px; font-size: 12.5px; }
  .zettel input.zeit { width: 52px; }
  th, td { padding: 4px 5px; font-size: 13px; }
  main { padding: 0 8px; }
}
