/* Staffing v2 - grille hebdo greffes. Style aligne sur le wireframe v2. */

.staffing-wrap { display: flex; flex-direction: column; gap: 16px; }

.staffing-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; flex-wrap: wrap;
}
.staffing-toolbar .week-nav { display: flex; align-items: center; gap: 6px; }
.staffing-toolbar .week-nav .week-label {
  font-family: var(--sk-font-hand); font-weight: 800; font-size: 16px;
  padding: 0 8px; min-width: 120px; text-align: center;
}
.staffing-toolbar .toggles { display: flex; gap: 6px; align-items: center; }

.staffing-table {
  display: grid;
  grid-template-columns: 88px repeat(var(--staffing-surgeon-cols, 3), minmax(220px, 1fr));
  background: var(--sk-paper);
  border: 1px solid var(--sk-line);
  border-radius: var(--sk-r);
  overflow: auto;
}

.staffing-section-title {
  margin: 0;
  font-family: var(--sk-font-hand);
  font-weight: 800;
  font-size: 20px;
}

/* --- Bandeau KPI (style design « revu ») ------------------------------- */
.staffing-kpis {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 10px;
}
.staffing-kpi {
  background: var(--sk-paper);
  border: 1px solid var(--sk-line);
  border-radius: var(--sk-r);
  padding: 12px 16px;
}
.staffing-kpi .l {
  font-family: var(--sk-font-hand); font-weight: 700; font-size: 10.5px;
  letter-spacing: .14em; text-transform: uppercase; color: var(--sk-muted);
}
.staffing-kpi .v {
  font-family: var(--sk-font-hand); font-weight: 800; font-size: 28px;
  line-height: 1.1; margin-top: 2px;
}
.staffing-kpi .v.warn { color: var(--sk-warn); }

/* --- Ligne planning membres + panneau présences ----------------------- */
.staffing-org-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 300px;
  gap: 14px;
  align-items: start;
}

.staffing-presence {
  background: var(--sk-bg);
  border: 1px solid var(--sk-line);
  border-radius: var(--sk-r-lg);
  padding: 16px;
  display: flex; flex-direction: column; gap: 14px;
}
.sp-pres-kicker {
  font-family: var(--sk-font-hand); font-weight: 700; font-size: 10.5px;
  letter-spacing: .18em; text-transform: uppercase; color: var(--sk-muted);
}
.sp-pres-kicker.warn { color: var(--sk-warn); }
.sp-pres-bars { display: flex; flex-direction: column; gap: 7px; }
.sp-bar-row { display: flex; align-items: center; gap: 10px; }
.sp-bar-day { font-size: 12px; font-weight: 500; min-width: 64px; }
.sp-bar-track {
  flex: 1; height: 7px; background: var(--sk-paper-hover);
  border-radius: var(--sk-r-pill); overflow: hidden;
}
.sp-bar-fill { height: 100%; background: var(--sk-accent); }
.sp-bar-fill.low { background: #c69a4e; }
.sp-bar-n { font-size: 11.5px; font-weight: 600; min-width: 34px; text-align: right; }
.sp-bar-n.low { color: var(--sk-warn); }

.sp-pres-conflicts { border-top: 1px solid var(--sk-line); padding-top: 12px; }
.sp-conflict-list { display: flex; flex-direction: column; gap: 8px; margin-top: 8px; }
.sp-conflict {
  background: var(--sk-warn-soft);
  border: 1px solid var(--sk-warn-border);
  border-radius: 12px;
  padding: 8px 10px;
}
.sp-conflict-top { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.sp-conflict-badge {
  font-family: var(--sk-font-mono); font-size: 9px; font-weight: 700;
  color: #fff; background: var(--r-color, var(--sk-warn));
  border-radius: 4px; padding: 1px 4px;
}
.sp-conflict-name { font-size: 12px; font-weight: 600; color: var(--sk-warn); }
.sp-conflict-day { font-size: 11px; color: var(--sk-warn); }
.sp-conflict-msg { font-size: 11px; color: var(--sk-warn); margin-top: 3px; }

.sp-pres-note {
  margin-top: auto;
  background: var(--sk-accent-soft);
  border: 1px solid var(--sk-accent-border);
  border-radius: var(--sk-r);
  padding: 11px 13px;
  font-size: 11.5px; color: var(--sk-accent-dark); line-height: 1.5;
}

/* Chip d'absence déclarée dans le planning membres + conflit */
.sp-abs-chip {
  display: inline-flex; align-items: center; gap: 5px; align-self: flex-start;
  padding: 3px 9px; border-radius: var(--sk-r-pill);
  font-size: 11px; font-weight: 600; color: var(--r-color, var(--sk-muted));
  background: color-mix(in srgb, var(--r-color, var(--sk-muted)) 12%, transparent);
  border: 1px solid color-mix(in srgb, var(--r-color, var(--sk-muted)) 40%, transparent);
}
.sp-abs-chip .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--r-color, var(--sk-muted)); }
.sp-cell.member-day.conflict {
  background: var(--sk-warn-soft);
  box-shadow: inset 0 0 0 1px var(--sk-warn-border);
}

@media (max-width: 1100px) {
  .staffing-kpis { grid-template-columns: repeat(2, 1fr); }
  .staffing-org-row { grid-template-columns: 1fr; }
}

.staffing-member-card {
  background: var(--sk-paper);
  border: 1px solid var(--sk-line);
  border-radius: var(--sk-r);
  overflow: auto;
}

.staffing-member-head {
  padding: 16px;
  border-bottom: 1px solid var(--sk-line);
}

.staffing-people-table {
  display: grid;
  grid-template-columns: 96px repeat(var(--staffing-member-cols, 1), minmax(180px, 1fr));
  overflow: auto;
}

.sp-cell {
  border-right: 1px solid var(--sk-line);
  border-bottom: 1px solid var(--sk-line);
  background: var(--sk-bg);
  padding: 10px 12px;
  min-height: 76px;
}
.sp-cell.head {
  min-height: 56px;
  background: var(--sk-paper);
  font-family: var(--sk-font-hand);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--sk-muted);
}
.sp-cell.member-head {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 180px;
}
.member-avatar {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: var(--sk-accent);
  color: white;
  font-size: 11px;
  font-family: var(--sk-font-hand);
  font-weight: 800;
  flex-shrink: 0;
}
.member-name {
  color: var(--sk-ink);
  letter-spacing: 0;
  text-transform: none;
  font-family: var(--sk-font-ui);
  font-weight: 600;
  font-size: 12px;
}
.member-job {
  color: var(--sk-muted);
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: 9px;
  margin-top: 2px;
}
.sp-cell.day {
  display: flex;
  flex-direction: column;
  gap: 3px;
  background: var(--sk-paper);
  font-family: var(--sk-font-mono);
  font-size: 11px;
  color: var(--sk-muted);
}
.sp-cell.day strong {
  font-family: var(--sk-font-hand);
  color: var(--sk-ink);
  text-transform: uppercase;
  letter-spacing: .08em;
}
.sp-cell.today { background: var(--sk-accent-soft); }
.sp-cell.closed {
  background-image: repeating-linear-gradient(135deg, rgba(0,0,0,.04) 0 6px, transparent 6px 12px);
  opacity: .75;
}
.member-day {
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-width: 180px;
}
.shift-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.shift-chip {
  border: 1px solid var(--sk-line);
  border-radius: var(--sk-r-sm);
  background: var(--sk-paper);
  padding: 8px 10px;
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.shift-chip.editable-shift {
  cursor: pointer;
}
.shift-chip.editable-shift:hover {
  border-color: var(--sk-accent-border);
  background: var(--sk-accent-soft);
}
.shift-time {
  font-family: var(--sk-font-mono);
  font-size: 11px;
  font-weight: 700;
}
.shift-role {
  font-size: 12px;
  font-weight: 600;
}
.shift-op {
  color: var(--sk-muted);
  font-size: 11px;
  overflow: hidden;
  text-overflow: ellipsis;
}
.shift-empty {
  color: var(--sk-muted);
  font-size: 11px;
}
.shift-add {
  align-self: flex-start;
  border: 1px dashed var(--sk-line);
  background: transparent;
  color: var(--sk-accent-dark);
  border-radius: var(--sk-r-pill);
  padding: 4px 10px;
  font-family: var(--sk-font-hand);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  cursor: pointer;
}
.shift-add:hover {
  background: var(--sk-accent-soft);
  border-color: var(--sk-accent-border);
}

.st-cell {
  border-right: 1px solid var(--sk-line);
  border-bottom: 1px solid var(--sk-line);
  padding: 10px 12px;
  background: var(--sk-bg);
  min-height: 92px;
  position: relative;
}
.st-cell:last-of-type { border-right: none; }
.st-cell.head {
  background: var(--sk-paper);
  font-family: var(--sk-font-hand); font-weight: 800;
  letter-spacing: 0.04em; text-transform: uppercase; font-size: 11.5px;
  color: var(--sk-muted);
  min-height: 44px; padding: 12px;
  display: flex; align-items: center; gap: 8px;
}
.st-cell.day-head {
  background: var(--sk-paper);
  display: flex; flex-direction: column; gap: 6px;
  font-family: var(--sk-font-ui); padding: 12px;
  min-height: 92px; justify-content: space-between;
}
.st-cell.day-head .d-day {
  font-family: var(--sk-font-hand); font-weight: 800; font-size: 14px;
  text-transform: uppercase; letter-spacing: 0.06em;
}
.st-cell.day-head .d-date {
  font-family: var(--sk-font-mono); font-size: 11px; color: var(--sk-muted);
}
.st-cell.day-head .d-flags { display: flex; flex-wrap: wrap; gap: 4px; }

.st-cell.today { background: var(--sk-accent-soft); }
.st-cell.today.day-head { background: var(--sk-accent-soft); }

.st-cell.closed {
  background-image: repeating-linear-gradient(135deg,
    rgba(0,0,0,.04) 0 6px, transparent 6px 12px);
  opacity: 0.7;
}

.st-cell.surgeon-off {
  background-image: repeating-linear-gradient(45deg,
    rgba(185,74,61,.05) 0 6px, transparent 6px 12px);
}

.graft {
  display: flex; flex-direction: column; gap: 4px;
  padding: 8px 10px;
  border: 1px solid var(--sk-line);
  border-radius: var(--sk-r-sm);
  background: var(--sk-paper);
  font-size: 12px;
  position: relative;
}
.graft-head {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 8px;
}
.graft-main {
  display: flex; flex-direction: column; gap: 6px;
  min-width: 0; flex: 1;
}
.graft .top-row { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.graft .hour {
  font-family: var(--sk-font-mono); font-weight: 600; font-size: 12px;
  color: var(--sk-ink);
}
.graft .patient {
  font-weight: 500; font-size: 13px; flex: 1; min-width: 0;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.graft .note {
  font-size: 11px; color: var(--sk-muted); font-family: var(--sk-font-mono);
}
.graft-actions {
  display: inline-flex; align-items: center; gap: 4px;
  flex-shrink: 0;
}
.graft-actions .btn {
  padding: 2px 6px; font-size: 9px;
}
.deposit-flag {
  align-self: flex-start;
  padding: 2px 8px;
  border-radius: var(--sk-r-pill);
  border: 1px solid var(--sk-warn-border);
  background: var(--sk-warn-soft);
  color: var(--sk-warn-ink);
  font-size: 10.5px;
  font-weight: 600;
  cursor: pointer;
}

.graft.has-deposit { border-color: var(--sk-warn-border); background: var(--sk-warn-soft); }
.graft.done { opacity: 0.65; }
.graft.cancelled { opacity: 0.4; text-decoration: line-through; }

.ht-row { display: flex; gap: 4px; align-items: center; flex-wrap: wrap; }
.ht-label {
  font-family: var(--sk-font-mono); font-size: 10px; color: var(--sk-muted);
  min-width: 22px;
}
.ht-pill {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 2px 8px; border-radius: var(--sk-r-pill);
  font-size: 11px; font-weight: 500;
  background: var(--sk-accent-soft); color: var(--sk-accent-dark);
  border: 1px solid var(--sk-accent-border);
  cursor: pointer;
}
.ht-pill.empty {
  color: var(--sk-muted); background: transparent;
  border: 1px dashed var(--sk-line);
}
.ht-pill.changed-from {
  text-decoration: line-through;
  opacity: 0.55;
}
.ht-arrow { font-family: var(--sk-font-mono); font-size: 10px; color: var(--sk-muted); }

.editable {
  cursor: text;
  border-bottom: 1px dashed transparent;
  padding: 1px 3px; margin: -1px -3px;
  border-radius: 3px;
}
.editable:hover { background: var(--sk-paper-hover); }
.editable.editing { padding: 0; background: transparent; }
.editable input, .editable select {
  font: inherit; color: inherit;
  border: 1px solid var(--sk-accent); border-radius: 4px;
  padding: 1px 4px; background: var(--sk-bg);
  width: 100%; min-width: 60px;
}

.empty-slot {
  display: flex; align-items: center; justify-content: center;
  min-height: 60px; cursor: pointer;
  color: var(--sk-muted); font-size: 12px;
  border: 1px dashed var(--sk-line);
  border-radius: var(--sk-r-sm);
}
.empty-slot:hover { color: var(--sk-accent-dark); border-color: var(--sk-accent-border); background: var(--sk-accent-soft); }

.day-comment-label,
.day-comment-cell {
  min-height: 0;
  padding-top: 10px;
  padding-bottom: 10px;
}
.day-comment-label {
  background: var(--sk-paper);
  display: flex; flex-direction: column; gap: 4px;
}
.day-comment-kicker {
  font-family: var(--sk-font-hand); font-weight: 800; font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.06em;
}
.day-comment-date {
  font-family: var(--sk-font-mono); font-size: 11px; color: var(--sk-muted);
}
.day-comment-row {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 12px;
}
.day-comment-body {
  display: flex; flex-direction: column; gap: 4px;
  min-width: 0; flex: 1;
}
.day-comment-title {
  font-size: 11px; font-weight: 600; color: var(--sk-ink);
}
.day-comment {
  font-size: 11.5px; color: var(--sk-muted); font-style: italic;
  padding: 8px 10px;
  background: var(--sk-bg); border-left: 3px solid var(--sk-accent-border);
  border-radius: 4px;
  line-height: 1.5;
}

.toggle-btn {
  font-family: var(--sk-font-hand); font-size: 10.5px; letter-spacing: 0.1em;
  text-transform: uppercase; font-weight: 700;
  padding: 5px 10px; border-radius: var(--sk-r-pill);
  border: 1px solid var(--sk-line); background: transparent; color: var(--sk-muted);
  cursor: pointer;
}
.toggle-btn.on { background: var(--sk-accent-soft); color: var(--sk-accent-dark); border-color: var(--sk-accent-border); }

.staffing-legend {
  display: flex; gap: 12px; flex-wrap: wrap; padding: 10px 14px;
  background: var(--sk-paper); border-radius: var(--sk-r-sm);
  font-size: 11.5px; color: var(--sk-muted);
}
.staffing-legend .lg { display: inline-flex; align-items: center; gap: 5px; }
.staffing-legend .swatch {
  width: 14px; height: 14px; border-radius: 3px; border: 1px solid var(--sk-line);
}
.staffing-legend .swatch.today { background: var(--sk-accent-soft); border-color: var(--sk-accent-border); }
.staffing-legend .swatch.closed { background-image: repeating-linear-gradient(135deg, rgba(0,0,0,.08) 0 4px, transparent 4px 8px); }
.staffing-legend .swatch.off { background-image: repeating-linear-gradient(45deg, rgba(185,74,61,.1) 0 4px, transparent 4px 8px); }
.staffing-legend .swatch.deposit { background: var(--sk-warn-soft); border-color: var(--sk-warn-border); }

.staff-hours-page .staffing-legend {
  align-items: center;
}

.staff-hours-table {
  display: grid;
  grid-template-columns: minmax(210px, 1.2fr) repeat(var(--hours-day-cols, 7), minmax(132px, 1fr)) minmax(104px, .65fr);
  background: var(--sk-paper);
  border: 1px solid var(--sk-line);
  border-radius: var(--sk-r);
  overflow: auto;
}

.hours-cell {
  border-right: 1px solid var(--sk-line);
  border-bottom: 1px solid var(--sk-line);
  min-height: 78px;
  padding: 10px 12px;
  background: var(--sk-bg);
}

.hours-head {
  min-height: 58px;
  background: var(--sk-paper);
  color: var(--sk-muted);
  font-family: var(--sk-font-hand);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.hours-head.today,
.hours-entry-cell.today {
  background: var(--sk-accent-soft);
}

.hours-day-name {
  color: var(--sk-ink);
}

.hours-day-date {
  margin-top: 3px;
  font-family: var(--sk-font-mono);
  font-size: 10.5px;
  letter-spacing: 0;
  text-transform: none;
}

.hours-person-cell {
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--sk-paper);
  min-width: 210px;
}

.hours-person-body {
  min-width: 0;
}

.hours-entry-cell {
  min-width: 132px;
  padding: 8px;
}

.hours-entry {
  width: 100%;
  min-height: 62px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  align-items: flex-start;
  justify-content: center;
  border: 1px dashed var(--sk-line);
  border-radius: var(--sk-r-sm);
  background: transparent;
  color: var(--sk-muted);
  text-align: left;
  font: inherit;
}

button.hours-entry {
  cursor: pointer;
}

button.hours-entry:hover {
  background: var(--sk-paper);
  border-color: var(--sk-accent-border);
  color: var(--sk-accent-dark);
}

.hours-entry.complete {
  border-style: solid;
  background: var(--sk-paper);
  color: var(--sk-ink);
}

.hours-entry.partial {
  border-style: solid;
  border-color: var(--sk-warn-border);
  background: var(--sk-warn-soft);
  color: var(--sk-warn-ink);
}

.hours-time {
  font-family: var(--sk-font-mono);
  font-size: 11px;
  font-weight: 700;
}

.hours-duration {
  font-size: 13px;
  font-weight: 700;
}

.hours-missing,
.hours-empty,
.hours-note {
  font-size: 11px;
}

.hours-note {
  max-width: 100%;
  overflow: hidden;
  color: var(--sk-muted);
  text-overflow: ellipsis;
  white-space: nowrap;
}

.hours-total-cell {
  display: flex;
  flex-direction: column;
  justify-content: center;
  background: var(--sk-paper);
}

.hours-total-value {
  font-family: var(--sk-font-mono);
  font-size: 14px;
  font-weight: 800;
}

.hours-contract {
  margin-top: 4px;
  color: var(--sk-muted);
  font-size: 10px;
  text-transform: uppercase;
}

.staff-hours-empty {
  padding: 24px;
  background: var(--sk-paper);
  border: 1px solid var(--sk-line);
  border-radius: var(--sk-r);
}

@media (max-width: 1100px) {
  .staffing-table,
  .staffing-people-table,
  .staff-hours-table {
    min-width: 760px;
  }
  .graft-head,
  .day-comment-row {
    flex-direction: column;
    align-items: stretch;
  }
  .graft-actions {
    justify-content: flex-end;
  }
}
