:root {
    --bg: #f5f7fa;
    --surface: #ffffff;
    --text: #1f2933;
    --muted: #627d98;
    --border: #d9e2ec;
    --accent: #2f855a;
    --accent-hover: #276749;
    --accent-bg: #e6f4ea;
    --header-bg: #556b2f;            /* Olivgrün – Header + Footer (bewusst entkoppelt vom Button-Grün --accent) */
    --header-text: #ffffff;
    --header-text-muted: #d4ebde;    /* helles Grün-Weiß für gedämpften Text auf dem Akzentgrün */
    --danger: #c0392b;
    --max-width: 2200px;      /* Arbeitsbereich: nahezu volle Breite – nur als Sicherheit für sehr breite Monitore gedeckelt */
    --max-width-public: 820px; /* Öffentliche Lese-Seite bleibt schmal */
    --sidebar-width: 220px;
    --radius: 6px;
}

* { box-sizing: border-box; }

html, body {
    margin: 0;
    padding: 0;
    background: var(--bg);
    color: var(--text);
    font-family: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
    line-height: 1.55;
}

/* Scrollbar-Spur dauerhaft reservieren: sonst lassen kurze (ohne Scrollbar) vs.
   lange Seiten (mit Scrollbar) die zentrierte Layout-Spalte seitlich verspringen
   – das war das „Springen hin und her" und die scheinbar unterschiedlichen Breiten. */
html { scrollbar-gutter: stable; }

a { color: var(--accent); }
a:hover { color: var(--accent-hover); }

/* ---------- Header ---------- */
/* Hintergrundbalken über volle Breite … */
.header {
    background: var(--header-bg);
    color: var(--header-text);
}
/* … Inhalt aber bündig zur Layout-Spalte (gleiche max-width + Seitenränder). */
.header__inner {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 0.75rem 1.5rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.5rem;
}
.header__brand a { color: var(--header-text); text-decoration: none; }
.header__logo { display: inline-flex; align-items: center; }
.header__logoimg { height: 56px; width: auto; display: block; border-radius: 6px; }
.header__nav { display: flex; gap: 1.5rem; flex: 1; }
.header__nav a { color: var(--header-text); text-decoration: none; opacity: 0.85; }
.header__nav a:hover { opacity: 1; }
.header__user { display: flex; align-items: center; gap: 0.75rem; }
.header__email { color: var(--header-text-muted); font-size: 0.9rem; }
.header__logoutform { margin: 0; }

/* ---------- Layout ---------- */
.layout {
    display: grid;
    grid-template-columns: var(--sidebar-width) 1fr;
    gap: 1.5rem;
    /* width:100% ist Pflicht: body ist Spalten-Flex, und ein auto-Querrand (margin:… auto)
       würde die Box sonst auf Inhaltsbreite SCHRUMPFEN statt auf volle Breite strecken
       (Kalender-1fr-Spalten kollabieren dann auf ihr Minimum → „Kalender am schmalsten").
       Mit width:100% füllt sie bis --max-width und bleibt darüber hinaus zentriert. */
    width: 100%;
    max-width: var(--max-width);
    margin: 1.25rem auto;
    padding: 0 1.5rem;
}
.layout--public {
    grid-template-columns: 1fr;
    max-width: var(--max-width-public);
}

.sidebar {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1rem;
}
.sidebar__list { list-style: none; margin: 0; padding: 0; }
.sidebar__list li + li { margin-top: 0.5rem; }
.sidebar__list a { display: block; padding: 0.4rem 0.6rem; border-radius: 4px; text-decoration: none; color: var(--text); }
.sidebar__list a:hover { background: var(--accent-bg); color: var(--accent); }

.main {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1.75rem 2rem;
    min-height: 60vh;
    min-width: 0; /* erlaubt der 1fr-Spalte zu schrumpfen; breite Kinder (Tabellen, .cal) scrollen statt die Spalte aufzublähen */
}

/* ---------- Buttons ---------- */
.button {
    display: inline-block;
    background: var(--accent);
    color: white;
    padding: 0.55rem 1.1rem;
    border-radius: 4px;
    text-decoration: none;
    border: 1px solid var(--accent);
    cursor: pointer;
    font-size: 0.95rem;
    line-height: 1.2;
}
.button:hover { background: var(--accent-hover); border-color: var(--accent-hover); color: white; }
.button--ghost {
    background: transparent;
    color: var(--header-text);
    border-color: rgba(255,255,255,0.4);
}
.button--ghost:hover { background: rgba(255,255,255,0.1); color: white; }
/* Buttons im Header stehen auf grünem Grund → heller Umriss statt grüner Füllung
   (sonst ginge der Login-Button im Header-Grün unter). Gilt für Login + Logout. */
.header .button {
    background: transparent;
    color: var(--header-text);
    border-color: rgba(255,255,255,0.5);
}
.header .button:hover {
    background: rgba(255,255,255,0.12);
    color: #fff;
    border-color: rgba(255,255,255,0.85);
}

/* ---------- Typografie ---------- */
h1 { margin-top: 0; font-size: 1.75rem; }
h2 { margin-top: 1.5rem; font-size: 1.2rem; color: var(--muted); }
hr { border: 0; border-top: 1px solid var(--border); margin: 1.5rem 0; }
.adresse { white-space: pre-line; }

/* ---------- Forms & Alerts ---------- */
.form { display: flex; flex-direction: column; gap: 1rem; max-width: 380px; }
.form label { display: flex; flex-direction: column; gap: 0.3rem; font-size: 0.9rem; color: var(--muted); }
.form input {
    padding: 0.55rem 0.75rem;
    border: 1px solid var(--border);
    border-radius: 4px;
    font-size: 1rem;
    font-family: inherit;
}
.form input:focus { outline: 2px solid var(--accent); outline-offset: -2px; border-color: var(--accent); }
.form select {
    padding: 0.5rem 0.6rem; border: 1px solid var(--border); border-radius: 4px;
    font-size: 1rem; font-family: inherit; background: var(--surface);
}
.form select:focus { outline: 2px solid var(--accent); outline-offset: -2px; border-color: var(--accent); }
/* Zwei Felder nebeneinander + Checkbox-Zeile (z. B. Abwesenheits-Formular) */
.form-row { display: flex; gap: 1rem; flex-wrap: wrap; align-items: stretch; }
.form-row > label { flex: 1; min-width: 160px; }
/* Bei mehrzeiligem Label (z. B. „Tageslimit …") Eingabefeld unten andocken,
   damit alle Felder einer Zeile auf gleicher Höhe fluchten. */
.form-row > label > input,
.form-row > label > select { margin-top: auto; }
.form .checkbox-label { flex-direction: row; align-items: center; gap: 0.5rem; color: var(--text); }
.form .checkbox-label input { width: auto; }

/* Arbeitszeiten-Wochenplan: kompakte Zeit-Eingaben je Tag/Block */
.az-table th[scope="row"] { white-space: nowrap; }
.az-cell { white-space: nowrap; }
.az-cell input { width: 5.2rem; padding: 0.4rem 0.5rem; border: 1px solid var(--border); border-radius: 4px; font: inherit; }
.az-cell input:focus { outline: 2px solid var(--accent); outline-offset: -2px; border-color: var(--accent); }
.az-dash { margin: 0 0.3rem; color: var(--muted); }

/* Patienten-Such-Combobox (Terminvergabe, skaliert auf große Bestände) */
.patient-picker { position: relative; }
.patient-picker__input { width: 100%; box-sizing: border-box; }
.patient-picker__results {
    list-style: none; margin: 2px 0 0; padding: 0; position: absolute; z-index: 30; left: 0; right: 0;
    background: var(--surface); border: 1px solid var(--border); border-radius: 4px;
    max-height: 16rem; overflow-y: auto; box-shadow: 0 4px 14px rgba(0,0,0,0.12);
}
.patient-picker__item { padding: 0.45rem 0.7rem; cursor: pointer; font-size: 0.95rem; color: var(--text); }
.patient-picker__item:hover, .patient-picker__item:focus { background: var(--accent-bg); outline: none; }
.patient-picker__item .muted { font-size: 0.85em; }
.patient-picker__empty { padding: 0.45rem 0.7rem; color: var(--muted); font-size: 0.9rem; }

/* ICD-10-GM-Nachschlagehilfe: Such-Combobox am Diagnose-Feld der Verordnung (initIcd10 in app.js) */
.icd-picker { position: relative; display: flex; flex-direction: column; gap: 0.3rem; }
.icd-picker > label { color: var(--muted); font-size: 0.9rem; }
.icd-picker__input { width: 100%; box-sizing: border-box; }
.icd-picker__results {
    list-style: none; margin: 2px 0 0; padding: 0; position: absolute; z-index: 30; left: 0; top: 100%;
    min-width: 24rem; width: max-content; max-width: min(34rem, 90vw);
    background: var(--surface); border: 1px solid var(--border); border-radius: 4px;
    max-height: 18rem; overflow-y: auto; box-shadow: 0 4px 14px rgba(0,0,0,0.12);
}
.icd-picker__item { padding: 0.45rem 0.7rem; cursor: pointer; font-size: 0.95rem; color: var(--text); display: flex; gap: 0.5rem; align-items: baseline; }
.icd-picker__item:hover, .icd-picker__item:focus { background: var(--accent-bg); outline: none; }
.icd-picker__code { font-weight: 600; font-variant-numeric: tabular-nums; white-space: nowrap; }
.icd-picker__item .icd-picker__flag { margin-left: auto; font-size: 0.78em; color: #8a5a12; white-space: nowrap; }
.icd-picker__empty { padding: 0.45rem 0.7rem; color: var(--muted); font-size: 0.9rem; }

/* Inline-Klartext zum ICD-Code + Quellenangabe (§ 63 UrhG) */
.icd-klartext { margin: 0.1rem 0 0.6rem; font-size: 0.9rem; }
.icd-klartext__code { font-weight: 600; font-variant-numeric: tabular-nums; margin-right: 0.35rem; }
.icd-klartext__note { color: #8a5a12; }
.icd-klartext.icd-klartext--ok { color: var(--accent-hover); }
.icd-klartext.icd-klartext--warn { color: #8a5a12; }
.icd-source { font-size: 0.78rem; margin: 0.2rem 0 0.8rem; line-height: 1.4; }

/* Datumsfeld mit Kalender-Knopf (siehe initDatePickers in app.js) */
.datefield { display: flex; align-items: stretch; gap: 0.3rem; position: relative; width: 100%; }
.datefield > input.js-date { flex: 1 1 auto; min-width: 0; }
.datefield__btn {
    flex: 0 0 auto; border: 1px solid var(--border); background: var(--surface);
    border-radius: 4px; padding: 0 0.6rem; cursor: pointer; font-size: 1.05rem; line-height: 1;
}
.datefield__btn:hover { background: var(--accent-bg); border-color: var(--accent); }
/* Natives type=date dient nur als Kalender-Quelle – unsichtbar, aber im DOM (showPicker). */
.datefield__native { position: absolute; right: 0; bottom: 0; width: 1px; height: 1px; padding: 0; border: 0; opacity: 0; pointer-events: none; }

.alert { padding: 0.75rem 1rem; border-radius: 4px; margin-bottom: 1rem; }
.alert--error { background: #fdecea; color: var(--danger); border: 1px solid #f5c2c0; }
.alert--success { background: var(--accent-bg); color: var(--accent-hover); border: 1px solid #b7dfc4; }
.alert ul { margin: 0; padding-left: 1.2rem; }

/* ---------- Sidebar active ---------- */
.sidebar__list a.is-active { background: var(--accent-bg); color: var(--accent); font-weight: 600; }

/* ---------- Page head ---------- */
.page-head { display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }
.page-head h1 { margin: 0; }
.dash-toggle { display: flex; align-items: center; gap: 0.5rem; font-size: 0.9rem; }
.kv-list { list-style: none; margin: 0 0 0.75rem; padding: 0; }
.kv-list li { padding: 0.3rem 0; }
.kv-list li + li { border-top: 1px solid var(--border); }
.page-head__actions { display: flex; gap: 0.6rem; flex-wrap: wrap; }

/* ---------- Filter bar ---------- */
.filterbar { display: flex; flex-wrap: wrap; align-items: center; gap: 0.5rem; margin: 1.25rem 0; }
.filterbar input[type="search"], .filterbar select {
    padding: 0.45rem 0.6rem; border: 1px solid var(--border); border-radius: 4px;
    font-size: 0.95rem; font-family: inherit;
}
.filterbar input[type="search"] { min-width: 220px; }
.filterbar__reset { font-size: 0.85rem; color: var(--muted); }

/* ---------- Table ---------- */
.table { width: 100%; border-collapse: collapse; font-size: 0.95rem; }
.table th, .table td { text-align: left; padding: 0.6rem 0.75rem; border-bottom: 1px solid var(--border); vertical-align: middle; }
.table thead th { font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--muted); }
.table tbody tr:hover { background: #f9fbfd; }
.table .num { text-align: right; }
.table .actions { white-space: nowrap; }
.table .actions a { margin-right: 0.75rem; }
.row--inactive td { color: var(--muted); }
.muted { color: var(--muted); }
.empty { color: var(--muted); padding: 1.5rem 0; }

/* Aufklappbarer Hinweis (z. B. Cron-Anleitung) */
.hint { margin: 1rem 0; padding: 0.5rem 0.9rem; background: var(--accent-bg); border-radius: 8px; }
.hint summary { cursor: pointer; font-weight: 600; }
.hint pre { overflow-x: auto; margin: 0.5rem 0 0; padding: 0.6rem 0.8rem; background: #fff; border-radius: 6px; font-size: 0.85rem; }

/* ---------- Badges ---------- */
.badge { display: inline-block; font-size: 0.75rem; padding: 0.15rem 0.55rem; border-radius: 999px; font-weight: 600; }
.badge--ok { background: var(--accent-bg); color: var(--accent-hover); }
.badge--off { background: #eceff1; color: var(--muted); }

/* ---------- Inline form / link button ---------- */
.inline-form { display: inline; margin: 0; }
.linkbtn { background: none; border: 0; padding: 0; color: var(--accent); cursor: pointer; font: inherit; }
.linkbtn:hover { color: var(--accent-hover); text-decoration: underline; }

/* ---------- Wide forms ---------- */
.form--wide { max-width: 640px; }
.form--wide textarea, .form--wide select {
    padding: 0.55rem 0.75rem; border: 1px solid var(--border); border-radius: 4px;
    font-size: 1rem; font-family: inherit; width: 100%;
}
.form--wide textarea:focus, .form--wide select:focus,
.form--wide input:focus { outline: 2px solid var(--accent); outline-offset: -2px; border-color: var(--accent); }
.form__row { display: flex; gap: 1rem; }
/* `.form__row { display:flex }` überschreibt sonst die UA-Regel [hidden]{display:none};
   per JS aus-/eingeblendete Zeilen (z. B. Anfahrt nur bei Hausbesuch) blieben dadurch sichtbar. */
.form__row[hidden] { display: none; }
/* min-width:0 erlaubt den flex:1-Spalten zu schrumpfen; sonst drückt eine fixe Spalte
   (.field--narrow, z. B. „Dauer") im engeren .form-section-Rahmen rechts aus der Box. */
.form__row > label { flex: 1; min-width: 0; }
.form__row .field--narrow { flex: 0 0 120px; }
.form__actions { display: flex; gap: 0.75rem; margin-top: 0.5rem; }

/* Formular-Abschnitt mit leichtem Rahmen: gruppiert zusammengehörige Felder optisch
   (Verordnungsdetail: Stammdaten / Diagnose / Heilmittel / Optionen). Liegt im weißen
   Inhaltsbereich, daher genügt der zarte Rahmen ohne eigene Hintergrundfarbe. Eigenes
   flex-Layout, weil die Felder nicht mehr direkte Kinder von .form sind (deren gap greift
   sonst nicht). */
.form-section {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1.1rem 1.25rem 1.25rem;
    min-width: 0;
}
.form-section > h2 { margin: 0; }
/* Doku-/Heilplan-Editor (WYSIWYG) hat keine eigene Breite → ohne Deckel liefe der
   .form-section-Rahmen vollbreit (genau der „Heilplan falsch"-Fall). Wie .stack-form
   auf Formgröße deckeln, damit der Rahmen das Formular umschließt. */
.doku-form { max-width: 760px; }
.checkbox { flex-direction: row !important; align-items: center; gap: 0.5rem !important; color: var(--text) !important; }
.checkbox input { width: auto; }
.button--secondary { background: var(--surface); color: var(--text); border-color: var(--border); }
.button--secondary:hover { background: var(--bg); color: var(--text); border-color: var(--muted); }
.button--danger { background: var(--danger); color: #fff; border-color: var(--danger); }
.button--danger:hover { background: #922b21; border-color: #922b21; }
.button--ausgefallen { background: #fdebd0; color: #9c4221; border-color: #e0a878; }
.button--ausgefallen:hover { background: #fbdcb6; color: #7b341e; border-color: #c05621; }

/* ---------- Branding ---------- */

/* ---------- Kalender-Toolbar ---------- */
.cal-toolbar { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 1rem; margin: 1rem 0; }
.cal-toolbar__ther label { display: flex; align-items: center; gap: 0.5rem; color: var(--muted); font-size: 0.9rem; }
.cal-toolbar select { padding: 0.4rem 0.6rem; border: 1px solid var(--border); border-radius: 4px; font: inherit; }
.cal-toolbar__nav { display: flex; align-items: center; gap: 0.6rem; }
.cal-toolbar__week { font-weight: 600; min-width: 11rem; text-align: center; }

/* ---------- Kalender-Gitter ---------- */
.cal { border: 1px solid var(--border); border-radius: var(--radius); overflow-x: auto; background: var(--surface); }
.cal__grid { display: grid; grid-template-columns: 56px repeat(var(--cols, 6), minmax(96px, 1fr)); min-width: 640px; }
/* Tagesansicht: eine Spalte, angenehm lesbare Breite statt voller Fensterbreite */
.cal--tag { max-width: 1000px; }
.cal--tag .cal__grid { min-width: 0; }
.cal__head { border-bottom: 1px solid var(--border); }
.cal__corner { border-right: 1px solid var(--border); }
.cal__dayhead {
    display: flex; align-items: center; justify-content: space-between; gap: 0.3rem;
    padding: 0.45rem 0.5rem; font-size: 0.82rem; font-weight: 600; border-left: 1px solid var(--border);
}
.cal__dayhead.is-today { background: var(--accent-bg); color: var(--accent-hover); }
.cal__daylink { text-decoration: none; color: inherit; font: inherit; flex: 1; }
.cal__daylink:hover { color: var(--accent); text-decoration: underline; }
.cal__add { text-decoration: none; font-weight: 700; color: var(--accent); padding: 0 0.35rem; border-radius: 3px; }
.cal__add:hover { background: var(--accent); color: #fff; }

.cal__axis { position: relative; border-right: 1px solid var(--border); }
.cal__hour { height: var(--hour-px); font-size: 0.72rem; color: var(--muted); text-align: right; padding: 0 0.4rem; transform: translateY(-0.5em); }
.cal__col {
    position: relative; border-left: 1px solid var(--border);
    background-image: linear-gradient(to bottom, var(--border) 1px, transparent 1px);
    background-size: 100% var(--hour-px);
}
.cal__col.is-today { background-color: #fbfdfc; }
/* Abwesenheiten/Sperrzeiten: schraffierte, nicht-klickbare Blöcke unter den Terminen */
.cal-abw {
    position: absolute; left: 2px; right: 2px; z-index: 0; border-radius: 4px; overflow: hidden;
    pointer-events: none; border: 1px dashed #b4b4b4; color: #5a5a5a; font-size: 0.68rem; padding: 2px 5px;
    background: repeating-linear-gradient(45deg, rgba(110,110,110,.07), rgba(110,110,110,.07) 7px, rgba(110,110,110,.16) 7px, rgba(110,110,110,.16) 14px);
}
.cal-abw__label { font-weight: 600; }

/* Klick-auf-Fläche: Cursor-Hinweis + Vorschau-Slot für „Neuer Termin" */
.cal__col { cursor: copy; }
.cal-ghost {
    position: absolute; left: 3px; right: 3px; z-index: 1; pointer-events: none;
    border: 1px dashed var(--accent); border-radius: 4px; background: var(--accent-bg);
    color: var(--accent-hover); font-size: 0.72rem; font-weight: 600; padding: 1px 5px;
    box-sizing: border-box; opacity: 0.9;
}

/* Geschlossene Zeiten (außerhalb der Arbeitszeit): dezent grau, unter allem, klickbar */
.cal-closed {
    position: absolute; left: 0; right: 0; z-index: 0; pointer-events: none;
    background: repeating-linear-gradient(45deg, #f3f4f5, #f3f4f5 6px, #e9ebed 6px, #e9ebed 12px);
}
.cal-legend .dot--closed {
    border-left: 0;
    background: repeating-linear-gradient(45deg, #f3f4f5, #f3f4f5 4px, #e9ebed 4px, #e9ebed 8px);
}

.term {
    position: absolute; left: 3px; right: 3px; overflow: hidden; box-sizing: border-box;
    padding: 2px 5px; border-radius: 4px; border-left: 3px solid; font-size: 0.72rem;
    line-height: 1.2; text-decoration: none; cursor: pointer;
}
.term:hover { filter: brightness(0.96); box-shadow: 0 1px 3px rgba(0,0,0,0.15); }
.term__time { font-weight: 600; }
.term__name { display: block; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* Hausbesuch-Anfahrt: eigener, farblich abgesetzter Block vor/nach dem Termin */
.term-travel {
    position: absolute; box-sizing: border-box; overflow: hidden; z-index: 1; cursor: default;
    border-radius: 4px; border-left: 3px solid #b7791f;
    background: repeating-linear-gradient(45deg, #fdf3d8, #fdf3d8 5px, #f6e3ad 5px, #f6e3ad 10px);
    display: flex; align-items: center; justify-content: center;
}
.term-travel__icon { font-size: 0.7rem; opacity: 0.85; }
.cal-legend .dot--travel {
    border-left-color: #b7791f;
    background: repeating-linear-gradient(45deg, #fdf3d8, #fdf3d8 3px, #f6e3ad 3px, #f6e3ad 6px);
}

.term--angefragt    { background: #fff4e0; border-left-color: #dd9b3b; color: #8a5a12; }
.term--offen        { background: #eef2f7; border-left-color: #9aa8b8; color: #33414f; }
.term--bestaetigt   { background: #e6f4ea; border-left-color: #2f855a; color: #22543d; }
.term--wahrgenommen { background: #e3f0fb; border-left-color: #2b6cb0; color: #1f4e7a; }
.term--ausgefallen  { background: #fdebd0; border-left-color: #c05621; color: #9c4221; }
.term--abgelehnt    { background: #f3e8e8; border-left-color: #9b6b6b; color: #7a4a4a; text-decoration: line-through; }
.term--abgesagt     { background: #fdecea; border-left-color: #c0392b; color: #9b2c2c; text-decoration: line-through; }

.cal-legend { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: 0.9rem; font-size: 0.85rem; color: var(--muted); }
.cal-legend__item { display: flex; align-items: center; gap: 0.35rem; }
.cal-legend__note { font-style: italic; }
.cal-legend .dot { width: 14px; height: 14px; border-radius: 3px; border-left: 3px solid; display: inline-block; }

/* Gesamtkalender „Alle Therapeuten": Farbe = Therapeut + Kürzel im Block */
.term__th { font-weight: 700; opacity: 0.8; margin-right: 0.15rem; }
.term.is-cancelled { text-decoration: line-through; opacity: 0.6; }
.term-th--0 { background: #e3eefb; border-left-color: #2b6cb0; color: #1f4e7a; }
.term-th--1 { background: #e6f4ea; border-left-color: #2f855a; color: #22543d; }
.term-th--2 { background: #efe7fb; border-left-color: #6b46c1; color: #44337a; }
.term-th--3 { background: #fdecd9; border-left-color: #c05621; color: #7b341e; }
.term-th--4 { background: #def7f4; border-left-color: #2c7a7b; color: #234e52; }
.term-th--5 { background: #fde5ef; border-left-color: #b83280; color: #702459; }
.term-th--6 { background: #fcf3cf; border-left-color: #b7791f; color: #744210; }
.term-th--7 { background: #e6e9fb; border-left-color: #4c51bf; color: #3c366b; }
.term-th--8 { background: #ddf2fb; border-left-color: #2b8bb0; color: #1f5a7a; }
.term-th--9 { background: #f0e6e0; border-left-color: #8a5a3b; color: #5a3a26; }

/* ---------- Gefahr-Aktion ---------- */
.danger-form { margin-top: 1.75rem; padding-top: 1rem; border-top: 1px solid var(--border); }
.linkbtn--danger { color: var(--danger); }
.linkbtn--danger:hover { color: #922b21; }

/* ---------- Status-Badges (Listen) ---------- */
.status { display: inline-block; font-size: 0.75rem; padding: 0.15rem 0.55rem; border-radius: 999px; font-weight: 600; white-space: nowrap; }
.status--angefragt    { background: #fff4e0; color: #8a5a12; }
.status--offen        { background: #eef2f7; color: #33414f; }
.status--bestaetigt   { background: #e6f4ea; color: #22543d; }
.status--wahrgenommen { background: #e3f0fb; color: #1f4e7a; }
.status--ausgefallen  { background: #fdebd0; color: #9c4221; }
.status--abgelehnt    { background: #fdecea; color: #9b2c2c; }
.status--abgesagt     { background: #eceff1; color: var(--muted); text-decoration: line-through; }

/* ---------- Dashboard-Panel & Anfragen ---------- */
/* .panel ist NUR ein vollbreiter Abstands-Container (Tabellen, Dashboard, Info-Boxen) –
   bewusst OHNE Rahmen. Rahmen kommen ausschließlich von .form-section (sitzt in einem
   max-width-Formular → immer inhaltsbreit). So bleibt ein Rahmen app-weit formgroß. */
.panel { margin-bottom: 1.75rem; }

/* Admin-Cockpit: Kennzahl-Karten */
.stat-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 1rem; margin-top: 0.5rem; }
.stat-card { border: 1px solid var(--border); border-radius: var(--radius); padding: 1rem 1.1rem; background: var(--surface); }
.stat-card__value { font-size: 1.6rem; font-weight: 700; color: var(--text); line-height: 1.1; }
.stat-card__label { color: var(--muted); font-size: 0.85rem; margin-top: 0.25rem; }
.stat-card__sub { color: var(--muted); font-size: 0.78rem; margin-top: 0.4rem; }
.badge--warn { background: #fff4e0; color: #8a5a12; }

/* Auswertungen: Zeitraumfilter, rechtsbündige Zahlen, Auslastungs-Balken */
.report-meta { color: var(--muted); font-size: 0.9rem; }
.report-presets { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-bottom: 0.9rem; }
.report-range { display: flex; flex-wrap: wrap; gap: 0.75rem; align-items: flex-end; }
.report-range label { display: flex; flex-direction: column; font-size: 0.85rem; color: var(--muted); gap: 0.2rem; }
.report-note { color: var(--muted); font-size: 0.82rem; line-height: 1.5; max-width: 70ch; }
.table td.num, .table th.num { text-align: right; white-space: nowrap; }
.bar { display: inline-block; vertical-align: middle; width: 120px; height: 9px; background: var(--border);
       border-radius: 999px; overflow: hidden; }
.bar__fill { display: block; height: 100%; background: var(--accent); border-radius: 999px; }
.bar__pct { margin-left: 0.5rem; font-variant-numeric: tabular-nums; color: var(--text); }

/* ---------- Übungspläne (Hausaufgaben) ---------- */
.table tr.is-inactive td { opacity: 0.55; }

/* Bibliotheks-Formular: vertikale Felder, volle Breite */
.stack-form { display: flex; flex-direction: column; gap: 1rem; max-width: 760px; }
/* Nicht nur direkte Kinder: Labels behalten ihr Styling auch innerhalb eines .form-section-Rahmens. */
.stack-form label { display: flex; flex-direction: column; gap: 0.3rem; font-size: 0.9rem; color: var(--muted); }
.stack-form label.check { flex-direction: row; align-items: center; gap: 0.5rem; color: var(--text); }
.stack-form input[type=text], .stack-form textarea, .stack-form select,
#uebungsplan-form input[type=text], #uebungsplan-form textarea, #uebungsplan-form select,
.ueb-ki textarea {
    padding: 0.5rem 0.7rem; border: 1px solid var(--border); border-radius: 4px;
    font: inherit; font-size: 1rem; width: 100%; background: var(--surface);
}
.stack-form label.check input { width: auto; }
/* Editor-Formular auf Formgröße deckeln (war ohne max-width → komplett vollbreit). */
#uebungsplan-form { max-width: 760px; }
#uebungsplan-form .panel > label { display: flex; flex-direction: column; gap: 0.3rem; font-size: 0.9rem; color: var(--muted); margin-bottom: 0.85rem; }

/* Positionen-Editor */
.ueb-add { display: flex; flex-wrap: wrap; gap: 0.5rem; align-items: center; margin-bottom: 1rem; }
.ueb-add .ueb-lib-select { flex: 1; min-width: 280px; }
.pos-list { display: flex; flex-direction: column; gap: 0.75rem; }
.pos-row { border: 1px solid var(--border); border-radius: var(--radius); padding: 0.75rem; background: var(--surface); }
.pos-row__main { display: flex; gap: 0.5rem; align-items: center; }
.pos-row__main .pos-bez { flex: 1; font-weight: 600; }
.pos-row__anl { display: flex; gap: 0.5rem; align-items: flex-start; margin-top: 0.5rem; }
.pos-row__anl textarea { flex: 1; }
.pos-row__anl .js-ueb-format { white-space: nowrap; }
.pos-row__meta { display: flex; gap: 0.5rem; margin-top: 0.5rem; flex-wrap: wrap; }
.pos-row__meta input { flex: 1; min-width: 110px; }

/* KI-Übungsvorschläge */
.ueb-ki { background: var(--accent-bg); border: 1px solid var(--border); border-radius: var(--radius); padding: 1.1rem 1.25rem; }
.ueb-ki__input { margin: 0.5rem 0; }
.ueb-ki__results { display: flex; flex-direction: column; gap: 0.5rem; margin-top: 0.75rem; }
.ueb-suggest { border: 1px dashed var(--border); border-radius: var(--radius); padding: 0.6rem 0.8rem; }
.ueb-suggest.is-used { opacity: 0.55; }
.ueb-suggest__name { font-weight: 600; }
.ueb-suggest__anl { font-size: 0.9rem; margin: 0.2rem 0; }
.ueb-suggest__meta { font-size: 0.82rem; color: var(--muted); margin-bottom: 0.45rem; }

/* Patientenansicht „Meine Übungen" */
.uebung-plan__hinweis { background: var(--accent-bg); border-radius: var(--radius); padding: 0.6rem 0.8rem; }
.uebung-liste { padding-left: 1.2rem; }
.uebung-item { margin-bottom: 0.9rem; }
.uebung-item__name { font-weight: 600; }
.uebung-item__anl { margin: 0.15rem 0; }
.uebung-item__meta { font-size: 0.85rem; color: var(--muted); }

@media print {
    .header, .sidebar, .footer, .no-print, .page-head__actions { display: none !important; }
    .layout, .main { display: block; margin: 0; padding: 0; }
}

/* ---------- Warteliste: Dashboard-Angebote ---------- */
.wl-angebot { border: 1px solid var(--border); border-radius: var(--radius); padding: 0.75rem 1rem; margin-bottom: 1rem; background: var(--surface); }
.wl-angebot__slot { margin-bottom: 0.5rem; }
.wl-angebot .table { margin-top: 0.25rem; }
.button--small { padding: 0.3rem 0.75rem; font-size: 0.85rem; }
.anfrage-actions { display: flex; flex-wrap: wrap; gap: 0.5rem; align-items: center; }
.anfrage-reject { display: flex; gap: 0.35rem; align-items: center; }
.grund-input { padding: 0.3rem 0.5rem; border: 1px solid var(--border); border-radius: 4px; font: inherit; font-size: 0.85rem; max-width: 150px; }

/* ---------- Online-Zugang im Formular ---------- */
.account-box { margin-top: 1.75rem; padding-top: 1.25rem; border-top: 1px solid var(--border); }
.account-box h2 { margin-top: 0; }
.danger-zone { border-top: 2px solid var(--danger); }
.danger-zone h2 { color: var(--danger); }

/* ---------- Responsive – Zielgeräte: PC + Tablet (kein Smartphone) ---------- */

/* Tablet quer / kleinere Notebooks: nur Abstände straffen */
@media (max-width: 1024px) {
    .layout { padding: 0 1rem; gap: 1.25rem; }
    .header__inner, .footer__inner { padding-left: 1rem; padding-right: 1rem; }
}

/* Tablet hoch (~768–834 px): schmalere Sidebar, Formularzeilen stapeln */
@media (max-width: 834px) {
    :root { --sidebar-width: 180px; }
    .layout { gap: 1rem; }
    .sidebar { padding: 0.75rem; }
    .main { padding: 1.25rem; }
    .form__row { flex-direction: column; gap: 1rem; }
    .form__row .field--narrow { flex: 1; }
    .table .actions a { display: inline-block; margin-bottom: 0.25rem; }
}

/* Sicherheitsnetz für sehr schmale Fenster – kein offizielles Zielgerät */
@media (max-width: 640px) {
    .layout { grid-template-columns: 1fr; }
    .header__inner { flex-wrap: wrap; }
    .header__nav { order: 3; flex-basis: 100%; }
    .footer__inner { flex-direction: column; align-items: flex-start; }
    .footer__links { margin-left: 0; }
}

/* ---------- Fußzeile (klebt am Seitenende) ---------- */
body { display: flex; flex-direction: column; min-height: 100vh; }
.layout { flex: 1 0 auto; }
.footer { flex-shrink: 0; background: var(--header-bg); color: var(--header-text-muted); }
.footer__inner {
    max-width: var(--max-width); margin: 0 auto; padding: 1rem 1.5rem;
    display: flex; flex-wrap: wrap; align-items: center; gap: 0.4rem 1.25rem; font-size: 0.85rem;
}
.footer__brand { font-weight: 600; color: var(--header-text); }
.footer__links { display: flex; flex-wrap: wrap; gap: 1rem; margin-left: auto; }
.footer__links a { color: var(--header-text); text-decoration: none; opacity: 0.85; }
.footer__links a:hover { opacity: 1; text-decoration: underline; }
.footer__soon { opacity: 0.7; }

/* ---------- Meine E-Mails ---------- */
.maillist { list-style: none; margin: 0; padding: 0; }
.mailitem { border: 1px solid var(--border); border-radius: var(--radius); padding: 0.9rem 1.1rem; margin-bottom: 1rem; }
.mailitem__head { display: flex; justify-content: space-between; align-items: baseline; gap: 1rem; }
.mailitem__subject { font-weight: 600; }
.mailitem__date { color: var(--muted); font-size: 0.85rem; white-space: nowrap; }
.mailitem__from { color: var(--muted); font-size: 0.85rem; margin-top: 0.15rem; }
.mailitem__body {
    white-space: pre-wrap; word-break: break-word; font-family: inherit; font-size: 0.9rem;
    margin: 0.7rem 0 0; padding-top: 0.7rem; border-top: 1px dashed var(--border);
}

/* ---------- Termin-Übertragung ---------- */
/* Vollbreiter Abstands-Container OHNE Rahmen (Rahmen nur via .form-section, formgroß). */
.panel--transfer { margin-top: 1.75rem; }
.transfer-form { display: flex; flex-wrap: wrap; align-items: flex-end; gap: 0.75rem; }
.transfer-form label { display: flex; flex-direction: column; gap: 0.3rem; font-size: 0.9rem; color: var(--muted); }
.transfer-form select { padding: 0.4rem 0.6rem; border: 1px solid var(--border); border-radius: 4px; font: inherit; }

/* ---------- Datei-Uploads ---------- */
/* Abstands-Container OHNE Rahmen, aber auf Formgröße gedeckelt (sonst zieht die Dateiliste
   voll auf, sobald Einträge da sind). 760px = gleiche Spaltenbreite wie .doku-form/.stack-form. */
.panel--files { max-width: 760px; margin-top: 1.5rem; }
.filelist { list-style: none; margin: 0 0 1rem; padding: 0; }
.fileitem { display: flex; align-items: center; gap: 0.75rem; padding: 0.5rem 0; border-bottom: 1px solid var(--border); }
.fileitem:last-child { border-bottom: none; }
.fileitem__name { font-weight: 500; margin-right: auto; }
.fileitem__meta { color: var(--muted); font-size: 0.8rem; white-space: nowrap; }
.fileitem__del { margin: 0; }
.fileupload { display: flex; flex-wrap: wrap; align-items: center; gap: 0.6rem; }
.filehint { margin: 0.5rem 0 0; font-size: 0.8rem; }

/* ---------- Dokumentations-Editor ---------- */
.alert--info { background: var(--accent-bg); color: var(--accent-hover); border: 1px solid #b8dccb; }
.doku-termininfo { display: flex; flex-wrap: wrap; gap: 0.4rem 2rem; }
.doku-termininfo > div { font-size: 0.95rem; }

.wysiwyg { margin-bottom: 1.25rem; }
.wysiwyg__label { display: block; font-size: 0.9rem; font-weight: 600; margin-bottom: 0.35rem; }
.wysiwyg__label .muted { font-weight: 400; }
.wysiwyg__toolbar {
    display: flex; flex-wrap: wrap; gap: 0.3rem; padding: 0.35rem;
    border: 1px solid var(--border); border-bottom: none; border-radius: 6px 6px 0 0; background: var(--bg3, #f0ede4);
}
.wysiwyg__btn {
    border: 1px solid var(--border); background: #fff; border-radius: 4px; padding: 0.2rem 0.55rem;
    font-size: 0.85rem; cursor: pointer; line-height: 1.4;
}
.wysiwyg__btn:hover { background: var(--accent-bg); border-color: var(--accent); }
.wysiwyg__improve { margin-left: auto; color: var(--accent); border-color: var(--accent); font-weight: 500; }
.wysiwyg__improve:disabled { opacity: 0.6; cursor: progress; }
.wysiwyg__aistatus { align-self: center; font-size: 0.8rem; color: var(--muted); }
.wysiwyg__size { border: 1px solid var(--border); border-radius: 4px; padding: 0.2rem 0.4rem; font: inherit; font-size: 0.85rem; }
.wysiwyg__area {
    border: 1px solid var(--border); border-radius: 0 0 6px 6px; padding: 0.6rem 0.75rem;
    min-height: 90px; background: #fff; line-height: 1.5;
}
.wysiwyg__area:focus { outline: 2px solid var(--accent); outline-offset: -2px; }
.wysiwyg__area ul, .wysiwyg__area ol { margin: 0.3rem 0 0.3rem 1.4rem; }

.doku-section { margin-bottom: 1rem; }
.doku-section h3 { font-size: 0.95rem; margin: 0 0 0.25rem; color: var(--accent-hover); }
.doku-readonly { border: 1px solid var(--border); border-radius: 6px; padding: 0.6rem 0.75rem; background: #fff; }
.doku-readonly ul, .doku-readonly ol { margin: 0.3rem 0 0.3rem 1.4rem; }
.doku-final__head { display: flex; flex-wrap: wrap; align-items: center; gap: 0.6rem; margin-bottom: 0.9rem; }
.doku-versions { list-style: none; margin: 0; padding: 0; }
.doku-versions > li { border-top: 1px solid var(--border); padding: 0.5rem 0; }
.doku-versions summary { cursor: pointer; display: flex; flex-wrap: wrap; align-items: center; gap: 0.4rem; }
.doku-versions summary > .muted { flex-basis: 100%; font-size: 0.8rem; }

/* ---------- Kalender: Hover-Detailkarte ---------- */
.cal .term { cursor: pointer; }
.cal-tip {
    position: fixed; z-index: 1000; max-width: 280px;
    background: #1f2a36; color: #fff; border-radius: 6px; padding: 0.6rem 0.75rem;
    font-size: 0.8rem; line-height: 1.45; box-shadow: 0 4px 14px rgba(0, 0, 0, 0.28);
    pointer-events: none;
}
.cal-tip[hidden] { display: none; }
.cal-tip__title { font-weight: 600; margin-bottom: 0.3rem; font-size: 0.85rem; }
.cal-tip__row + .cal-tip__row { margin-top: 0.1rem; }
.cal-tip__label { color: #9fb3c8; }

/* ---------- KI-Doku-Assist ---------- */
.ki-assist {
    background: var(--accent-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1.1rem 1.25rem;
}
.ki-assist__title { display: flex; align-items: center; gap: 0.5rem; margin-bottom: 0.4rem; }
.ki-assist__hint { margin-bottom: 0.75rem; }
.ki-assist__input {
    width: 100%; resize: vertical; padding: 0.6rem 0.7rem; font: inherit;
    border: 1px solid var(--border); border-radius: 6px; background: var(--surface);
}
.ki-assist__input:focus { outline: none; border-color: var(--accent); }
.ki-assist__actions { display: flex; align-items: center; gap: 0.9rem; margin-top: 0.7rem; }
.ki-assist__status { font-size: 0.9rem; }
.ki-assist__run[disabled] { opacity: 0.6; cursor: progress; }
.ki-verlauf__actions { display: flex; align-items: center; gap: 0.9rem; }
.ki-verlauf__run[disabled] { opacity: 0.6; cursor: progress; }
.ki-verlauf__status { font-size: 0.9rem; }
.ki-verlauf__result { margin-top: 0.9rem; background: var(--surface); border: 1px solid var(--border); border-radius: 6px; padding: 0.9rem 1.1rem; line-height: 1.55; }

/* --- Verordnungen: Behandlungszähler + Positionen --- */
.vo-meter { margin: 0.25rem 0 0.85rem; }
.vo-meter__bar { height: 14px; border-radius: 7px; background: var(--accent-bg); overflow: hidden; display: flex; }
.vo-meter__bar span { display: block; height: 100%; background: var(--accent); transition: width 0.2s; flex: 0 0 auto; }
/* zweites Segment: bereits verplante (gebuchte, noch nicht wahrgenommene) Behandlungen */
.vo-meter__bar .vo-meter__plan { background: #9cc1ab; }
.vo-meter__label { margin-top: 0.45rem; font-size: 0.95rem; }
.vo-facts { list-style: none; padding: 0; margin: 0.25rem 0 0.6rem; display: flex; flex-wrap: wrap; gap: 0.35rem 1.5rem; }
.vo-facts li { margin: 0; }
.vo-positionen { margin-bottom: 0.6rem; }
.vo-pos-row { align-items: end; }
.vo-termin--zaehlt td { background: var(--accent-bg); }
.text--warn { color: #9c4221; }

/* --- Serientermine --- */
.serie-weekdays { border: 1px solid var(--border); border-radius: var(--radius); padding: 0.6rem 0.9rem; margin: 0.25rem 0 0.9rem; }
.serie-weekdays legend { padding: 0 0.4rem; font-size: 0.9rem; }
.checkbox-inline { display: inline-flex; align-items: center; gap: 0.3rem; margin-right: 1rem; font-weight: normal; }
/* In .form überschreibt sonst `.form label` (column) das inline-flex → höhere Spezifität nötig. */
.form .checkbox-inline { display: inline-flex; flex-direction: row; align-items: center; gap: 0.3rem; margin: 0 1rem 0 0; color: var(--text); font-weight: normal; }
.form .checkbox-inline input { width: auto; }
.serie-skip td { opacity: 0.6; }

/* --- Feiertage / Schließtage (praxisweit, eigene Farbe ggü. Arbeitszeit/Abwesenheit) --- */
.cal-feiertag {
    position: absolute; left: 0; right: 0; z-index: 0; pointer-events: none; overflow: hidden;
    background: repeating-linear-gradient(45deg, #fbeeee, #fbeeee 7px, #f6dede 7px, #f6dede 14px);
}
.cal-feiertag__label { display: block; padding: 3px 5px; font-size: 0.7rem; font-weight: 600; color: #9b2c2c; white-space: nowrap; }
.cal__dayhead.is-closed .cal__daylink { color: #9b2c2c; }
.cal__closed-name { display: block; font-size: 0.66rem; color: #9b2c2c; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cal-legend .dot--feiertag {
    border-left: 0;
    background: repeating-linear-gradient(45deg, #fbeeee, #fbeeee 4px, #f6dede 4px, #f6dede 8px);
}
