/* =====================================================================
   AZIS 6.0 — COMPONENT-CSS  ·  Vanilla, plain CSS, kein Build-Step
   ---------------------------------------------------------------------
   • Nutzt die in pwa/styles.css bereits definierten Tokens (--accent,
     --surface-1, --konto-bg, --radius-md, --font-num …). NICHT neu
     definieren — diese Datei NACH styles.css laden:
         <link rel="stylesheet" href="styles.css">
         <link rel="stylesheet" href="azis-6.0.css">   <-- neu
   • Klassennamen folgen der bestehenden kebab-case-Konvention der PWA
     (today-hero, stats-band, stats-chip …). Wo die PWA die Klasse schon
     hat, wird sie hier nur RE-STYLED — Markup/IDs bleiben gleich, das
     existierende JS läuft unverändert weiter.
   • Jede Sektion ist mit  >> WO  markiert: an welcher Stelle in der App.
   • Mapping prototype-BEM → diese Klassen: siehe MAPPING.md.
   ===================================================================== */

/* ---------------------------------------------------------------------
   0 · KLEINE TOKEN-ERGÄNZUNGEN
   Diese 6 Tokens nutzt der 6.0-Look, sie fehlen in styles.css noch.
   Block einmalig irgendwo nach dem :root[data-theme="dark"] einfügen
   (oder hier lassen — schadet nicht).
   --------------------------------------------------------------------- */
:root {
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1); /* überschwingend, für Tap/Pop */
  --t-med: 260ms;
  --glow-mult: 1;          /* 0 setzen, um alle Akzent-Glows global zu dämpfen */
  --violet: #a78bfa;       /* nur Gleitzeit-Tönung + Easter-Egg-Tag */
  --teal: #2dd4bf;         /* Lehrgang-Tönung */
  --grid-line: rgba(255, 255, 255, 0.04);
}

/* Die 6.0-Preview ist iPhone-first. Auf Desktop bleibt die App daher als
   kompakter Mobile-Viewport zentriert, statt auf 820px auseinanderzulaufen. */
.app {
  width: min(100%, 430px);
  max-width: 430px;
  padding-bottom: calc(96px + env(safe-area-inset-bottom));
}

/* Bottom-Navigation wie in der 6.0-Preview: kein Pill-Strip oben, sondern
   eine feste, glasige Mobile-Tabbar mit Icon + Label. */
.tabs {
  position: fixed;
  left: 50%;
  right: auto;
  bottom: 10px;
  z-index: 80;
  width: min(calc(100% - 24px), 430px);
  transform: translateX(-50%);
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0;
  margin: 0;
  padding: 6px 9px calc(6px + env(safe-area-inset-bottom));
  border: 1px solid var(--border);
  border-radius: 22px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface-1-solid) 94%, transparent), color-mix(in srgb, var(--bg) 96%, transparent));
  box-shadow: 0 -18px 46px -24px rgba(0, 0, 0, 0.9), 0 0 0 1px rgba(255,255,255,0.02);
  -webkit-backdrop-filter: blur(18px) saturate(150%);
  backdrop-filter: blur(18px) saturate(150%);
}

.tabs:has(#adminTabBtn:not(.hidden)) {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.tab {
  min-width: 0;
  min-height: 44px;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  padding: 5px 4px;
  border: 0;
  border-radius: 16px;
  background: transparent;
  box-shadow: none;
  color: var(--muted);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0;
  line-height: 1.1;
  transition:
    color 160ms var(--ease-out),
    background 160ms var(--ease-out),
    transform 120ms var(--ease-out);
}

.tab .icon {
  width: 19px;
  height: 19px;
  stroke-width: 2.3;
}

.tab span {
  display: block;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.tab.active {
  color: var(--accent);
  background: transparent;
  border: 0;
  box-shadow: none;
  animation: none;
}

.tab.active .icon {
  filter: drop-shadow(0 0 6px var(--accent-glow));
}

.tab:active {
  transform: scale(0.96);
}

/* Gemeinsame Saldo-Farbhelfer (mono-Zahlen, plus/minus/null) ----------
   >> WO: überall wo ein h:mm-Saldo steht (Hero, Band, Tagesliste, KW). */
.val-pos  { color: var(--success); }
.val-neg  { color: var(--danger); }
.val-zero { color: var(--text); }

/* Sanfte Entrance — optional, nur Deko. Greift nicht bei reduced-motion.
   >> WO: an Karten/Listen, die beim Screen-Wechsel reinkommen sollen. */
.rise { opacity: 0; transform: translateY(10px); animation: azis-rise 520ms var(--ease-out) forwards; }
@keyframes azis-rise { to { opacity: 1; transform: none; } }
@media (prefers-reduced-motion: reduce) {
  .rise { animation: none; opacity: 1; transform: none; }
}


/* =====================================================================
   1 · HEUTE-HERO     >> WO: <section class="today-hero" id="todayHero">
   ---------------------------------------------------------------------
   Markup + IDs bleiben wie in index.html. Nur Look auf 6.0 gehoben:
   größeres Datum, Status-Pille, Saldo-Trennlinie, Glow-Stempelbutton.
   ===================================================================== */
.today-hero {
  padding: 18px;
  position: relative;
  overflow: hidden;
}
.today-hero-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 14px;
}
.today-hero-day {
  font-size: 12px; font-weight: 700; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--muted);
}
.today-hero-date {
  font-family: var(--font-num); font-variant-numeric: tabular-nums;
  font-size: 27px; font-weight: 700; line-height: 1.05; margin-top: 4px;
  color: var(--text);
}
.today-hero-status {
  display: inline-flex; align-items: center; gap: 6px; margin-top: 9px;
  font-size: 11px; font-weight: 700; letter-spacing: 0.04em;
  padding: 4px 10px; border-radius: 999px;
  background: var(--accent-soft); color: var(--accent);
  border: 1px solid var(--konto-border);
}
.today-hero-status::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%; background: currentColor;
}

/* Progress-Ring (SVG bleibt wie in index.html: .progress-ring) -------- */
.today-hero-progress { position: relative; width: 86px; height: 86px; flex: 0 0 auto; }
.today-hero-progress .progress-ring { width: 100%; height: 100%; transform: rotate(-90deg); }
.today-hero-progress .progress-ring circle { fill: none; stroke-width: 7; stroke-linecap: round; }
.today-hero-progress .progress-ring-bg { stroke: var(--border); }
.today-hero-progress .progress-ring-fill {
  stroke: var(--accent);
  filter: drop-shadow(0 0 calc(var(--glow-mult) * 5px) var(--accent-glow));
  transition: stroke-dashoffset 900ms var(--ease-out);
}
.today-hero-progress-text {
  position: absolute; inset: 0; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 1px;
}
.today-hero-progress-text strong {
  font-family: var(--font-num); font-variant-numeric: tabular-nums;
  font-size: 16px; font-weight: 700; color: var(--text); line-height: 1;
}
.today-hero-progress-text span { font-family: var(--font-num); font-size: 10px; color: var(--muted); }

.today-hero-saldo-row {
  display: flex; align-items: baseline; justify-content: space-between;
  margin-top: 18px; padding-top: 15px; border-top: 1px solid var(--border);
}
.today-hero-saldo-label {
  font-size: 12px; font-weight: 600; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--muted);
}
.today-hero-saldo {
  font-family: var(--font-num); font-variant-numeric: tabular-nums;
  font-size: 34px; font-weight: 600; line-height: 1; letter-spacing: 0.01em;
}

/* Stempel-Button — .punch-btn (PWA-Klasse). data-punch togglet Zustand.
   Live-Timer-Text kommt aus dem JS in .punch-label. -------------------- */
.punch-btn {
  margin-top: 16px; width: 100%;
  display: flex; align-items: center; justify-content: center; gap: 10px;
  padding: 15px; border: none; cursor: pointer; border-radius: var(--radius-lg);
  font-family: var(--font-ui); font-size: 15px; font-weight: 800; letter-spacing: 0.03em;
  color: #04181c;
  background: linear-gradient(180deg, var(--accent) 0%, var(--accent-strong) 100%);
  box-shadow: 0 8px 22px calc(var(--glow-mult) * 1px) var(--accent-glow),
              0 1px 0 rgba(255,255,255,0.25) inset;
  transition: transform var(--t-fast) var(--ease-spring), filter var(--t-fast);
}
.punch-btn:active { transform: scale(0.965); }
.punch-btn .icon { width: 18px; height: 18px; }
/* laufender Dienst: data-punch="running" */
.punch-btn[data-punch="running"] {
  color: var(--text); background: var(--soft-bg);
  border: 1px solid var(--danger);
  box-shadow: 0 0 0 1px rgba(248,113,113,0.2), 0 8px 22px -10px rgba(248,113,113,0.4);
}
.punch-btn[data-punch="running"] .punch-icon {
  width: 9px; height: 9px; border-radius: 50%; background: var(--danger);
  animation: azis-pulse 1.6s var(--ease-out) infinite;
}
@keyframes azis-pulse {
  0%   { box-shadow: 0 0 0 0 rgba(248,113,113,0.55); }
  70%  { box-shadow: 0 0 0 9px rgba(248,113,113,0); }
  100% { box-shadow: 0 0 0 0 rgba(248,113,113,0); }
}
.punch-label { font-variant-numeric: tabular-nums; }
:root[data-theme="terminal"] .punch-btn { color: #04140a; }
:root[data-theme="light"] .punch-btn { color: #fff; }


/* =====================================================================
   2 · MONATS-NAV     >> WO: <div class="month-nav-bar"> (bleibt wie PWA)
   ===================================================================== */
.month-nav-bar {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  margin: 14px 2px 0;
}
.month-nav-bar .btn.soft {
  width: 36px; height: 36px; min-width: 36px; padding: 0;
  display: grid; place-items: center; border-radius: 10px; font-size: 18px; line-height: 1;
}
.month-label {
  font-family: var(--font-num); font-variant-numeric: tabular-nums;
  font-size: 14px; font-weight: 700; letter-spacing: 0.02em;
  min-width: 120px; text-align: center;
}


/* =====================================================================
   3 · STATS-BAND  (Monats-Saldo + Sparkline + Konto-Chips)
   >> WO: <section class="card stats-band">
   ===================================================================== */
.stats-band { padding: 18px 18px 14px; margin-top: 14px; }
.stats-band-hero { display: flex; flex-direction: column; }
.stats-band-label {
  font-size: 11px; font-weight: 700; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--muted);
}
.stats-band-saldo {
  font-family: var(--font-num); font-variant-numeric: tabular-nums;
  font-size: 30px; font-weight: 600; line-height: 1; margin-top: 4px;
}
.stats-band-sub { font-family: var(--font-num); font-size: 11.5px; color: var(--muted); margin-top: 5px; }

/* --- Sparkline (NEU in 6.0) ------------------------------------------
   >> WO: direkt unter .stats-band-hero einfügen.
   Bars rendert das JS in #monthSparkBars (ein <div class="spark-bar">
   je Tag; Klassen: .pos / .neg / .today / .weekend). ------------------ */
.month-spark { margin-top: 16px; }
.month-spark-bars { display: flex; align-items: flex-end; gap: 2px; height: 46px; }
.spark-bar {
  flex: 1 1 0; border-radius: 2px 2px 0 0; min-height: 2px;
  background: var(--border-strong);
  transform-origin: bottom; transform: scaleY(0);
  animation: azis-spark-grow 600ms var(--ease-out) forwards;
}
.spark-bar.pos { background: linear-gradient(180deg, var(--success), color-mix(in srgb, var(--success) 50%, transparent)); }
.spark-bar.neg { background: linear-gradient(180deg, var(--danger), color-mix(in srgb, var(--danger) 50%, transparent)); }
.spark-bar.today { background: var(--accent); box-shadow: 0 0 8px calc(var(--glow-mult) * 1px) var(--accent-glow); }
.spark-bar.weekend { opacity: 0.12; }
@keyframes azis-spark-grow { to { transform: scaleY(1); } }
@media (prefers-reduced-motion: reduce) { .spark-bar { animation: none; transform: none; } }
.month-spark-axis {
  display: flex; justify-content: space-between; margin-top: 6px;
  font-family: var(--font-num); font-size: 9px; color: var(--text-muted); letter-spacing: 0.04em;
}

/* --- Konto-Chips (horizontal scrollend) ------------------------------
   >> WO: <div class="stats-chip-row"> — Buttons .stats-chip.konto-tile
   behalten ihre IDs (#mehrarbeitKontoValue …). Icon + Trend sind neu. -- */
.stats-chip-row {
  display: flex; gap: 10px; margin-top: 16px;
  overflow-x: auto; padding-bottom: 4px;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
}
.stats-chip-row::-webkit-scrollbar { height: 0; }
.stats-chip {
  flex: 0 0 auto; min-width: 104px; scroll-snap-align: start;
  text-align: left; cursor: pointer;
  padding: 12px 14px; border-radius: var(--radius-md);
  background: var(--konto-bg); border: 1px solid var(--konto-border);
  display: flex; flex-direction: column; gap: 6px;
  transition: transform var(--t-fast) var(--ease-out), border-color var(--t-fast);
}
.stats-chip:active { transform: scale(0.96); }
.stats-chip-top { display: flex; align-items: center; gap: 7px; }
.stats-chip-icon { width: 15px; height: 15px; color: var(--accent); flex: 0 0 auto; }
.stats-chip > span { /* Label */
  font-size: 10.5px; font-weight: 700; letter-spacing: 0.04em;
  text-transform: uppercase; color: var(--muted);
}
.stats-chip > strong { /* Wert (#…KontoValue) */
  font-family: var(--font-num); font-variant-numeric: tabular-nums;
  font-size: 21px; font-weight: 700; color: var(--konto-text); line-height: 1;
}
.stats-chip-trend { font-family: var(--font-num); font-size: 10px; font-weight: 700; color: var(--text-muted); }
/* nicht-klickbare Statistik-Chips (Urlaub/ATB/…): dezenter */
.stats-chip-stat { background: var(--summary-bg); border-color: var(--border); cursor: default; }
.stats-chip-stat:active { transform: none; }


/* =====================================================================
   4 · TAGESLISTE  (KW-Gruppen + Tageskarten)
   >> WO: <ul id="daysList" class="days"> — wird vom JS befüllt.
   WICHTIG: Die renderDay()-Funktion muss diese Klassen ausgeben
   (Mapping in MAPPING.md). Tönung über Modifier .tone-plus/minus/…
   ===================================================================== */
.days { display: flex; flex-direction: column; gap: 8px; list-style: none; margin: 0; padding: 0; }

/* KW-Kopfzeile (sticky) */
.kw-group { margin-bottom: 6px; }
.kw-head {
  display: flex; align-items: center; gap: 10px; padding: 14px 6px 8px;
  position: sticky; top: -4px; z-index: 5;
}
.kw-head::before {
  content: ""; position: absolute; inset: -4px -16px 0;
  background: linear-gradient(180deg, var(--bg) 60%, transparent); z-index: -1; opacity: 0.92;
}
.kw-tag {
  font-family: var(--font-num); font-size: 10px; font-weight: 800; letter-spacing: 0.1em;
  color: var(--accent); background: var(--accent-soft); text-transform: uppercase;
  padding: 3px 8px; border-radius: 6px; border: 1px solid var(--konto-border);
}
.kw-range { font-size: 11px; color: var(--text-muted); letter-spacing: 0.02em; }
.kw-sum {
  margin-left: auto; font-family: var(--font-num); font-variant-numeric: tabular-nums;
  font-size: 12px; font-weight: 700;
}

/* Tageskarte */
.day {
  --tone: transparent; --tone-tint: transparent;
  position: relative; display: flex; align-items: center; gap: 14px;
  width: 100%; text-align: left; cursor: pointer;
  padding: 13px 15px 13px 17px; border-radius: var(--radius-md);
  background: linear-gradient(0deg, var(--tone-tint), var(--tone-tint)), var(--surface-1-solid);
  border: 1px solid var(--border); color: var(--text); overflow: hidden;
  transition: transform var(--t-fast) var(--ease-out), border-color var(--t-fast), background var(--t-fast);
}
/* Farbstreifen links — klar sichtbar, damit Kategorie auf einen Blick lesbar */
.day::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 4px; background: var(--tone); }
.day:active { transform: scale(0.985); }
.day.is-weekend { opacity: 0.62; }
.day.is-today { border-color: var(--konto-border); box-shadow: 0 0 0 1px var(--accent-soft), 0 6px 18px -10px var(--accent-glow); }
.day.is-today::before { width: 5px; }
/* Tag-Tönungen — Modifier setzt --tone + --tone-tint (Tönung kräftig genug,
   um Krank/ATB/Urlaub/… sofort zu erkennen; Streifen + Hintergrund + Pille) */
.day.tone-plus     { --tone: var(--success); --tone-tint: color-mix(in srgb, var(--success) 9%, transparent); }
.day.tone-minus    { --tone: var(--danger);  --tone-tint: color-mix(in srgb, var(--danger) 9%, transparent); }
.day.tone-urlaub   { --tone: var(--warning); --tone-tint: color-mix(in srgb, var(--warning) 11%, transparent); }
.day.tone-krank    { --tone: var(--muted);   --tone-tint: color-mix(in srgb, var(--muted) 12%, transparent); }
.day.tone-lehrgang { --tone: var(--teal);    --tone-tint: color-mix(in srgb, var(--teal) 11%, transparent); }
.day.tone-gleitzeit{ --tone: var(--violet);  --tone-tint: color-mix(in srgb, var(--violet) 11%, transparent); }
.day.tone-atb      { --tone: var(--info);    --tone-tint: color-mix(in srgb, var(--info) 11%, transparent); }

.day-num { width: 38px; flex: 0 0 auto; text-align: center; }
.day-dow { font-size: 10px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; color: var(--muted); }
.day-dom { font-family: var(--font-num); font-variant-numeric: tabular-nums; font-size: 20px; font-weight: 700; line-height: 1.1; color: var(--text); }
.day-main { flex: 1 1 auto; min-width: 0; display: flex; flex-direction: column; align-items: flex-start; gap: 4px; }
.day-label { font-size: 14px; font-weight: 700; }
.day-meta { font-family: var(--font-num); font-size: 11px; color: var(--muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 100%; }
.day-right { text-align: right; flex: 0 0 auto; }
.day-saldo { font-family: var(--font-num); font-variant-numeric: tabular-nums; font-size: 17px; font-weight: 700; line-height: 1; }
.day-hours { font-family: var(--font-num); font-size: 10.5px; color: var(--text-muted); margin-top: 3px; }
.day-chev { color: var(--text-muted); width: 16px; height: 16px; flex: 0 0 auto; }

/* Kategorie-Pille — farbige Kennzeichnung direkt auf der Karte.
   >> WO: renderDay() gibt sie bei Sondertagen statt/zusätzlich zum Meta-Text
   aus: <span class="day-badge">Krank</span> (Farbe erbt automatisch --tone).
   Bei normalen Dienst-Tagen weglassen. */
.day-badge {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 10px; font-weight: 800; letter-spacing: 0.04em; text-transform: uppercase;
  padding: 2px 8px; border-radius: 6px;
  color: var(--tone);
  background: color-mix(in srgb, var(--tone) 16%, transparent);
  border: 1px solid color-mix(in srgb, var(--tone) 34%, transparent);
}
/* der Tages-Zahl (DOM) bei Sondertagen einen Hauch Tönung geben */
.day[class*="tone-"]:not(.tone-plus):not(.tone-minus) .day-dom { color: var(--tone); }


/* =====================================================================
   5 · EINSTELLUNGEN
   >> WO: <section id="settingsScreen"> — bestehende Eingabe-IDs
   (#nameInput, #vornameInput, #coreStart …) bleiben erhalten, wandern
   nur in die Unter-Screens. Theme-Auswahl wird Karten statt <select>.
   ===================================================================== */
.settings-section-title {
  font-size: 11px; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--muted); margin: 18px 6px 10px;
}

/* Theme-Familien-Karten (Electric / Classic / + gesperrte Eggs) ------- */
.theme-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 9px; }
.theme-card {
  cursor: pointer; text-align: left; padding: 12px; border-radius: var(--radius-md);
  background: var(--surface-1-solid); border: 1px solid var(--border); color: var(--text);
  display: flex; flex-direction: column; gap: 9px; position: relative;
  transition: border-color var(--t-fast), transform var(--t-fast), box-shadow var(--t-fast);
}
.theme-card:active { transform: scale(0.975); }
.theme-card.active { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent-soft); }
.theme-card.locked { opacity: 0.7; }
.theme-card-swatch {
  height: 38px; border-radius: 9px; position: relative; overflow: hidden;
  border: 1px solid rgba(255,255,255,0.08);
  display: flex; align-items: center; justify-content: flex-end; padding: 0 9px; gap: 5px;
}
.theme-card-swatch i { width: 13px; height: 13px; border-radius: 50%; }
.theme-card-lock { position: absolute; inset: 0; display: grid; place-items: center; background: rgba(4,6,10,0.55); color: #fff; }
.theme-card-lock svg { width: 16px; height: 16px; }
.theme-card-name { display: flex; align-items: center; gap: 7px; font-size: 13px; font-weight: 700; }
.theme-card-tag {
  font-family: var(--font-num); font-size: 8.5px; font-weight: 800; letter-spacing: 0.1em;
  text-transform: uppercase; padding: 2px 6px; border-radius: 5px;
  background: var(--accent-soft); color: var(--accent); border: 1px solid var(--konto-border);
}
.theme-card-tag.egg { background: rgba(167,139,250,0.14); color: var(--violet); border-color: rgba(167,139,250,0.3); }
.theme-card-meta { font-size: 11px; color: var(--muted); }

/* Hell/Dunkel segmented — PWA hat .theme-mode-switch / .theme-seg schon.
   Hier nur 6.0-Feinschliff (Icon-Slot, aktiver Zustand). --------------- */
.theme-mode-switch {
  display: flex; gap: 4px; padding: 4px;
  background: var(--soft-bg); border: 1px solid var(--border); border-radius: 12px;
}
.theme-mode-switch.disabled { opacity: 0.4; pointer-events: none; }
.theme-seg {
  flex: 1 1 0; cursor: pointer; border: none; background: none; color: var(--muted);
  padding: 9px; border-radius: 8px;
  font-family: var(--font-ui); font-size: 13px; font-weight: 700; letter-spacing: 0.02em;
  display: flex; align-items: center; justify-content: center; gap: 7px;
  transition: color var(--t-fast), background var(--t-fast);
}
.theme-seg svg { width: 15px; height: 15px; }
.theme-seg.active { background: var(--surface-1-solid); color: var(--text); box-shadow: 0 2px 8px -3px var(--shadow-strong); }

/* Settings-Zeilen (navigierbar) — .settings-list/.srow existieren in PWA */
.settings-list { display: flex; flex-direction: column; gap: 8px; }
.srow {
  display: flex; align-items: center; gap: 13px; width: 100%; cursor: pointer; text-align: left;
  padding: 15px 16px; border-radius: var(--radius-md);
  background: var(--surface-1-solid); border: 1px solid var(--border); color: var(--text);
  transition: transform var(--t-fast), border-color var(--t-fast);
}
.srow:active { transform: scale(0.985); }
.srow-icon { width: 20px; height: 20px; color: var(--accent); flex: 0 0 auto; }
.srow-label { flex: 1 1 auto; font-size: 14px; font-weight: 600; }
.srow-chev { color: var(--text-muted); font-size: 18px; line-height: 1; }
.srow-badge {
  font-family: var(--font-num); font-size: 9.5px; font-weight: 800; letter-spacing: 0.08em;
  padding: 3px 7px; border-radius: 5px; text-transform: uppercase;
  background: rgba(248,113,113,0.14); color: var(--danger); border: 1px solid rgba(248,113,113,0.3);
}
.srow-danger .srow-icon { color: var(--danger); }

/* --- Unter-Screen (slide-in von rechts) -----------------------------
   >> WO: je ein <div class="subscreen" id="subKopfdaten"> … direkt im
   settingsScreen. Mit .show reinfahren (JS togglet). Zurück = .show entfernen. */
.subscreen {
  position: fixed; inset: 0; z-index: 70;
  background: var(--bg); display: flex; flex-direction: column;
  transform: translateX(100%); transition: transform 340ms var(--ease-out);
  pointer-events: none;
}
.subscreen.show { transform: translateX(0); pointer-events: auto; }
.sub-head {
  flex: 0 0 auto; display: flex; align-items: center; gap: 12px;
  padding: 14px 18px; border-bottom: 1px solid var(--border);
}
.sub-head-back {
  width: 34px; height: 34px; flex: 0 0 auto; border-radius: 10px; cursor: pointer;
  display: grid; place-items: center;
  background: var(--soft-bg); border: 1px solid var(--border); color: var(--text);
}
.sub-head-back svg { width: 17px; height: 17px; transform: rotate(180deg); }
.sub-head-title { font-size: 16px; font-weight: 800; letter-spacing: 0.01em; }
.sub-head-sub { font-size: 10.5px; color: var(--muted); margin-top: 2px; }
.sub-body { flex: 1 1 auto; overflow-y: auto; padding: 16px 18px calc(20px + env(safe-area-inset-bottom)); }
.sub-body::-webkit-scrollbar { width: 0; }
.sfield { margin-bottom: 16px; }
.sfield label { display: block; font-size: 11px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-muted); margin-bottom: 7px; }
.sfield input, .sfield select {
  width: 100%; padding: 13px 12px; border-radius: var(--radius-md);
  background: var(--bg); border: 1px solid var(--border); color: var(--text);
  font-family: var(--font-ui); font-size: 15px;
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
}
.sfield input.mono { font-family: var(--font-num); font-variant-numeric: tabular-nums; }
.sfield input:focus, .sfield select:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }
.sfield-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.sfield-2 .sfield { margin-bottom: 0; }
.sub-note { font-size: 11.5px; color: var(--muted); line-height: 1.5; margin: 6px 2px 18px; }
.sub-save { position: sticky; bottom: 0; padding-top: 4px; }
.sub-save button {
  width: 100%; cursor: pointer; border: none; padding: 15px; border-radius: var(--radius-md);
  color: #04181c; background: linear-gradient(180deg, var(--accent), var(--accent-strong));
  font-family: var(--font-ui); font-size: 15px; font-weight: 800; letter-spacing: 0.02em;
  box-shadow: 0 8px 22px calc(var(--glow-mult) * 1px) var(--accent-glow);
}
:root[data-theme="terminal"] .sub-save button, :root[data-theme="light"] .sub-save button { color: #fff; }


/* =====================================================================
   6 · EXPORT / BACKUP   >> WO: <section id="backupScreen">
   Nutzt .settings-section-title + .settings-list + .srow (s. §5).
   ===================================================================== */
.export-note { font-size: 11.5px; color: var(--muted); line-height: 1.5; margin: 16px 6px; }
.export-note code { font-family: var(--font-num); color: var(--text); }


/* =====================================================================
   7 · ADMIN   >> WO: <section id="adminScreen"> + Admin-Login-Overlay
   Mehr rote Akzente: roter Kachel-Strich, rote Icons, roter Header.
   HINWEIS: Feature-Flags-Kachel entfällt bewusst (Security).
   ===================================================================== */

/* Admin-Login (rot) — Overlay über der App ---------------------------- */
.admin-overlay {
  position: fixed; inset: 0; z-index: 65; background: var(--bg);
  display: flex; flex-direction: column;
  transform: translateX(100%); transition: transform 360ms var(--ease-out);
}
.admin-overlay.show { transform: translateX(0); }
.alogin {
  flex: 1 1 auto; display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 32px 26px; text-align: center;
  background: radial-gradient(120% 60% at 50% 0%, rgba(248,113,113,0.12) 0%, transparent 55%), var(--bg);
}
.alogin-shield {
  width: 64px; height: 64px; border-radius: 18px; display: grid; place-items: center;
  background: rgba(248,113,113,0.10); border: 1px solid rgba(248,113,113,0.35); color: var(--danger);
  margin-bottom: 20px; box-shadow: 0 0 0 6px rgba(248,113,113,0.05), 0 16px 40px -16px rgba(248,113,113,0.4);
}
.alogin-shield svg { width: 30px; height: 30px; }
.alogin-title { font-size: 19px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: #ffd1d1; }
.alogin-sub { margin-top: 8px; font-family: var(--font-num); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(240,167,167,0.6); }
.alogin-form { width: 100%; max-width: 290px; margin-top: 26px; display: flex; flex-direction: column; gap: 12px; }
.alogin-field-label { text-align: left; font-size: 10px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(240,167,167,0.6); }
.alogin-input {
  width: 100%; padding: 14px; border-radius: 12px; text-align: center;
  background: rgba(248,113,113,0.06); border: 1px solid rgba(248,113,113,0.3); color: #ffd9d9;
  font-family: var(--font-num); font-size: 18px; letter-spacing: 0.3em;
}
.alogin-input:focus { outline: none; border-color: var(--danger); box-shadow: 0 0 0 3px rgba(248,113,113,0.18); }
.alogin-submit {
  margin-top: 4px; width: 100%; padding: 14px; border: none; cursor: pointer; border-radius: 12px;
  background: linear-gradient(180deg, #f87171, #dc2626); color: #fff;
  font-family: var(--font-ui); font-size: 14px; font-weight: 800; letter-spacing: 0.1em; text-transform: uppercase;
}
.alogin-cancel { background: none; border: none; color: rgba(240,167,167,0.5); cursor: pointer; font-size: 12px; margin-top: 14px; }
.alogin-hint { margin-top: 18px; font-family: var(--font-num); font-size: 10px; color: rgba(240,167,167,0.4); }

/* Admin-Dashboard-Header (rot getönt) --------------------------------- */
.admin-head {
  flex: 0 0 auto; padding: 14px 18px; display: flex; align-items: center; gap: 12px;
  border-bottom: 1px solid rgba(248,113,113,0.22);
  background: color-mix(in srgb, var(--danger) 8%, var(--bg));
}
.admin-head-back { width: 34px; height: 34px; flex: 0 0 auto; border-radius: 10px; cursor: pointer; display: grid; place-items: center; background: var(--soft-bg); border: 1px solid var(--border); color: var(--text); }
.admin-head-back svg { width: 17px; height: 17px; transform: rotate(180deg); }
.admin-head-title { font-size: 16px; font-weight: 800; display: flex; align-items: center; gap: 8px; }
.admin-head-badge {
  font-family: var(--font-num); font-size: 9px; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase;
  padding: 3px 7px; border-radius: 5px;
  background: rgba(248,113,113,0.16); color: var(--danger); border: 1px solid rgba(248,113,113,0.35);
}
.admin-head-sub { font-size: 10.5px; color: var(--muted); margin-top: 2px; }
.admin-logout {
  flex: 0 0 auto; cursor: pointer; padding: 8px 13px; border-radius: 9px;
  background: rgba(248,113,113,0.12); border: 1px solid rgba(248,113,113,0.4); color: var(--danger);
  font-family: var(--font-ui); font-size: 12px; font-weight: 800;
}
.admin-scroll { flex: 1 1 auto; overflow-y: auto; padding: 14px 16px 30px; display: flex; flex-direction: column; gap: 12px; background: radial-gradient(120% 40% at 50% 0%, rgba(248,113,113,0.06), transparent 60%); }
.admin-scroll::-webkit-scrollbar { width: 0; }

/* Admin-Kachel (roter Strich + rote Icons) ---------------------------- */
.atile { padding: 16px; position: relative; border: 1px solid rgba(248,113,113,0.18); }
.atile::before { content: ""; position: absolute; left: 0; top: 14px; bottom: 14px; width: 3px; border-radius: 0 3px 3px 0; background: linear-gradient(180deg, var(--danger), rgba(248,113,113,0.2)); }
.atile-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 10px; margin-bottom: 14px; }
.atile-title { font-size: 14.5px; font-weight: 800; display: flex; align-items: center; gap: 8px; }
.atile-title svg { width: 16px; height: 16px; color: var(--danger); }
.atile-sub { font-size: 11px; color: var(--muted); margin-top: 3px; line-height: 1.4; }
.atile-pill {
  font-family: var(--font-num); font-size: 9.5px; font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase; white-space: nowrap;
  padding: 3px 8px; border-radius: 999px;
  background: var(--soft-bg); color: var(--muted); border: 1px solid var(--border);
}
.atile-pill.on { background: rgba(52,211,153,0.14); color: var(--success); border-color: rgba(52,211,153,0.32); }
.atile-pill.off { background: rgba(248,113,113,0.12); color: var(--danger); border-color: rgba(248,113,113,0.3); }

.atoggle { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 12px 0; }
.atoggle-text strong { display: block; font-size: 13px; font-weight: 700; }
.atoggle-text small { display: block; font-size: 10.5px; color: var(--muted); margin-top: 2px; line-height: 1.4; }
.switch { flex: 0 0 auto; width: 46px; height: 27px; border-radius: 999px; cursor: pointer; position: relative; background: var(--soft-bg); border: 1px solid var(--border); transition: background var(--t-fast), border-color var(--t-fast); }
.switch::after { content: ""; position: absolute; top: 2px; left: 2px; width: 21px; height: 21px; border-radius: 50%; background: var(--muted); transition: transform var(--t-fast) var(--ease-spring), background var(--t-fast); }
.switch.on { background: var(--accent-soft); border-color: var(--konto-border); }
.switch.on::after { transform: translateX(19px); background: var(--accent); }
.switch.on.danger { background: rgba(248,113,113,0.16); border-color: rgba(248,113,113,0.35); }
.switch.on.danger::after { background: var(--danger); }
.adivide { height: 1px; background: var(--border); margin: 4px 0; }

.ainput { width: 100%; padding: 11px 12px; border-radius: 10px; resize: none; background: var(--bg); border: 1px solid var(--border); color: var(--text); font-family: var(--font-ui); font-size: 13px; line-height: 1.45; }
.ainput:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }
.afield-label { font-size: 10.5px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; color: var(--muted); margin: 0 0 8px; }
.arow-actions { display: flex; align-items: center; gap: 9px; margin-top: 10px; }
.arow-actions .spacer { flex: 1 1 auto; }
.abtn { cursor: pointer; border: none; padding: 9px 16px; border-radius: 9px; font-family: var(--font-ui); font-size: 12.5px; font-weight: 700; }
.abtn-soft { background: var(--soft-bg); border: 1px solid var(--border); color: var(--text); }
.abtn-accent { background: var(--accent); color: #04181c; }
.abtn-danger { background: rgba(248,113,113,0.14); border: 1px solid rgba(248,113,113,0.35); color: var(--danger); }
.asaved { font-family: var(--font-num); font-size: 11px; color: var(--success); opacity: 0; transition: opacity var(--t-fast); }
.asaved.show { opacity: 1; }

.alist { display: flex; flex-direction: column; gap: 8px; }
.aitem { padding: 11px 12px; border-radius: 10px; background: var(--summary-bg); border: 1px solid var(--border); }
.aitem-top { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.aitem-tag { font-family: var(--font-num); font-size: 9.5px; font-weight: 700; padding: 2px 7px; border-radius: 5px; text-transform: uppercase; }
.aitem-tag.bug { background: rgba(248,113,113,0.14); color: var(--danger); }
.aitem-tag.idea { background: rgba(96,165,250,0.14); color: var(--info); }
.aitem-tag.praise { background: rgba(52,211,153,0.14); color: var(--success); }
.aitem-time { font-family: var(--font-num); font-size: 10px; color: var(--text-muted); }
.aitem-body { font-size: 12px; color: var(--text); margin-top: 6px; line-height: 1.45; }
.aitem-meta { font-family: var(--font-num); font-size: 10px; color: var(--text-muted); margin-top: 6px; }

.aaudit { display: flex; align-items: baseline; gap: 10px; padding: 8px 0; border-bottom: 1px solid var(--border); }
.aaudit:last-child { border-bottom: none; }
.aaudit-time { font-family: var(--font-num); font-size: 10.5px; color: var(--text-muted); white-space: nowrap; }
.aaudit-act { font-size: 12px; color: var(--text); }
.aaudit-act b { font-family: var(--font-num); font-weight: 700; color: var(--accent); }

.ahealth { display: grid; grid-template-columns: 1fr 1fr; gap: 9px; }
.ahealth-cell { padding: 11px; border-radius: 10px; background: var(--summary-bg); border: 1px solid var(--border); }
.ahealth-k { font-size: 9.5px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; color: var(--muted); }
.ahealth-v { font-family: var(--font-num); font-variant-numeric: tabular-nums; font-size: 18px; font-weight: 700; margin-top: 5px; }
.ahealth-v small { font-size: 11px; color: var(--muted); font-weight: 600; }
.adot { display: inline-block; width: 7px; height: 7px; border-radius: 50%; margin-right: 6px; vertical-align: middle; }
.adot.ok { background: var(--success); box-shadow: 0 0 6px var(--success); }

/* Admin-Tab (4. Tab) + Admin-Pille oben — sichtbar nach Login --------- */
.admin-tab.hidden, .admin-badge.hidden, .admin-pill.hidden { display: none !important; }
.admin-tab.active { color: var(--danger); }
.admin-tab.active svg { filter: drop-shadow(0 0 5px rgba(248,113,113,0.5)); }
.admin-pill {
  font-family: var(--font-num); font-size: 10px; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase;
  padding: 4px 9px; border-radius: 999px; color: #fff;
  background: linear-gradient(180deg, #f87171, #dc2626); border: 1px solid rgba(248,113,113,0.5);
  box-shadow: 0 0 0 1px rgba(248,113,113,0.25), 0 6px 16px -6px rgba(220,38,38,0.7);
}


/* =====================================================================
   8 · REVEAL 6.0   >> WO: eigener <section id="reveal60"> Vollbild-Overlay
   Eigener reveal-* Namespace, kollidiert NICHT mit dem bestehenden
   welcome-screen. Trace-/Glitch-Animation siehe README-Timeline; hier
   die Struktur + „Was ist neu"-Sheet (der eigentlich neue 6.0-Inhalt).
   ===================================================================== */
.reveal {
  position: absolute; inset: 0; z-index: 90; display: flex; flex-direction: column; justify-content: flex-end;
  background: radial-gradient(130% 70% at 50% 0%, color-mix(in srgb, var(--accent) 16%, transparent) 0%, transparent 52%), color-mix(in srgb, var(--bg) 92%, #000);
  opacity: 0; pointer-events: none; transition: opacity var(--t-med, 260ms) var(--ease-out);
}
.reveal.show { opacity: 1; pointer-events: auto; }
.reveal-top { flex: 1 1 auto; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 30px; text-align: center; }
.reveal-logo {
  width: 84px; height: 84px; border-radius: 22px; overflow: hidden; margin-bottom: 22px;
  border: 1px solid var(--konto-border); box-shadow: 0 0 0 7px var(--accent-soft), 0 24px 60px -20px var(--accent-glow);
  animation: reveal-pop 700ms var(--ease-spring) both;
}
.reveal-logo svg { width: 100%; height: 100%; display: block; }
@keyframes reveal-pop { from { transform: scale(0.6); opacity: 0; } }
.reveal-eyebrow { font-family: var(--font-num); font-size: 11px; font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase; color: var(--accent); }
.reveal-title { font-size: 34px; font-weight: 800; letter-spacing: 0.04em; margin: 10px 0 4px; display: flex; align-items: baseline; gap: 10px; justify-content: center; }
.reveal-ver {
  font-family: var(--font-num); font-weight: 800;
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 60%, #fff) 0%, var(--accent) 55%, var(--accent-strong) 100%);
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.reveal-sub { font-size: 14px; color: var(--muted); }
.reveal-sheet {
  flex: 0 0 auto; padding: 22px 22px calc(24px + env(safe-area-inset-bottom));
  background: var(--surface-1-solid); border-top-left-radius: 26px; border-top-right-radius: 26px;
  border-top: 1px solid var(--border-strong);
}
.reveal-sheet-title { font-size: 11px; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted); margin-bottom: 14px; }
.reveal-list { display: flex; flex-direction: column; gap: 13px; margin-bottom: 22px; }
.reveal-hl { display: flex; align-items: flex-start; gap: 13px; opacity: 0; transform: translateY(8px); animation: azis-rise 460ms var(--ease-out) forwards; }
.reveal-hl-icon { width: 36px; height: 36px; flex: 0 0 auto; border-radius: 10px; display: grid; place-items: center; background: var(--accent-soft); border: 1px solid var(--konto-border); color: var(--accent); }
.reveal-hl-icon svg { width: 18px; height: 18px; }
.reveal-hl-text strong { display: block; font-size: 14px; font-weight: 700; }
.reveal-hl-where { display: block; font-family: var(--font-num); font-size: 10px; font-weight: 700; letter-spacing: 0.04em; color: var(--accent); margin-top: 4px; }
.reveal-cta {
  width: 100%; padding: 16px; border: none; cursor: pointer; border-radius: var(--radius-lg);
  color: #04181c; background: linear-gradient(180deg, var(--accent), var(--accent-strong));
  font-family: var(--font-ui); font-size: 15px; font-weight: 800; letter-spacing: 0.03em;
  box-shadow: 0 8px 22px calc(var(--glow-mult) * 1px) var(--accent-glow);
}
:root[data-theme="terminal"] .reveal-cta, :root[data-theme="light"] .reveal-cta { color: #fff; }


/* =====================================================================
   9 · TAGESERFASSUNGS-BOTTOM-SHEET   >> WO: ans App-Root (vor </main>)
   Snippet: snippets/sheet.html · Öffnen: .show auf .day-sheet + .sheet-scrim
   ===================================================================== */
.sheet-scrim {
  position: absolute; inset: 0; z-index: 70;
  background: rgba(2,4,8,0.55);
  -webkit-backdrop-filter: blur(2px); backdrop-filter: blur(2px);
  opacity: 0; pointer-events: none;
  transition: opacity var(--t-base) var(--ease-out);
}
.sheet-scrim.show { opacity: 1; pointer-events: auto; }

.day-sheet {
  position: absolute; left: 0; right: 0; bottom: 0; z-index: 71;
  max-height: 88%; display: flex; flex-direction: column;
  background: var(--surface-1-solid);
  border-top-left-radius: 26px; border-top-right-radius: 26px;
  border-top: 1px solid var(--border-strong);
  box-shadow: 0 -24px 60px -20px rgba(0,0,0,0.8);
  transform: translateY(102%);
  transition: transform 420ms var(--ease-spring, cubic-bezier(0.34,1.56,0.64,1));
}
.day-sheet.show { transform: translateY(0); }
.day-sheet-grip { width: 40px; height: 4px; border-radius: 2px; background: var(--border-strong); margin: 10px auto 4px; flex: 0 0 auto; }
.day-sheet-head { display: flex; align-items: center; justify-content: space-between; padding: 8px 18px 14px; flex: 0 0 auto; border-bottom: 1px solid var(--border); }
.day-sheet-dow { font-size: 11px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); }
.day-sheet-title { font-family: var(--font-num); font-variant-numeric: tabular-nums; font-size: 22px; font-weight: 700; margin-top: 2px; color: var(--text); }
.day-sheet-close { width: 34px; height: 34px; border-radius: 50%; cursor: pointer; background: var(--soft-bg); border: 1px solid var(--border); color: var(--text); display: grid; place-items: center; }
.day-sheet-close svg { width: 16px; height: 16px; }
.day-sheet-body { overflow-y: auto; padding: 16px 18px 8px; flex: 1 1 auto; }
.day-sheet-body::-webkit-scrollbar { width: 0; }
.day-sheet-field { margin-bottom: 18px; }
.flabel { font-size: 11px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--muted); margin-bottom: 9px; }

/* Status-Chips */
.status-chips { display: flex; flex-wrap: wrap; gap: 7px; }
.status-chip {
  --chip-tone: var(--muted);
  cursor: pointer; padding: 8px 13px; border-radius: 999px;
  font-family: var(--font-ui); font-size: 13px; font-weight: 600;
  background: var(--soft-bg); border: 1px solid var(--border); color: var(--text);
  transition: all var(--t-fast) var(--ease-out);
}
.status-chip.active {
  background: color-mix(in srgb, var(--chip-tone) 18%, transparent);
  border-color: color-mix(in srgb, var(--chip-tone) 55%, transparent);
  color: var(--chip-tone);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--chip-tone) 30%, transparent);
}
.status-chip:active { transform: scale(0.95); }
/* Tones per status */
.status-chip[data-status="standard"].active  { --chip-tone: var(--text); }
.status-chip[data-status="abweichend"].active { --chip-tone: var(--violet); }
.status-chip[data-status="urlaub"].active     { --chip-tone: var(--warning); }
.status-chip[data-status="krank"].active      { --chip-tone: var(--muted); }
.status-chip[data-status="lehrgang"].active   { --chip-tone: var(--teal); }
.status-chip[data-status="atb"].active        { --chip-tone: var(--info); }
.status-chip[data-status="stundenabbau"].active  { --chip-tone: var(--danger); }
.status-chip[data-status="stundenaufbau"].active { --chip-tone: var(--success); }

/* Zeitfelder */
.time-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.time-field label { display: block; font-size: 10px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--text-muted); margin-bottom: 6px; }
.time-field input {
  width: 100%; padding: 13px 12px; border-radius: var(--radius-md);
  background: var(--bg); border: 1px solid var(--border); color: var(--text);
  font-family: var(--font-num); font-variant-numeric: tabular-nums;
  font-size: 20px; font-weight: 700; text-align: center; letter-spacing: .04em;
}
.time-field input:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }

/* Live-Berechnung */
.compute { display: flex; gap: 10px; margin: 4px 0 18px; padding: 14px; border-radius: var(--radius-md); background: var(--summary-bg); border: 1px solid var(--border); }
.compute-cell { flex: 1 1 0; text-align: center; position: relative; }
.compute-cell + .compute-cell::before { content: ""; position: absolute; left: 0; top: 14%; bottom: 14%; width: 1px; background: var(--border); }
.compute-k { font-size: 10px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--muted); }
.compute-v { font-family: var(--font-num); font-variant-numeric: tabular-nums; font-size: 20px; font-weight: 700; margin-top: 4px; }

/* Sheet-Footer */
.day-sheet-foot { flex: 0 0 auto; padding: 12px 18px calc(16px + env(safe-area-inset-bottom)); border-top: 1px solid var(--border); display: flex; gap: 10px; }
.btn-ghost { flex: 0 0 auto; padding: 15px 20px; border-radius: var(--radius-md); border: 1px solid var(--border); background: var(--soft-bg); color: var(--text); cursor: pointer; font-family: var(--font-ui); font-size: 15px; font-weight: 800; }
.btn-primary {
  flex: 1 1 0; padding: 15px; border: none; border-radius: var(--radius-md); cursor: pointer;
  font-family: var(--font-ui); font-size: 15px; font-weight: 800; letter-spacing: .02em;
  color: #04181c; background: linear-gradient(180deg, var(--accent), var(--accent-strong));
  box-shadow: 0 8px 22px calc(var(--glow-mult,1) * 1px) var(--accent-glow);
}
:root[data-theme="terminal"] .btn-primary, :root[data-theme="light"] .btn-primary { color: #fff; }


/* =====================================================================
   10 · LEGACY DAY-DIALOG ALS FUNKTIONALES 6.0-BOTTOM-SHEET
   ---------------------------------------------------------------------
   Das Handoff-Sheet ist nur ein visuelles Minimalgeruest. Die echte App
   braucht das vollstaendige Formular (#dayDialog) fuer Urlaubsspannen,
   Lehrgang, Wachdienst, Gleitzeit und Validierung. Deshalb wird der
   vorhandene Dialog optisch zum Sheet gemacht, ohne IDs/JS umzubauen.
   ===================================================================== */
#dayDialog {
  position: fixed;
  inset: auto 0 0 0;
  width: min(100%, 720px);
  max-width: 720px;
  max-height: min(88dvh, 820px);
  margin: auto auto 0;
  padding: 0;
  overflow: hidden;
  color: var(--text);
  background: var(--surface-1-solid);
  border: 1px solid var(--border-strong);
  border-bottom: 0;
  border-radius: 26px 26px 0 0;
  box-shadow: 0 -24px 60px -20px rgba(0, 0, 0, 0.82);
  transform: translateY(105%);
  transition:
    transform 360ms var(--ease-out),
    opacity 220ms var(--ease-out),
    overlay 360ms var(--ease-out) allow-discrete,
    display 360ms var(--ease-out) allow-discrete;
}

#dayDialog[open] {
  opacity: 1;
  transform: translateY(0);
}

@starting-style {
  #dayDialog[open] {
    opacity: 0;
    transform: translateY(105%);
  }
}

#dayDialog::backdrop {
  background: rgba(2, 4, 8, 0);
  -webkit-backdrop-filter: blur(0);
  backdrop-filter: blur(0);
  transition:
    background 260ms var(--ease-out),
    backdrop-filter 260ms var(--ease-out),
    overlay 260ms var(--ease-out) allow-discrete,
    display 260ms var(--ease-out) allow-discrete;
}

#dayDialog[open]::backdrop {
  background: rgba(2, 4, 8, 0.58);
  -webkit-backdrop-filter: blur(3px);
  backdrop-filter: blur(3px);
}

#dayDialog::before {
  content: "";
  display: block;
  width: 42px;
  height: 4px;
  margin: 10px auto 4px;
  border-radius: 999px;
  background: var(--border-strong);
}

#dayForm {
  display: flex;
  flex-direction: column;
  max-height: calc(min(88dvh, 820px) - 14px);
  padding: 0;
  overflow-y: auto;
  overscroll-behavior: contain;
  scrollbar-width: none;
}

#dayForm::-webkit-scrollbar {
  width: 0;
}

#dayDialog .day-dialog-head {
  position: sticky;
  top: 0;
  z-index: 2;
  flex: 0 0 auto;
  margin: 0;
  padding: 8px 18px 14px;
  background: var(--surface-1-solid);
  border-bottom: 1px solid var(--border);
}

#dayDialog .day-dialog-head h3 {
  margin: 0;
  font-family: var(--font-num);
  font-size: 18px;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0;
}

#dayDialog .day-dialog-head ~ *:not(.dialog-actions) {
  margin-left: 18px;
  margin-right: 18px;
}

#dayDialog .day-status-field {
  margin-top: 16px;
  padding: 0;
}

#dayDialog .day-section {
  padding: 0;
}

#dayDialog .field,
#dayDialog .day-section,
#dayDialog #stundenabbauFields,
#dayDialog #atbFields,
#dayDialog #dayVacationFields,
#dayDialog #daySickFields,
#dayDialog #dayLehrgangFields,
#dayDialog #gleitzeitFields,
#dayDialog #dayWatchFields,
#dayDialog #dayStatusHint {
  flex: 0 0 auto;
}

#dayDialog #dayForm > .day-status-field,
#dayDialog #dayForm > .day-section,
#dayDialog #dayForm > .field,
#dayDialog #dayForm > div:not(.dialog-actions),
#dayDialog #dayForm > p:not(.hint),
#dayDialog #dayForm > p.hint:not(#dayStatusHint) {
  max-width: calc(100% - 36px);
}

#dayDialog #timeFields,
#dayDialog #stundenabbauFields,
#dayDialog #atbFields,
#dayDialog #dayVacationFields,
#dayDialog #daySickFields,
#dayDialog #dayLehrgangFields,
#dayDialog #gleitzeitFields,
#dayDialog #dayWatchFields,
#dayDialog #dayBuchungsgrundField,
#dayDialog #dayBuchungsgrundCustomField,
#dayDialog #dayReisezeitField,
#dayDialog #dayStatusHint {
  margin-bottom: 16px;
}

#dayDialog label,
#dayDialog .section-label {
  display: block;
  margin-bottom: 7px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

#dayDialog input,
#dayDialog select,
#dayDialog textarea {
  min-height: 44px;
  border-radius: var(--radius-md);
  background: var(--bg);
  border: 1px solid var(--border);
  color: var(--text);
}

#dayDialog input:focus,
#dayDialog select:focus,
#dayDialog textarea:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

#dayDialog .time-inputs,
#dayDialog .gleit-time-inputs,
#dayDialog .stundenabbau-time-inputs {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

#dayDialog .status-chip-group,
#dayDialog .status-sub-switch {
  gap: 7px;
}

#dayDialog .status-chip {
  --chip-tone: var(--muted);
  padding: 8px 13px;
  border-radius: 999px;
  background: var(--soft-bg);
  border-color: var(--border);
  color: var(--text);
  transition:
    transform 120ms var(--ease-out),
    border-color 160ms var(--ease-out),
    background 160ms var(--ease-out),
    color 160ms var(--ease-out),
    box-shadow 160ms var(--ease-out);
}

#dayDialog .status-chip.active {
  background: color-mix(in srgb, var(--chip-tone) 18%, transparent);
  border-color: color-mix(in srgb, var(--chip-tone) 58%, transparent);
  color: var(--chip-tone);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--chip-tone) 30%, transparent);
}

#dayDialog .status-chip:active {
  transform: scale(0.96);
}

#dayDialog .status-chip[data-status="standard"].active { --chip-tone: var(--text); }
#dayDialog .status-chip[data-status-family="gleitzeit"].active,
#dayDialog .status-chip[data-status="abweichend"].active,
#dayDialog .status-chip[data-status="gleitzeit"].active { --chip-tone: var(--violet); }
#dayDialog .status-chip[data-status="urlaub"].active { --chip-tone: var(--warning); }
#dayDialog .status-chip[data-status="krankgeschrieben"].active { --chip-tone: var(--muted); }
#dayDialog .status-chip[data-status="lehrgang"].active { --chip-tone: var(--teal); }
#dayDialog .status-chip[data-status="wach_zusatzdienst"].active,
#dayDialog .status-chip[data-status="stundenaufbau"].active { --chip-tone: var(--success); }
#dayDialog .status-chip[data-status="atb"].active { --chip-tone: var(--info); }
#dayDialog .status-chip[data-status="stundenabbau"].active { --chip-tone: var(--danger); }

#dayDialog .status-sub-switch {
  margin-top: 10px;
  padding: 7px;
  border-style: solid;
  border-color: color-mix(in srgb, var(--violet) 42%, transparent);
  background: color-mix(in srgb, var(--violet) 12%, transparent);
}

#dayDialog .hint {
  color: var(--text-muted);
  line-height: 1.45;
}

#dayDialog .dialog-actions {
  position: sticky;
  bottom: 0;
  z-index: 3;
  display: flex;
  gap: 10px;
  margin-top: auto;
  padding: 12px 18px calc(16px + env(safe-area-inset-bottom));
  background: var(--surface-1-solid);
  border-top: 1px solid var(--border);
}

#dayDialog .dialog-actions .btn {
  min-height: 46px;
  border-radius: var(--radius-md);
}

#dayDialog .dialog-actions .btn[value="save"],
#dayDialog #dayDialogSaveBtn {
  flex: 1 1 auto;
  color: #04181c;
  background: linear-gradient(180deg, var(--accent), var(--accent-strong));
  border-color: transparent;
  box-shadow: 0 8px 22px calc(var(--glow-mult, 1) * 1px) var(--accent-glow);
}

:root[data-theme="terminal"] #dayDialog .dialog-actions .btn[value="save"],
:root[data-theme="light"] #dayDialog .dialog-actions .btn[value="save"],
:root[data-theme="terminal"] #dayDialog #dayDialogSaveBtn,
:root[data-theme="light"] #dayDialog #dayDialogSaveBtn {
  color: #fff;
}

#dayDialog #deleteDayBtn {
  flex: 0 0 auto;
}

@media (max-width: 520px) {
  #dayDialog {
    width: 100%;
    max-height: 92dvh;
  }

  #dayForm {
    max-height: calc(92dvh - 14px);
  }

  #dayDialog .dialog-actions {
    flex-wrap: wrap;
  }

  #dayDialog #deleteDayBtn {
    order: 3;
    width: 100%;
  }
}

@media (min-width: 760px) {
  #dayDialog {
    bottom: 22px;
    border: 1px solid var(--border-strong);
    border-radius: 26px;
  }

  #dayDialog .dialog-actions {
    border-bottom-left-radius: 26px;
    border-bottom-right-radius: 26px;
  }
}
