/* ============================================================
   Schleuse-App — Komponenten ohne Design-System-Pendant.
   Helles iconference.ch-Theme: Cream-Seite, Navy-Text, Ochre-Akzent.
   Tokens + .ic-* Typo kommen aus colors_and_type.css.
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; }

html, body { height: 100%; }

body {
  margin: 0;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  background: var(--bg-1);
  color: var(--fg-1);
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: var(--leading-normal);
  -webkit-font-smoothing: antialiased;
}

/* Content-Breite 1200px + 32px Padding — identisch zu iconference.ch (website.css). */
.wrap { max-width: 1200px; margin: 0 auto; padding-left: 32px; padding-right: 32px; width: 100%; }

/* ---- Header / Nav ------------------------------------------------
   Navy-Glasleiste wie iconference.ch (Marken-Anker): dunkler Grund,
   Ochre-Wortmarke, helle Nav-Links. Sticky wie auf der Website. */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(27, 51, 70, .86);
  backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(255, 255, 255, .09);
}
/* Feste Leistenhoehe 66px + einzeilig wie .nav-inner der Website.
   Breite kommt aus .wrap (1200px, wie iconference.ch); Leiste full-bleed. */
.site-header__inner {
  height: 66px; display: flex; align-items: center; flex-wrap: nowrap; gap: var(--space-6);
}
.brand { display: inline-flex; align-items: center; gap: var(--space-3); text-decoration: none; flex: none; }
.brand img { display: block; }
/* Nav: Primaer-Links links, rechte Gruppe via margin-left:auto ans Ende. */
.site-nav { display: flex; align-items: center; flex-wrap: nowrap; flex: 1 1 auto; min-width: 0;
  gap: var(--space-5); font-family: var(--font-mono); font-size: var(--text-sm); }
.nav-links { display: flex; align-items: center; gap: var(--space-5); min-width: 0; }
.nav-right { display: flex; align-items: center; gap: var(--space-4); margin-left: auto; flex: none; }
.site-nav a { color: var(--fg-on-dark-2); text-decoration: none; white-space: nowrap; transition: color var(--dur-fast) var(--ease); }
.site-nav a:hover { color: var(--ochre-300); }
/* Logout als Text-Link im Nav (kein Button-Pill), Optik wie .site-nav a. */
.nav-linkbtn { background: none; border: 0; padding: 0; cursor: pointer;
  font: inherit; color: var(--fg-on-dark-2); white-space: nowrap; transition: color var(--dur-fast) var(--ease); }
.nav-linkbtn:hover { color: var(--ochre-300); }
.nav-logout-form { display: contents; }

/* ---- Main / Footer ---------------------------------------------- */
.main { flex: 1 0 auto; padding-top: var(--space-7); padding-bottom: var(--space-9); }
.site-footer { background: var(--navy-800); color: var(--fg-on-dark); margin-top: auto; padding-top: var(--space-6); padding-bottom: var(--space-6); }
.site-footer__inner { display: flex; gap: var(--space-7); align-items: flex-start; justify-content: space-between; flex-wrap: wrap; }
.site-footer__how { max-width: 60ch; }
.site-footer__title { color: var(--fg-on-dark-2); margin: 0 0 var(--space-3); }
.site-footer__steps { margin: 0; padding-left: var(--space-5); display: flex; flex-direction: column; gap: var(--space-2);
  color: var(--fg-on-dark-2); font-family: var(--font-body); font-size: var(--text-sm); line-height: var(--leading-normal); }
.site-footer__steps strong { color: var(--fg-on-dark); font-weight: 600; }
.site-footer__contact { min-width: 200px; }
.site-footer__line { color: var(--fg-on-dark-2); margin: 0 0 var(--space-2); }
.site-footer__brand { color: var(--fg-on-dark); margin: 0 0 var(--space-2); }
.site-footer a { color: var(--fg-on-dark); text-decoration: underline; text-underline-offset: 2px; }
.site-footer a:hover { color: #fff; }
.site-footer__copyright { color: var(--fg-on-dark-2); font-size: var(--text-xs);
  margin: var(--space-5) 0 0; padding-top: var(--space-4); border-top: 1px solid rgba(242,235,220,.12); }

/* ---- Seiten-Eyebrow ----------------------------------------------
   12px Mono-Caps wie das Design-System / iconference.ch (das kleine
   gold-getoente Label ist ein Marken-Merkmal). Nur Margin-Override. */
.main .ic-eyebrow { margin: 0 0 var(--space-3); }

/* ---- Headings (page body uses .ic-* in templates) --------------- */
.main h2 { font-family: var(--font-display); font-size: var(--text-xl); font-weight: 700; color: var(--fg-1); line-height: var(--leading-snug); letter-spacing: var(--tracking-snug); margin: var(--space-6) 0 var(--space-3); }

/* ---- Forms ------------------------------------------------------- */
label { display: block; font-family: var(--font-body); font-weight: 600; color: var(--fg-1); margin: 0 0 var(--space-2); font-size: var(--text-sm); }
textarea, input[type=text], input[type=file] {
  width: 100%; background: var(--white); color: var(--fg-1);
  border: 1px solid var(--border-2); border-radius: var(--radius-sm);
  padding: var(--space-3) var(--space-4); font-family: var(--font-body); font-size: var(--text-base);
  transition: border-color var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease);
}
textarea { min-height: 180px; resize: vertical; font-family: var(--font-mono); font-size: var(--text-sm); line-height: 1.5; }
textarea:focus, input[type=text]:focus { outline: none; border-color: var(--ochre-500); box-shadow: var(--ring); }
input[type=file] { padding: var(--space-2) var(--space-3); background: var(--bg-2); }
/* Lokalisierter Datei-Upload: nativen Button verstecken, eigenes Label rendern */
.filefield { display: flex; align-items: center; gap: var(--space-3); flex-wrap: wrap; }
.filefield input[type=file] { position: absolute; width: 1px; height: 1px; padding: 0;
  overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0; }
.filefield .file-btn { display: inline-block; cursor: pointer; border: 1px solid var(--border-2);
  border-radius: var(--radius-sm); background: var(--bg-2); color: var(--fg-1); font-weight: 600;
  font-size: var(--text-sm); padding: var(--space-2) var(--space-4); white-space: nowrap; }
.filefield .file-btn:hover { border-color: var(--ochre-500); }
.filefield input[type=file]:focus + .file-btn { outline: none; border-color: var(--ochre-500); box-shadow: var(--ring); }
.filefield .file-name { color: var(--fg-3); font-size: var(--text-sm); }
input[type=password], select { width: 100%; background: var(--white); color: var(--fg-1);
  border: 1px solid var(--border-2); border-radius: var(--radius-sm);
  padding: var(--space-3) var(--space-4); font-family: var(--font-body); font-size: var(--text-base);
  transition: border-color var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease); }
input[type=password]:focus, select:focus { outline: none; border-color: var(--ochre-500); box-shadow: var(--ring); }
/* Gestapeltes Formularfeld: Label oben, Eingabe darunter volle Breite (DE/EN-robust) */
label.field { display: block; font-weight: 600; color: var(--fg-1); font-size: var(--text-sm);
  margin: 0 0 var(--space-4); }
label.field > input, label.field > select { display: block; width: 100%; box-sizing: border-box;
  margin-top: var(--space-2); font-weight: 400;
  background: var(--white); color: var(--fg-1); border: 1px solid var(--border-2);
  border-radius: var(--radius-sm); padding: var(--space-3) var(--space-4);
  font-family: var(--font-body); font-size: var(--text-base);
  transition: border-color var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease); }
label.field > input:focus, label.field > select:focus { outline: none; border-color: var(--ochre-500); box-shadow: var(--ring); }
.hint { color: var(--fg-3); font-size: var(--text-sm); margin: var(--space-2) 0 0; }

/* ---- Buttons ----------------------------------------------------- */
.btn {
  display: inline-block; cursor: pointer; border: 0; border-radius: var(--radius-pill);
  background: var(--ochre-500); color: #fff; font-weight: 600;
  font-family: var(--font-display); font-size: var(--text-sm); padding: var(--space-3) var(--space-5);
  box-shadow: var(--shadow-sm);
  text-decoration: none; transition: background var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease), transform var(--dur-fast) var(--ease);
}
.btn:hover { background: var(--ochre-600); box-shadow: var(--shadow-md); transform: translateY(-1px); }
.btn:active { transform: translateY(1px); }
.btn:disabled { opacity: .45; cursor: not-allowed; }
.btn:disabled:hover { background: var(--ochre-500); box-shadow: var(--shadow-sm); transform: none; }
.btn-ghost { background: transparent; color: var(--fg-1); border: 1.5px solid var(--border-2); box-shadow: none; }
.btn-ghost:hover { background: var(--ochre-50); border-color: var(--ochre-500); transform: none; }
.row { display: flex; gap: var(--space-3); flex-wrap: wrap; align-items: center; margin-top: var(--space-5); }

/* ---- Card -------------------------------------------------------- */
.card {
  background: var(--bg-card); border: 1px solid var(--border-1);
  border-radius: var(--radius-lg); padding: var(--space-5) var(--space-5);
  margin: 0 0 var(--space-5); box-shadow: var(--shadow-sm);
}
.card h2 { margin-top: 0; }

/* ---- Error / Gate ------------------------------------------------ */
.error { background: var(--danger-bg); border: 1px solid var(--danger); color: var(--danger); border-radius: var(--radius-sm); padding: var(--space-4) var(--space-4); margin: 0 0 var(--space-5); }
.gate { background: var(--bg-tint); border: 1px dashed var(--ochre-500); border-radius: var(--radius-md); padding: var(--space-5); margin: var(--space-5) 0; }
.gate p { margin: 0 0 var(--space-3); color: var(--fg-1); }
.gate strong { color: var(--fg-1); }

/* ---- Anonymisierter Text + Highlights --------------------------- */
pre.anon {
  white-space: pre-wrap; word-break: break-word; background: var(--bg-2);
  border: 1px solid var(--border-1); border-radius: var(--radius-md); padding: var(--space-4);
  font-family: var(--font-mono); font-size: var(--text-sm); line-height: 1.6; margin: 0; color: var(--fg-1);
}
mark.ph { font-family: var(--font-mono); padding: 1px 6px; border-radius: var(--radius-xs); font-weight: 600; color: var(--navy-900); }
mark.ph-person   { background: #e8c89a; }
mark.ph-org      { background: #bcd4c4; }
mark.ph-location { background: #bcccdf; }
mark.ph-contact  { background: #e6c2d3; }
mark.ph-date     { background: #e6d6a4; }
mark.ph-ahv      { background: #e6c489; }
mark.ph-iban, mark.ph-ch_iban { background: #cdd4a8; }
mark.ph-misc     { background: #d8cbb2; }
mark.ph-unknown  { background: var(--danger-bg); color: var(--danger); border: 1px solid var(--danger); font-weight: 700; }

/* ---- Mapping-Tabelle -------------------------------------------- */
table { width: 100%; border-collapse: collapse; font-size: var(--text-sm); margin-top: var(--space-2); }
th, td { text-align: left; padding: var(--space-2) var(--space-3); border-bottom: 1px solid var(--border-1); vertical-align: top; }
th { color: var(--fg-brand); font-family: var(--font-mono); text-transform: uppercase; letter-spacing: var(--tracking-wide); font-size: var(--text-xs); font-weight: 500; }
td.mono { font-family: var(--font-mono); }

/* ---- Entitaets-Chips -------------------------------------------- */
.counts { display: flex; gap: var(--space-2); flex-wrap: wrap; margin: var(--space-2) 0 0; }
.chip { font-family: var(--font-mono); font-size: var(--text-xs); background: var(--cream-200); border: 1px solid var(--border-1); border-radius: var(--radius-pill); padding: 3px var(--space-3); color: var(--fg-1); }

/* ---- Integritaets-Badge ----------------------------------------- */
.badge { display: inline-block; font-size: var(--text-xs); border-radius: var(--radius-pill); padding: 3px var(--space-3); border: 1px solid transparent; }
.badge--ok { background: var(--success-bg); border-color: var(--success); color: var(--success); }
.badge--warn { background: var(--danger-bg); border-color: var(--danger); color: var(--danger); }

/* ---- Aktions-Zelle in der Vorgang-Liste: kompakte Buttons ---- */
/* wrap statt nowrap: bei schmalem Viewport bricht der zweite Button in die naechste
   Zeile, statt rechts aus der Karte zu laufen. */
.cell-actions { display: flex; flex-wrap: wrap; gap: var(--space-2); align-items: center; }
.cell-actions form { display: inline-flex; margin: 0; }
.btn-sm { padding: 5px 12px; font-size: var(--text-sm); white-space: nowrap; }

/* Tabellen-Container darf bei Bedarf horizontal scrollen, statt zu ueberlaufen
   (Fallback fuer sehr schmale Fenster). Gilt fuer Tabellen in Karten. */
.card { overflow-x: auto; }

/* ---- Review-Dialog (Gate-Deselect) ------------------------------ */
pre.review {
  white-space: pre-wrap; word-break: break-word; background: var(--bg-2);
  border: 1px solid var(--border-1); border-radius: var(--radius-md); padding: var(--space-4);
  font-family: var(--font-mono); font-size: var(--text-sm); line-height: 1.7; margin: 0; color: var(--fg-1);
}
.candidates { list-style: none; margin: 0 0 var(--space-3); padding: 0; display: flex; flex-direction: column; gap: var(--space-2); }
.candidates li { margin: 0; }
label.candidate {
  display: flex; align-items: center; gap: var(--space-3); margin: 0; font-weight: 400;
  padding: var(--space-2) var(--space-3); border: 1px solid var(--border-1);
  border-radius: var(--radius-sm); background: var(--white); cursor: pointer;
}
label.candidate:hover { border-color: var(--ochre-500); }
label.candidate input[type=checkbox] { width: 16px; height: 16px; flex: none; accent-color: var(--ochre-500); cursor: pointer; }
.candidate__text { flex: 1 1 auto; word-break: break-word; color: var(--fg-1); }

/* ---- Gruppiertes Gate ------------------------------------------- */
.cand-group { border: 1px solid var(--border-1); border-radius: var(--radius-sm); padding: 0; margin: 0 0 var(--space-2); background: var(--white); }
.group-head { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-3); }
.group-head input.group-master { width: 16px; height: 16px; flex: none; accent-color: var(--ochre-500); cursor: pointer; }
.group-toggle { flex: 1 1 auto; display: flex; align-items: center; gap: var(--space-2); background: none; border: none; padding: 0; cursor: pointer; font: inherit; color: var(--fg-1); text-align: left; }
.group-caret { display: inline-block; width: 1em; color: var(--fg-2); transition: transform .12s; }
.group-toggle[aria-expanded="true"] .group-caret { transform: rotate(90deg); }
.group-label { font-weight: 600; }
.group-count { color: var(--fg-2); font-size: var(--text-xs); flex: none; }
.group-count.badge--warn { color: var(--danger); font-weight: 600; font-family: var(--font-mono); }
.group-items { padding: 0 var(--space-3) var(--space-3); }
.group-items[hidden] { display: none; }
/* Gruppe mit ungehakten Kandidaten: links ein Warn-Akzent, damit '0 / n' nicht wie
   'erledigt' aussieht (P1-1, Restrisiko sichtbar). */
.cand-group--incomplete { border-left: 3px solid var(--danger); }
.group-locked-hint { padding: 0 var(--space-3) var(--space-3); margin: 0; }

/* Restrisiko-Hinweis auf der Ergebnis-Seite: 'geprueft' heisst nicht 'vollstaendig'. */
.residual-risk {
  background: var(--danger-bg); border: 1px solid var(--danger); border-radius: var(--radius-sm);
  color: var(--fg-1); padding: var(--space-3) var(--space-4); margin: 0 0 var(--space-4);
  font-size: var(--text-sm);
}

/* ---- Zeichen-Zaehler (Eingabe-Limit) ---------------------------- */
.counter { font-family: var(--font-mono); text-align: right; }
.counter.over { color: var(--danger); font-weight: 600; }

/* ---- Verarbeitungs-Overlay (waehrend der lokalen Erkennung) ----- */
#working-overlay { position: fixed; inset: 0; z-index: 50; display: flex; align-items: center; justify-content: center; background: rgba(20, 30, 48, .55); }
#working-overlay[hidden] { display: none; }
.working-box {
  display: flex; align-items: center; gap: var(--space-3);
  background: var(--bg-card); color: var(--fg-1); border: 1px solid var(--border-1);
  border-radius: var(--radius-md); padding: var(--space-5) var(--space-6);
  font-family: var(--font-display); font-weight: 700; box-shadow: var(--shadow-sm);
}
.working-spinner { width: 18px; height: 18px; border: 3px solid var(--ochre-300); border-top-color: var(--ochre-500); border-radius: 50%; animation: ic-spin .8s linear infinite; }
@keyframes ic-spin { to { transform: rotate(360deg); } }

/* ---- Language Switcher -.lang ----------------------------------- */
.lang { display: inline-flex; border: 1.5px solid rgba(255, 255, 255, .22); border-radius: var(--radius-pill); overflow: hidden; }
.lang a { font-family: var(--font-mono); font-size: 12px; font-weight: 600; padding: 4px 10px; color: var(--fg-on-dark-2); text-decoration: none; line-height: 1.4; transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease); }
.lang a:hover { background: rgba(255, 255, 255, .08); color: var(--fg-on-dark); }
.lang a.on { background: var(--ochre-500); color: #fff; }
.lang a.on:hover { background: var(--ochre-500); color: #fff; }

.err-text { color: var(--danger); }
.user-status-link { font-size: var(--text-sm); }
.hint-spacer { margin-bottom: var(--space-3); }
.card-table { width: 100%; }
.inline-form { display: inline; }
.textarea-lg { min-height: 120px; }

/* ---- Select (role dropdown in benutzer.html) --------------------- */
.card select { font: inherit; color: var(--navy-700); background: var(--white); border: 1px solid var(--border-2); border-radius: var(--radius-sm); padding: var(--space-2) var(--space-3); }
.card select:focus { outline: 2px solid var(--ochre-300); outline-offset: 1px; }

/* ---- Test-Umgebung-Banner (TEST_MODE=1) -------------------------- */
.test-banner { background: #7a1f1f; color: #fff; text-align: center; padding: .55rem 1rem; font-weight: 600; font-size: .9rem; letter-spacing: .01em; }
