/* ===========================================================================
   Dienstplaner — NUR das Station×Tag-Matrix-Grid + ein paar dünne Layout-Helfer.
   Alles andere (Header, Tabs, Karten, KPIs, Chips, Buttons, Felder, Listen)
   nutzt die Cockpit-Primitives (cock-*). Maße/Farben strikt über Design-Tokens,
   damit es identisch zu dark/light/wellness-light themt und „aus einem Guss" wirkt.
   =========================================================================== */

/* Seiten-Padding wie alle Portal-Seiten (entspricht Bewerbungen-Wrapper `p-4 sm:p-6`).
   .dp-root hatte vorher kein Padding → Inhalt klebte an den Kanten. */
.dp-root { padding:16px; }
@media (min-width:640px) { .dp-root { padding:24px; } }

/* Dünne Layout-Helfer (kein Cockpit-Pendant) */
.dp-grid { display:grid; gap:var(--s-3); }
.dp-g2 { grid-template-columns:repeat(2,1fr); }
.dp-g3 { grid-template-columns:repeat(3,1fr); }
.dp-g4 { grid-template-columns:repeat(4,1fr); }
@media (max-width:760px) { .dp-g4 { grid-template-columns:repeat(2,1fr); } .dp-g3, .dp-g2 { grid-template-columns:1fr; } }
.dp-qual-row { display:flex; flex-wrap:wrap; gap:var(--s-2); }
.dp-toolbar { display:flex; align-items:center; gap:var(--s-2); }

/* Kompakte Team-Tabelle (alle auf einen Blick): enge Zeilen, einzeilig. */
html[data-cockpit="on"] .dp-team-table thead th { padding:6px 14px; }
html[data-cockpit="on"] .dp-team-table tbody td { padding:5px 14px; font-size:13px; }
.dp-tt-name { font-weight:var(--weight-body-strong); color:var(--text-primary); white-space:nowrap; }
.dp-tt-quals { max-width:360px; font-size:12px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.dp-tt-ist { font-weight:var(--weight-body-strong); }

/* Reiter-Zeile: Tabs links, tab-spezifische Steuerung (z. B. Wochen-Nav) rechts — eine Kopfzeile. */
.dp-tabbar { display:flex; align-items:center; justify-content:space-between; gap:var(--s-3); flex-wrap:wrap; margin-bottom:var(--s-4); }
.dp-tabbar .cock-tabs { margin-bottom:0; }
/* Zähler-Badge am „Anfragen"-Reiter */
.dp-badge { display:inline-flex; align-items:center; justify-content:center; min-width:17px; height:17px; padding:0 5px; margin-left:5px;
  border-radius:var(--r-pill); background:var(--danger); color:#fff; font-size:10px; font-weight:var(--weight-body-strong); line-height:1; vertical-align:middle; }

/* Neutrale Icon-Kachel für Stationen (Emoji auf ruhigem Grund statt Accent-Tint) */
.dp-sticon { width:32px; height:32px; flex:0 0 auto; border-radius:var(--r-md);
  background:var(--surface-base); border:1px solid var(--hairline); display:grid; place-items:center; font-size:15px; line-height:1; }
.dp-sticon--lg { width:38px; height:38px; font-size:18px; }

/* Einfache, einheitliche Listenzeile mit Trenner (Schichttypen u. a.) */
.dp-list-row { display:flex; align-items:center; gap:var(--s-3); padding:var(--s-3) var(--s-1); }
.dp-list-row + .dp-list-row { border-top:1px solid var(--hairline); }

/* Qualifikations-Auswahl im Stations-Modal */
.dp-checkgrid { display:flex; flex-wrap:wrap; gap:var(--s-2); }
.dp-checkrow { display:inline-flex; align-items:center; gap:7px; padding:7px 12px; border-radius:var(--r-pill);
  border:1px solid var(--hairline); background:var(--surface-base); cursor:pointer; font-size:13px; color:var(--text-secondary);
  transition:border-color var(--t-fast), background var(--t-fast); user-select:none; }
.dp-checkrow:hover { border-color:var(--accent); }
.dp-checkrow:has(input:checked) { border-color:var(--accent); background:var(--accent-soft); color:var(--text-primary); }
.dp-checkrow input { accent-color:var(--accent); width:15px; height:15px; }

/* Farb-Picker (Schicht-Modal) */
.dp-color { width:100%; height:40px; padding:3px; border:1px solid var(--hairline); border-radius:var(--r-md);
  background:var(--surface-base); cursor:pointer; }

/* ---- Wochenplan: volle Matrix-Breite + Team als sticky Ablage unten ---- */
.dp-tray { position:sticky; bottom:0; z-index:6; display:flex; align-items:center; gap:var(--s-3);
  margin-top:var(--s-3); padding:var(--s-2) var(--s-3);
  background:var(--surface-1); border:1px solid var(--hairline); border-radius:var(--r-lg);
  box-shadow:0 -6px 18px rgba(0,0,0,.07); }
.dp-tray__label { flex:0 0 auto; }
/* Mind. 2 Reihen: Grid füllt 2 Zeilen, fließt dann in neue Spalten (horizontal scrollbar). */
.dp-tray__list { display:grid; grid-auto-flow:column; grid-template-rows:repeat(3,auto); gap:6px var(--s-2);
  align-content:center; overflow-x:auto; padding-bottom:2px; flex:1; min-width:0; }
/* Kompakter Name-Chip (nur Name, keine Kenntnisse — Quals im title-Tooltip). */
.dp-rchip { min-width:112px; max-width:172px; display:flex; align-items:center; gap:7px; padding:4px 10px 4px 4px; border-radius:var(--r-pill);
  border:1px solid var(--hairline); background:var(--surface-base); cursor:grab; transition:border-color var(--t-fast); }
.dp-rchip:hover { border-color:var(--accent); }
.dp-rchip:active, .dp-rchip.dragging { cursor:grabbing; opacity:.5; }
.dp-rchip__name { font-size:12.5px; font-weight:var(--weight-body-strong); line-height:1.2; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; color:var(--text-primary); }

.dp-matrix { width:100%; overflow:hidden;
  background:var(--surface-1); border:1px solid var(--hairline); border-radius:var(--r-lg); box-shadow:var(--shadow-1); }
.dp-matrix-scroll { overflow-x:auto; }
/* table-layout:fixed → Tagesspalten bleiben GLEICH breit, egal wie viele Chips drin sind
   (Chips brechen in der Zelle um statt die Spalte zu verbreitern). */
.dp-table { border-collapse:separate; border-spacing:0; width:100%; min-width:840px; table-layout:fixed; }
.dp-table th, .dp-table td { border-bottom:1px solid var(--hairline); border-right:1px solid var(--hairline); }
.dp-table thead th { background:var(--surface-base); padding:var(--s-2) var(--s-2); position:sticky; top:0; z-index:2; text-align:center; }
.dp-th-day { font-size:12px; font-weight:var(--weight-body-strong); color:var(--text-primary); }
.dp-th-date { font-size:10px; font-weight:var(--weight-label); color:var(--text-muted); margin-top:2px; }
.dp-table thead th.dp-today, .dp-table td.dp-today { background:var(--accent-soft); }
.dp-corner { text-align:left !important; padding-left:var(--s-3) !important; left:0; z-index:3 !important; width:160px; }
.dp-rowhead { background:var(--surface-1); text-align:left; padding:var(--s-2) var(--s-3); position:sticky; left:0; z-index:1; min-width:136px; white-space:nowrap; }
.dp-rowhead__name { font-size:13px; font-weight:var(--weight-body-strong); color:var(--text-primary); }
.dp-cell { vertical-align:top; padding:var(--s-1); min-width:128px; }
.dp-slot { position:relative; display:flex; flex-wrap:wrap; gap:4px; align-content:flex-start;
  border-radius:var(--r-sm); padding:17px var(--s-2) 6px; min-height:26px; margin-bottom:4px; transition:background var(--t-fast); }
.dp-slot:last-child { margin-bottom:0; }
.dp-slot.ok { background:var(--success-soft); }
.dp-slot.under { background:var(--warning-soft); }
.dp-slot.empty { background:var(--interactive); }
/* Wunschtag/-schicht des gezogenen MA: dezenter Accent-Rahmen während des Ziehens. */
.dp-slot.pref { box-shadow:inset 0 0 0 1.5px var(--accent); }
.dp-slot.hov { outline:2px dashed var(--accent); outline-offset:-2px; background:var(--accent-soft) !important; }
.dp-slot-tag { position:absolute; top:3px; left:7px; font-size:10px; font-weight:var(--weight-label); letter-spacing:var(--tracking-label); text-transform:uppercase; color:var(--text-muted); line-height:1; }
.dp-mchip { display:inline-flex; align-items:center; gap:5px; padding:2px 8px 2px 2px; border-radius:var(--r-pill); max-width:100%; min-width:0;
  background:var(--surface-1); border:1px solid var(--hairline-strong); cursor:pointer; transition:border-color var(--t-fast), background var(--t-fast); }
.dp-mchip:hover { border-color:var(--danger); background:var(--danger-soft); }
.dp-mchip.bad { border-color:var(--danger); background:var(--danger-soft); }
/* Innenelemente klick-transparent → jeder Klick auf den Chip löst dessen onclick aus
   (sonst „verschluckt" z. B. das ⚠-SVG den Klick und der Entfernen-Dialog kommt nicht). */
.dp-mchip > * { pointer-events:none; }
.dp-mchip__av { width:20px; height:20px; border-radius:var(--r-pill); display:grid; place-items:center; font-size:9px; font-weight:var(--weight-body-strong); background:var(--accent-soft); color:var(--accent); flex:0 0 auto; }
.dp-mchip__nm { font-size:11px; font-weight:var(--weight-body-strong); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; min-width:0; color:var(--text-primary); }
.dp-mchip.bad .dp-mchip__nm { color:var(--danger); }
.dp-mchip__warn { color:var(--danger); display:inline-flex; }
.dp-mchip__warn svg { width:11px; height:11px; }
/* Wunschtag/-schicht erfüllt: dezenter Accent-Stern im Chip. */
.dp-mchip__pref { color:var(--accent); font-size:10px; line-height:1; flex:0 0 auto; }
.dp-frei { display:inline-flex; align-items:center; gap:3px; padding:2px 8px; border-radius:var(--r-pill);
  border:1px dashed var(--hairline); background:transparent; color:var(--text-muted); font-size:10px; font-weight:var(--weight-label); opacity:.72; }
.dp-frei::before { content:"＋"; font-weight:var(--weight-body-strong); opacity:.55; }
.dp-slot.hov .dp-frei { opacity:1; }

