/* Protokoll-App - BSK Corporate Design
   Farben laut BSK CI:
     Navy   #17283B  Hauptfarbe (Header), dunkle Flaechen
     Rot    #C73133  Akzent / aktive Buttons (Logo-Rot, NICHT Warn-Rot)
     Blau   #324E71  sekundaer, Linien
     Hellgrau #E8E8E8 Flaechen/Rahmen
     Dunkelgrau #878787 Sekundaertext
     Text   #1D1D1B
     Weiss  #FFFFFF
     Warn-Rot #C00000 nur fuer Fehler/Gefahr (getrennt vom Akzent-Rot)
   Schrift: Maven Pro, selbst gehostet (woff2), kein externes Font-CDN. */

/* ---- Maven Pro (Variable Font, selbst gehostet) ---- */
@font-face {
  font-family: "Maven Pro";
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url("/static/fonts/maven-pro-latin.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA,
    U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193,
    U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: "Maven Pro";
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url("/static/fonts/maven-pro-latin-ext.woff2") format("woff2");
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF,
    U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020,
    U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

:root {
  --navy: #17283b;
  --rot: #c73133;
  --rot-dunkel: #a8292b;
  --blau: #324e71;
  --hellgrau: #e8e8e8;
  --dunkelgrau: #878787;
  --text: #1d1d1b;
  --weiss: #ffffff;
  --warn: #c00000;
  --flaeche: #f4f5f6;
  --radius: 8px;
  --radius-karte: 12px;
  --font: "Maven Pro", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  font-family: var(--font);
  color: var(--text);
  background: var(--flaeche);
  -webkit-text-size-adjust: 100%;
}

button { font-family: inherit; cursor: pointer; }

/* ---- Buttons ---- */
.btn-primary {
  background: var(--rot);
  color: var(--weiss);
  border: none;
  border-radius: var(--radius);
  padding: 14px 18px;
  font-size: 16px;
  font-weight: 600;
  width: 100%;
  transition: background 0.15s ease;
}
.btn-primary:hover { background: var(--rot-dunkel); }

.btn-sekundaer {
  background: transparent;
  color: var(--weiss);
  border: 1px solid rgba(255, 255, 255, 0.4);
  border-radius: var(--radius);
  padding: 8px 14px;
  font-size: 14px;
}
.btn-sekundaer:hover { border-color: var(--weiss); background: rgba(255, 255, 255, 0.08); }

.btn-sekundaer-dunkel {
  background: transparent;
  color: var(--text);
  border: 1px solid var(--hellgrau);
  border-radius: var(--radius);
  padding: 10px 16px;
  font-size: 14px;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
}
.btn-sekundaer-dunkel:hover { border-color: var(--blau); color: var(--blau); }

/* ---- Logo ---- */
.logo-chip {
  background: var(--weiss);
  border-radius: 6px;
  padding: 5px 9px;
  display: inline-flex;
  align-items: center;
  line-height: 0;
}
.logo-chip img { height: 26px; display: block; }

/* ---- Login ---- */
.login-body {
  min-height: 100dvh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--navy);
  padding: 24px;
}
.login-card {
  background: var(--weiss);
  border-radius: var(--radius-karte);
  padding: 32px 28px;
  width: 100%;
  max-width: 360px;
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.35);
  text-align: center;
}
.login-logo { margin-bottom: 18px; }
.login-logo img { height: 38px; }
.login-marke { font-size: 26px; font-weight: 700; color: var(--navy); }
.login-unter { margin: 4px 0 24px; color: var(--dunkelgrau); font-size: 14px; }

.login-form { display: flex; flex-direction: column; gap: 14px; text-align: left; }
.login-form label { font-size: 14px; font-weight: 600; color: var(--text); }
.login-form input {
  border: 1px solid var(--hellgrau);
  border-radius: var(--radius);
  padding: 13px 14px;
  font-size: 16px;
  outline: none;
  transition: border-color 0.15s ease;
}
.login-form input:focus { border-color: var(--rot); }
.login-fuss { margin-top: 22px; color: var(--dunkelgrau); font-size: 12px; }

.fehler {
  background: rgba(192, 0, 0, 0.09);
  color: var(--warn);
  border-radius: var(--radius);
  padding: 10px 12px;
  font-size: 14px;
  margin: 0 0 16px;
}
.ok {
  background: rgba(50, 78, 113, 0.1);
  color: var(--blau);
  border-radius: var(--radius);
  padding: 10px 12px;
  font-size: 14px;
  margin: 0 0 14px;
}

/* ---- App-Rahmen ---- */
.app-body { min-height: 100dvh; display: flex; flex-direction: column; }

.app-kopf {
  background: var(--navy);
  color: var(--weiss);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 20px;
  padding-top: max(12px, env(safe-area-inset-top));
}
.kopf-marke { display: flex; align-items: center; gap: 12px; }
.app-marke { font-size: 20px; font-weight: 700; color: var(--weiss); text-decoration: none; }
.kopf-nav { display: flex; align-items: center; gap: 10px; }
.kopf-aktion { margin: 0; }

.app-inhalt { flex: 1; padding: 24px; max-width: 760px; width: 100%; margin: 0 auto; }
.app-fuss { text-align: center; padding: 16px; color: var(--dunkelgrau); font-size: 12px; }

/* ---- Karten + Formulare ---- */
.karte {
  background: var(--weiss);
  border: 1px solid var(--hellgrau);
  border-radius: var(--radius-karte);
  padding: 24px;
  box-shadow: 0 1px 3px rgba(23, 40, 59, 0.06);
  margin-bottom: 20px;
}
.karte h1, .karte h2 { margin-top: 0; color: var(--navy); }

.formular { display: flex; flex-direction: column; gap: 12px; }
.formular label { font-size: 14px; font-weight: 600; color: var(--text); }
.formular input {
  border: 1px solid var(--hellgrau);
  border-radius: var(--radius);
  padding: 13px 14px;
  font-size: 16px;
  outline: none;
  transition: border-color 0.15s ease;
}
.formular input:focus { border-color: var(--rot); }
.formular-aktionen { display: flex; gap: 12px; align-items: center; margin-top: 8px; }
.formular-aktionen .btn-primary { width: auto; flex: 1; }

/* ---- Aufnahme ---- */
.hinweis {
  background: rgba(50, 78, 113, 0.08);
  color: var(--blau);
  border: 1px solid rgba(50, 78, 113, 0.25);
  border-radius: var(--radius);
  padding: 12px 14px;
  font-size: 14px;
  margin-bottom: 16px;
}

.aufnahme-steuerung { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }

.rec-knopf {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: var(--rot);
  color: var(--weiss);
  border: none;
  border-radius: 999px;
  padding: 14px 22px;
  font-size: 16px;
  font-weight: 600;
  transition: background 0.15s ease;
}
.rec-knopf:hover { background: var(--rot-dunkel); }
.rec-knopf:disabled { opacity: 0.6; cursor: default; }
.rec-knopf.aktiv { background: var(--warn); box-shadow: 0 0 0 4px rgba(192, 0, 0, 0.18); }

.rec-punkt { width: 12px; height: 12px; border-radius: 50%; background: var(--weiss); }
.rec-knopf.aktiv .rec-punkt { animation: blink 1s steps(2, start) infinite; }
@keyframes blink { 50% { opacity: 0.2; } }

.rec-zeit { font-variant-numeric: tabular-nums; font-size: 22px; font-weight: 700; color: var(--navy); }
.rec-status { margin: 14px 0 0; font-size: 14px; min-height: 1.2em; }
.rec-status.ok { color: var(--blau); }
.rec-status.fehler { color: var(--warn); }

/* ---- Liste ---- */
.liste-kopf { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.aufnahme-liste { list-style: none; margin: 12px 0 0; padding: 0; }
.liste-leer { color: var(--dunkelgrau); padding: 14px 0; font-size: 14px; }

.liste-eintrag {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 0;
  border-top: 1px solid var(--hellgrau);
}
.liste-eintrag:first-child { border-top: none; }
.eintrag-info { min-width: 0; }
.eintrag-titel { font-weight: 600; color: var(--text); }
.eintrag-meta { font-size: 13px; color: var(--dunkelgrau); margin-top: 2px; }
.eintrag-aktionen { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }

.badge {
  font-size: 12px;
  font-weight: 600;
  padding: 5px 10px;
  border-radius: 999px;
  white-space: nowrap;
}
.badge-neu { background: var(--hellgrau); color: var(--dunkelgrau); }
.badge-arbeit { background: rgba(50, 78, 113, 0.14); color: var(--blau); }
.badge-fertig { background: rgba(23, 40, 59, 0.12); color: var(--navy); }
.badge-fehler { background: rgba(192, 0, 0, 0.1); color: var(--warn); }

/* ---- Loeschen-Knopf ---- */
.btn-loeschen {
  background: transparent;
  color: var(--dunkelgrau);
  border: 1px solid var(--hellgrau);
  border-radius: var(--radius);
  padding: 6px 12px;
  font-size: 13px;
}
.btn-loeschen:hover { border-color: var(--warn); color: var(--warn); }
