/* ============================================================
   MVZ Dienstplan — Basis-Stylesheet
   Grünes Design, DM Sans (analog Leitlinien-Assistent)
   ============================================================ */
:root {
  --c-bg:#F4F3F0; --c-surface:#FFFFFF; --c-surface2:#F9F8F6;
  --c-border:#E8E6E1; --c-border2:#F0EEE9;
  --c-text:#1A1916; --c-text2:#6B6860; --c-text3:#A8A49D;
  --c-accent:#2D6A4F; --c-accent2:#1B4332; --c-accent-l:#D8EEE4; --c-accent-t:#52B788;
  --c-warn:#E76F51; --c-warn-l:#FDE8E0;
  --c-info:#2B6CB0; --c-info-l:#EBF4FF;
  --c-yellow:#F4A261; --c-yellow-l:#FEF0E4;
  --r-sm:6px; --r-md:10px; --r-lg:14px;
  --shadow:0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);
  --shadow-md:0 4px 12px rgba(0,0,0,.08),0 2px 4px rgba(0,0,0,.04);
  --shadow-lg:0 8px 32px rgba(0,0,0,.16);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'DM Sans',system-ui,sans-serif;background:var(--c-bg);color:var(--c-text);font-size:13px;-webkit-font-smoothing:antialiased}

/* ── Buttons ── */
.btn{font-size:11px;font-weight:500;padding:6px 12px;border-radius:var(--r-sm);border:1px solid var(--c-border);background:var(--c-surface);color:var(--c-text2);cursor:pointer;display:inline-flex;align-items:center;gap:5px;transition:all .15s;white-space:nowrap;font-family:inherit}
.btn:hover{background:var(--c-surface2);border-color:var(--c-text3)}
.btn-primary{background:var(--c-accent);color:#fff;border-color:var(--c-accent)}
.btn-primary:hover{background:var(--c-accent2);border-color:var(--c-accent2)}
.btn-warn{background:var(--c-warn-l);color:var(--c-warn);border-color:var(--c-warn)}
.btn-danger{background:#FEE2E2;color:#DC2626;border-color:#FCA5A5}
.btn-sm{font-size:10px;padding:3px 8px}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* ── Pills ── */
.pill{display:inline-block;font-size:9px;font-weight:600;padding:2px 7px;border-radius:99px;letter-spacing:.02em}
.pill-ok{background:var(--c-accent-l);color:var(--c-accent2)}
.pill-warn{background:var(--c-warn-l);color:var(--c-warn)}
.pill-info{background:var(--c-info-l);color:var(--c-info)}
.pill-neutral{background:var(--c-surface2);color:var(--c-text3);border:1px solid var(--c-border)}
.pill-mfa{background:#D1FAE5;color:#065F46}
.pill-buro{background:#DBEAFE;color:#1E40AF}
.pill-quer{background:#FEF3C7;color:#92400E}
.pill-azubi{background:#EDE9FE;color:#5B21B6}
.pill-mini{background:var(--c-surface2);color:var(--c-text2);border:1px solid var(--c-border)}
.pill-urlaub{background:#FEE2E2;color:#991B1B}
.pill-krank{background:#FEF3C7;color:#92400E}
.pill-eltern{background:#EDE9FE;color:#5B21B6}

/* ── Cards ── */
.card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-lg);padding:16px 18px;margin-bottom:14px;box-shadow:var(--shadow)}
.card-title{font-size:12px;font-weight:600;color:var(--c-text2);margin-bottom:12px;display:flex;align-items:center;justify-content:space-between;gap:8px}

/* ── Form-Elemente ── */
.field{margin-bottom:10px}
.field-label{font-size:10px;font-weight:600;color:var(--c-text3);text-transform:uppercase;letter-spacing:.05em;margin-bottom:3px}
.field-input,.field-select{font-size:12px;color:var(--c-text);background:var(--c-surface2);border:1px solid var(--c-border);border-radius:var(--r-sm);padding:6px 9px;width:100%;font-family:inherit}
.field-input:focus,.field-select:focus{outline:none;border-color:var(--c-accent-t)}
.field-val{font-size:12px;color:var(--c-text);background:var(--c-surface2);border:1px solid var(--c-border);border-radius:var(--r-sm);padding:6px 9px}
.field-val.readonly{color:var(--c-text3);background:#FAFAFA;font-style:italic;display:flex;align-items:center;gap:5px}

/* ── Tabellen ── */
.data-table{width:100%;border-collapse:collapse;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-lg);overflow:hidden}
.data-table thead th{background:var(--c-surface2);border-bottom:1px solid var(--c-border);padding:9px 12px;font-size:10px;font-weight:600;color:var(--c-text3);text-transform:uppercase;letter-spacing:.05em;text-align:left;cursor:pointer;user-select:none;white-space:nowrap}
.data-table thead th:hover{color:var(--c-accent)}
.data-table tbody tr{border-bottom:1px solid var(--c-border2);cursor:pointer;transition:background .1s}
.data-table tbody tr:last-child{border-bottom:none}
.data-table tbody tr:hover{background:var(--c-surface2)}
.data-table td{padding:8px 12px;vertical-align:middle}

/* ── Avatare ── */
.av{border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;flex-shrink:0}
.av-sm{width:24px;height:24px;font-size:9px}
.av-md{width:28px;height:28px;font-size:10px}
.av-lg{width:34px;height:34px;font-size:11px}

/* ── Toggle ── */
.toggle{width:34px;height:20px;border-radius:99px;background:var(--c-border);cursor:pointer;position:relative;border:none;flex-shrink:0;transition:background .2s}
.toggle.on{background:var(--c-accent)}
.toggle::after{content:'';position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:left .2s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.toggle.on::after{left:16px}

/* ── Toast / Bestätigung ── */
#toast-container{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);z-index:9999;display:flex;flex-direction:column;gap:8px;align-items:center}
.toast{background:var(--c-text);color:#fff;padding:9px 16px;border-radius:var(--r-md);font-size:12px;font-weight:500;box-shadow:var(--shadow-lg);opacity:0;transform:translateY(10px);transition:all .25s;display:flex;align-items:center;gap:7px}
.toast.show{opacity:1;transform:translateY(0)}
.toast.success{background:var(--c-accent)}
.toast.error{background:var(--c-warn)}

/* ── Modal ── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:500;display:none;align-items:center;justify-content:center;padding:20px}
.modal-overlay.open{display:flex}
.modal{background:var(--c-surface);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);width:100%;max-width:480px;max-height:85vh;overflow-y:auto}
.modal-header{padding:16px 20px;border-bottom:1px solid var(--c-border);display:flex;align-items:center;justify-content:space-between}
.modal-title{font-size:15px;font-weight:600}
.modal-body{padding:20px}
.modal-footer{padding:14px 20px;border-top:1px solid var(--c-border);display:flex;justify-content:flex-end;gap:8px}

/* ── Loading / Empty States ── */
.loading{display:flex;align-items:center;justify-content:center;padding:40px;color:var(--c-text3);font-size:12px;gap:8px}
.spinner{width:16px;height:16px;border:2px solid var(--c-border);border-top-color:var(--c-accent);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.empty-state{text-align:center;padding:48px 20px;color:var(--c-text3)}
.empty-state i{font-size:40px;opacity:.4;margin-bottom:10px;display:block}
.empty-state-text{font-size:13px}

.skeleton{background:linear-gradient(90deg,var(--c-surface2) 25%,var(--c-border2) 50%,var(--c-surface2) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:var(--r-sm)}
@keyframes shimmer{to{background-position:-200% 0}}

/* ── Scrollbars ── */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--c-border);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--c-text3)}

.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
