/* ============================================================
   Centorva — Zeiterfassung  |  style.css
   Saubere, konfliktfreie Styles ohne globale .active-Klasse
   ============================================================ */

/* ── Design Tokens ─────────────────────────────────────────── */
:root {
  --petrol:     #1a3a4a;
  --petrol-mid: #1f4a5e;
  --teal:       #4a9aa8;
  --teal-lt:    #7bbfcc;
  --teal-pale:  #eaf5f8;
  --gold:       #c9a020;

  --white:      #ffffff;
  --bg:         #f2f5f8;
  --surface:    #ffffff;
  --surface2:   #f7f9fb;
  --border:     #dde6ec;
  --border2:    #c8d8e2;

  --txt:        #1a3a4a;
  --txt2:       #4a6878;
  --txt3:       #8aa4b0;

  --ok:         #2a9e6e;
  --err:        #c44040;
  --warn:       #b87e10;

  --sidebar-w:  260px;
  --rad:        8px;
  --rad-sm:     5px;
  --sh:         0 1px 4px rgba(0,0,0,.06), 0 4px 16px rgba(26,58,74,.07);
  --sh-lg:      0 4px 24px rgba(26,58,74,.12);

  --f-sans: 'Outfit', system-ui, sans-serif;
  --f-mono: 'JetBrains Mono', monospace;
  --f-serif:'Playfair Display', serif;
}

/* ── Reset ──────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html, body {
  height: 100%;
  font-family: var(--f-sans);
  font-size: 15px;
  line-height: 1.5;
  color: var(--txt);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
}

/* ============================================================
   LOGIN PAGE
   ============================================================ */
#screen-login {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg);
  padding: 24px;
}

.login-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 14px;
  box-shadow: var(--sh-lg);
  width: 100%;
  max-width: 420px;
  overflow: hidden;
}

.login-brand {
  background: var(--white);
  border-bottom: 1px solid var(--border);
  padding: 32px 36px 24px;
  text-align: center;
}
.login-logo {
  height: 48px;
  width: auto;
  object-fit: contain;
  display: block;
  margin: 0 auto 10px;
}
.login-tagline {
  font-size: 11px;
  color: var(--txt3);
  text-transform: uppercase;
  letter-spacing: .12em;
}

.login-form {
  padding: 28px 36px 32px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.login-hint {
  font-size: 12px;
  color: var(--txt3);
  text-align: center;
  margin-top: 4px;
}
.login-hint code {
  font-family: var(--f-mono);
  font-size: 11px;
  background: var(--teal-pale);
  color: var(--teal);
  padding: 1px 6px;
  border-radius: 4px;
}

/* ============================================================
   FORM ELEMENTS  (shared across login + modals)
   ============================================================ */
.field {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.field label {
  font-size: 11px;
  font-weight: 600;
  color: var(--txt2);
  text-transform: uppercase;
  letter-spacing: .08em;
}
.field input,
.field select,
.field textarea {
  width: 100%;
  background: var(--surface2);
  border: 1.5px solid var(--border);
  border-radius: var(--rad-sm);
  color: var(--txt);
  font-family: var(--f-sans);
  font-size: 14px;
  padding: 9px 13px;
  outline: none;
  transition: border-color .15s, box-shadow .15s, background .15s;
}
.field input::placeholder,
.field textarea::placeholder { color: var(--txt3); }
.field input:focus,
.field select:focus,
.field textarea:focus {
  background: var(--white);
  border-color: var(--teal);
  box-shadow: 0 0 0 3px rgba(74,154,168,.14);
}
.field select {
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='6'%3E%3Cpath d='M1 1l4.5 4.5L10 1' stroke='%238aa4b0' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 11px center;
  padding-right: 30px;
}
.field textarea {
  resize: vertical;
  min-height: 80px;
}
.field-hint {
  font-size: 12px;
  color: var(--txt3);
}

/* Field with icon button attached */
.field-with-btn {
  display: flex;
  align-items: stretch;
}
.field-with-btn input,
.field-with-btn textarea {
  border-radius: var(--rad-sm) 0 0 var(--rad-sm);
  flex: 1;
}
.field-btn {
  flex-shrink: 0;
  width: 38px;
  background: var(--surface2);
  border: 1.5px solid var(--border);
  border-left: none;
  border-radius: 0 var(--rad-sm) var(--rad-sm) 0;
  color: var(--txt3);
  font-size: 15px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .15s, color .15s, border-color .15s;
}
.field-btn:hover { background: var(--teal-pale); color: var(--teal); border-color: var(--teal); }
.field-btn.mic.active {
  background: rgba(74,154,168,.15);
  color: var(--teal);
  border-color: var(--teal);
  animation: micPulse 1.1s ease infinite;
}
@keyframes micPulse {
  0%,100% { box-shadow: 0 0 0 0 rgba(74,154,168,.3); }
  50%      { box-shadow: 0 0 0 5px rgba(74,154,168,0); }
}
.field-with-btn--ta { align-items: flex-start; }
.field-btn--ta      { border-radius: 0 var(--rad-sm) var(--rad-sm) 0; align-self: stretch; width: 38px; }
.auto-calc { background: #f0f4f4 !important; color: var(--txt2); }

/* Section labels inside modals */
.section-title {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--teal);
  padding-bottom: 8px;
  border-bottom: 2px solid var(--teal-pale);
  margin-top: 4px;
}

/* Grid helpers */
.row2  { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.row3  { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 14px; }
.grow1 { flex: 1; }
.grow2 { grid-column: span 2; }
.w120  { max-width: 120px; }
.w160  { max-width: 160px; }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 9px 18px;
  border-radius: var(--rad-sm);
  font-family: var(--f-sans);
  font-size: 14px;
  font-weight: 500;
  border: none;
  cursor: pointer;
  white-space: nowrap;
  transition: background .15s, box-shadow .15s, transform .1s;
  text-decoration: none;
}
.btn:active { transform: scale(.97); }

.btn-primary {
  background: var(--petrol);
  color: #fff;
  box-shadow: 0 2px 8px rgba(26,58,74,.2);
}
.btn-primary:hover { background: var(--petrol-mid); box-shadow: 0 4px 14px rgba(26,58,74,.28); }

.btn-outline {
  background: transparent;
  border: 1.5px solid var(--teal);
  color: var(--teal);
}
.btn-outline:hover { background: var(--teal-pale); }

.btn-ghost {
  background: transparent;
  border: 1.5px solid var(--border2);
  color: var(--txt2);
}
.btn-ghost:hover { background: var(--surface2); color: var(--txt); }

.btn-danger {
  background: rgba(196,64,64,.08);
  border: 1px solid rgba(196,64,64,.25);
  color: var(--err);
  padding: 7px 12px;
  font-size: 13px;
}
.btn-danger:hover { background: rgba(196,64,64,.16); }

.btn-sm    { padding: 6px 13px; font-size: 13px; }
.btn-block { width: 100%; }

/* ============================================================
   ADMIN SHELL — Sidebar + Main
   ============================================================ */
#screen-admin {
  display: flex;
  min-height: 100vh;
}

/* ── Sidebar ─────────────────────────────────────────────────── */
.sidebar {
  width: var(--sidebar-w);
  flex-shrink: 0;
  background: var(--white);
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  position: sticky;
  top: 0;
  height: 100vh;
  overflow-y: auto;
}

.sidebar-logo-wrap {
  padding: 16px 20px 14px;
  border-bottom: 1px solid var(--border);
  background: var(--white);
}
.sidebar-logo {
  height: 52px;
  width: auto;
  max-width: 210px;
  object-fit: contain;
  display: block;
}

.sidebar-nav {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 16px 8px 0;
  flex: 1;
}
.sidebar-nav-label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--txt3);
  padding: 0 8px 8px;
  display: block;
}
.nav-btn {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 9px 10px;
  border-radius: var(--rad-sm);
  font-family: var(--f-sans);
  font-size: 14px;
  font-weight: 400;
  color: var(--txt2);
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  transition: background .14s, color .14s;
  position: relative;
  width: 100%;
}
.nav-btn:hover { background: var(--surface2); color: var(--txt); }
.nav-btn.active {
  background: var(--teal-pale);
  color: var(--petrol);
  font-weight: 600;
}
.nav-btn.active::before {
  content: '';
  position: absolute;
  left: 0; top: 20%; bottom: 20%;
  width: 3px;
  border-radius: 0 3px 3px 0;
  background: var(--teal);
}
.nav-ico   { font-size: 14px; width: 18px; text-align: center; flex-shrink: 0; }
.nav-count {
  margin-left: auto;
  font-family: var(--f-mono);
  font-size: 11px;
  background: var(--surface2);
  color: var(--txt3);
  border: 1px solid var(--border);
  padding: 1px 6px;
  border-radius: 20px;
  min-width: 22px;
  text-align: center;
}
.nav-btn.active .nav-count {
  background: rgba(74,154,168,.12);
  color: var(--teal);
  border-color: rgba(74,154,168,.3);
}

.sidebar-user {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 12px;
  border-top: 1px solid var(--border);
  margin-top: auto;
}
.user-avatar {
  width: 32px; height: 32px; border-radius: 50%; flex-shrink: 0;
  background: linear-gradient(135deg, var(--teal), var(--petrol));
  color: #fff; font-weight: 700; font-size: 13px;
  display: flex; align-items: center; justify-content: center;
}
.user-info { flex: 1; min-width: 0; }
.user-name { font-size: 13px; font-weight: 600; color: var(--txt); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.user-role { font-size: 11px; color: var(--txt3); }
.btn-logout {
  background: none; border: none; cursor: pointer;
  color: var(--txt3); font-size: 17px; padding: 5px;
  border-radius: var(--rad-sm);
  transition: color .14s, background .14s;
}
.btn-logout:hover { color: var(--err); background: rgba(196,64,64,.07); }

/* ── Main content area ───────────────────────────────────────── */
.main {
  flex: 1;
  min-width: 0;
  background: var(--bg);
  padding: 32px 36px 48px;
  overflow-y: auto;
}

/* Tab panes — simple block visibility, no flex override */
.tab { display: none; }
.tab.is-active { display: block; }

/* Page header */
.page-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 24px;
  flex-wrap: wrap;
}
.page-title {
  font-family: var(--f-serif);
  font-size: 26px;
  font-weight: 400;
  color: var(--petrol);
  line-height: 1.2;
}
.page-sub { font-size: 13px; color: var(--txt3); margin-top: 3px; }
.page-actions { display: flex; gap: 8px; align-items: center; flex-shrink: 0; }

/* ============================================================
   DASHBOARD
   ============================================================ */

/* KPI row */
.kpi-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 20px;
}

.kpi-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--rad);
  padding: 20px;
  display: flex;
  align-items: center;
  gap: 14px;
  text-align: left;
  font-family: var(--f-sans);
  box-shadow: var(--sh);
  transition: border-color .15s, box-shadow .15s, transform .12s;
}
.kpi-card.kpi-active {
  cursor: pointer;
  border-left: 3px solid var(--teal);
}
.kpi-card.kpi-active:hover {
  border-color: var(--teal);
  box-shadow: 0 4px 20px rgba(74,154,168,.15);
  transform: translateY(-2px);
}
.kpi-card.kpi-muted { border-left: 3px solid var(--border); }

.kpi-icon { font-size: 20px; flex-shrink: 0; }
.kpi-icon.teal { color: var(--teal); }
.kpi-icon.grey { color: var(--txt3); }
.kpi-body  { flex: 1; min-width: 0; }
.kpi-num   { font-family: var(--f-mono); font-size: 28px; color: var(--petrol); line-height: 1; margin-bottom: 4px; }
.kpi-num.muted { font-size: 22px; color: var(--txt3); }
.kpi-label { font-size: 11px; color: var(--txt3); text-transform: uppercase; letter-spacing: .07em; }
.kpi-arrow { color: var(--txt3); font-size: 14px; transition: transform .15s, color .15s; margin-left: auto; }
.kpi-card.kpi-active:hover .kpi-arrow { color: var(--teal); transform: translateX(4px); }

/* Dashboard grid */
.dash-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

/* White cards */
.card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--rad);
  box-shadow: var(--sh);
  overflow: hidden;
}
.card.p0 { /* table sits flush */ }
.card.card-system { grid-column: 1 / -1; }

.card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 18px;
  border-bottom: 1px solid var(--border);
}
.card-title { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .09em; color: var(--petrol); }
.card-link  { background: none; border: none; cursor: pointer; font-size: 13px; color: var(--teal); font-family: var(--f-sans); transition: opacity .14s; }
.card-link:hover { opacity: .7; }

/* Dashboard lists */
.dash-list-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 11px 18px;
  border-bottom: 1px solid var(--border);
  transition: background .12s;
}
.dash-list-item:last-child { border-bottom: none; }
.dash-list-item:hover { background: var(--teal-pale); }

.dash-avatar {
  width: 32px; height: 32px; border-radius: 50%; flex-shrink: 0;
  background: linear-gradient(135deg, var(--teal), var(--petrol));
  color: #fff; font-size: 12px; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
}
.dash-avatar.square {
  border-radius: 7px;
  background: var(--teal-pale);
  color: var(--teal);
  font-size: 15px;
}
.dash-item-body { flex: 1; min-width: 0; }
.dash-item-name { font-size: 14px; font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dash-item-sub  { font-size: 12px; color: var(--txt3); }

.list-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 36px 20px;
  color: var(--txt3);
  font-size: 13px;
  text-align: center;
}
.list-empty span { font-size: 26px; opacity: .3; }

/* System card */
.system-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border-bottom: 1px solid var(--border);
}
.system-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 16px 18px;
  border-right: 1px solid var(--border);
}
.system-item:last-child { border-right: none; }
.dot         { width: 8px; height: 8px; border-radius: 50%; margin-top: 4px; flex-shrink: 0; }
.dot-green   { background: var(--ok);   box-shadow: 0 0 5px rgba(42,158,110,.4); }
.dot-teal    { background: var(--teal); }
.dot-grey    { background: var(--txt3); }
.sys-label   { font-size: 11px; color: var(--txt3); text-transform: uppercase; letter-spacing: .07em; margin-bottom: 2px; }
.sys-val     { font-size: 14px; color: var(--txt); }
.sys-val.mono{ font-family: var(--f-mono); font-size: 13px; color: var(--petrol); }

.checklist {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
  padding: 12px 18px;
  background: var(--surface2);
}
.check-item {
  display: flex; align-items: center; gap: 7px;
  font-size: 13px; color: var(--txt3);
}
.check-item.done { color: var(--txt2); }
.check-ico {
  width: 17px; height: 17px; border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center; font-size: 9px;
}
.check-ico.done    { background: rgba(42,158,110,.12); color: var(--ok);  border: 1px solid rgba(42,158,110,.3); }
.check-ico.pending { background: var(--white); color: var(--txt3); border: 1px solid var(--border2); }

/* ============================================================
   DATA TABLE
   ============================================================ */
.tbl {
  width: 100%;
  border-collapse: collapse;
}
.tbl th {
  background: var(--surface2);
  border-bottom: 2px solid var(--border);
  padding: 11px 16px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--petrol);
  text-align: left;
  white-space: nowrap;
}
.tbl td {
  padding: 12px 16px;
  font-size: 14px;
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
}
.tbl tbody tr:last-child td { border-bottom: none; }
.tbl tbody tr { transition: background .1s; }
.tbl tbody tr:hover { background: var(--teal-pale); }

.tbl-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding: 56px 20px;
  color: var(--txt3);
  font-size: 14px;
  text-align: center;
}
.tbl-empty span { font-size: 36px; opacity: .25; display: block; }

.td-actions { display: flex; gap: 6px; }

/* ============================================================
   BADGES
   ============================================================ */
.badge {
  display: inline-block;
  font-size: 11px; font-weight: 600;
  padding: 2px 8px; border-radius: 20px;
}
.badge-aktiv         { background: rgba(42,158,110,.1);  color: var(--ok);   border: 1px solid rgba(42,158,110,.25); }
.badge-inaktiv       { background: var(--surface2);      color: var(--txt3); border: 1px solid var(--border); }
.badge-admin         { background: rgba(26,58,74,.08);   color: var(--petrol); border: 1px solid rgba(26,58,74,.2); }
.badge-teamlead      { background: rgba(201,160,32,.1);  color: #8a6a00;     border: 1px solid rgba(201,160,32,.3); }
.badge-mitarbeiterin { background: var(--teal-pale);     color: var(--teal); border: 1px solid rgba(74,154,168,.25); }
.badge-match-top  { background: rgba(42,158,110,.12);  color: var(--ok);   border: 1px solid rgba(42,158,110,.3); }
.badge-match-mid  { background: rgba(201,160,32,.12);  color: #8a6a00;     border: 1px solid rgba(201,160,32,.35); }
.badge-match-low  { background: rgba(196,64,64,.1);    color: var(--err);  border: 1px solid rgba(196,64,64,.3); }

/* ============================================================
   DRAG & DROP UPLOAD ZONE (KAN-77 / KAN-81)
   ============================================================ */
.drag-drop-zone {
  border: 2px dashed var(--teal);
  border-radius: 12px;
  padding: 56px 32px;
  text-align: center;
  cursor: pointer;
  transition: background .18s, border-color .18s, border-width .18s, box-shadow .18s;
  background: var(--teal-pale);
  min-height: 400px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  user-select: none;
}
.drag-drop-zone:hover {
  border-color: var(--petrol);
  border-width: 2px;
  background: rgba(74,154,168,.12);
  box-shadow: 0 2px 12px rgba(74,154,168,.15);
}
.drag-drop-zone.dragover {
  border-color: var(--teal);
  border-width: 3px;
  border-style: solid;
  background: rgba(74,154,168,.18);
  box-shadow: 0 4px 20px rgba(74,154,168,.2);
}
.drag-drop-icon { font-size: 56px; line-height: 1; filter: drop-shadow(0 2px 4px rgba(74,154,168,.3)); }
.drag-drop-text { font-size: 17px; font-weight: 600; color: var(--petrol); margin: 0; }
.drag-drop-subtext { font-size: 14px; color: var(--teal); margin: 0; font-weight: 500; }
.drag-drop-hint { font-size: 12px; color: var(--txt3); margin: 0; }
.file-preview {
  margin-top: 14px;
  padding: 14px 18px;
  background: rgba(42,158,110,.08);
  border: 1px solid rgba(42,158,110,.3);
  border-radius: 10px;
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 14px;
  color: var(--txt1);
}
.file-preview-icon { font-size: 26px; flex-shrink: 0; }
.file-preview-name { font-weight: 600; flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--ok); }
.file-preview-size {
  color: var(--txt3);
  flex-shrink: 0;
  font-size: 12px;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 2px 8px;
}

/* ============================================================
   DRAG & DROP MULTI-FILE ZONE + UPLOAD PROGRESS (KAN-78 / KAN-81)
   ============================================================ */
.drag-drop-zone-multi {
  border: 2px dashed var(--teal);
  border-radius: 12px;
  padding: 56px 32px;
  text-align: center;
  cursor: pointer;
  transition: background .18s, border-color .18s, border-width .18s, box-shadow .18s;
  background: var(--teal-pale);
  min-height: 240px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  user-select: none;
}
.drag-drop-zone-multi:hover {
  border-color: var(--petrol);
  background: rgba(74,154,168,.12);
  box-shadow: 0 2px 12px rgba(74,154,168,.15);
}
.drag-drop-zone-multi.dragover {
  border-color: var(--teal);
  border-width: 3px;
  border-style: solid;
  background: rgba(74,154,168,.18);
  box-shadow: 0 4px 20px rgba(74,154,168,.2);
}
.upload-progress {
  width: 100%;
  height: 6px;
  background: var(--border);
  border-radius: 3px;
  overflow: hidden;
}
.upload-progress-bar {
  height: 100%;
  background: var(--petrol);
  border-radius: 3px;
  width: 0%;
  transition: width .25s ease;
}
.cv-list-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 8px;
  margin-bottom: 8px;
  font-size: 13px;
}
.cv-list-item-icon { font-size: 20px; flex-shrink: 0; }
.cv-list-item-name { font-weight: 500; flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--txt1); }
.cv-list-item-meta { color: var(--txt3); flex-shrink: 0; white-space: nowrap; }

/* ============================================================
   CV-UPLOAD / CV-REVIEW FORM CONTROLS (KAN-84)
   ============================================================ */
.form-group {
  margin-bottom: 24px;
}
.form-label {
  display: block;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--txt2);
  margin-bottom: 6px;
}
.form-input,
.form-control {
  width: 100%;
  background: var(--surface2);
  border: 1.5px solid var(--border);
  border-radius: var(--rad-sm);
  padding: 10px 30px 10px 14px;
  font-size: 15px;
  font-family: var(--f-sans);
  color: var(--txt);
  outline: none;
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='6'%3E%3Cpath d='M1 1l4.5 4.5L10 1' stroke='%238aa4b0' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  transition: border-color .15s, box-shadow .15s, background .15s;
}
.form-input:hover,
.form-control:hover {
  border-color: var(--border2);
}
.form-input:focus,
.form-control:focus {
  background: var(--white);
  border-color: var(--teal);
  box-shadow: 0 0 0 3px rgba(74,154,168,.14);
}

/* ============================================================
   MODALS
   ============================================================ */
.modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 200;
  background: rgba(26,58,74,.3);
  backdrop-filter: blur(3px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}

.modal {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 12px;
  width: 100%;
  max-width: 500px;
  max-height: 90vh;
  overflow-y: auto;
  box-shadow: var(--sh-lg);
  display: flex;
  flex-direction: column;
}
.modal-wide { max-width: 740px; }

.modal-hd {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 18px 22px 14px;
  border-bottom: 1px solid var(--border);
  position: sticky; top: 0;
  background: var(--white);
  z-index: 1;
  flex-shrink: 0;
}
.modal-hd h2 { font-family: var(--f-serif); font-size: 19px; font-weight: 400; color: var(--petrol); }
.modal-x {
  background: none; border: none; cursor: pointer;
  color: var(--txt3); font-size: 17px; padding: 4px 8px;
  border-radius: var(--rad-sm); transition: background .14s, color .14s;
  line-height: 1;
}
.modal-x:hover { background: var(--surface2); color: var(--txt); }

.modal-bd {
  padding: 20px 22px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  overflow-y: auto;
  flex: 1;
  min-height: 0;
}

.modal-ft {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  padding: 14px 22px;
  border-top: 1px solid var(--border);
  position: sticky; bottom: 0;
  background: var(--white);
  flex-shrink: 0;
}

/* ============================================================
   EMAIL PREVIEW
   ============================================================ */
.email-preview     { background: var(--surface2); border: 1px solid var(--border); border-radius: var(--rad-sm); overflow: hidden; }
.email-preview-hd  { padding: 8px 14px; font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: .07em; color: var(--txt3); background: var(--surface2); border-bottom: 1px solid var(--border); }
.email-preview-body{ padding: 12px 14px; font-size: 13px; color: var(--txt2); line-height: 1.7; font-family: var(--f-mono); white-space: pre-wrap; margin: 0; }

/* ============================================================
   DETAIL VIEW (in client detail modal)
   ============================================================ */
.detail-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.detail-item { display: flex; flex-direction: column; gap: 3px; }
.detail-label { font-size: 11px; text-transform: uppercase; letter-spacing: .08em; color: var(--txt3); }
.detail-value { font-size: 14px; color: var(--txt); }
.detail-value.mono { font-family: var(--f-mono); }

/* ============================================================
   FEEDBACK
   ============================================================ */
.msg-error {
  background: rgba(196,64,64,.07);
  border: 1px solid rgba(196,64,64,.25);
  border-radius: var(--rad-sm);
  color: var(--err);
  font-size: 13px;
  padding: 10px 14px;
}

.toast {
  position: fixed;
  bottom: 24px; right: 24px;
  z-index: 500;
  padding: 12px 18px;
  border-radius: var(--rad-sm);
  font-size: 14px;
  font-weight: 500;
  color: #fff;
  background: var(--petrol);
  box-shadow: var(--sh-lg);
  max-width: 320px;
  animation: toastIn .22s ease both;
}
.toast.ok  { background: var(--ok); }
.toast.err { background: var(--err); }
@keyframes toastIn { from { opacity:0; transform:translateY(8px); } to { opacity:1; transform:translateY(0); } }

/* ============================================================
   KI-SPRACHEINGABE (Stufe 2)
   ============================================================ */
.btn-ai-voice {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 13px; border-radius: var(--rad-sm);
  font-family: var(--f-sans); font-size: 13px; font-weight: 500;
  background: var(--teal-pale); border: 1.5px solid var(--teal);
  color: var(--petrol); cursor: pointer; transition: all .15s;
}
.btn-ai-voice:hover { background: rgba(74,154,168,.16); box-shadow: 0 2px 8px rgba(74,154,168,.2); }
.btn-ai-voice.active { background: rgba(74,154,168,.2); }

.ai-panel {
  border-bottom: 1px solid var(--border);
  background: var(--teal-pale);
}
.ai-panel-inner {
  padding: 16px 22px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.ai-panel-top { display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap; }
.ai-panel-top strong { font-size: 14px; color: var(--petrol); }
.ai-hint { font-size: 13px; color: var(--txt2); }
.ai-example {
  font-size: 12px; color: var(--txt2);
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--rad-sm); padding: 9px 13px; line-height: 1.6;
}
.ai-example em { color: var(--petrol); font-style: italic; }

.ai-controls { display: flex; align-items: center; gap: 14px; }
.btn-mic {
  width: 50px; height: 50px; border-radius: 50%; flex-shrink: 0;
  background: var(--petrol); border: none; cursor: pointer; font-size: 20px;
  display: flex; align-items: center; justify-content: center;
  color: #fff; box-shadow: 0 3px 12px rgba(26,58,74,.25);
  transition: transform .14s, box-shadow .14s;
}
.btn-mic:hover { transform: scale(1.05); }
.btn-mic.recording {
  background: var(--err);
  animation: micGlow 1.3s ease infinite;
}
@keyframes micGlow {
  0%,100% { box-shadow: 0 3px 12px rgba(196,64,64,.35); }
  50%      { box-shadow: 0 3px 20px rgba(196,64,64,.6), 0 0 0 7px rgba(196,64,64,.08); }
}

.ai-transcript-wrap { flex: 1; }
.ai-transcript-label { font-size: 11px; text-transform: uppercase; letter-spacing: .07em; color: var(--txt3); margin-bottom: 5px; }
.ai-transcript {
  min-height: 44px; background: var(--white); border: 1px solid var(--border2);
  border-radius: var(--rad-sm); padding: 9px 13px;
  font-size: 14px; color: var(--txt3); line-height: 1.5;
}
.ai-transcript.live { color: var(--txt); border-color: var(--teal); }

.ai-status { font-size: 13px; color: var(--txt3); min-height: 18px; display: flex; align-items: center; gap: 7px; }
.ai-status.loading { color: var(--teal); }
.ai-status.ok  { color: var(--ok); }
.ai-status.err { color: var(--err); }
.ai-actions { display: flex; justify-content: flex-end; gap: 8px; }

/* Spinner */
.spinner { display: inline-block; width: 13px; height: 13px; border: 2px solid rgba(74,154,168,.3); border-top-color: var(--teal); border-radius: 50%; animation: spin .7s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

/* ============================================================
   VOICE BAR — Stufe 1 global indicator
   ============================================================ */
.voice-bar {
  position: fixed;
  bottom: 20px; left: 50%; transform: translateX(-50%);
  z-index: 400;
  display: flex; align-items: center; gap: 14px;
  background: var(--petrol); border-radius: 40px;
  padding: 11px 18px;
  box-shadow: var(--sh-lg);
  animation: riseUp .22s ease both;
}
@keyframes riseUp { from { opacity:0; transform:translateX(-50%) translateY(10px); } to { opacity:1; transform:translateX(-50%) translateY(0); } }

.voice-waves { display: flex; align-items: center; gap: 3px; height: 20px; }
.voice-waves span {
  display: block; width: 3px; border-radius: 99px;
  background: var(--teal-lt); animation: wave 1s ease infinite;
}
.voice-waves span:nth-child(1){height:6px;  animation-delay:0s}
.voice-waves span:nth-child(2){height:13px; animation-delay:.1s}
.voice-waves span:nth-child(3){height:20px; animation-delay:.2s}
.voice-waves span:nth-child(4){height:13px; animation-delay:.3s}
.voice-waves span:nth-child(5){height:6px;  animation-delay:.4s}
@keyframes wave { 0%,100%{transform:scaleY(1);opacity:.6} 50%{transform:scaleY(1.5);opacity:1} }

.voice-bar-text { font-size: 14px; color: rgba(255,255,255,.8); white-space: nowrap; }
.voice-bar-stop {
  background: none; border: 1px solid rgba(255,255,255,.25); border-radius: 20px;
  color: rgba(255,255,255,.7); font-size: 12px; padding: 4px 12px;
  cursor: pointer; font-family: var(--f-sans); transition: all .14s;
}
.voice-bar-stop:hover { border-color: rgba(255,255,255,.6); color: #fff; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1080px) {
  .kpi-row { grid-template-columns: 1fr 1fr; }
  .system-row { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 900px) {
  :root { --sidebar-w: 200px; }
  .main { padding: 24px 20px 40px; }
  .dash-grid { grid-template-columns: 1fr; }
  .card.card-system { grid-column: span 1; }
  .detail-grid { grid-template-columns: 1fr; }
  .row2, .row3 { grid-template-columns: 1fr; }
}
@media (max-width: 680px) {
  #screen-admin { flex-direction: column; }
  .sidebar { width: 100%; height: auto; position: static; flex-direction: row; flex-wrap: wrap; }
  .sidebar-nav { flex-direction: row; flex-wrap: wrap; padding: 8px; gap: 4px; }
  .kpi-row { grid-template-columns: 1fr 1fr; }
  .system-row { grid-template-columns: 1fr 1fr; }
}

/* ============================================================
   SETTINGS TAB
   ============================================================ */
.settings-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.settings-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--rad);
  box-shadow: var(--sh);
  overflow: hidden;
}
.settings-card-wide { grid-column: 1 / -1; }

.settings-card-head {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 18px 20px;
  border-bottom: 1px solid var(--border);
  background: var(--surface2);
}
.settings-card-icon  { font-size: 22px; flex-shrink: 0; margin-top: 1px; }
.settings-card-title { font-size: 15px; font-weight: 600; color: var(--petrol); }
.settings-card-sub   { font-size: 13px; color: var(--txt3); margin-top: 2px; }

.settings-card-body {
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.settings-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.settings-msg {
  padding: 10px 14px;
  border-radius: var(--rad-sm);
  font-size: 13px;
}
.settings-msg.ok  { background: rgba(42,158,110,.08); border: 1px solid rgba(42,158,110,.25); color: var(--ok); }
.settings-msg.err { background: rgba(196,64,64,.07);  border: 1px solid rgba(196,64,64,.25);  color: var(--err); }
.settings-msg.info{ background: var(--teal-pale);     border: 1px solid rgba(74,154,168,.3);  color: var(--petrol); }

/* Status dot */
.status-dot {
  width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0;
  margin-left: auto; margin-top: 4px;
  transition: background .3s, box-shadow .3s;
}
.status-dot.dot-green { background: var(--ok);   box-shadow: 0 0 6px rgba(42,158,110,.4); }
.status-dot.dot-teal  { background: var(--teal); box-shadow: 0 0 6px rgba(74,154,168,.4); }
.status-dot.dot-grey  { background: var(--txt3); }
.status-dot.dot-err   { background: var(--err);  }

/* Storage status */
.storage-status-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  border-radius: var(--rad-sm);
  overflow: hidden;
}
.storage-item {
  background: var(--white);
  padding: 14px 16px;
}

/* Sidebar divider */
.sidebar-nav-divider {
  height: 1px;
  background: var(--border);
  margin: 10px 8px 8px;
}

/* Voice info grid */
.voice-info-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.voice-info-item {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: var(--rad-sm);
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.voice-info-label  { font-size: 14px; font-weight: 600; color: var(--petrol); }
.voice-info-status { font-size: 13px; font-weight: 500; }
.voice-info-status.ok  { color: var(--ok); }
.voice-info-status.err { color: var(--err); }
.voice-info-status.warn{ color: var(--warn); }
.voice-info-desc   { font-size: 12px; color: var(--txt3); line-height: 1.5; }

.settings-note {
  background: rgba(74,154,168,.07);
  border: 1px solid rgba(74,154,168,.2);
  border-radius: var(--rad-sm);
  padding: 12px 14px;
  font-size: 13px;
  color: var(--txt2);
  line-height: 1.5;
}

@media (max-width: 900px) {
  .settings-grid { grid-template-columns: 1fr; }
  .settings-card-wide { grid-column: span 1; }
  .storage-status-row { grid-template-columns: 1fr 1fr; }
  .voice-info-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   MITARBEITERIN-BEREICH
   ============================================================ */
#screen-employee {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  background: var(--bg);
}

/* Header */
.emp-header {
  background: var(--white);
  border-bottom: 1px solid var(--border);
  padding: 12px 28px;
  display: flex;
  align-items: center;
  gap: 20px;
  position: sticky; top: 0; z-index: 50;
  box-shadow: var(--sh);
}
.emp-logo { height: 36px; width: auto; object-fit: contain; }
.emp-header-center { flex: 1; text-align: center; }
.emp-clock {
  font-family: var(--f-mono); font-size: 28px; font-weight: 500;
  color: var(--petrol); letter-spacing: .08em; line-height: 1;
}
.emp-date { font-size: 12px; color: var(--txt3); margin-top: 2px; }
.emp-header-right { display: flex; align-items: center; gap: 12px; flex-shrink: 0; }
.emp-user-name { font-size: 14px; font-weight: 600; color: var(--petrol); }

/* Body: two columns */
.emp-body {
  flex: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  padding: 28px;
  max-width: 1200px;
  margin: 0 auto;
  width: 100%;
}

.emp-section { display: flex; flex-direction: column; gap: 16px; }
.emp-section-title {
  font-family: var(--f-serif); font-size: 20px; font-weight: 400;
  color: var(--petrol); padding-bottom: 8px;
  border-bottom: 2px solid var(--teal-pale);
}

/* Timer card */
.emp-timer-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--rad);
  padding: 28px 24px 20px;
  text-align: center;
  box-shadow: var(--sh);
  display: flex; flex-direction: column; align-items: center; gap: 12px;
}
.emp-timer-display {
  font-family: var(--f-mono); font-size: 52px; font-weight: 500;
  color: var(--petrol); letter-spacing: .06em; line-height: 1;
}
.emp-timer-display.running { color: var(--teal); }
.emp-timer-status { font-size: 13px; color: var(--txt3); text-transform: uppercase; letter-spacing: .08em; }
.emp-timer-btns { display: flex; gap: 10px; margin-top: 4px; }

/* Big start/stop button */
.btn-big-start {
  padding: 14px 40px;
  border-radius: 40px;
  font-family: var(--f-sans); font-size: 16px; font-weight: 600;
  border: none; cursor: pointer;
  background: linear-gradient(135deg, var(--teal), var(--petrol-mid));
  color: #fff;
  box-shadow: 0 4px 18px rgba(74,154,168,.35);
  transition: all .18s;
  letter-spacing: .02em;
}
.btn-big-start:hover { transform: translateY(-2px); box-shadow: 0 6px 24px rgba(74,154,168,.45); }
.btn-big-start:active { transform: scale(.97); }
.btn-big-start.running {
  background: linear-gradient(135deg, var(--err), #8a2020);
  box-shadow: 0 4px 18px rgba(196,64,64,.35);
}

/* Timer meta (client/service selection during timer) */
.perf-timer-meta {
  width: 100%; text-align: left;
  border-top: 1px solid var(--border);
  padding-top: 14px;
  margin-top: 4px;
  display: flex; flex-direction: column; gap: 10px;
}

/* Manual entry form */
.emp-manual-toggle { text-align: center; }
.emp-toggle-link {
  background: none; border: none; cursor: pointer;
  font-size: 13px; color: var(--teal); font-family: var(--f-sans);
  text-decoration: underline; text-decoration-style: dotted;
  transition: color .14s;
}
.emp-toggle-link:hover { color: var(--petrol); }

.emp-manual-form {
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--rad); padding: 18px 20px;
  display: flex; flex-direction: column; gap: 12px;
  box-shadow: var(--sh);
}
.emp-form-title { font-size: 14px; font-weight: 600; color: var(--petrol); margin-bottom: 2px; }
.emp-form-row { display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; gap: 10px; }

/* Entries list */
.emp-entries-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 2px;
}
.emp-entries-title { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--txt3); }
.emp-entries-total { font-family: var(--f-mono); font-size: 14px; font-weight: 600; color: var(--petrol); }

.emp-entries-list { display: flex; flex-direction: column; gap: 8px; }
.emp-entry-card {
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--rad-sm); padding: 12px 14px;
  display: flex; align-items: flex-start; gap: 12px;
  box-shadow: var(--sh);
}
.emp-entry-icon {
  width: 32px; height: 32px; border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 14px;
}
.emp-entry-icon.work { background: rgba(74,154,168,.12); color: var(--teal); }
.emp-entry-icon.perf { background: rgba(26,58,74,.1); color: var(--petrol); }
.emp-entry-body { flex: 1; min-width: 0; }
.emp-entry-main { font-size: 14px; font-weight: 500; color: var(--txt); }
.emp-entry-sub  { font-size: 12px; color: var(--txt3); margin-top: 2px; }
.emp-entry-dur  { font-family: var(--f-mono); font-size: 14px; font-weight: 600; color: var(--petrol); flex-shrink: 0; }
.emp-entry-actions { display: flex; gap: 4px; flex-shrink: 0; }
.emp-entry-del {
  background: none; border: none; cursor: pointer;
  color: var(--txt3); font-size: 14px; padding: 2px 6px;
  border-radius: 4px; transition: color .13s, background .13s;
}
.emp-entry-del:hover { color: var(--err); background: rgba(196,64,64,.07); }

/* Multi-client rows */
.multi-client-wrap { display: flex; flex-direction: column; gap: 6px; }
.client-row {
  display: flex; align-items: center; gap: 8px;
}
.client-row select { flex: 1; }
.client-row-del {
  background: none; border: none; cursor: pointer;
  color: var(--txt3); font-size: 16px; padding: 2px 6px;
  flex-shrink: 0; border-radius: 4px;
  transition: color .13s, background .13s;
}
.client-row-del:hover { color: var(--err); background: rgba(196,64,64,.07); }

/* Split modal */
.split-options {
  display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 10px;
  margin-bottom: 14px;
}
.split-opt {
  background: var(--surface2); border: 2px solid var(--border);
  border-radius: var(--rad); padding: 16px 12px;
  text-align: center; cursor: pointer;
  transition: all .16s; font-family: var(--f-sans);
}
.split-opt:hover { border-color: var(--teal); background: var(--teal-pale); }
.split-opt.selected { border-color: var(--teal); background: var(--teal-pale); }
.split-opt-icon { font-size: 22px; margin-bottom: 6px; }
.split-opt-label { font-size: 13px; font-weight: 600; color: var(--petrol); }
.split-opt-sub   { font-size: 11px; color: var(--txt3); margin-top: 3px; }
.split-custom { display: flex; flex-direction: column; gap: 8px; margin-top: 4px; }
.split-custom-row { display: flex; align-items: center; gap: 10px; font-size: 14px; }
.split-custom-row span { flex: 1; color: var(--txt2); }
.split-custom-row input { width: 90px; text-align: right; font-family: var(--f-mono); }

/* Sync indicator */
.sync-indicator {
  font-size: 11px; text-align: center; padding: 4px 12px 2px;
  color: var(--ok); opacity: 0; transition: opacity .4s;
  font-family: var(--f-mono); letter-spacing: .02em;
}

/* Responsive employee */
@media (max-width: 800px) {
  .emp-body { grid-template-columns: 1fr; }
  .emp-form-row { grid-template-columns: 1fr 1fr; }
  .split-options { grid-template-columns: 1fr; }
}
@media (max-width: 500px) {
  .emp-header { padding: 10px 14px; }
  .emp-clock { font-size: 20px; }
  .emp-body { padding: 14px; gap: 16px; }
  .emp-timer-display { font-size: 38px; }
  .emp-form-row { grid-template-columns: 1fr; }
}

/* ── Perf voice input ───────────────────────────────────── */
.perf-voice-bar {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 0 4px;
}
.btn-perf-voice {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 14px; border-radius: var(--rad-sm);
  font-family: var(--f-sans); font-size: 13px; font-weight: 500;
  background: var(--teal-pale); border: 1.5px solid var(--teal);
  color: var(--petrol); cursor: pointer; transition: all .15s;
}
.btn-perf-voice:hover { background: rgba(74,154,168,.2); }
.btn-perf-voice.active { background: rgba(217,96,88,.1); border-color: var(--err); color: var(--err); }
.perf-voice-status { font-size: 12px; color: var(--txt3); }
.perf-voice-transcript-wrap {
  background: var(--teal-pale); border: 1px solid rgba(74,154,168,.3);
  border-radius: var(--rad-sm); padding: 12px 14px; margin-bottom: 4px;
}

/* ── emp-form-title-row ─────────────────────────────────── */
.emp-form-title-row {
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
}

/* ── Leistungsübersicht ─────────────────────────────────── */
.ov-summary {
  display: grid; grid-template-columns: repeat(4,1fr); gap: 12px; margin-bottom: 16px;
}
.ov-sum-card {
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--rad); padding: 16px 18px; box-shadow: var(--sh);
}
.ov-sum-label { font-size: 11px; text-transform: uppercase; letter-spacing:.08em; color: var(--txt3); margin-bottom:4px; }
.ov-sum-value { font-family: var(--f-mono); font-size: 22px; color: var(--petrol); }
.ov-sum-value.diff-pos { color: var(--ok); }
.ov-sum-value.diff-neg { color: var(--err); }
.ov-footer {
  display: flex; gap: 24px; flex-wrap: wrap;
  padding: 12px 16px; background: var(--surface2);
  border-top: 1px solid var(--border);
  font-size: 13px; color: var(--txt2);
}
.ov-footer strong { color: var(--petrol); font-family: var(--f-mono); }

/* Diff badge in table */
.diff-badge {
  display: inline-block; font-family: var(--f-mono); font-size: 12px;
  padding: 2px 7px; border-radius: 4px;
}
.diff-badge.pos { background: rgba(42,158,110,.1); color: var(--ok); }
.diff-badge.neg { background: rgba(196,64,64,.08); color: var(--err); }
.diff-badge.zero{ background: var(--surface2); color: var(--txt3); }

@media (max-width:900px) { .ov-summary { grid-template-columns: 1fr 1fr; } }

/* ── Perf mode tabs ───────────────────────────────────────── */
/* KAN-28/30: jetzt 5 Eingabe-Modi (Timer / Sprache / Manuell / Datei
   / Text) — alle in einer Zeile. Auf engen Bildschirmen werden die
   Text-Labels per .pmb-label ausgeblendet, nur das Icon bleibt; das
   title-Attribut zeigt den Namen im Tooltip. */
.perf-mode-tabs {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 6px;
  margin-bottom: 14px;
}
.perf-mode-btn {
  padding: 9px 6px; border-radius: var(--rad-sm);
  font-family: var(--f-sans); font-size: 13px; font-weight: 500;
  border: 1.5px solid var(--border2); background: var(--white);
  color: var(--txt2); cursor: pointer; text-align: center;
  transition: all .15s;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.pmb-label { display: inline; }
@media (max-width: 720px) {
  .perf-mode-btn { font-size: 13px; padding: 10px 4px; }
  .pmb-label { display: none; }
}
.perf-mode-btn:hover { border-color: var(--teal); color: var(--teal); background: var(--teal-pale); }
.perf-mode-btn.active {
  border-color: var(--teal); background: var(--teal-pale);
  color: var(--petrol); font-weight: 600;
}
.perf-panel { display: block; }

/* ── Voice entry card ─────────────────────────────────────── */
.voice-entry-card {
  display: flex; flex-direction: column; align-items: center;
  gap: 12px; padding: 24px 20px; text-align: center;
}
.voice-entry-icon  { font-size: 32px; }
.voice-entry-title { font-size: 16px; font-weight: 600; color: var(--petrol); }
.voice-entry-hint  { font-size: 13px; color: var(--txt3); max-width: 380px; line-height: 1.5; }
.voice-entry-examples {
  display: flex; flex-direction: column; gap: 6px; width: 100%;
}
.voice-example {
  background: var(--teal-pale); border: 1px solid rgba(74,154,168,.2);
  border-radius: var(--rad-sm); padding: 8px 12px;
  font-size: 12px; font-style: italic; color: var(--txt2); text-align: left;
}
.voice-entry-status {
  font-size: 12px; color: var(--txt3); text-transform: uppercase;
  letter-spacing: .07em;
}
.voice-entry-status.recording { color: var(--err); animation: blink .8s ease infinite; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.4} }

/* Voice preview after AI parse */
.perf-voice-preview {
  background: var(--teal-pale); border: 1px solid rgba(74,154,168,.3);
  border-radius: var(--rad-sm); padding: 14px 16px;
  margin-top: 8px;
}
.perf-voice-preview-title { font-size: 12px; font-weight: 600; color: var(--petrol); text-transform: uppercase; letter-spacing: .07em; margin-bottom: 10px; }
.voice-preview-grid { display: grid; grid-template-columns: auto 1fr; gap: 4px 12px; font-size: 13px; }
.voice-preview-label { color: var(--txt3); font-weight: 500; white-space: nowrap; }
.voice-preview-value { color: var(--petrol); font-weight: 500; }

/* ── KI-Spracheingabe kombiniert ────────────────────────── */
.ki-entry-header {
  display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap;
  padding-bottom: 8px; border-bottom: 1px solid var(--border);
}
.ki-entry-title { font-size: 15px; font-weight: 600; color: var(--petrol); }
.ki-entry-hint  { font-size: 13px; color: var(--txt3); }

.ki-examples {
  display: flex; flex-direction: column; gap: 5px;
}
.ki-example {
  background: var(--teal-pale); border: 1px solid rgba(74,154,168,.2);
  border-radius: var(--rad-sm); padding: 7px 11px;
  font-size: 12px; font-style: italic; color: var(--txt2);
}

.ki-input-row {
  display: flex; gap: 12px; align-items: flex-start;
}
.ki-input-field {
  flex: 1; display: flex; flex-direction: column; gap: 5px;
}
.ki-input-label {
  font-size: 11px; font-weight: 600; color: var(--txt2);
  text-transform: uppercase; letter-spacing: .07em;
}
.ki-input-field textarea {
  width: 100%; background: var(--surface2); border: 1.5px solid var(--border);
  border-radius: var(--rad-sm); color: var(--txt); font-family: var(--f-sans);
  font-size: 14px; padding: 9px 13px; outline: none; resize: vertical; min-height: 80px;
  transition: border-color .15s, background .15s;
}
.ki-input-field textarea:focus {
  background: var(--white); border-color: var(--teal);
  box-shadow: 0 0 0 3px rgba(74,154,168,.14);
}

.ki-mic-col {
  flex-shrink: 0; display: flex; flex-direction: column;
  align-items: center; gap: 6px; padding-top: 18px;
}
.btn-mic-ki {
  width: 52px; height: 52px; border-radius: 50%; border: none; cursor: pointer;
  background: var(--petrol); color: #fff; font-size: 22px;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 3px 12px rgba(26,58,74,.25); transition: all .15s;
}
.btn-mic-ki:hover { background: var(--petrol-mid); transform: scale(1.05); }
.btn-mic-ki.recording {
  background: var(--err);
  animation: micGlow 1.2s ease infinite;
}
.ki-mic-status {
  font-size: 10px; color: var(--txt3); text-align: center;
  text-transform: uppercase; letter-spacing: .06em; max-width: 60px;
}
.ki-mic-status.recording { color: var(--err); }

/* Forgot password link */
.login-forgot {
  background: none; border: none; cursor: pointer;
  font-family: var(--f-sans); font-size: 13px;
  color: var(--teal); text-decoration: underline;
  text-decoration-style: dotted; padding: 0;
  text-align: center; width: 100%;
  transition: color .14s;
}
.login-forgot:hover { color: var(--petrol); }

/* ── Multi-Rollen ─────────────────────────────────────────── */
.role-checkboxes {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  padding: 10px 0 4px;
}
.role-cb {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 14px;
  color: var(--txt1);
  cursor: pointer;
  background: var(--bg2);
  border: 1.5px solid var(--border);
  border-radius: 8px;
  padding: 7px 12px;
  transition: border-color .14s, background .14s;
}
.role-cb:hover { border-color: var(--teal); background: var(--teal-pale); }
.role-cb input[type=checkbox] {
  width: 16px; height: 16px;
  accent-color: var(--teal);
  cursor: pointer;
}
.role-cb:has(input:checked) {
  border-color: var(--teal);
  background: var(--teal-pale);
}

/* ── Rollen-Umschalter (inline, Header) ───────────────────── */
.role-switcher-wrap {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
  align-items: center;
  margin-top: 4px;
}
.role-pill {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: var(--f-sans);
  font-size: 11px;
  font-weight: 500;
  padding: 3px 10px;
  border-radius: 20px;
  border: 1.5px solid var(--border);
  background: var(--bg2);
  color: var(--txt2);
  cursor: pointer;
  transition: all .14s;
  white-space: nowrap;
}
.role-pill:hover {
  border-color: var(--teal);
  color: var(--teal);
  background: var(--teal-pale);
}
.role-pill--active {
  border-color: var(--teal);
  background: var(--teal);
  color: #fff;
  cursor: default;
}
.role-pill--active:hover {
  background: var(--teal);
  color: #fff;
}
.emp-user-info {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
}

/* ── Mehrfach-Buchungs-Vorschau ───────────────────────────── */
.voice-booking-card {
  background: var(--bg2);
  border: 1.5px solid var(--border);
  border-radius: 10px;
  padding: 12px 14px;
  margin-bottom: 10px;
}
.voice-booking-card:last-child { margin-bottom: 0; }
.vbc-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border);
}
.vbc-num {
  font-size: 11px;
  font-weight: 700;
  color: var(--teal);
  text-transform: uppercase;
  letter-spacing: .06em;
}
.vbc-check {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: var(--txt2);
  cursor: pointer;
  user-select: none;
}
.vbc-check input { accent-color: var(--teal); width:15px; height:15px; cursor:pointer; }
/* Grid für Label/Wert-Paare innerhalb einer Buchungskarte */
.voice-booking-card .voice-preview-grid {
  display: grid;
  grid-template-columns: 90px 1fr;
  gap: 5px 12px;
  font-size: 13px;
  align-items: start;
}
.voice-booking-card .voice-preview-label {
  color: var(--txt3);
  font-size: 12px;
  font-weight: 500;
  white-space: nowrap;
  padding-top: 1px;
}
.voice-booking-card .voice-preview-value {
  color: var(--petrol);
  font-weight: 500;
  word-break: break-word;
}

/* ── Rollen-Umschalter im Header (prominent) ──────────────── */
.emp-user-name-row {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.role-switcher-header {
  margin-top: 0 !important;
}
.role-switcher-header .role-pill {
  font-size: 12px;
  padding: 4px 12px;
  border-radius: 20px;
  border-width: 2px;
}
.role-switcher-header .role-pill--active {
  background: var(--teal);
  color: #fff;
  border-color: var(--teal);
  box-shadow: 0 2px 8px rgba(74,154,168,.35);
}
.role-switcher-header .role-pill:not(.role-pill--active) {
  background: rgba(255,255,255,.15);
  border-color: rgba(255,255,255,.4);
  color: rgba(255,255,255,.85);
}
.role-switcher-header .role-pill:not(.role-pill--active):hover {
  background: rgba(255,255,255,.25);
  border-color: #fff;
  color: #fff;
}

/* ── Meine Buchungen ──────────────────────────────────────── */
.emp-bookings-section {
  padding: 20px 24px 32px;
  background: var(--bg1);
  border-top: 1px solid var(--border);
}
.emp-bookings-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 16px;
}
.emp-bookings-filters {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.filter-sel {
  font-family: var(--f-sans);
  font-size: 13px;
  padding: 5px 10px;
  border: 1.5px solid var(--border);
  border-radius: 8px;
  background: var(--bg2);
  color: var(--txt1);
  cursor: pointer;
}
.filter-sel:focus { outline: none; border-color: var(--teal); }
.emp-bookings-total {
  font-size: 13px;
  color: var(--txt3);
  font-weight: 500;
  white-space: nowrap;
}
.my-bookings-empty {
  text-align: center;
  padding: 32px;
  color: var(--txt3);
  font-size: 14px;
}
.my-bookings-day {
  margin-bottom: 16px;
}
.my-bookings-day-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 6px 0;
  border-bottom: 1px solid var(--border);
  margin-bottom: 6px;
}
.my-bookings-day-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--txt3);
  text-transform: uppercase;
  letter-spacing: .05em;
}
.my-bookings-day-total {
  font-size: 12px;
  font-weight: 600;
  color: var(--petrol);
}
.my-booking-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 8px 10px;
  border-radius: 8px;
  transition: background .12s;
}
.my-booking-row:hover { background: var(--teal-pale); }
.my-booking-icon {
  width: 32px; height: 32px;
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; flex-shrink: 0;
}
.my-booking-icon.perf { background: rgba(74,154,168,.12); color: var(--teal); }
.my-booking-icon.work { background: rgba(26,58,74,.1); color: var(--petrol); }
.my-booking-body { flex: 1; min-width: 0; }
.my-booking-title {
  font-size: 14px; font-weight: 500; color: var(--txt1);
  display: flex; align-items: center; gap: 6px; flex-wrap: wrap;
}
.my-booking-meta {
  font-size: 12px; color: var(--txt3); margin-top: 2px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.my-booking-hours {
  display: flex; flex-direction: column; align-items: flex-end;
  gap: 2px; flex-shrink: 0;
}
.my-booking-h {
  font-size: 14px; font-weight: 600; color: var(--petrol);
  font-family: var(--f-mono);
}
.my-booking-actions {
  display: flex; gap: 4px; flex-shrink: 0; opacity: 0;
  transition: opacity .15s;
}
.my-booking-row:hover .my-booking-actions { opacity: 1; }

/* ── Mikrofon-Button sauber ────────────────────────────────── */
.ki-mic-col {
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding-top: 18px;
}
.btn-mic-ki {
  width: 56px; height: 56px;
  border-radius: 50%;
  border: none;
  cursor: pointer;
  background: var(--petrol);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 3px 14px rgba(26,58,74,.28);
  transition: all .15s;
  flex-shrink: 0;
}
.btn-mic-ki svg { display: block; pointer-events: none; }
.btn-mic-ki:hover { background: var(--petrol-mid, #2a5a6e); transform: scale(1.05); }
.btn-mic-ki.recording {
  background: var(--err);
  box-shadow: 0 0 0 0 rgba(220,53,69,.4);
  animation: micPulse 1.2s ease infinite;
}
@keyframes micPulse {
  0%   { box-shadow: 0 0 0 0 rgba(220,53,69,.4); }
  70%  { box-shadow: 0 0 0 10px rgba(220,53,69,0); }
  100% { box-shadow: 0 0 0 0 rgba(220,53,69,0); }
}
.ki-mic-status {
  font-size: 10px;
  color: var(--txt3);
  text-align: center;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.ki-mic-label {
  font-size: 11px;
  font-weight: 700;
  color: var(--petrol);
  text-transform: uppercase;
  letter-spacing: .08em;
  text-align: center;
}
.ki-mic-status.recording { color: var(--err); }

/* ── Tages-Zusammenfassung Arbeitszeit ────────────────────── */
.day-summary-card {
  border: 1.5px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
  margin-bottom: 8px;
}
.day-summary-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 14px;
  background: var(--bg2);
  cursor: pointer;
  user-select: none;
  transition: background .12s;
}
.day-summary-head:hover { background: var(--teal-pale); }
.day-summary-left {
  display: flex;
  align-items: center;
  gap: 8px;
}
.day-summary-icon { font-size: 16px; }
.day-summary-label {
  font-size: 13px;
  font-weight: 600;
  color: var(--petrol);
}
.day-summary-right {
  display: flex;
  align-items: center;
  gap: 10px;
}
.day-summary-total {
  font-size: 15px;
  font-weight: 700;
  color: var(--petrol);
  font-family: var(--f-mono);
}
.day-summary-toggle {
  font-size: 14px;
  color: var(--txt3);
  transition: transform .15s;
}
.day-summary-entries {
  border-top: 1px solid var(--border);
  padding: 4px 0;
}

/* ── Edit-Button für Einträge ─────────────────────────────── */
.emp-entry-edit {
  background: none;
  border: 1px solid var(--border);
  border-radius: 6px;
  width: 26px; height: 26px;
  cursor: pointer;
  font-size: 13px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--txt2);
  transition: all .12s;
}
.emp-entry-edit:hover {
  border-color: var(--teal);
  color: var(--teal);
  background: var(--teal-pale);
}

/* ── Employee Unified Layout ───────────────────────────────── */
#screen-employee {
  display: none;
  flex-direction: row;
  height: 100vh;
  overflow: hidden;
}
.emp-tab {
  padding: 24px;
  overflow-y: auto;
  height: 100%;
  box-sizing: border-box;
}
.main-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 24px;
  border-bottom: 1px solid var(--border);
  background: var(--bg1);
  flex-shrink: 0;
}
.main-header-left { display: flex; align-items: center; gap: 12px; }
.main-header-right { display: flex; align-items: center; gap: 16px; }
.main-title {
  font-family: var(--f-serif);
  font-size: 22px;
  color: var(--petrol);
  margin: 0;
}
#emp-main {
  display: flex;
  flex-direction: column;
  flex: 1;
  overflow: hidden;
}
.emp-clock-wrap { text-align: right; }
.emp-clock { font-family: var(--f-mono); font-size: 18px; font-weight: 700; color: var(--petrol); }
.emp-date { font-size: 12px; color: var(--txt3); }

/* Employee KPI cards same as admin */
.my-data-val {
  font-size: 15px;
  font-weight: 500;
  color: var(--petrol);
  padding: 4px 0;
}

/* ── Buchungen Filter-Bar ──────────────────────────────────── */
.bookings-filter-bar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 20px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--border);
}
.bookings-filter-group {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.filter-pick {
  font-family: var(--f-mono);
  font-size: 13px;
}

/* ── KAN-103: Quick-Filter Leistungen ─────────────────────── */
.leistungen-filter-bar {
  padding: 10px 0 6px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 8px;
}
.quick-filters {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: 8px;
}
.quick-filters .qf-btn {
  font-size: 12px;
  padding: 4px 10px;
}
.quick-filters .qf-btn.active {
  background-color: var(--teal);
  color: #fff;
  border-color: var(--teal);
}
.leistungen-date-range {
  display: flex;
  align-items: center;
  gap: 6px;
}

/* ── Abrechnung ───────────────────────────────────────────── */
.abr-empty {
  padding: 40px; text-align: center; color: var(--txt3); font-size: 14px;
}
.abr-month-label {
  font-size: 13px; color: var(--txt3); margin-bottom: 16px;
}
.abr-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 16px;
}
.abr-card {
  background: var(--bg2);
  border: 1.5px solid var(--border);
  border-radius: 12px;
  padding: 16px;
  transition: box-shadow .15s;
}
.abr-card:hover { box-shadow: 0 4px 16px rgba(26,58,74,.1); }
.abr-card-head {
  display: flex; justify-content: space-between; align-items: flex-start;
  margin-bottom: 6px;
}
.abr-client-name {
  font-size: 15px; font-weight: 600; color: var(--petrol);
}
.abr-card-total {
  font-size: 17px; font-weight: 700; color: var(--teal);
  font-family: var(--f-mono);
}
.abr-card-meta {
  font-size: 12px; color: var(--txt3); margin-bottom: 12px;
}
.abr-card-foot {
  display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 8px;
}
.abr-card-actions {
  display: flex; flex-wrap: wrap; gap: 6px; align-items: center;
}
.abr-entries-count {
  font-size: 12px; color: var(--txt3);
}

/* Rollen-Umschalter in der Sidebar (Icon-Style) */
.role-switcher-sidebar {
  display: flex !important;
  flex-direction: column;
  gap: 3px;
  margin: 0;
}
.role-switcher-sidebar .role-pill {
  font-size: 10px;
  padding: 2px 8px;
  border-color: rgba(255,255,255,.3);
  background: transparent;
  color: rgba(255,255,255,.7);
}
.role-switcher-sidebar .role-pill:hover {
  border-color: rgba(255,255,255,.7);
  background: rgba(255,255,255,.1);
  color: #fff;
}
.role-switcher-sidebar .role-pill--active {
  background: rgba(255,255,255,.2);
  border-color: rgba(255,255,255,.5);
  color: #fff;
}

/* Rolle-Wechsel-Button gleich wie Abmelden */
#emp-role-switch-btn, #admin-role-switch-btn {
  font-size: 15px;
}


/* ── Login Screen zentriert ─────────────────────────────────── */
#screen-login {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 100vh !important;
  background: var(--bg) !important;
}
.login-box {
  width: 100%;
  max-width: 420px;
  margin: auto;
}

/* ── KAN-13: Beschreibung-Zelle in Admin-Overview ─────────────
   Truncated, bei Mouseover zeigt native title ueber dem Cursor
   den vollstaendigen Text. */
.ov-desc-cell {
  max-width: 220px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  cursor: help;
}

/* ── KAN-14: Buchungen-Tabelle fuer Mitarbeiterinnen ─────── */
.my-bookings-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13.5px;
}
.my-bookings-table thead th {
  text-align: left;
  font-weight: 600;
  color: var(--txt2);
  padding: 10px 8px;
  border-bottom: 2px solid var(--border);
  background: var(--bg2, #f7f7f5);
  position: sticky;
  top: 0;
  z-index: 1;
}
.my-bookings-table tbody td {
  padding: 8px;
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
}
.my-bookings-table tbody tr:hover { background: rgba(74,154,168,0.04); }
.mb-desc-cell {
  max-width: 240px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  cursor: help;
}
.mb-cell-mono { font-family: var(--f-mono); white-space: nowrap; }
.mb-actions {
  display: flex;
  gap: 4px;
  white-space: nowrap;
}

/* ── KAN-16: Sofort-Tooltip ohne Browser-Delay ────────────────
   data-tooltip statt title — der Overlay erscheint instant beim
   hover, nicht erst nach 0.5–2 s wie bei native title. */
.has-tooltip { position: relative; cursor: help; }
.has-tooltip::after {
  content: attr(data-tooltip);
  position: absolute;
  bottom: calc(100% + 6px);
  left: 50%;
  transform: translateX(-50%);
  background: rgba(26,58,74,0.95);
  color: #fff;
  font-size: 12.5px;
  font-weight: 400;
  font-family: var(--f-base, system-ui);
  padding: 6px 10px;
  border-radius: 6px;
  white-space: pre-wrap;
  max-width: 360px;
  width: max-content;
  box-shadow: 0 4px 12px rgba(0,0,0,0.18);
  pointer-events: none;
  opacity: 0;
  visibility: hidden;
  z-index: 5000;
  text-align: left;
  line-height: 1.4;
}
.has-tooltip::before {
  content: "";
  position: absolute;
  bottom: 100%;
  left: 50%;
  transform: translateX(-50%);
  border: 5px solid transparent;
  border-top-color: rgba(26,58,74,0.95);
  pointer-events: none;
  opacity: 0;
  visibility: hidden;
  z-index: 5000;
}
.has-tooltip:hover::after,
.has-tooltip:hover::before {
  opacity: 1;
  visibility: visible;
  /* kein transition-delay — sofortige Anzeige */
}
/* Wenn das Tooltip-Element leer (keine Beschreibung), nicht anzeigen */
.has-tooltip[data-tooltip=""]::after,
.has-tooltip[data-tooltip=""]::before { display: none; }

/* ── KAN-20: Sync-Status-Pille ───────────────────────────────
   Zeigt jederzeit, ob Daten frisch sind. Klick = manueller Reload.
   Sitzt unten in der Sidebar, direkt unter dem User-Block. */
.sync-pill {
  margin: 8px 14px 12px;
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid var(--border, #ddd);
  background: rgba(255,255,255,0.06);
  font-family: var(--f-mono, monospace);
  font-size: 12px;
  color: var(--txt2, #555);
  cursor: pointer;
  transition: background 0.15s ease, border-color 0.15s ease;
  text-align: center;
  display: block;
}
.sync-pill:hover { background: rgba(74,154,168,0.10); border-color: var(--teal, #4a9aa8); }
.sync-pill.is-loading {
  background: rgba(74,154,168,0.08);
  border-color: rgba(74,154,168,0.4);
  color: var(--petrol, #1a3a4a);
}
.sync-pill.is-ok {
  background: rgba(42,158,110,0.06);
  border-color: rgba(42,158,110,0.30);
  color: var(--ok, #2a9e6e);
}
.sync-pill.is-err {
  background: rgba(220,53,69,0.10);
  border-color: rgba(220,53,69,0.40);
  color: var(--err, #dc3545);
  animation: sync-pulse 1.5s ease-in-out infinite;
}
@keyframes sync-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.65; }
}

/* ============================================================
   KAN-21: MOBILE / TABLET — Burger-Menü + Off-Canvas-Sidebar
   ============================================================
   - Burger oben links (fixed) öffnet die Sidebar als Off-Canvas
   - Backdrop dunkelt den Hintergrund ab und schließt bei Tap
   - Tabellen scrollen horizontal, Filter-Bar stackt vertikal
   - Inputs >= 16px Schrift, damit iOS Safari nicht heranzoomt
   - Buttons mit min-height 44px für Touch-Trefferflächen
   - Login-Screen bleibt unangetastet
   ============================================================ */

/* Burger-Button — auf Desktop unsichtbar */
.mobile-menu-btn {
  display: none;
  position: fixed;
  top: 12px;
  left: 12px;
  z-index: 200;
  width: 44px;
  height: 44px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--rad-sm);
  font-size: 22px;
  line-height: 1;
  color: var(--petrol);
  box-shadow: 0 2px 8px rgba(0,0,0,0.10);
  cursor: pointer;
  align-items: center;
  justify-content: center;
  transition: background .15s ease;
}
.mobile-menu-btn:hover { background: var(--surface2, #f5f5f3); }
.mobile-menu-btn:active { transform: scale(0.96); }

/* Backdrop für offenes Off-Canvas */
.mobile-backdrop {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.45);
  z-index: 95;
  animation: backdrop-fade 0.2s ease;
}
body.mobile-menu-open .mobile-backdrop { display: block; }
@keyframes backdrop-fade { from { opacity: 0; } to { opacity: 1; } }

/* ── Mobile-Layout (Tablet & kleiner) ──────────────────────── */
@media (max-width: 900px) {
  .mobile-menu-btn { display: flex; }

  /* Sidebar wird Off-Canvas */
  .sidebar {
    position: fixed !important;
    top: 0; left: 0; bottom: 0;
    width: 280px;
    max-width: 85vw;
    height: 100vh !important;
    transform: translateX(-100%);
    transition: transform 0.25s ease;
    z-index: 100;
    box-shadow: 2px 0 12px rgba(0,0,0,0.18);
    flex-direction: column !important;
    flex-wrap: nowrap !important;
  }
  body.mobile-menu-open .sidebar { transform: translateX(0); }

  /* Vorherige 680px-Regel hat die Sidebar horizontal ausgerollt —
     mit Off-Canvas brauchen wir die Layout-Änderungen nicht mehr. */
  #screen-admin, #screen-employee {
    flex-direction: row !important;
  }
  .sidebar-nav {
    flex-direction: column !important;
    flex-wrap: nowrap !important;
    padding: 16px 8px 0 !important;
    gap: 4px !important;
    overflow-y: auto;
  }

  /* Main bekommt oben Platz für den Burger */
  .main, .main-content, #emp-main {
    width: 100%;
    padding-top: 64px;
  }
  .emp-tab {
    padding: 16px 14px;
  }
  .main {
    padding: 64px 16px 32px;
  }

  /* Header der Mitarbeiter-Ansicht enger */
  .main-header {
    padding: 12px 16px 12px 64px;
    flex-wrap: wrap;
    gap: 8px;
  }
  .main-title { font-size: 18px; }

  /* Page-Head des Admins kompakter */
  .page-head {
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
  }
  .page-actions {
    flex-wrap: wrap;
    gap: 6px;
  }
  .page-title { font-size: 22px; }

  /* Tabellen scrollen horizontal */
  .card.p0 { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .tbl { min-width: 600px; }
  .my-bookings-table { min-width: 720px; }

  /* Filter-Bar stackt vertikal */
  .bookings-filter-bar {
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
  }
  .bookings-filter-group {
    flex-direction: column;
    align-items: stretch;
    width: 100%;
  }
  .bookings-filter-group .filter-sel,
  .bookings-filter-group select,
  .bookings-filter-group input[type="date"],
  .bookings-filter-group input[type="month"],
  .bookings-filter-group input[type="week"],
  .bookings-filter-group input[type="number"] {
    width: 100% !important;
  }

  /* Inputs vermeiden iOS-Auto-Zoom */
  input, select, textarea {
    font-size: 16px !important;
  }

  /* Touch-Trefferflächen */
  .btn, .btn-primary, .btn-ghost, .btn-danger {
    min-height: 44px;
    font-size: 14.5px;
  }
  .btn-sm { min-height: 36px; font-size: 13.5px; }
  .nav-btn { padding: 13px 12px; font-size: 15px; }

  /* Stat-Grids einspaltig */
  .kpi-row, .system-row, .ov-summary {
    grid-template-columns: 1fr 1fr !important;
  }
  .stats-row {
    grid-template-columns: 1fr 1fr;
  }
  .dash-grid { grid-template-columns: 1fr !important; }
  .row2, .row3 { grid-template-columns: 1fr !important; }
  .detail-grid { grid-template-columns: 1fr !important; }

  /* Modal nimmt mehr Platz */
  .modal-card {
    width: calc(100% - 24px);
    max-width: 100%;
    margin: 12px;
  }
  .modal-wide { max-width: 100%; }

  /* Voice-Vorschau einspaltig */
  .voice-preview-edit {
    grid-template-columns: 1fr !important;
  }

  /* Settings-Karten einspaltig */
  .settings-grid { grid-template-columns: 1fr !important; }
  .storage-status-row { grid-template-columns: 1fr 1fr !important; }

  /* Sync-Pille kompakter */
  .sync-pill { margin: 6px 12px; padding: 5px 10px; font-size: 11.5px; }
}

/* Smartphone (≤ 480px) — noch enger */
@media (max-width: 480px) {
  .kpi-row, .system-row, .ov-summary, .stats-row {
    grid-template-columns: 1fr !important;
  }
  .page-title { font-size: 19px; }
  .emp-tab, .main { padding-left: 12px; padding-right: 12px; }
  .modal-card { padding: 14px; }
  /* KAN-28: 4 Modi bleiben in einer Zeile, nur das Label faellt weg */
  .perf-mode-tabs { gap: 4px; }
  .emp-timer-display { font-size: 36px; }
  .my-bookings-table { font-size: 12.5px; }
  .my-bookings-table thead th { padding: 8px 6px; }
  .my-bookings-table tbody td { padding: 6px; }
}

/* Wenn Mobile-Menü offen ist, Body-Scroll sperren */
body.mobile-menu-open {
  overflow: hidden;
}

/* ── KAN-23: Datei-Upload-Status ───────────────────────────── */
.upload-status {
  font-size: 13px;
  color: var(--txt2);
  padding: 8px 12px;
  border-radius: var(--rad-sm);
  background: transparent;
  margin-top: 6px;
  min-height: 18px;
}
.upload-status.is-loading {
  background: rgba(74,154,168,0.07);
  border: 1px solid rgba(74,154,168,0.25);
  color: var(--petrol);
}
.upload-status.is-ok {
  background: rgba(42,158,110,0.07);
  border: 1px solid rgba(42,158,110,0.25);
  color: var(--ok);
}
.upload-status.is-err {
  background: rgba(220,53,69,0.07);
  border: 1px solid rgba(220,53,69,0.30);
  color: var(--err);
}
#upload-file {
  width: 100%;
  padding: 8px;
  border: 1px dashed var(--border);
  border-radius: var(--rad-sm);
  background: var(--surface2, #f7f7f5);
  cursor: pointer;
}
#upload-file:hover { border-color: var(--teal); background: rgba(74,154,168,0.04); }

/* ── KAN-24/26/29: Dashboard-Charts ──────────────────────────
   Alle Charts gleich breit, in einer Zeile (Admin: 4, User: 3).
   Das frühere chart-wide-Span-Verhalten ist deaktiviert — der
   Trend-Chart steht jetzt gleichberechtigt neben den anderen.
   Auf Mobile/Tablet (<=900 px, also dort wo der Burger greift)
   werden die Charts komplett ausgeblendet (KAN-29). */
.dash-charts {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 16px;
  margin-top: 16px;
}
/* KAN-25: gleicher vertikaler Abstand wie zwischen den Karten in
   .dash-grid selbst (dort gap:16px). */
.dash-charts + .dash-grid { margin-top: 16px; }
.chart-card {
  padding: 12px 14px 14px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--rad);
  box-shadow: var(--sh);
}
/* chart-wide bleibt als Klasse im HTML stehen — KAN-29: nicht mehr
   spannen, alle Charts liegen jetzt in einer Zeile nebeneinander. */
.chart-card.chart-wide { grid-column: auto; }
.chart-card .card-head {
  margin-bottom: 6px;
  border-bottom: none;
  padding: 0;
}
.chart-card .card-title { font-size: 13.5px; }
.chart-canvas-wrap {
  position: relative;
  height: 220px;
}
.chart-canvas-wrap canvas {
  max-width: 100% !important;
  max-height: 100% !important;
}
@media (max-width: 1200px){
  .chart-canvas-wrap { height: 200px; }
}
@media (max-width: 900px) {
  /* KAN-29: Auf Mobile/Tablet keine grafischen Auswertungen */
  .dash-charts { display: none !important; }
  .dash-charts + .dash-grid { margin-top: 0; }
}

/* ── KAN-32: Browser-Diktat-Button im Text-Panel ─────────── */
#btn-paste-dict.is-recording {
  background: rgba(220,53,69,0.10);
  border-color: rgba(220,53,69,0.5);
  color: var(--err);
  animation: paste-dict-pulse 1.4s ease-in-out infinite;
}
@keyframes paste-dict-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(220,53,69,0.0); }
  50%      { box-shadow: 0 0 0 4px rgba(220,53,69,0.15); }
}

/* ── KAN-33: HR-Section im User-Modal ────────────────────── */
.hr-section {
  margin-top: 12px;
  border: 1px solid var(--border);
  border-radius: var(--rad-sm);
  background: var(--surface2, #f7f7f5);
}
.hr-section > summary {
  cursor: pointer;
  list-style: none;
  padding: 10px 14px;
  font-size: 13.5px;
  font-weight: 600;
  color: var(--petrol);
  user-select: none;
}
.hr-section > summary::-webkit-details-marker { display: none; }
.hr-section > summary::before {
  content: "▸";
  display: inline-block;
  margin-right: 8px;
  transition: transform .15s ease;
  color: var(--txt3);
}
.hr-section[open] > summary::before { transform: rotate(90deg); }
.hr-section > summary:hover { background: rgba(74,154,168,0.04); }
.hr-fields {
  padding: 4px 14px 14px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

/* KAN-33 Phase 10: Banner offene Monatsabschluesse */
.dash-mc-banner {
  display: flex; align-items: center; gap: 14px; padding: 14px 18px;
  background: linear-gradient(135deg, rgba(212,154,58,0.12), rgba(212,154,58,0.05));
  border: 1px solid rgba(212,154,58,0.40);
  border-radius: var(--rad);
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.dash-mc-banner.is-empty { display: none; }
.dash-mc-banner-icon {
  font-size: 24px; line-height: 1;
}
.dash-mc-banner-body {
  flex: 1; min-width: 220px;
}
.dash-mc-banner-title {
  font-weight: 700; color: #8a601a; font-size: 14.5px;
}
.dash-mc-banner-sub {
  font-size: 13px; color: var(--txt2); margin-top: 2px;
}
.dash-mc-banner-actions {
  display: flex; gap: 8px; flex-wrap: wrap;
}

/* KAN-33 Phase 7: Pause-Eintraege optisch absetzen */
.emp-entry-card.is-pause { background: rgba(74,154,168,0.05); }
.emp-entry-card.is-pause .emp-entry-icon { background: rgba(212,154,58,0.18); color: #b07e1a; }

/* KAN-33: AzG-Pause-Warnung unter dem Work-Timer */
.azg-warn {
  margin-top: 10px;
  padding: 8px 12px;
  border-radius: var(--rad-sm);
  background: rgba(212,154,58,0.10);
  border: 1px solid rgba(212,154,58,0.35);
  color: #b07e1a;
  font-size: 13px;
  line-height: 1.45;
}

/* KAN-33: Urlaubs-Saldo-Karten */
.vac-balance-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 14px;
  margin-bottom: 16px;
}
.vac-balance-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--rad);
  padding: 14px 16px;
  box-shadow: var(--sh);
}
.vac-balance-card .vbc-num {
  font-size: 26px;
  font-weight: 700;
  color: var(--petrol);
  line-height: 1.1;
}
.vac-balance-card.is-remaining .vbc-num { color: var(--ok); }
.vac-balance-card.is-pending   .vbc-num { color: #b07e1a; }
.vac-balance-card .vbc-label {
  font-size: 12.5px;
  color: var(--txt3);
  margin-top: 4px;
  text-transform: uppercase;
  letter-spacing: .04em;
}

/* Status-Pillen für Urlaubsanträge */
.vac-status {
  display: inline-block;
  padding: 2px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
  white-space: nowrap;
}
.vac-status.s-pending  { background: rgba(212,154,58,0.12); color: #b07e1a; border: 1px solid rgba(212,154,58,0.3); }
.vac-status.s-approved { background: rgba(42,158,110,0.10); color: var(--ok);  border: 1px solid rgba(42,158,110,0.3); }
.vac-status.s-rejected { background: rgba(196,64,64,0.08);  color: var(--err); border: 1px solid rgba(196,64,64,0.3); }
.vac-status.s-cancelled{ background: rgba(150,150,150,0.10);color: var(--txt3);border: 1px solid var(--border); }
.vac-type {
  font-size: 12px; padding: 2px 8px; border-radius: 4px; font-weight: 500;
  background: var(--surface2,#f7f7f5); color: var(--txt2);
}
.vac-type.t-krank { background: rgba(196,64,64,0.08); color: var(--err); }
.vac-type.t-sonstiges { background: rgba(74,154,168,0.08); color: var(--petrol); }

/* ── KAN-33 Phase 3: Monatsabschluss ─────────────────────── */
.mc-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--rad);
  box-shadow: var(--sh);
  padding: 16px 18px;
}
.mc-card-head {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; flex-wrap: wrap;
}
.mc-card-title {
  font-size: 15px; font-weight: 600; color: var(--petrol);
}
.mc-list { margin-top: 12px; display: flex; flex-direction: column; gap: 8px; }
.mc-row {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; padding: 10px 12px;
  border: 1px solid var(--border); border-radius: var(--rad-sm);
  background: var(--surface2, #f7f7f5);
  flex-wrap: wrap;
}
.mc-row.is-confirmed { background: rgba(42,158,110,0.06); border-color: rgba(42,158,110,0.25); }
.mc-row.is-current   { background: rgba(74,154,168,0.05); border-color: rgba(74,154,168,0.20); }
.mc-row-month {
  font-weight: 600; color: var(--petrol); font-size: 14px; min-width: 140px;
}
.mc-row-meta {
  font-size: 12.5px; color: var(--txt3); flex: 1;
}
.mc-row-state {
  font-size: 12.5px; font-weight: 600; padding: 3px 10px; border-radius: 999px;
}
.mc-row-state.s-open      { background: rgba(212,154,58,0.12); color: #b07e1a; border: 1px solid rgba(212,154,58,0.3); }
.mc-row-state.s-confirmed { background: rgba(42,158,110,0.10); color: var(--ok); border: 1px solid rgba(42,158,110,0.3); }
.mc-row-state.s-current   { background: rgba(74,154,168,0.10); color: var(--petrol); border: 1px solid rgba(74,154,168,0.3); }

/* KAN-141: Monatsabschluss-Bestätigungsbox */
.mc-confirm-box {
  margin-top: 16px; padding: 14px 16px;
  background: rgba(74,154,168,0.06); border: 1px solid rgba(74,154,168,0.2);
  border-radius: 8px;
}

/* Admin Mc-Tabelle */
#mc-admin-table th, #mc-admin-table td {
  text-align: center; padding: 8px 10px; min-width: 80px;
}
#mc-admin-table th:first-child, #mc-admin-table td:first-child {
  text-align: left; min-width: 180px; position: sticky; left: 0; background: var(--white); z-index: 1;
}
.mc-cell { display:inline-block; padding:3px 8px; border-radius:6px; font-size:12px; font-weight:600; cursor:default; }
.mc-cell.is-confirmed { background: rgba(42,158,110,0.10); color: var(--ok); border: 1px solid rgba(42,158,110,0.3); cursor: pointer; }
.mc-cell.is-confirmed:hover { background: rgba(42,158,110,0.18); }
.mc-cell.is-open      { background: rgba(212,154,58,0.10); color: #b07e1a; border: 1px solid rgba(212,154,58,0.25); }

/* ── KAN-83: CV-Review Filter ─────── */
.filter-section {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 20px;
}
.filter-section .form-control { max-width: 260px; }
.filter-tabs { display: flex; gap: 4px; }
.filter-tab {
  padding: 6px 14px;
  font-size: 13.5px;
  font-weight: 500;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--bg2, #f7f7f5);
  color: var(--txt2);
  cursor: pointer;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.filter-tab:hover { background: var(--bg3, #ebebea); color: var(--txt); }
.filter-tab.active { background: var(--acc, #4a9aa8); color: #fff; border-color: var(--acc, #4a9aa8); }

/* ── KAN-99: Abgesagte Kandidaten Sektion ─────── */
.rejected-section {
  margin-top: 24px;
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
}
.rejected-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  background: var(--bg2, #f7f7f5);
  cursor: pointer;
  font-weight: 600;
  font-size: 14px;
  color: var(--txt2);
  user-select: none;
}
.rejected-section-header:hover { background: var(--bg3, #ebebea); }
.rejected-section-arrow { font-size: 12px; }
.rejected-section-list { padding: 12px 16px; }

.mc-cell.is-future    { background: transparent; color: var(--txt3); border: 1px dashed var(--border); }

/* Invoice Edit Modal (KAN-133) */
#invoice-edit-modal .modal {
  max-width: 900px;
}

#invoice-edit-modal h3 {
  margin: 0;
  font-size: 1.5rem;
  font-weight: 600;
}

.inv-edit-body {
  padding: 24px;
  overflow-y: auto;
  flex: 1;
}

#invoice-edit-modal h4 {
  margin: 20px 0 12px 0;
  font-size: 1.1rem;
  font-weight: 600;
  color: #333;
}

#invoice-edit-modal .field {
  margin-bottom: 16px;
}

#invoice-edit-modal .field label {
  display: block;
  font-weight: 600;
  margin-bottom: 6px;
  color: #555;
}

#invoice-edit-modal input[type="date"],
#invoice-edit-modal input[type="number"],
#invoice-edit-modal textarea {
  width: 100%;
  padding: 8px 12px;
  border: 1px solid #ddd;
  border-radius: 4px;
  font-size: 14px;
  font-family: inherit;
}

#invoice-edit-modal input:focus,
#invoice-edit-modal textarea:focus {
  outline: none;
  border-color: #007bff;
  box-shadow: 0 0 0 3px rgba(0,123,255,0.1);
}

.invoice-positions-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 8px;
  margin-bottom: 8px;
  align-items: center;
}

.invoice-positions-grid input {
  padding: 6px 8px;
  border: 1px solid #ddd;
  border-radius: 4px;
  font-size: 14px;
}

.invoice-positions-grid .pos-amount {
  font-weight: 600;
  text-align: right;
  color: #333;
}

.invoice-sums {
  background: #f9f9f9;
  padding: 16px;
  border-radius: 6px;
  margin: 16px 0;
  border: 1px solid #e5e5e5;
}

.invoice-sums > div {
  display: flex;
  justify-content: space-between;
  margin-bottom: 8px;
  font-size: 14px;
}

.invoice-sums > div:last-child {
  margin-bottom: 0;
  padding-top: 8px;
  border-top: 2px solid #ddd;
  font-size: 16px;
  font-weight: 700;
}

.modal-actions {
  display: flex;
  gap: 12px;
  margin-top: 24px;
  justify-content: flex-end;
}

@media (max-width: 767px) {
  #invoice-edit-modal .modal {
    max-width: 95%;
    padding: 16px;
  }

  .invoice-positions-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }
}

@media (max-width: 767px) {
  .btn-edit-invoice {
    display: none !important;
  }
}

/* ── KAN-162: E-Mail-Vorlagen WYSIWYG-Editor ─────────────────── */
.tpl-editor-wrap {
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
}
.tpl-toolbar {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 8px 12px;
  background: var(--surface2);
  border-bottom: 1px solid var(--border);
  flex-wrap: wrap;
}
.tpl-tb-btn {
  padding: 4px 8px;
  border: 1px solid var(--border);
  border-radius: 4px;
  background: var(--white);
  cursor: pointer;
  font-size: 13px;
  color: var(--txt);
  line-height: 1.4;
  transition: background 0.15s;
}
.tpl-tb-btn:hover { background: var(--teal-pale); }
.tpl-tb-sep {
  width: 1px;
  height: 20px;
  background: var(--border2);
  margin: 0 4px;
  flex-shrink: 0;
}
.tpl-tb-label {
  font-size: 12px;
  color: var(--txt3);
  white-space: nowrap;
}
.tpl-tb-var {
  padding: 3px 8px;
  border: 1px solid var(--teal-lt);
  border-radius: 12px;
  background: var(--teal-pale);
  cursor: pointer;
  font-size: 11px;
  color: var(--petrol);
  font-family: monospace;
  transition: background 0.15s;
}
.tpl-tb-var:hover { background: var(--teal-lt); }
.tpl-editor {
  min-height: 320px;
  max-height: 520px;
  padding: 16px;
  outline: none;
  font-size: 14px;
  line-height: 1.6;
  overflow-y: auto;
  background: var(--white);
}
.tpl-editor:focus { box-shadow: inset 0 0 0 2px var(--teal-lt); }
