/**
 * Dashboard: sidebar + weekrooster (exact ontwerp)
 */

/* Layout */
.rb-dashboard-layout {
  display: flex;
  min-height: 100vh;
}

.rb-dashboard-sidebar {
  width: 300px;
  flex-shrink: 0;
  box-sizing: border-box;
  background: color-mix(in srgb, var(--rb-bg-highlight) 55%, var(--rb-bg));
  border-right: 1px solid var(--rb-border);
  padding: var(--rb-space-8) var(--rb-space-5) var(--rb-space-5);
  display: flex;
  flex-direction: column;
  position: sticky;
  top: 0;
  height: 100vh;
  align-self: flex-start;
  transition: width 0.2s ease, padding 0.2s ease;
}

/* Collapsed sidebar */
.rb-dashboard-layout.rb-sidebar-collapsed .rb-dashboard-sidebar {
  width: 72px;
  padding-left: var(--rb-space-3);
  padding-right: var(--rb-space-3);
}

.rb-dashboard-layout.rb-sidebar-collapsed .rb-logo {
  justify-content: center;
}

.rb-dashboard-sidebar-nav a .rb-nav-text {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
}

.rb-dashboard-layout.rb-sidebar-collapsed .rb-logo-brand,
.rb-dashboard-layout.rb-sidebar-collapsed .rb-dashboard-sidebar-nav a .rb-nav-text {
  overflow: hidden;
  width: 0;
  opacity: 0;
  pointer-events: none;
  white-space: nowrap;
  transition: opacity 0.2s ease, width 0.2s ease;
}

.rb-dashboard-layout.rb-sidebar-collapsed .rb-dashboard-sidebar-nav a {
  justify-content: center;
  padding-left: var(--rb-space-3);
  padding-right: var(--rb-space-3);
  gap: 0;
}

.rb-dashboard-layout.rb-sidebar-collapsed .rb-dashboard-sidebar-nav a.rb-active {
  padding-left: var(--rb-space-3);
  padding-right: var(--rb-space-3);
}

.rb-dashboard-layout.rb-sidebar-collapsed .rb-sidebar-logout .rb-sidebar-logout-text {
  overflow: hidden;
  width: 0;
  opacity: 0;
  pointer-events: none;
}

.rb-dashboard-layout.rb-sidebar-collapsed .rb-sidebar-profile .rb-sidebar-profile-text {
  overflow: hidden;
  width: 0;
  opacity: 0;
  pointer-events: none;
}

.rb-dashboard-layout.rb-sidebar-collapsed .rb-sidebar-logout {
  justify-content: center;
  width: calc(72px - 2 * var(--rb-space-3));
  min-width: 0;
  padding-left: var(--rb-space-3);
  padding-right: var(--rb-space-3);
  gap: 0;
}

.rb-dashboard-layout.rb-sidebar-collapsed .rb-sidebar-profile {
  justify-content: center;
  width: calc(72px - 2 * var(--rb-space-3));
  min-width: 0;
  padding-left: var(--rb-space-3);
  padding-right: var(--rb-space-3);
  gap: 0;
}

/* Toggle button */
.rb-sidebar-toggle {
  position: absolute;
  top: var(--rb-space-5);
  right: -12px;
  z-index: 10;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  border: 1px solid var(--rb-border);
  background: var(--rb-bg);
  color: var(--rb-text-muted);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--rb-shadow-sm), 0 0 0 1px rgb(15 23 42 / 0.04);
  transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

.rb-sidebar-toggle:hover {
  background: var(--rb-bg);
  color: var(--rb-text);
  border-color: #DDE3EB;
  box-shadow: 0 2px 8px rgb(15 23 42 / 0.08);
}

.rb-sidebar-toggle:focus-visible {
  outline: none;
  box-shadow: var(--rb-shadow-sm), 0 0 0 2px var(--rb-bg), 0 0 0 4px var(--rb-primary-ring);
}

.rb-sidebar-toggle svg {
  width: 14px;
  height: 14px;
  transition: transform 0.2s ease;
  display: block;
}

.rb-dashboard-layout.rb-sidebar-collapsed .rb-sidebar-toggle svg {
  transform: rotate(180deg);
}

.rb-logo.rb-logo-with-tagline {
  display: flex;
  align-items: center;
  gap: var(--rb-space-3);
  margin-bottom: var(--rb-space-6);
  text-decoration: none;
  color: inherit;
  flex-shrink: 0;
}

.rb-logo-with-tagline .rb-logo-icon {
  flex-shrink: 0;
}

.rb-logo-brand {
  display: flex;
  flex-direction: column;
  gap: 0;
  min-width: 0;
}

.rb-logo-app-name {
  font-size: 0.6875rem;
  color: var(--rb-text-muted);
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  line-height: 1.2;
}

.rb-logo-org-name {
  font-weight: 600;
  font-size: var(--rb-text-body);
  letter-spacing: -0.015em;
  color: var(--rb-text);
  line-height: 1.3;
}

.rb-dashboard-sidebar-nav {
  display: flex;
  flex-direction: column;
  gap: var(--rb-space-1);
  flex: 1;
  min-width: 0;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
}

/* Nav groups */
.rb-nav-group {
  display: flex;
  flex-direction: column;
  margin-top: var(--rb-space-3);
}

.rb-nav-group:first-child {
  margin-top: 0;
}

.rb-nav-group-label {
  display: block;
  padding: 0 var(--rb-space-4);
  margin-bottom: var(--rb-space-1);
  color: var(--rb-text-muted);
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  white-space: nowrap;
  overflow: hidden;
  opacity: 1;
  transition: opacity 0.2s ease, width 0.2s ease;
}

.rb-nav-group-items {
  display: flex;
  flex-direction: column;
  gap: var(--rb-space-1);
}

/* Collapsed sidebar: hide group labels */
.rb-dashboard-layout.rb-sidebar-collapsed .rb-nav-group-label {
  overflow: hidden;
  width: 0;
  opacity: 0;
  padding: 0;
  margin: 0;
}

.rb-dashboard-layout.rb-sidebar-collapsed .rb-nav-group {
  margin-top: var(--rb-space-1);
}

.rb-dashboard-sidebar-nav a {
  --rb-proximity: 0;
  display: flex;
  align-items: center;
  gap: var(--rb-space-3);
  min-width: 0;
  width: 100%;
  box-sizing: border-box;
  padding: 0.625rem var(--rb-space-4);
  border-radius: calc(var(--rb-radius-btn) + 2px);
  color: var(--rb-text);
  text-decoration: none;
  font-size: var(--rb-text-small);
  font-weight: 500;
  transition: background 0.18s ease, color 0.18s ease, box-shadow 0.18s ease;
}

.rb-dashboard-sidebar-nav .rb-nav-icon {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  color: inherit;
}

.rb-dashboard-sidebar-nav .rb-nav-icon svg {
  display: block;
  width: 100%;
  height: 100%;
}

.rb-dashboard-sidebar-nav a:hover {
  background: rgb(255 255 255 / 0.72);
}

.rb-dashboard-sidebar-nav a.rb-proximity-active:not(:hover):not(.rb-active) {
  background: color-mix(in srgb, white calc(22% + (var(--rb-proximity, 0) * 38%)), transparent);
  box-shadow: inset 2px 0 0 rgb(59 130 246 / 0.16);
}

.rb-dashboard-sidebar-nav a:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px var(--rb-primary-ring);
}

.rb-dashboard-sidebar-nav a.rb-active {
  background: var(--rb-primary);
  color: white;
  /* Optisch evenwicht: content naar rechts (icoon gecentreerd in blauwe balk) */
  padding-left: calc(var(--rb-space-4) + 5px);
  padding-right: calc(var(--rb-space-4) - 5px);
}

.rb-sidebar-footer {
  margin-top: auto;
  padding-top: var(--rb-space-4);
  display: flex;
  flex-direction: column;
  gap: var(--rb-space-2);
}

.rb-sidebar-logout,
.rb-sidebar-profile {
  display: flex;
  align-items: center;
  gap: var(--rb-space-3);
  width: 100%;
  box-sizing: border-box;
  padding: 0.625rem var(--rb-space-4);
  border-radius: calc(var(--rb-radius-btn) + 2px);
  font-size: var(--rb-text-small);
  font-weight: 500;
  text-align: left;
  cursor: pointer;
  transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease, width 0.2s ease, box-shadow 0.18s ease;
}

.rb-sidebar-logout {
  border: 1px solid var(--rb-border);
  background: rgb(255 255 255 / 0.5);
  color: var(--rb-text-muted);
}

.rb-sidebar-profile {
  border: none;
  background: transparent;
  color: var(--rb-text);
}

.rb-sidebar-logout .rb-nav-icon {
  flex-shrink: 0;
}

.rb-sidebar-profile .rb-nav-icon {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  color: inherit;
}

.rb-sidebar-profile .rb-nav-icon svg {
  display: block;
  width: 100%;
  height: 100%;
}

.rb-sidebar-logout:hover {
  background: #fef2f2;
  color: #b91c1c;
  border-color: #fecaca;
}

.rb-sidebar-profile:hover {
  background: rgb(255 255 255 / 0.72);
  color: var(--rb-text);
}

.rb-sidebar-profile:focus-visible,
.rb-sidebar-logout:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px var(--rb-primary-ring);
}

.rb-profile-menu {
  position: relative;
}

.rb-profile-popover {
  position: fixed;
  background: var(--rb-bg);
  border: 1px solid rgb(15 23 42 / 0.06);
  border-radius: var(--rb-radius-card);
  box-shadow: var(--rb-shadow-modal);
  padding: var(--rb-space-5);
  z-index: 500;
}

.rb-profile-row {
  display: flex;
  flex-direction: column;
  gap: 2px;
  margin-bottom: var(--rb-space-3);
}

.rb-profile-label {
  font-size: 0.6875rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--rb-text-muted);
  font-weight: 600;
}

.rb-profile-value {
  font-size: var(--rb-text-small);
  color: var(--rb-text);
  font-weight: 600;
  word-break: break-word;
}

.rb-profile-value.rb-profile-value-muted {
  font-weight: 500;
  color: var(--rb-text-muted);
}

.rb-profile-actions {
  display: flex;
  flex-direction: column;
  gap: var(--rb-space-2);
  margin-top: var(--rb-space-4);
}

.rb-profile-actions .rb-profile-privacy,
.rb-profile-actions .rb-profile-logout {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--rb-space-2);
  padding: var(--rb-space-3) var(--rb-space-4);
  border-radius: var(--rb-radius-btn);
  font-size: var(--rb-text-small);
  font-weight: 600;
  cursor: pointer;
  width: 100%;
}

.rb-profile-actions .rb-profile-privacy {
  border: 1px solid var(--rb-border);
  background: #f8fafc;
  color: var(--rb-text);
  transition: background 0.18s ease, border-color 0.18s ease;
}

.rb-profile-actions .rb-profile-privacy:hover {
  background: #f1f5f9;
  border-color: #DDE3EB;
}

.rb-profile-actions .rb-profile-logout {
  border: 1px solid #fca5a5;
  background: #fee2e2;
  color: #b91c1c;
}

.rb-profile-actions .rb-profile-logout:hover {
  background: #fecaca;
}

/* Privacy modal (in-page popup) */
.rb-privacy-modal-backdrop {
  position: fixed;
  inset: 0;
  background: var(--rb-overlay-scrim);
  z-index: 2000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--rb-space-6);
}
.rb-privacy-modal-backdrop[hidden] {
  display: none;
}
.rb-privacy-modal {
  width: 100%;
  max-width: 520px;
  background: var(--rb-bg);
  border: 1px solid rgb(15 23 42 / 0.06);
  border-radius: var(--rb-radius-card);
  box-shadow: var(--rb-shadow-modal);
  padding: var(--rb-space-8);
}
.rb-privacy-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--rb-space-5);
}
.rb-privacy-modal-header h2 {
  margin: 0;
  font-size: 1.125rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--rb-text);
}
.rb-privacy-modal-close {
  border: none;
  background: none;
  color: var(--rb-text-muted);
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: var(--rb-radius-btn);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.18s ease, color 0.18s ease;
}

.rb-privacy-modal-close:hover {
  background: #F1F5F9;
  color: var(--rb-text);
}

.rb-privacy-modal-close:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px var(--rb-primary-ring);
}
.rb-privacy-modal-toggle {
  display: flex;
  gap: var(--rb-space-3);
  align-items: flex-start;
  line-height: 1.35;
  color: var(--rb-text);
  font-size: var(--rb-text-small);
}
.rb-privacy-modal-toggle input[type="checkbox"] {
  width: 1.125rem;
  height: 1.125rem;
  margin-top: 2px;
  accent-color: var(--rb-primary);
  flex-shrink: 0;
}
.rb-privacy-modal-meta {
  margin-top: var(--rb-space-3);
  font-size: var(--rb-text-small);
  color: var(--rb-text-muted);
}

.rb-privacy-modal-body {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.rb-privacy-modal-section {
  padding: var(--rb-space-5) 0;
  border-top: 1px solid var(--rb-border);
}

.rb-privacy-modal-section:first-child {
  padding-top: 0;
  border-top: none;
}

.rb-privacy-modal-section-title {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--rb-text);
  margin: 0 0 var(--rb-space-3);
}

.rb-privacy-modal-section-copy {
  font-size: var(--rb-text-small);
  color: var(--rb-text-muted);
  margin: 0 0 var(--rb-space-3);
}

.rb-dashboard-main {
  flex: 1;
  min-width: 0;
  padding: var(--rb-space-10) var(--rb-space-6) var(--rb-space-12);
  max-width: 1700px;
  margin: 0 auto;
  background: var(--rb-bg);
  width: 100%;
}

/* --- Weekrooster header: alleen titel --- */
.rb-weekrooster-header {
  display: flex;
  flex-direction: column;
  gap: var(--rb-space-1);
  margin-bottom: var(--rb-space-8);
}

.rb-weekrooster-title-line {
  display: flex;
  align-items: center;
  gap: var(--rb-space-3);
  flex-wrap: wrap;
}

.rb-weekrooster-title-row {
  display: flex;
  align-items: center;
  gap: var(--rb-space-6);
  flex-wrap: wrap;
}

.rb-weekrooster-title {
  font-size: var(--rb-text-title);
  font-weight: var(--rb-text-title-weight);
  letter-spacing: -0.025em;
  color: var(--rb-text);
  margin: 0;
  line-height: var(--rb-line-height-tight);
}

.rb-weekrooster-published-hint {
  display: block;
  margin: 0;
  font-size: var(--rb-text-small);
  color: var(--rb-text-muted);
  line-height: 1.4;
}

.rb-weekrooster-published-hint[hidden] {
  display: none;
}

.rb-concept-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-height: 1.35rem;
  padding: 0 10px;
  font-size: 0.725rem;
  font-weight: 700;
  border-radius: 9999px;
  background-color: #ffedd5;
  color: #c2410c;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.rb-concept-badge-dot {
  display: block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background-color: #ea580c;
}

.rb-concept-published-text {
  display: inline-flex;
  align-items: center;
  min-height: 1.35rem;
  font-size: 0.875rem;
  color: var(--rb-text-muted, #64748b);
  font-weight: 500;
  line-height: 1;
}

.rb-badge-orange {
  background-color: #ffedd5 !important;
  color: #c2410c !important;
}
.rb-dot-orange {
  background-color: #ea580c !important;
}

.rb-badge-green {
  background-color: #dcfce7 !important;
  color: #15803d !important;
}
.rb-dot-green {
  background-color: #22c55e !important;
}

.rb-wr-shift-card--readonly {
  cursor: default;
  opacity: 0.96;
}

/* Switch Rooster | Beschikbaarheid: Apple segmented control style */
.rb-dashboard-view-switch-wrap {
  display: flex;
  justify-content: center;
  margin-bottom: var(--rb-space-6);
}

.rb-dashboard-view-switch {
  display: inline-flex;
  align-items: center;
  background: rgb(15 23 42 / 0.06);
  border: none;
  border-radius: 12px;
  padding: 4px;
  gap: 0;
  -webkit-appearance: none;
  appearance: none;
}

.rb-dashboard-view-tab {
  --rb-proximity: 0;
  padding: 7px 16px;
  background: transparent;
  border: none;
  border-radius: 9px;
  font-size: 0.8125rem;
  font-weight: 500;
  color: rgb(71 85 105 / 0.85);
  cursor: pointer;
  transition: background 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
  white-space: nowrap;
  font-family: var(--rb-font-sans);
}

.rb-dashboard-view-tab:hover:not(.rb-active) {
  color: var(--rb-text);
}

.rb-dashboard-view-tab.rb-proximity-active:not(:hover):not(.rb-active) {
  color: color-mix(in srgb, var(--rb-text) calc(68% + (var(--rb-proximity, 0) * 24%)), rgb(71 85 105));
  background: color-mix(in srgb, white calc(var(--rb-proximity, 0) * 42%), transparent);
}

.rb-dashboard-view-tab.rb-active {
  background: #fff;
  color: var(--rb-text);
  font-weight: 600;
  box-shadow: 0 1px 3px rgb(15 23 42 / 0.08), 0 1px 2px rgb(15 23 42 / 0.04);
}

.rb-dashboard-view-tab:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px var(--rb-primary-ring);
}

.rb-dashboard-panel {
  display: block;
}

.rb-dashboard-panel.rb-dashboard-panel-hidden {
  display: none;
}

/* Beschikbaarheid matrix */
.rb-avail-intro {
  font-size: var(--rb-text-small);
  color: var(--rb-text-muted);
  margin: 0 0 var(--rb-space-4);
}

.rb-avail-matrix-wrap {
  overflow-x: auto;
  border: 1px solid var(--rb-border);
  border-radius: var(--rb-radius-btn);
  background: #fff;
  box-shadow: var(--rb-shadow-sm);
}

.rb-avail-matrix {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: var(--rb-text-small);
}

.rb-avail-matrix th,
.rb-avail-matrix td {
  padding: var(--rb-space-3) var(--rb-space-4);
  border-bottom: 1px solid var(--rb-border);
  text-align: left;
}

.rb-avail-matrix th {
  font-weight: 600;
  color: var(--rb-text-muted);
  background: var(--rb-bg-highlight);
}

.rb-avail-matrix .rb-avail-th {
  text-align: center;
  min-width: 5rem;
}

.rb-avail-matrix .rb-avail-th-label,
.rb-avail-matrix .rb-avail-td-label {
  min-width: 180px;
}

.rb-avail-td-label {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  padding: var(--rb-space-3) var(--rb-space-4);
}

.rb-avail-name {
  font-weight: 600;
}

.rb-avail-contract {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--rb-text);
}

.rb-avail-vakantie {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.78rem;
  color: var(--rb-text-muted);
  flex-wrap: wrap;
}

.rb-avail-vakantie-boek {
  border: 1px solid var(--rb-border);
  background: var(--rb-bg);
  color: var(--rb-text);
  font-size: 0.875rem;
  font-weight: 600;
  padding: 0.4rem 0.75rem;
  border-radius: 999px;
  cursor: pointer;
  line-height: 1.2;
  transition: background 0.16s ease, border-color 0.16s ease, box-shadow 0.16s ease, color 0.16s ease, transform 0.16s ease;
}

.rb-avail-vakantie-boek:hover:not(:disabled) {
  background: #f1f5f9;
}


.rb-avail-vakantie-boek:disabled {
  opacity: 0.5;
  cursor: default;
}

.rb-avail-vakantie-saldo {
  white-space: nowrap;
}

.rb-avail-vakantie-list {
  list-style: none;
  margin: 0.5rem 0 0;
  padding: 0;
  color: var(--rb-text);
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.rb-avail-vakantie-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.55rem 0.75rem;
  background: #f8fafc;
  border: 1px solid var(--rb-border);
  border-left: 3px solid #2563eb;
  border-radius: 8px;
  cursor: pointer;
  transition: background 0.14s ease, border-color 0.14s ease, box-shadow 0.14s ease, transform 0.14s ease;
}

.rb-avail-vakantie-item:hover {
  background: #eff6ff;
  border-color: #bfdbfe;
  border-left-color: #1d4ed8;
}


.rb-avail-vakantie-item:focus-visible {
  outline: 2px solid #2563eb;
  outline-offset: 2px;
}

.rb-avail-vakantie-info {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  flex-wrap: wrap;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--rb-text);
}

.rb-avail-vakantie-days {
  font-weight: 700;
}

.rb-avail-vakantie-hours {
  color: #2563eb;
  font-weight: 700;
}

.rb-avail-vakantie-dows {
  display: inline-flex;
  gap: 0.25rem;
  flex-wrap: wrap;
}

.rb-avail-vakantie-dow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.75rem;
  padding: 0.1rem 0.45rem;
  font-size: 0.8rem;
  font-weight: 600;
  color: #1e3a8a;
  background: #dbeafe;
  border-radius: 999px;
  text-transform: lowercase;
}

.rb-avail-vakantie-undo {
  width: 1.6rem;
  height: 1.6rem;
  border-radius: 999px;
  border: 1px solid var(--rb-border);
  background: var(--rb-bg);
  color: var(--rb-text);
  font-size: 1.05rem;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  padding: 0;
  flex-shrink: 0;
  transition: background 0.14s ease, border-color 0.14s ease, color 0.14s ease, box-shadow 0.14s ease;
}

.rb-avail-vakantie-undo:hover:not(:disabled) {
  background: #fee2e2;
  border-color: #fca5a5;
  color: #991b1b;
}


.rb-vakantie-modal {
  max-width: 28rem;
}

.rb-vakantie-modal-sub {
  font-size: 0.85rem;
  color: var(--rb-text-muted);
  margin: 0 0 1.25rem;
  padding: 0.55rem 0.7rem;
  background: #f8fafc;
  border-radius: var(--rb-radius, 6px);
}

.rb-vakantie-preview {
  font-size: 0.82rem;
  color: var(--rb-text-muted);
  margin: 0.75rem 0 0;
  padding: 0;
  background: transparent;
}

.rb-vakantie-summary-row {
  display: grid;
  grid-template-columns: minmax(7rem, 0.8fr) minmax(10rem, 1.2fr);
  gap: 0.75rem;
  margin-bottom: 0.25rem;
}

.rb-vakantie-days-field input[readonly] {
  background: #f8fafc;
  color: var(--rb-text);
  cursor: default;
}

.rb-vakantie-dows {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 0.4rem;
  margin-top: 0.35rem;
}

.rb-modal .rb-field .rb-vakantie-dows .rb-dow {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.3rem;
  margin-bottom: 0;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--rb-text-muted, #64748b);
  text-transform: lowercase;
  cursor: pointer;
  user-select: none;
}

.rb-modal .rb-field .rb-vakantie-dows .rb-dow input {
  width: 1rem;
  height: 1rem;
  margin: 0;
  cursor: pointer;
  accent-color: #3b82f6;
}

.rb-modal .rb-field .rb-vakantie-dows .rb-dow.rb-dow-disabled {
  opacity: 0.4;
  cursor: not-allowed;
  text-decoration: line-through;
}

.rb-modal .rb-field .rb-vakantie-dows .rb-dow.rb-dow-disabled input {
  cursor: not-allowed;
}

.rb-personnel-vak {
  font-style: italic;
  color: var(--rb-text-muted);
  font-size: 0.85em;
  margin-left: 0.25rem;
}

.rb-avail-matrix tbody tr:last-child td {
  border-bottom: none;
}

.rb-avail-cell {
  cursor: pointer;
  text-align: center;
  min-width: 5rem;
  transition: background 0.18s ease, border-color 0.18s ease, box-shadow 0.14s ease, color 0.14s ease;
}

.rb-avail-card {
  display: block;
  cursor: pointer;
}

.rb-mr-avail-options {
  padding: var(--rb-space-2) 0;
}

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

.rb-avail-cards-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--rb-space-3);
  padding: var(--rb-space-4) var(--rb-space-6);
}

.rb-avail-card-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--rb-space-2);
  min-height: 5.25rem;
  padding: var(--rb-space-3) var(--rb-space-2);
  border: 2px solid var(--rb-border);
  border-radius: var(--rb-radius-lg);
  background: var(--rb-bg);
  color: var(--rb-text-muted);
  transition: background-color 0.18s ease, border-color 0.18s ease, color 0.18s ease, transform 130ms cubic-bezier(0.2, 0.8, 0.2, 1);
}

.rb-avail-card-icon {
  display: block;
  width: 1.5rem;
  height: 1.5rem;
  flex: 0 0 1.5rem;
  opacity: 0.8;
}

.rb-avail-card span {
  font-size: 0.75rem;
  font-weight: 600;
  line-height: 1.2;
  text-align: center;
}

.rb-avail-card:hover .rb-avail-card-content {
  border-color: var(--rb-primary);
  color: var(--rb-primary);
  background: var(--rb-bg-highlight);
}

.rb-avail-card.danger:hover .rb-avail-card-content,
.rb-avail-card.sick:hover .rb-avail-card-content {
  border-color: #ef4444;
  color: #ef4444;
}

.rb-avail-card input:checked + .rb-avail-card-content {
  border-color: var(--rb-primary);
  background: var(--rb-primary);
  color: #fff;
}

.rb-avail-card input:checked + .rb-avail-card-content .rb-avail-card-icon {
  opacity: 1;
}

.rb-avail-card.danger input:checked + .rb-avail-card-content,
.rb-avail-card.sick input:checked + .rb-avail-card-content {
  border-color: #ef4444;
  background: #ef4444;
  color: #fff;
}

#dashboard-avail-options .rb-avail-cards-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

#dashboard-avail-options .rb-avail-card.sick {
  grid-column: 1 / -1;
  justify-self: end;
}

#dashboard-avail-options .rb-avail-card.sick .rb-avail-card-content {
  flex-direction: row;
  width: auto;
  min-height: 2.25rem;
  padding: 0.45rem 0.75rem;
  gap: 0.4rem;
  border-width: 1px;
  border-color: #cbd5e1;
  border-radius: var(--rb-radius-md);
  background: transparent;
  color: #64748b;
}

#dashboard-avail-options .rb-avail-card.sick .rb-avail-card-icon {
  width: 0.95rem;
  height: 0.95rem;
  flex-basis: 0.95rem;
  opacity: 0.65;
}

#dashboard-avail-options .rb-avail-card.sick span {
  font-size: 0.72rem;
  font-weight: 600;
}

#dashboard-avail-options .rb-avail-card.sick:hover .rb-avail-card-content {
  border-color: #94a3b8;
  color: #475569;
  background: #f8fafc;
}

#dashboard-avail-options .rb-avail-card.sick input:checked + .rb-avail-card-content {
  border-color: #f59e0b;
  background: #fffbeb;
  color: #92400e;
}

.rb-avail-td-label {
  border-left: 3px solid transparent;
  transition: border-color 0.15s ease, background 0.15s ease;
}

.rb-avail-row:has(.rb-avail-cell:hover) .rb-avail-td-label {
  border-left-color: var(--rb-text);
  background: #f1f5f9;
}

.rb-avail-row:has(.rb-avail-cell-drag-fill) .rb-avail-td-label {
  border-left-color: var(--rb-primary);
  background: #eff6ff;
}

.rb-avail-th {
  border-top: 3px solid transparent;
  transition: border-color 0.15s ease, background 0.15s ease;
}

.rb-avail-th.rb-avail-th--hover {
  border-top-color: var(--rb-text);
  background: #eef2f7;
}

.rb-avail-th.rb-avail-th--drag {
  border-top-color: var(--rb-primary);
  background: #eff6ff;
}

.rb-avail-cell.rb-avail-cell-available {
  --rb-avail-proximity-line: #22c55e;
  --rb-avail-proximity-glow: rgb(34 197 94 / 0.065);
  background: #dcfce7;
  color: #166534;
  font-weight: 500;
}

.rb-avail-cell.rb-avail-cell-available:hover {
  background: #bbf7d0;
}

.rb-avail-cell.rb-avail-cell-empty {
  --rb-avail-proximity-line: #94a3b8;
  --rb-avail-proximity-glow: rgb(100 116 139 / 0.055);
  background: #f8fafc;
  color: #64748b;
  font-weight: 500;
}

.rb-avail-cell.rb-avail-cell-empty:hover {
  background: #eef2f7;
}

.rb-avail-cell:not(.rb-avail-cell-available):not(.rb-avail-cell-empty):not(.rb-avail-cell-sick) {
  --rb-avail-proximity-line: #ef4444;
  --rb-avail-proximity-glow: rgb(239 68 68 / 0.06);
  background: #fef2f2;
  color: #991b1b;
}

.rb-avail-cell:not(.rb-avail-cell-available):not(.rb-avail-cell-empty):not(.rb-avail-cell-sick):hover {
  background: #fecaca;
}

.rb-avail-cell.rb-avail-cell-sick {
  --rb-avail-proximity-line: #f59e0b;
  --rb-avail-proximity-glow: rgb(245 158 11 / 0.065);
  background: #fef3c7;
  color: #92400e;
}

.rb-avail-cell.rb-avail-cell-sick:hover {
  background: #fde68a;
}

.rb-avail-fixed-badge {
  display: block;
  font-size: 0.67rem;
  font-weight: 500;
  color: var(--rb-text-muted);
  letter-spacing: 0.02em;
  margin-top: 1px;
  opacity: 0.75;
}

.rb-avail-cell.rb-avail-cell-drag-fill {
  background: rgba(37, 99, 235, 0.16) !important;
  color: #2563eb !important;
  border-bottom: 1px solid transparent !important; /* Hide default bottom border seamlessly */
  box-shadow: 
    inset 0 var(--rb-drag-t, 0) 0 0 #2563eb,
    inset 0 var(--rb-drag-b, 0) 0 0 #2563eb,
    inset var(--rb-drag-l, 0) 0 0 0 #2563eb,
    inset var(--rb-drag-r, 0) 0 0 0 #2563eb !important;
  box-sizing: border-box !important;
  transition: background 0.15s ease, color 0.15s ease, box-shadow 0.15s ease, border-radius 0.15s ease;
}

/* Outer borders for selection range */
.rb-avail-cell.rb-avail-drag-top {
  --rb-drag-t: 2px;
}
.rb-avail-cell.rb-avail-drag-bottom {
  --rb-drag-b: -2px;
}
.rb-avail-cell.rb-avail-drag-left {
  --rb-drag-l: 2px;
}
.rb-avail-cell.rb-avail-drag-right {
  --rb-drag-r: -2px;
}

/* Corner radius for selection range */
.rb-avail-cell.rb-avail-drag-tl {
  border-top-left-radius: 8px !important;
}
.rb-avail-cell.rb-avail-drag-tr {
  border-top-right-radius: 8px !important;
}
.rb-avail-cell.rb-avail-drag-bl {
  border-bottom-left-radius: 8px !important;
}
.rb-avail-cell.rb-avail-drag-br {
  border-bottom-right-radius: 8px !important;
}

.rb-avail-loading {
  padding: var(--rb-space-8) !important;
  text-align: center;
  color: var(--rb-text-muted);
}

/* Weekkiezer in het midden boven het rooster */
.rb-weekrooster-week-bar {
  display: flex;
  align-items: center;
  margin-bottom: var(--rb-space-6);
}

.rb-weekrooster-week-bar-spacer {
  flex: 1;
}

.rb-weekrooster-week-bar-right {
  flex: 1;
  display: flex;
  justify-content: flex-end;
}

.rb-weekrooster-nav {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--rb-space-4);
  padding: var(--rb-space-4) var(--rb-space-6);
  border: 1px solid var(--rb-border);
  border-radius: calc(var(--rb-radius-btn) + 4px);
  background: var(--rb-bg);
  font-size: 1.05rem;
  box-shadow: var(--rb-shadow-sm);
}

.rb-weekrooster-nav-range {
  font-weight: 700;
  color: var(--rb-text);
  font-size: 1.1rem;
}

.rb-weekrooster-nav-label {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.15em;
  width: 260px;
}
.rb-ziek-nav-label-btn {
  --rb-proximity: 0;
  cursor: pointer;
  border-radius: 0.5rem;
  padding: 4px 10px;
  margin: -4px -10px;
  transition: background 0.15s, box-shadow 0.15s, color 0.15s;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.1em;
  width: 260px;
  line-height: 1.2;
}
.rb-ziek-nav-label-btn:hover {
  background: var(--rb-bg-highlight, #f8fafc);
}
.rb-ziek-nav-label-btn.rb-proximity-active:not(:hover) {
  background: color-mix(in srgb, var(--rb-primary) calc(var(--rb-proximity, 0) * 7%), transparent);
  box-shadow: 0 calc(var(--rb-proximity, 0) * 2px) calc(var(--rb-proximity, 0) * 8px) rgb(59 130 246 / 0.08);
}
.rb-ziek-nav-dropdown {
  position: absolute;
  background: var(--rb-bg);
  border: 1px solid var(--rb-border);
  border-radius: var(--rb-radius-lg);
  box-shadow: 0 4px 16px rgba(0,0,0,0.12);
  z-index: 200;
  max-height: 260px;
  overflow-y: auto;
  min-width: 180px;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  margin-top: 8px;
}
.rb-ziek-nav-dropdown-item {
  --rb-proximity: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  width: 100%;
  text-align: left;
  padding: 8px 14px;
  background: none;
  border: none;
  border-bottom: 1px solid var(--rb-border);
  font-size: var(--rb-text-small);
  color: var(--rb-text);
  cursor: pointer;
  line-height: 1.3;
  transition: background 0.14s ease, color 0.14s ease;
}
.rb-ziek-nav-dropdown-item:last-child {
  border-bottom: none;
}
.rb-ziek-nav-dropdown-item:hover {
  background: var(--rb-bg-highlight, #f8fafc);
}
.rb-ziek-nav-dropdown-item.rb-proximity-active:not(:hover):not(.rb-active) {
  background: color-mix(in srgb, var(--rb-primary) calc(var(--rb-proximity, 0) * 7%), transparent);
  color: color-mix(in srgb, var(--rb-primary) calc(var(--rb-proximity, 0) * 30%), var(--rb-text));
}
.rb-ziek-nav-dropdown-item.rb-active {
  font-weight: 600;
  color: var(--rb-primary, #3B82F6);
}

.rb-weekrooster-nav-dates {
  font-size: 1rem;
  color: var(--rb-text);
  font-weight: 500;
}

.rb-weekrooster-nav-btn {
  --rb-proximity: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.25rem;
  min-height: 2.25rem;
  padding: var(--rb-space-2) var(--rb-space-3);
  border: 1px solid var(--rb-border);
  border-radius: var(--rb-radius-btn);
  background: var(--rb-bg);
  font-size: 1rem;
  line-height: 1;
  color: var(--rb-text);
  cursor: pointer;
  transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

.rb-weekrooster-nav-btn:hover {
  background: #F8FAFC;
  border-color: #DDE3EB;
}

.rb-weekrooster-nav-btn.rb-proximity-active:not(:hover) {
  background: color-mix(in srgb, var(--rb-primary) calc(var(--rb-proximity, 0) * 7%), var(--rb-bg));
  border-color: color-mix(in srgb, var(--rb-primary) calc(10% + (var(--rb-proximity, 0) * 26%)), var(--rb-border));
  box-shadow: 0 calc(var(--rb-proximity, 0) * 2px) calc(var(--rb-proximity, 0) * 8px) rgb(59 130 246 / 0.1);
}

.rb-weekrooster-nav-btn:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px var(--rb-primary-ring);
}

.rb-btn-deze-week {
  --rb-proximity: 0;
  padding: var(--rb-space-2) var(--rb-space-4);
  border: 1px solid var(--rb-border);
  border-radius: var(--rb-radius-btn);
  background: var(--rb-bg);
  font-size: var(--rb-text-small);
  font-weight: 500;
  color: var(--rb-text);
  cursor: pointer;
  box-shadow: var(--rb-shadow-sm);
  transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease, box-shadow 0.18s ease;
}

.rb-btn-deze-week:hover {
  background: #F8FAFC;
  border-color: #DDE3EB;
}

.rb-btn-deze-week.rb-proximity-active:not(:hover) {
  background: color-mix(in srgb, var(--rb-primary) calc(var(--rb-proximity, 0) * 7%), var(--rb-bg));
  border-color: color-mix(in srgb, var(--rb-primary) calc(10% + (var(--rb-proximity, 0) * 26%)), var(--rb-border));
  box-shadow: var(--rb-shadow-sm), 0 calc(var(--rb-proximity, 0) * 2px) calc(var(--rb-proximity, 0) * 8px) rgb(59 130 246 / 0.1);
}

.rb-btn-deze-week:focus-visible {
  outline: none;
  box-shadow: var(--rb-shadow-sm), 0 0 0 2px var(--rb-primary-ring);
}

/* --- Alle-dropdown boven het rooster, links --- */
.rb-weekrooster-alle-bar {
  margin-bottom: var(--rb-space-4);
}

.rb-weekrooster-alle-select {
  padding: 0.5rem var(--rb-space-4);
  border: 1px solid var(--rb-border);
  border-radius: var(--rb-radius-btn);
  font-size: var(--rb-text-small);
  background: var(--rb-bg);
  color: var(--rb-text);
  min-width: 140px;
  box-shadow: var(--rb-shadow-sm);
  transition: border-color 0.18s ease, box-shadow 0.18s ease;
}

.rb-weekrooster-alle-select:hover {
  border-color: #DDE3EB;
}

.rb-weekrooster-alle-select:focus {
  outline: none;
  border-color: var(--rb-primary);
  box-shadow: var(--rb-shadow-sm), 0 0 0 3px var(--rb-primary-ring);
}

/* ---- Versie herstellen: custom dropdown ---- */
.rb-restore-wrap {
  --rb-proximity: 0;
}

.rb-restore-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  min-height: 36px;
  padding: 0.44rem 0.82rem;
  border: 1px solid var(--rb-border);
  border-radius: var(--rb-radius-btn);
  font-size: var(--rb-text-small);
  font-weight: 500;
  background: var(--rb-bg);
  color: var(--rb-text);
  cursor: pointer;
  white-space: nowrap;
  box-shadow: var(--rb-shadow-sm);
  transition: border-color 0.15s, color 0.15s, background 0.15s, box-shadow 0.15s;
  min-width: 0;
}
.rb-restore-btn:not(:disabled):hover {
  border-color: #94a3b8;
  color: #0f172a;
  background: #ffffff;
  box-shadow: 0 2px 8px rgb(15 23 42 / 0.08);
}
.rb-restore-btn:not(:disabled)[aria-expanded="true"] {
  border-color: #2563eb;
  color: #1d4ed8;
  background: #eff6ff;
  box-shadow: 0 0 0 3px rgb(59 130 246 / 0.16);
}
.rb-restore-btn:not(:disabled)[aria-expanded="true"] .rb-restore-chevron {
  transform: rotate(180deg);
}
.rb-restore-btn:disabled {
  opacity: 0.45;
  cursor: default;
  box-shadow: none;
}
.rb-restore-wrap--empty {
  cursor: default;
}
.rb-restore-wrap--empty .rb-restore-btn:disabled {
  opacity: 1;
  cursor: default;
}
.rb-restore-wrap--empty:hover .rb-restore-btn:disabled,
.rb-restore-wrap--empty.rb-proximity-active .rb-restore-btn:disabled {
  background: #F8FAFC;
  border-color: #DDE3EB;
}
.rb-restore-wrap--empty:focus-visible {
  outline: none;
}
.rb-restore-btn-loading {
  cursor: wait;
}
.rb-restore-chevron {
  flex-shrink: 0;
  transition: transform 0.18s ease;
}
.rb-restore-dropdown {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  z-index: 200;
  width: min(360px, calc(100vw - 32px));
  background: var(--rb-bg);
  border: 1px solid var(--rb-border);
  border-radius: 8px;
  box-shadow: 0 18px 42px rgb(15 23 42 / 0.16), 0 2px 8px rgb(15 23 42 / 0.08);
  overflow: hidden;
  animation: rb-restore-dropdown-in 0.15s ease;
}
@keyframes rb-restore-dropdown-in {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}
.rb-restore-dropdown-header {
  padding: 0.62rem 0.9rem;
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0;
  color: var(--rb-text-muted);
  border-bottom: 1px solid var(--rb-border);
  background: #f8fafc;
}
.rb-restore-dropdown-list {
  max-height: 260px;
  overflow-y: auto;
  overscroll-behavior: contain;
}
.rb-restore-dropdown-empty {
  padding: 1rem 0.9rem;
  font-size: var(--rb-text-small);
  color: var(--rb-text-muted);
  text-align: left;
}
.rb-restore-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  width: 100%;
  padding: 0.72rem 0.9rem;
  border: none;
  background: transparent;
  text-align: left;
  cursor: pointer;
  font-size: var(--rb-text-small);
  color: var(--rb-text);
  transition: background 0.12s, color 0.12s;
  border-bottom: 1px solid var(--rb-border);
}
.rb-restore-item:last-child {
  border-bottom: none;
}
.rb-restore-item:hover {
  background: #eff6ff;
}
.rb-restore-item.rb-active {
  background: #eff6ff;
  color: #1d4ed8;
}
.rb-restore-item-icon {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border-radius: 7px;
  background: #dbeafe;
  color: #2563eb;
  display: flex;
  align-items: center;
  justify-content: center;
}
.rb-restore-item-body {
  flex: 1;
  min-width: 0;
}
.rb-restore-item-label {
  font-weight: 600;
  color: var(--rb-text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.rb-restore-item-date {
  font-size: 0.72rem;
  color: var(--rb-text-muted);
  display: block;
  margin-top: 5px;
  line-height: 1.35;
}
.rb-restore-item.rb-active .rb-restore-item-icon {
  background: #2563eb;
  color: #ffffff;
}
.rb-archive-btn {
  max-width: 320px;
}
.rb-archive-btn #rooster-archive-label {
  overflow: hidden;
  text-overflow: ellipsis;
}
.rb-archive-dropdown {
  width: min(390px, calc(100vw - 32px));
}
@media (max-width: 720px) {
  .rb-restore-wrap,
  .rb-archive-wrap {
    width: 100%;
  }
  .rb-restore-dropdown {
    left: 0;
    right: auto;
    width: min(100%, calc(100vw - 32px));
  }
}

/* --- Rooster: volle breedte --- */
.rb-weekrooster-table-wrap {
  width: 100%;
  overflow-x: auto;
  border: 1px solid var(--rb-border);
  border-radius: var(--rb-radius-card);
  background: var(--rb-bg);
  margin-bottom: var(--rb-space-8);
  box-shadow: var(--rb-shadow-sm);
  transition: box-shadow 0.2s ease;
}
.rb-weekrooster-table-wrap.rb-weekrooster-just-updated {
  box-shadow: 0 0 0 2px var(--rb-primary, #2563eb), var(--rb-shadow-sm);
}

.rb-weekrooster-table-wrap.rb-weekrooster-just-updated .rb-wr-shift-card:not(.rb-wr-shift-card-loading) {
  animation: rbGenerateCardIn 220ms cubic-bezier(0.2, 0.9, 0.25, 1.15) both;
  animation-delay: var(--rb-generate-card-delay, 0ms);
}

@keyframes rbGenerateCardIn {
  0% {
    opacity: 0;
    transform: translateY(6px) scale(0.985);
    filter: saturate(0.86);
  }
  70% {
    opacity: 1;
    transform: translateY(-1px) scale(1.006);
    filter: saturate(1.04);
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
    filter: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  .rb-weekrooster-table-wrap.rb-weekrooster-just-updated .rb-wr-shift-card:not(.rb-wr-shift-card-loading) {
    animation: none;
  }
}

.rb-weekrooster-table {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
  min-width: 1400px;
}

/* Tabel header: lege cel + 7 dagen */
.rb-wr-th-label {
  width: 100px;
  min-width: 100px;
  padding: var(--rb-space-3) var(--rb-space-4);
  font-size: var(--rb-text-small);
  font-weight: 600;
  color: var(--rb-text);
  text-align: left;
  border-bottom: 1px solid var(--rb-border);
  border-right: 1px solid var(--rb-border);
  background: var(--rb-bg);
}

.rb-wr-th {
  padding: var(--rb-space-3) var(--rb-space-4);
  font-size: var(--rb-text-small);
  font-weight: 600;
  color: var(--rb-text);
  text-align: left;
  border-bottom: 1px solid var(--rb-border);
  border-right: 1px solid var(--rb-border);
  background: var(--rb-bg);
  vertical-align: bottom;
}

/* Dag dikgedrukt, datum daaronder normaal */
.rb-wr-day {
  display: block;
  font-weight: 700;
  font-size: var(--rb-text-small);
  color: var(--rb-text);
  margin-bottom: 0.15em;
}

.rb-wr-date {
  display: block;
  font-weight: 400;
  font-size: 0.8125rem;
  color: var(--rb-text-muted);
}

.rb-wr-th:last-child {
  border-right: none;
}

/* Mobile day strip */
.rb-mobile-day-strip-wrap {
  display: none;
}

.rb-mobile-day-strip {
  display: none;
}

/* Mobile dept filter (onder dag-strip) */
.rb-mobile-dept-filter {
  display: none;
}

/* Dag-kop klikbaar voor dagweergave */
.rb-wr-th-day {
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
}
.rb-wr-th-day:hover {
  background: color-mix(in srgb, var(--rb-primary) 12%, var(--rb-bg)) !important;
  color: var(--rb-primary);
}

.rb-wr-th {
  transition: box-shadow 0.15s ease, background 0.15s ease, color 0.15s ease;
}

.rb-wr-th.rb-wr-th--hover {
  box-shadow: inset 0 3px 0 var(--rb-text);
  background: #f1f5f9;
}
.rb-wr-th-day:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px var(--rb-primary-ring);
  position: relative;
  z-index: 1;
}

/* Rijen: achtergrondkleur = afdelingskleur uit backend (Mijn bedrijf → skills) */
.rb-wr-row {
  --rb-proximity: 0;
}

.rb-wr-row .rb-wr-td-label,
.rb-wr-row .rb-wr-td {
  background: color-mix(in srgb, var(--rb-dept-color, #94a3b8) 10%, white);
}

.rb-wr-row .rb-wr-td-label {
  transition: border-left 0.15s ease, background 0.2s ease;
}

.rb-wr-row.rb-proximity-active .rb-wr-td-label {
  border-left: calc(var(--rb-proximity, 0) * 3px) solid color-mix(in srgb, var(--rb-dept-color, #94a3b8) calc(40% + (var(--rb-proximity, 0) * 40%)), transparent);
}

.rb-wr-td-label {
  width: 100px;
  min-width: 100px;
  padding: var(--rb-space-3) var(--rb-space-4);
  font-size: var(--rb-text-small);
  font-weight: 600;
  color: var(--rb-text);
  border-bottom: 1px solid var(--rb-border);
  border-right: 1px solid var(--rb-border);
}

.rb-wr-td {
  vertical-align: top;
  padding: var(--rb-space-3);
  border-bottom: 1px solid var(--rb-border);
  border-right: 1px solid var(--rb-border);
  min-width: 0;
}

.rb-wr-td:last-child {
  border-right: none;
}

/* Witruimte tussen afdelingen */
.rb-wr-row-spacer {
  height: 0;
  pointer-events: none;
}

.rb-wr-spacer-td {
  height: 32px;
  padding: 0 !important;
  border: none !important;
  background: var(--rb-bg) !important;
  vertical-align: middle;
}

/* Cel-inhoud: shift-kaarten + plus-knop */
.rb-wr-cell-inner {
  display: flex;
  flex-direction: column;
  gap: var(--rb-space-2);
}

/* Shiftkaart: wit, afgerond, tijd + naam + vaardigheid-pill + checkbox/lock */
.rb-wr-shift-card {
  position: relative;
  --rb-proximity: 0;
  background: #fff;
  border: 1px solid var(--rb-border);
  border-radius: calc(var(--rb-radius-btn) + 2px);
  padding: var(--rb-space-3);
  font-size: var(--rb-text-small);
  box-shadow: var(--rb-shadow-sm);
  min-width: 130px;
  transform: translateY(calc(var(--rb-proximity, 0) * -1px));
  transition: border-color 0.16s ease, box-shadow 0.16s ease, transform 0.16s ease, background 0.16s ease;
}

.rb-wr-row-loading .rb-wr-td-label,
.rb-wr-row-loading .rb-wr-td {
  background: #f8fafc;
}

.rb-wr-shift-card-loading {
  min-height: 78px;
  border-color: #e5e7eb;
  box-shadow: none;
}

.rb-wr-skeleton {
  display: block;
  overflow: hidden;
  border-radius: 999px;
  background: linear-gradient(90deg, #edf2f7 0%, #f8fafc 45%, #edf2f7 90%);
  background-size: 220% 100%;
  animation: rbSkeletonShimmer 1.15s ease-in-out infinite;
}

.rb-wr-skeleton-label {
  width: min(72px, 100%);
  height: 14px;
}

.rb-wr-skeleton-time {
  width: 74%;
  height: 13px;
  margin-bottom: 10px;
}

.rb-wr-skeleton-name {
  width: 58%;
  height: 12px;
  margin-bottom: 12px;
}

.rb-wr-skeleton-pill {
  width: 46px;
  height: 20px;
}

@keyframes rbSkeletonShimmer {
  0% { background-position: 120% 0; }
  100% { background-position: -120% 0; }
}

/* Ingeroosterd terwijl niet beschikbaar: lichtgrijs + dichte schuine strepen */
.rb-wr-shift-card--avail-conflict {
  background-color: #e8e8ec;
  border-color: #c5c5cd;
  border-top: 3px solid #EF4444;
  box-shadow: none;
  padding: var(--rb-space-2);
  opacity: 0.85;
  background-image:
    repeating-linear-gradient(
      -42deg,
      transparent,
      transparent 5px,
      rgb(0 0 0 / 0.09) 5px,
      rgb(0 0 0 / 0.09) 6px,
      transparent 6px,
      transparent 10px,
      rgb(0 0 0 / 0.07) 10px,
      rgb(0 0 0 / 0.07) 11px
    );
}

.rb-wr-shift-card--avail-conflict .rb-wr-shift-time {
  font-size: 0.72rem;
  font-weight: 600;
}

.rb-wr-shift-card--avail-conflict .rb-wr-shift-time,
.rb-wr-shift-card--avail-conflict .rb-wr-shift-name {
  color: #5c5c66;
}

.rb-wr-shift-card--avail-conflict .rb-wr-shift-name {
  display: inline;
  margin-bottom: 0;
  font-size: 0.72rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 80px;
}

.rb-wr-shift-card--avail-conflict .rb-wr-shift-vaardigheid {
  font-size: 0.62rem;
  padding: 0.1em 0.4em;
  margin-left: 4px;
}

.rb-wr-shift-card-clickable.rb-wr-shift-card--avail-conflict:hover {
  border-color: #a1a1ad;
  border-top-color: #EF4444;
  box-shadow: 0 1px 3px rgb(0 0 0 / 0.08);
}

.rb-wr-shift-card-clickable.rb-wr-shift-card--sick:hover {
  border-top-color: #F59E0B;
}

.rb-wr-shift-card-clickable.rb-wr-shift-card--vacation:hover {
  border-top-color: #10B981;
}

.rb-wr-shift-card--sick {
  border-top: 3px solid #F59E0B;
  background: #fffbeb;
  padding: var(--rb-space-2);
  opacity: 0.85;
}

.rb-wr-shift-card--vacation {
  border-top: 3px solid #10B981;
  background: #ecfdf5;
  padding: var(--rb-space-2);
  opacity: 0.9;
}

.rb-wr-shift-card--sick .rb-wr-shift-time,
.rb-wr-shift-card--vacation .rb-wr-shift-time {
  font-size: 0.72rem;
  font-weight: 600;
}

.rb-wr-shift-sick-row {
  display: flex;
  align-items: center;
  flex-wrap: nowrap;
  gap: 4px;
  overflow: hidden;
}

.rb-wr-shift-sick-row .rb-wr-shift-name {
  display: inline;
  margin-bottom: 0;
  font-size: 0.72rem;
  color: var(--rb-text-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 80px;
}

.rb-wr-shift-sick-row .rb-wr-shift-vaardigheid {
  font-size: 0.62rem;
  padding: 0.1em 0.4em;
}

.rb-wr-shift-sick-badge {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-size: 0.68rem;
  color: #B45309;
  font-weight: 600;
  background: #FEF3C7;
  padding: 1px 5px;
  border-radius: 4px;
  flex-shrink: 0;
}

.rb-wr-shift-vacation-badge {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-size: 0.68rem;
  color: #047857;
  font-weight: 600;
  background: #d1fae5;
  padding: 1px 5px;
  border-radius: 4px;
  flex-shrink: 0;
}

.rb-sick-section {
  margin-top: var(--rb-space-4);
}

.rb-modal-divider {
  border: none;
  border-top: 1px solid var(--rb-border);
  margin: 0 0 var(--rb-space-3);
}


.rb-sick-replacements-title {
  font-size: var(--rb-text-small);
  font-weight: 600;
  color: var(--rb-text-muted);
  margin: var(--rb-space-3) 0 var(--rb-space-2);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* ── Ziek vervanging modal ── */
.rb-sick-repl-modal {
  max-width: 460px;
  padding: 0;
  overflow: hidden;
}

.rb-sick-repl-header {
  display: flex;
  align-items: flex-start;
  gap: var(--rb-space-3);
  padding: var(--rb-space-6) var(--rb-space-6) var(--rb-space-4);
  border-bottom: 1px solid var(--rb-border);
}

.rb-sick-repl-header-icon {
  flex-shrink: 0;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 50%;
  background: #FEF3C7;
  color: #D97706;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 1px;
}

.rb-sick-repl-title {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--rb-text);
  margin: 0 0 2px;
  letter-spacing: -0.01em;
  line-height: 1.3;
}

.rb-sick-repl-progress {
  margin: 0;
  font-size: 0.78rem;
  color: var(--rb-text-muted);
}

.rb-sick-repl-body {
  padding: var(--rb-space-4) var(--rb-space-5) var(--rb-space-3);
}

.rb-sick-repl-shift-info {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--rb-text);
  margin: 0 0 var(--rb-space-3);
  padding: var(--rb-space-2) var(--rb-space-3);
  background: var(--rb-bg-highlight);
  border-radius: 8px;
  border-left: 3px solid var(--rb-primary);
  display: flex;
  align-items: center;
  gap: var(--rb-space-2);
  flex-wrap: wrap;
}

.rb-sick-repl-skill-badge {
  display: inline-flex;
  align-items: center;
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--rb-text);
  background: transparent;
  border: 1px solid #cbd5e1;
  padding: 1px 8px;
  border-radius: 999px;
  white-space: nowrap;
}

.rb-sick-repl-list-wrap {
  max-height: 280px;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--rb-border) transparent;
  margin: 0 -2px;
  padding: 0 2px;
}

.rb-sick-replacements-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--rb-space-2);
}

.rb-sick-replacement-item {
  display: flex;
  align-items: center;
  gap: var(--rb-space-3);
  padding: var(--rb-space-2) var(--rb-space-3);
  background: var(--rb-bg);
  border: 1px solid var(--rb-border);
  border-radius: 10px;
  transition: border-color 0.15s, box-shadow 0.15s;
}

.rb-sick-replacement-item:hover {
  border-color: var(--rb-primary);
  box-shadow: 0 0 0 3px var(--rb-primary-ring);
}

.rb-sick-replacement-avatar {
  flex-shrink: 0;
  width: 2.375rem;
  height: 2.375rem;
  border-radius: 50%;
  color: #fff;
  font-size: 0.72rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  letter-spacing: 0.03em;
}

.rb-sick-replacement-info {
  display: flex;
  flex-direction: column;
  gap: 1px;
  min-width: 0;
  flex: 1;
}

.rb-sick-replacement-name {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--rb-text);
  display: flex;
  align-items: center;
  gap: var(--rb-space-2);
  flex-wrap: wrap;
}


.rb-sick-replacement-hours {
  font-size: 0.75rem;
  color: var(--rb-text-muted);
  display: flex;
  align-items: center;
  gap: var(--rb-space-2);
}

.rb-sick-replacement-over {
  font-size: 0.68rem;
  color: #B45309;
  font-weight: 600;
  background: #FEF3C7;
  padding: 1px 5px;
  border-radius: 4px;
  white-space: nowrap;
}

.rb-sick-repl-empty {
  color: var(--rb-text-muted);
  font-size: var(--rb-text-small);
  text-align: center;
  padding: var(--rb-space-4) 0 var(--rb-space-2);
}

.rb-sick-repl-fallback-section {
  margin-top: var(--rb-space-3);
  border-top: 1px solid var(--rb-border);
  padding-top: var(--rb-space-3);
}

.rb-sick-repl-fallback-section--first {
  border-top: none;
  margin-top: 0;
  padding-top: 0;
}

.rb-sick-repl-fallback-title {
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--rb-text-muted);
  margin: 0 0 var(--rb-space-2);
}

.rb-sick-repl-fallback-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  margin-bottom: var(--rb-space-2);
}

.rb-sick-repl-fallback-toggle .rb-sick-repl-fallback-title {
  margin: 0;
}

.rb-sick-repl-toggle-icon {
  color: var(--rb-text-muted);
  transition: transform 0.25s ease;
  flex-shrink: 0;
}

.rb-sick-repl-fallback-toggle[aria-expanded="true"] .rb-sick-repl-toggle-icon {
  transform: rotate(180deg);
}

#rb-sick-repl-candidates-body,
#rb-sick-repl-skill-unavail-list,
#rb-sick-repl-avail-noskill-list {
  overflow: hidden;
  transition: max-height 0.28s ease;
  max-height: 0;
}

#rb-sick-repl-candidates-body.rb-collapsible--open,
#rb-sick-repl-skill-unavail-list.rb-collapsible--open,
#rb-sick-repl-avail-noskill-list.rb-collapsible--open {
  max-height: 600px;
}

.rb-sick-repl-fallback-section .rb-sick-replacement-item {
  border-color: transparent;
  background: var(--rb-bg-highlight);
}

.rb-sick-repl-fallback-section .rb-sick-replacement-item:hover {
  border-color: var(--rb-border);
  box-shadow: none;
}

.rb-sick-repl-footer {
  display: flex;
  justify-content: flex-end;
  padding: var(--rb-space-3) var(--rb-space-5) var(--rb-space-5);
  border-top: 1px solid var(--rb-border);
}

.rb-sick-repl-skip-btn {
  background: none;
  border: none;
  padding: var(--rb-space-2) var(--rb-space-3);
  font-size: 0.875rem;
  color: var(--rb-text-muted);
  cursor: pointer;
  border-radius: var(--rb-radius-btn);
  transition: color 0.15s, background 0.15s;
}

.rb-sick-repl-skip-btn:hover {
  color: var(--rb-text);
  background: var(--rb-bg-highlight);
}

/* ── Ziekmeldingen – gedeelde stijlen (niet afhankelijk van cascade-volgorde) ── */
.rb-ziekmeldingen-list {
  display: flex;
  flex-direction: column;
}

.rb-ziekmelding-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--rb-space-4);
  padding: var(--rb-space-4) var(--rb-space-5);
  border-bottom: 1px solid #fde68a;
  background: #fffbeb;
}

.rb-ziekmelding-item:last-child {
  border-bottom: none;
}

.rb-ziekmelding-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.rb-ziekmelding-naam {
  font-size: var(--rb-text-body);
  font-weight: 600;
  color: #78350f;
  display: flex;
  align-items: center;
  gap: var(--rb-space-2);
}

.rb-ziekmelding-dag {
  font-size: var(--rb-text-small);
  color: #92400e;
}

.rb-ziekmelding-badge {
  font-size: 0.68rem;
  font-weight: 600;
  background: #fef9c3;
  color: #854d0e;
  border: 1px solid #fcd34d;
  border-radius: 4px;
  padding: 1px 5px;
}

.rb-ziekmelding-skill-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--rb-space-1);
  margin-top: var(--rb-space-1);
}

.rb-ziekmelding-skill-pill {
  display: inline-block;
  font-size: 0.72rem;
  font-weight: 500;
  border: 1.5px solid;
  border-radius: 999px;
  padding: 1px 8px;
  color: var(--rb-text);
  background: transparent;
  white-space: nowrap;
}

.rb-ziekmelding-actions {
  display: flex;
  align-items: center;
  gap: var(--rb-space-2);
  flex-shrink: 0;
}

.rb-ziekmelding-sluit-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  padding: 0;
  border: none;
  border-radius: var(--rb-radius-btn);
  background: transparent;
  color: #b45309;
  cursor: pointer;
  transition: background 0.12s;
  flex-shrink: 0;
}

.rb-ziekmelding-sluit-btn:hover {
  background: #fde68a;
}

.rb-btn-sm {
  font-size: var(--rb-text-small);
  padding: var(--rb-space-1) var(--rb-space-3);
  height: auto;
  white-space: nowrap;
  flex-shrink: 0;
}

/* Tijd + slotje op één regel bovenaan de kaart, altijd volledig zichtbaar */
.rb-wr-shift-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--rb-space-2);
  margin-bottom: 0.35em;
  white-space: nowrap;
}

.rb-wr-shift-card-clickable {
  cursor: pointer;
}

.rb-wr-shift-card-clickable:hover {
  border-color: color-mix(in srgb, var(--rb-primary) 24%, var(--rb-border));
  box-shadow: 0 2px 8px rgb(59 130 246 / 0.065);
}

.rb-wr-shift-card-clickable.rb-proximity-active:not(:hover) {
  border-color: color-mix(in srgb, var(--rb-primary) calc(6% + (var(--rb-proximity, 0) * 16%)), var(--rb-border));
  box-shadow:
    0 1px 2px rgb(15 23 42 / 0.03),
    0 calc(var(--rb-proximity, 0) * 3px) calc(3px + (var(--rb-proximity, 0) * 7px)) rgb(59 130 246 / 0.055);
}

.rb-wr-shift-card-clickable.rb-wr-shift-card--avail-conflict.rb-proximity-active,
.rb-wr-shift-card-clickable.rb-wr-shift-card--avail-conflict:hover {
  border-color: #a1a1ad;
  border-top-color: #EF4444;
  box-shadow: 0 calc(var(--rb-proximity, 0) * 1px) calc(2px + (var(--rb-proximity, 0) * 5px)) rgb(239 68 68 / 0.055);
}

.rb-wr-shift-card-clickable.rb-wr-shift-card--sick.rb-proximity-active,
.rb-wr-shift-card-clickable.rb-wr-shift-card--sick:hover {
  border-color: #fcd34d;
  border-top-color: #F59E0B;
  box-shadow: 0 calc(var(--rb-proximity, 0) * 1px) calc(2px + (var(--rb-proximity, 0) * 5px)) rgb(245 158 11 / 0.06);
}

.rb-wr-shift-card--open-slot {
  border-style: dashed;
  border-color: color-mix(in srgb, var(--rb-border) 70%, var(--rb-text-muted, #64748b));
}

.rb-wr-shift-card--open-slot .rb-wr-shift-name {
  color: var(--rb-text-muted, #64748b);
  font-style: italic;
}

.rb-wr-shift-time {
  font-weight: 700;
  color: var(--rb-text);
  white-space: nowrap;
}

.rb-wr-shift-name {
  display: block;
  font-weight: 500;
  color: var(--rb-text);
  margin-bottom: 0.35em;
  font-size: 0.8rem; /* slightly smaller to fit names on one line where possible */
  line-height: 1.25;
}

.rb-wr-shift-vaardigheid {
  display: inline-block;
  font-size: 0.7rem;
  font-weight: 500;
  padding: 0.2em 0.6em;
  border-radius: 9999px;
  background: #fff;
  border: 2px solid var(--rb-vaardigheid-color, var(--rb-primary));
  color: #000;
}

.rb-wr-shift-vaardigheid--muted {
  opacity: 0.75;
  font-weight: 400;
}

/* Aanvinkknop: slotje vastzetten voor generator (Weekrooster) */
.rb-wr-shift-check {
  position: static;
  width: 28px;
  height: 28px;
  min-width: 28px;
  min-height: 28px;
  border: 2px solid var(--rb-border);
  border-radius: 4px;
  background: #fff;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  flex-shrink: 0;
  transition: background 0.15s, border-color 0.15s;
}

.rb-wr-shift-check:hover {
  border-color: var(--rb-primary);
}

.rb-wr-shift-check--checked,
.rb-wr-shift-check[aria-pressed="true"] {
  background: var(--rb-primary);
  border-color: var(--rb-primary);
  color: #fff;
}

/* Slot-icoon altijd zichtbaar: leeg vierkant is te onduidelijk; vastgezet = gevuld primary */
.rb-wr-check-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}

.rb-wr-shift-check:not(.rb-wr-shift-check--checked):not([aria-pressed="true"]) {
  border-color: var(--rb-primary);
  background: #eff6ff;
}

.rb-wr-shift-check:not(.rb-wr-shift-check--checked):not([aria-pressed="true"]) .rb-wr-check-icon {
  color: var(--rb-primary);
  opacity: 0.55;
}

/* Vaste dienst (geen assignment-id): slot is decoratief; klik gaat naar kaart (weekrooster.js) */
.rb-wr-shift-check--fixed {
  cursor: pointer;
}

.rb-wr-shift-check--checked .rb-wr-check-icon,
.rb-wr-shift-check[aria-pressed="true"] .rb-wr-check-icon {
  color: #fff;
  opacity: 1;
}

.rb-wr-check-icon svg {
  width: 16px;
  height: 16px;
  display: block;
}

/* Plus-knop onder in cel: gebruikt rb-add-btn uit design-system.css */
.rb-wr-cell-inner .rb-add-btn {
  --rb-proximity: 0;
  align-self: flex-start;
  opacity: calc(0.5 + (var(--rb-proximity, 0) * 0.32));
  transform: scale(calc(0.96 + (var(--rb-proximity, 0) * 0.03)));
}

.rb-wr-cell-inner .rb-add-btn.rb-proximity-active:not(:hover) {
  border-color: color-mix(in srgb, var(--rb-primary) calc(8% + (var(--rb-proximity, 0) * 26%)), var(--rb-border));
  color: color-mix(in srgb, var(--rb-primary) calc(24% + (var(--rb-proximity, 0) * 34%)), var(--rb-text-muted));
  background: color-mix(in srgb, var(--rb-primary) calc(var(--rb-proximity, 0) * 4%), var(--rb-bg));
  box-shadow: 0 calc(var(--rb-proximity, 0) * 1px) calc(var(--rb-proximity, 0) * 5px) rgb(59 130 246 / 0.07);
}

/* --- Dagweergave: één dag, gegroepeerd per afdeling (teamrooster-stijl) --- */
.rb-dagweergave-wrap {
  width: 100%;
  margin-bottom: var(--rb-space-12);
}
.rb-dagweergave-header {
  display: flex;
  align-items: center;
  gap: var(--rb-space-4);
  margin-bottom: var(--rb-space-6);
  flex-wrap: wrap;
}
.rb-dagweergave-back {
  flex-shrink: 0;
}
.rb-dagweergave-title {
  margin: 0;
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--rb-text);
}
.rb-dagweergave-body {
  display: flex;
  flex-direction: column;
  gap: var(--rb-space-8);
}
.rb-dagweergave-afdeling {
  border: 1px solid var(--rb-border);
  border-radius: var(--rb-radius-card);
  background: var(--rb-bg);
  overflow: hidden;
}
.rb-dagweergave-afdeling-title {
  margin: 0;
  padding: var(--rb-space-3) var(--rb-space-4);
  font-size: var(--rb-text-body);
  font-weight: 700;
  color: var(--rb-text);
  background: color-mix(in srgb, var(--rb-dept-color, var(--rb-border)) 12%, var(--rb-bg));
  border-bottom: 1px solid color-mix(in srgb, var(--rb-dept-color, var(--rb-border)) 25%, var(--rb-border));
  border-left: 3px solid var(--rb-dept-color, var(--rb-border));
}
.rb-dagweergave-cards {
  display: flex;
  flex-direction: column;
  gap: var(--rb-space-2);
  padding: var(--rb-space-3);
  background: color-mix(in srgb, var(--rb-dept-color, #94a3b8) 8%, transparent);
}
.rb-dagweergave-cards .rb-wr-shift-card {
  max-width: 360px;
}
.rb-dagweergave-cards .rb-add-btn {
  align-self: flex-start;
}
.rb-dagweergave-empty {
  margin: 0;
  padding: var(--rb-space-4);
  color: var(--rb-text-muted);
  font-size: var(--rb-text-small);
}

/* Genereer en Publiceer knoppen */
.rb-weekrooster-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: var(--rb-space-4);
  margin-bottom: var(--rb-space-10);
}

.rb-weekrooster-feedback {
  width: 100%;
  margin: 0;
  padding: var(--rb-space-3) var(--rb-space-4);
  font-size: var(--rb-text-small);
  font-weight: 600;
  color: var(--rb-primary);
  text-align: left;
  min-height: 2.5em;
  border-radius: var(--rb-radius-btn);
  background: var(--rb-bg-secondary, #f1f5f9);
}

.rb-weekrooster-feedback[hidden] {
  min-height: 0;
  padding: 0;
  margin: 0;
}

.rb-chatbot {
  width: 100%;
  margin: 0;
  padding: var(--rb-space-4);
  border-radius: var(--rb-radius-card);
  background: var(--rb-bg-secondary, #f1f5f9);
  border: 1px solid var(--rb-border, #e8ecf1);
  box-shadow: var(--rb-shadow-card);
  color: var(--rb-text);
  display: flex;
  flex-direction: column;
  gap: var(--rb-space-3);
}

.rb-chatbot[hidden] {
  display: none;
}

.rb-chatbot-header {
  display: flex;
  flex-direction: column;
  gap: var(--rb-space-1);
}

.rb-chatbot-title {
  margin: 0;
  font-size: var(--rb-text-small);
  font-weight: 700;
  color: var(--rb-text);
}

.rb-chatbot-hint {
  font-size: 0.8125rem;
  color: var(--rb-text-muted, #64748B);
}

.rb-chatbot-messages {
  list-style: none;
  margin: 0;
  padding: var(--rb-space-2);
  display: flex;
  flex-direction: column;
  gap: var(--rb-space-2);
  max-height: 360px;
  overflow-y: auto;
  background: #ffffff;
  border: 1px solid var(--rb-border, #e8ecf1);
  border-radius: var(--rb-radius-btn);
}

.rb-chatbot-messages {
  gap: var(--rb-space-3);
}

.rb-chatbot-bubble {
  max-width: 85%;
  width: fit-content;
  padding: var(--rb-space-3) var(--rb-space-4);
  border-radius: var(--rb-radius-card);
  font-size: 0.9375rem;
  line-height: 1.55;
  word-wrap: break-word;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
  position: relative;
}

.rb-chatbot-bubble > p {
  margin: 0;
}

.rb-chatbot-bubble > p + p,
.rb-chatbot-bubble > ul + p,
.rb-chatbot-bubble > p + ul,
.rb-chatbot-bubble > p + ol,
.rb-chatbot-bubble > ol + p {
  margin-top: var(--rb-space-2);
}

.rb-chatbot-bubble ul,
.rb-chatbot-bubble ol {
  margin: 0;
  padding-left: 1.25rem;
}

.rb-chatbot-bubble li {
  margin: 0;
  padding: 0;
}

.rb-chatbot-bubble li + li {
  margin-top: var(--rb-space-1);
}

.rb-chatbot-bubble strong {
  font-weight: 700;
}

.rb-chatbot-bubble em {
  font-style: italic;
}

.rb-chatbot-bubble code {
  font-family: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;
  font-size: 0.875em;
  padding: 0 0.25em;
  background: rgba(15, 23, 42, 0.06);
  border-radius: 4px;
}

.rb-chatbot-bubble--assistant {
  align-self: flex-start;
  background: #ffffff;
  border: 1px solid var(--rb-border, #e8ecf1);
  color: var(--rb-text);
  margin-left: 2.25rem;
}

.rb-chatbot-bubble--assistant::before {
  content: "R";
  position: absolute;
  left: -2.25rem;
  top: 0;
  width: 1.75rem;
  height: 1.75rem;
  border-radius: 50%;
  background: var(--rb-primary, #3B82F6);
  color: #ffffff;
  font-size: 0.8125rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.12);
}

.rb-chatbot-bubble--user {
  align-self: flex-end;
  background: var(--rb-primary, #3B82F6);
  color: #ffffff;
}

.rb-chatbot-bubble--user code {
  background: rgba(255, 255, 255, 0.2);
  color: #ffffff;
}

.rb-chatbot-bubble--pending {
  padding: var(--rb-space-3) var(--rb-space-4);
  min-height: 1.75rem;
  display: flex;
  align-items: center;
  gap: var(--rb-space-2);
}

.rb-chatbot-pending-text {
  line-height: 1.35;
}

.rb-chatbot-dots {
  display: inline-flex;
  gap: 4px;
  flex: 0 0 auto;
}

.rb-chatbot-dots > span {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--rb-text-muted, #64748B);
  opacity: 0.6;
  animation: rb-chatbot-dots-bounce 1.1s infinite ease-in-out;
}

.rb-chatbot-dots > span:nth-child(2) {
  animation-delay: 0.18s;
}

.rb-chatbot-dots > span:nth-child(3) {
  animation-delay: 0.36s;
}

@keyframes rb-chatbot-dots-bounce {
  0%, 80%, 100% {
    transform: translateY(0);
    opacity: 0.6;
  }
  40% {
    transform: translateY(-3px);
    opacity: 1;
  }
}

.rb-chatbot-bubble--typing::after {
  content: "▍";
  display: inline-block;
  margin-left: 2px;
  color: var(--rb-primary, #3B82F6);
  animation: rb-chatbot-caret-blink 0.9s steps(1) infinite;
}

@keyframes rb-chatbot-caret-blink {
  0%, 50% { opacity: 1; }
  51%, 100% { opacity: 0; }
}

.rb-chatbot-bubble--typing {
  cursor: pointer;
}

.rb-chatbot-error {
  margin: 0;
  padding: var(--rb-space-2) var(--rb-space-3);
  border-radius: var(--rb-radius-btn);
  background: var(--rb-error-bg, #fef2f2);
  color: var(--rb-error-fg, #b91c1c);
  border: 1px solid var(--rb-error-border, #fecaca);
  font-size: 0.8125rem;
}

.rb-chatbot-error[hidden] {
  display: none;
}

.rb-chatbot-input-bar {
  display: flex;
  gap: var(--rb-space-2);
  align-items: flex-end;
}

.rb-chatbot-input {
  flex: 1;
  min-height: 2.5rem;
  max-height: 8rem;
  resize: vertical;
  padding: var(--rb-space-2) var(--rb-space-3);
  border: 1px solid var(--rb-border, #e8ecf1);
  border-radius: var(--rb-radius-btn);
  font-family: inherit;
  font-size: var(--rb-text-small);
  line-height: 1.4;
  color: var(--rb-text);
  background: #ffffff;
}

.rb-chatbot-input:focus {
  outline: none;
  border-color: var(--rb-primary, #3B82F6);
  box-shadow: 0 0 0 3px var(--rb-primary-ring, rgb(59 130 246 / 0.22));
}

.rb-chatbot-send {
  flex: 0 0 auto;
  background: var(--rb-primary, #3B82F6);
  color: #ffffff;
  border: none;
  padding: var(--rb-space-2) var(--rb-space-4);
}

.rb-chatbot-send:hover:not(:disabled) {
  background: var(--rb-primary-hover, #2563EB);
}

.rb-chatbot-send:disabled,
.rb-chatbot-input:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

/* Feedback sticky bovenaan viewport bij genereren (altijd zichtbaar op mobiel) */
.rb-weekrooster-feedback.rb-feedback-sticky {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 9999;
  margin: 0;
  padding: var(--rb-space-3) var(--rb-space-4);
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}
@media (min-width: 768px) {
  .rb-weekrooster-feedback.rb-feedback-sticky {
    left: 50%;
    right: auto;
    width: 90%;
    max-width: 480px;
    transform: translateX(-50%);
    top: var(--rb-space-4);
    border-radius: var(--rb-radius-card);
  }
}

.rb-btn-genereer {
  background: var(--rb-primary);
  color: white;
  padding: 0.625rem var(--rb-space-6);
  border: none;
  border-radius: var(--rb-radius-btn);
  font-size: var(--rb-text-body);
  font-weight: 600;
  cursor: pointer;
  box-shadow: var(--rb-shadow-sm);
  transition: background 0.18s ease, box-shadow 0.18s ease;
}

.rb-btn-genereer:hover {
  background: var(--rb-primary-hover);
  color: white;
  box-shadow: 0 2px 8px rgb(37 99 235 / 0.25);
}

.rb-btn-genereer:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px var(--rb-bg), 0 0 0 4px var(--rb-primary-ring);
}

.rb-btn-publiceer {
  background: var(--rb-bg);
  color: var(--rb-text);
  padding: 0.625rem var(--rb-space-6);
  border: 1px solid var(--rb-border);
  border-radius: var(--rb-radius-btn);
  font-size: var(--rb-text-body);
  font-weight: 600;
  cursor: pointer;
  box-shadow: var(--rb-shadow-sm);
  transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

.rb-btn-publiceer:hover {
  background: #F8FAFC;
  border-color: color-mix(in srgb, var(--rb-primary) 35%, var(--rb-border));
  color: var(--rb-primary);
}

.rb-btn-publiceer:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px var(--rb-primary-ring);
}

.rb-btn-publiceer:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.rb-btn-publiceer:hover:disabled {
  background: var(--rb-bg);
  border-color: var(--rb-border);
  color: var(--rb-text);
}

/* --- Roosteroverzicht: card, afdelingsfilter, statusblokken --- */
.rb-roosteroverzicht {
  margin-top: var(--rb-space-8);
}

.rb-roosteroverzicht-card {
  border: 1px solid var(--rb-border);
  border-radius: var(--rb-radius-card);
  background: var(--rb-bg);
  overflow: hidden;
}

.rb-roosteroverzicht-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--rb-space-4);
  padding: var(--rb-space-4) var(--rb-space-6);
  border-bottom: 1px solid var(--rb-border);
  background: var(--rb-bg);
}

.rb-period-toggle {
  display: inline-flex;
  align-items: center;
  background: rgb(15 23 42 / 0.06);
  border: none;
  border-radius: 12px;
  padding: 4px;
  gap: 0;
}

.rb-period-btn {
  padding: 7px 16px;
  background: transparent;
  border: none;
  border-radius: 9px;
  font-size: 0.8125rem;
  font-weight: 500;
  color: rgb(71 85 105 / 0.85);
  cursor: pointer;
  transition: background 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
  white-space: nowrap;
  font-family: var(--rb-font-sans);
}

.rb-period-btn:hover:not(.rb-active) { color: var(--rb-text); }

.rb-period-btn.rb-active {
  background: #fff;
  color: var(--rb-text);
  font-weight: 600;
  box-shadow: 0 1px 3px rgb(15 23 42 / 0.08), 0 1px 2px rgb(15 23 42 / 0.04);
}

.rb-period-btn:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px var(--rb-primary-ring);
}

.rb-balance-toggle {
  display: inline-flex;
  gap: 0;
  margin: var(--rb-space-4) var(--rb-space-6) 0;
  padding: 3px;
  background: rgb(15 23 42 / 0.07);
  border-radius: calc(var(--rb-radius-btn) + 2px);
  width: fit-content;
}

.rb-balance-toggle-btn {
  --rb-proximity: 0;
  padding: var(--rb-space-2) var(--rb-space-4);
  border: none;
  background: transparent;
  border-radius: var(--rb-radius-btn);
  font-size: var(--rb-text-small);
  font-weight: 500;
  color: var(--rb-text-muted);
  cursor: pointer;
  transition: background 0.18s ease, color 0.18s ease, box-shadow 0.18s ease;
}

.rb-balance-toggle-btn.rb-active {
  background: var(--rb-bg);
  color: var(--rb-text);
  box-shadow: var(--rb-shadow-sm);
}

.rb-balance-toggle-btn.rb-proximity-active:not(:hover):not(.rb-active) {
  color: color-mix(in srgb, var(--rb-text) calc(60% + (var(--rb-proximity, 0) * 30%)), var(--rb-text-muted));
  background: color-mix(in srgb, white calc(var(--rb-proximity, 0) * 38%), transparent);
}

.rb-roosteroverzicht-toggle {
  display: inline-flex;
  align-items: center;
  gap: var(--rb-space-3);
  flex: 1;
  min-width: 0;
  margin: 0;
  padding: 0;
  color: var(--rb-text);
}

.rb-roosteroverzicht-title {
  font-size: var(--rb-text-title);
  font-weight: var(--rb-text-title-weight);
  color: inherit;
  margin: 0;
}

.rb-roosteroverzicht-summary-badge {
  font-size: var(--rb-text-small);
  font-weight: 600;
  color: var(--rb-text-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.rb-roosteroverzicht-summary-badge.is-warn {
  color: #b91c1c;
}

.rb-roosteroverzicht-alle {
  padding: 0.5rem var(--rb-space-4);
  border: 1px solid var(--rb-border);
  border-radius: var(--rb-radius-btn);
  font-size: var(--rb-text-small);
  background: var(--rb-bg);
  color: var(--rb-text);
  min-width: 140px;
  box-shadow: var(--rb-shadow-sm);
  transition: border-color 0.18s ease, box-shadow 0.18s ease;
}

.rb-roosteroverzicht-filters {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--rb-space-2);
  flex-wrap: wrap;
}

.rb-roosteroverzicht-alle:hover {
  border-color: #DDE3EB;
}

.rb-roosteroverzicht-alle:focus {
  outline: none;
  border-color: var(--rb-primary);
  box-shadow: var(--rb-shadow-sm), 0 0 0 3px var(--rb-primary-ring);
}

.rb-roosteroverzicht-body {
  padding: var(--rb-space-6);
  display: flex;
  flex-direction: column;
  gap: var(--rb-space-6);
}

.rb-roosteroverzicht-helptext {
  margin: 0 0 var(--rb-space-2);
  font-size: var(--rb-text-small);
  color: var(--rb-text-muted);
  line-height: 1.4;
}

.rb-roosteroverzicht-block {
  padding: var(--rb-space-4);
  border-radius: var(--rb-radius-btn);
  background: #fafafa;
  border: 1px solid var(--rb-border);
}

/* Staat bewust ná .rb-roosteroverzicht-block zodat cascade klopt */
.rb-ziekmeldingen-block {
  padding: 0;
  margin: var(--rb-space-4) var(--rb-space-6);
  border: 1.5px solid #fcd34d;
  border-radius: var(--rb-radius-card);
  background: #fffbeb;
  overflow: hidden;
}

.rb-ziekmeldingen-title {
  background: #fef3c7;
  border-bottom: 1.5px solid #fcd34d;
  color: #92400e;
  font-weight: 700;
  margin: 0;
  padding: var(--rb-space-3) var(--rb-space-5);
  display: flex;
  align-items: center;
  gap: var(--rb-space-2);
}

.rb-ziekmeldingen-title .rb-ziekmelding-count-badge {
  margin-left: 0;
  margin-right: auto;
}

.rb-roosteroverzicht-columns {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--rb-space-6);
  margin-top: var(--rb-space-3);
}

@media (max-width: 640px) {
  .rb-roosteroverzicht-columns {
    grid-template-columns: 1fr;
  }
}

.rb-roosteroverzicht-col-header {
  display: flex;
  align-items: center;
  gap: var(--rb-space-2);
  margin: 0 0 var(--rb-space-3);
}

.rb-roosteroverzicht-col-title {
  font-weight: 600;
  font-size: var(--rb-text-small);
  color: var(--rb-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.rb-overview-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.5rem;
  height: 1.25rem;
  padding: 0 0.45rem;
  border-radius: 999px;
  font-size: 0.6875rem;
  font-weight: 600;
  line-height: 1;
}

.rb-overview-count--hard {
  background: #fee2e2;
  color: #b91c1c;
}

.rb-overview-count--soft {
  background: #fef3c7;
  color: #b45309;
}

.rb-roosteroverzicht-block-title {
  font-weight: 600;
  font-size: var(--rb-text-small);
  margin: 0 0 var(--rb-space-3);
  color: var(--rb-text);
  position: relative;
  cursor: pointer;
  user-select: none;
  padding-right: 28px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.rb-roosteroverzicht-block-title::after {
  content: "";
  width: 6px;
  height: 6px;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: translateY(-2px) rotate(45deg);
  transition: transform 0.25s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.25s ease;
  opacity: 0.65;
  margin-right: 4px;
}

.rb-roosteroverzicht-block-title:hover::after {
  opacity: 1;
}

.rb-roosteroverzicht-block-title.rb-collapsed::after {
  transform: translateY(1px) rotate(-135deg);
}

.rb-roosteroverzicht-block-content {
  overflow: hidden;
  transition: max-height 0.3s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.25s ease;
  max-height: 2000px;
  opacity: 1;
}

.rb-roosteroverzicht-block-content.rb-collapsed,
.rb-ziekmeldingen-list.rb-collapsed {
  max-height: 0 !important;
  overflow: hidden !important;
  opacity: 0 !important;
  pointer-events: none;
}

.rb-ziekmeldingen-list {
  max-height: 800px;
  overflow: hidden;
  opacity: 1;
  transition: max-height 0.3s ease, opacity 0.2s ease;
}

.rb-ziekmelding-count-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.35rem;
  height: 1.35rem;
  padding: 0 0.4rem;
  border-radius: 999px;
  background: #f59e0b;
  color: #fff;
  font-size: 0.7rem;
  font-weight: 700;
  line-height: 1;
  margin-left: var(--rb-space-2);
}

.rb-roosteroverzicht-block-title.rb-roosteroverzicht-status-fail {
  color: #b91c1c;
}

.rb-roosteroverzicht-block-title.rb-roosteroverzicht-status-ok {
  color: #15803d;
}

.rb-roosteroverzicht-quality {
  margin-top: var(--rb-space-3);
  padding: var(--rb-space-3);
  background: var(--rb-bg);
  border-radius: 6px;
  font-size: var(--rb-text-small);
}

.rb-roosteroverzicht-quality-total {
  margin-bottom: var(--rb-space-2);
  color: var(--rb-text);
}

.rb-roosteroverzicht-quality-breakdown {
  display: flex;
  flex-wrap: wrap;
  gap: var(--rb-space-2) var(--rb-space-4);
}

.rb-quality-item {
  display: inline-flex;
  align-items: center;
  gap: var(--rb-space-1);
}

.rb-quality-label {
  color: var(--rb-text-muted);
}

.rb-quality-value {
  font-weight: 500;
  color: var(--rb-text);
}

.rb-roosteroverzicht-issues-count {
  margin-top: var(--rb-space-2);
  font-size: var(--rb-text-small);
  color: var(--rb-text-muted);
}

.rb-overview-day-row {
  margin-bottom: var(--rb-space-6);
  transition: margin-bottom 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}

.rb-overview-day-row.rb-collapsed {
  margin-bottom: var(--rb-space-3);
}

.rb-overview-day-row:last-child {
  margin-bottom: 0;
}

.rb-overview-day-header {
  display: flex;
  align-items: center;
  gap: var(--rb-space-2);
  margin-bottom: var(--rb-space-3);
  padding-bottom: var(--rb-space-2);
  border-bottom: 1px solid rgba(15, 23, 42, 0.06);
  cursor: pointer;
  user-select: none;
}

.rb-overview-day-header::after {
  content: "";
  width: 5px;
  height: 5px;
  border-right: 1.5px solid currentColor;
  border-bottom: 1.5px solid currentColor;
  transform: translateY(-2px) rotate(45deg);
  transition: transform 0.25s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.25s ease;
  opacity: 0.55;
}

.rb-overview-day-header:hover::after {
  opacity: 0.9;
}

.rb-overview-day-header.rb-collapsed::after {
  transform: translateY(0px) rotate(-135deg);
}

.rb-overview-day-name {
  font-weight: 600;
  font-size: var(--rb-text-small);
  color: var(--rb-text);
  text-transform: capitalize;
  letter-spacing: 0.02em;
}

.rb-overview-day-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.25rem;
  height: 1.25rem;
  padding: 0 0.45rem;
  border-radius: 999px;
  font-size: 0.6875rem;
  font-weight: 600;
  background: var(--rb-bg-highlight);
  color: var(--rb-text-muted);
  border: 1px solid var(--rb-border);
}

.rb-roosteroverzicht-list {
  margin: 0;
  padding: 0;
  list-style: none;
  font-size: var(--rb-text-small);
  color: var(--rb-text);
  line-height: 1.45;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--rb-space-3);
  overflow: hidden;
  transition: max-height 0.25s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.2s ease, margin-top 0.25s ease;
  max-height: 500px;
  opacity: 1;
}

.rb-roosteroverzicht-list.rb-collapsed {
  max-height: 0 !important;
  opacity: 0 !important;
  pointer-events: none;
  margin-top: 0 !important;
}

.rb-roosteroverzicht-list li {
  position: relative;
  padding: 0.5rem 0.75rem 0.5rem 0.8rem;
  background: var(--rb-bg);
  border: 1px solid var(--rb-border);
  border-left: 3px solid #b91c1c;
  border-radius: 6px;
  box-shadow: 0 1px 1px rgb(0 0 0 / 0.02);
}

.rb-roosteroverzicht-list li.rb-roosteroverzicht-issue-segment {
  color: var(--rb-text);
  border-left-color: #d97706;
  background: #fffbeb;
  border-color: #fde68a;
}

.rb-roosteroverzicht-list li.rb-overview-empty {
  grid-column: 1 / -1;
  border-left-color: #15803d;
  background: #f0fdf4;
  border-color: #bbf7d0;
  color: #166534;
  font-weight: 500;
}

.rb-roosteroverzicht-list li.rb-overview-empty--muted {
  grid-column: 1 / -1;
  border-left-color: var(--rb-border);
  background: var(--rb-bg);
  color: var(--rb-text-muted);
  font-weight: 400;
}

.rb-issue-sep {
  color: var(--rb-text-muted);
  font-weight: 400;
}

.rb-issue-body {
  display: block;
  margin-top: 4px;
  color: var(--rb-text-muted);
  font-weight: 400;
  line-height: 1.4;
}

.rb-roosteroverzicht-muted {
  margin: 0;
  font-size: var(--rb-text-small);
  color: var(--rb-text-muted);
}

/* Personeelstabel: zelfde stijl als Mijn team-tabel */
.rb-roosteroverzicht-personnel-table-wrap {
  overflow-x: auto;
  margin-top: var(--rb-space-3);
  width: 100%;
  min-width: 0;
  background: var(--rb-bg);
  border: 1px solid var(--rb-border);
  border-radius: var(--rb-radius-card);
  box-shadow: 0 1px 2px rgb(0 0 0 / 0.04);
}

.rb-roosteroverzicht-personnel-table {
  width: 100%;
  min-width: 480px;
  border-collapse: collapse;
  table-layout: fixed;
  font-size: var(--rb-text-small);
}

.rb-roosteroverzicht-personnel-table th {
  text-align: left;
  padding: var(--rb-space-3) var(--rb-space-5);
  font-weight: 600;
  font-size: 0.6875rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--rb-text-muted);
  border-bottom: 1px solid var(--rb-border);
  background: var(--rb-bg-highlight);
}

.rb-roosteroverzicht-personnel-table td {
  padding: var(--rb-space-4) var(--rb-space-5);
  border-bottom: 1px solid rgba(0, 0, 0, 0.06);
  vertical-align: middle;
  text-align: left;
}

.rb-roosteroverzicht-personnel-table th:nth-child(1),
.rb-roosteroverzicht-personnel-table td:nth-child(1) {
  width: 30%;
}

.rb-roosteroverzicht-personnel-table th:nth-child(2),
.rb-roosteroverzicht-personnel-table td:nth-child(2),
.rb-roosteroverzicht-personnel-table th:nth-child(3),
.rb-roosteroverzicht-personnel-table td:nth-child(3),
.rb-roosteroverzicht-personnel-table th:nth-child(4),
.rb-roosteroverzicht-personnel-table td:nth-child(4) {
  width: 16%;
}

.rb-roosteroverzicht-personnel-table th:nth-child(5),
.rb-roosteroverzicht-personnel-table td:nth-child(5) {
  width: 22%;
}

.rb-roosteroverzicht-personnel-table th:nth-child(2),
.rb-roosteroverzicht-personnel-table th:nth-child(3),
.rb-roosteroverzicht-personnel-table th:nth-child(4),
.rb-roosteroverzicht-personnel-table td:nth-child(2),
.rb-roosteroverzicht-personnel-table td:nth-child(3),
.rb-roosteroverzicht-personnel-table td:nth-child(4) {
  text-align: right;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}

.rb-roosteroverzicht-personnel-table td:nth-child(5),
.rb-roosteroverzicht-personnel-table th:nth-child(5) {
  text-align: right;
}

.rb-roosteroverzicht-status-neutral {
  color: var(--rb-text);
}

.rb-th-help {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1rem;
  height: 1rem;
  margin-left: 0.25rem;
  border: 1px solid var(--rb-border);
  border-radius: 50%;
  color: var(--rb-text);
  background: var(--rb-bg);
  font-size: 0.6875rem;
  font-weight: 700;
  line-height: 1;
  text-transform: none;
  letter-spacing: 0;
  cursor: help;
}

.rb-th-help:hover,
.rb-th-help:focus-visible {
  border-color: var(--rb-primary);
  color: var(--rb-primary);
  outline: none;
}

.rb-floating-tooltip {
  position: fixed;
  z-index: 2147483647;
  width: min(18rem, 72vw);
  padding: 0.55rem 0.7rem;
  border: 1px solid var(--rb-border);
  border-radius: 6px;
  background: #111827;
  color: #fff;
  box-shadow: 0 12px 32px rgb(15 23 42 / 0.22);
  font-size: 0.75rem;
  font-weight: 500;
  line-height: 1.35;
  letter-spacing: 0;
  text-align: left;
  text-transform: none;
  white-space: normal;
  pointer-events: none;
}

.rb-personnel-delta--neg { color: #b91c1c; font-weight: 600; }
.rb-personnel-delta--pos { color: #15803d; font-weight: 600; }
.rb-personnel-delta--zero { color: var(--rb-text); }

.rb-personnel-status {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.2rem 0.6rem;
  border-radius: 999px;
  font-size: 0.75rem;
  font-weight: 600;
  line-height: 1;
  white-space: nowrap;
}

.rb-personnel-status::before {
  content: "";
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 50%;
  background: currentColor;
}

.rb-personnel-status--ok { background: #f0fdf4; color: #15803d; }
.rb-personnel-status--under { background: #fee2e2; color: #b91c1c; }
.rb-personnel-status--plus { background: #f0fdf4; color: #15803d; }

.rb-roosteroverzicht-personnel-table tbody tr:last-child td {
  border-bottom: none;
}

.rb-roosteroverzicht-personnel-table tbody tr:hover {
  background: #f1f5f9;
}

.rb-personnel-row {
  cursor: pointer;
}

.rb-personnel-row:focus-visible {
  outline: 2px solid var(--rb-link, #1d4ed8);
  outline-offset: -2px;
}

.rb-text-muted {
  color: var(--rb-text-muted);
  font-size: var(--rb-text-small);
  margin: 0;
}

/* --- Extra shift modal --- */
.rb-extra-shift-modal {
  max-width: 500px;
  padding: 0;
  overflow: hidden;
}

.rb-shift-edit-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--rb-space-4);
  padding: 1.25rem 1.5rem 1rem;
  border-bottom: 1px solid var(--rb-border);
}

.rb-shift-edit-header .rb-modal-title {
  margin: 0;
}

.rb-shift-edit-close {
  width: 32px;
  height: 32px;
  padding: 0;
  border: none;
  background: transparent;
  color: var(--rb-text-muted);
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
  border-radius: var(--rb-radius-btn);
  flex-shrink: 0;
}

.rb-shift-edit-close:hover {
  background: #f1f5f9;
  color: var(--rb-text);
}

.rb-shift-edit-title {
  padding: 1.5rem 1.5rem 0;
}

.rb-shift-edit-info {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  font-size: var(--rb-text-small);
  color: #1e40af;
  margin: 0.75rem 1.5rem 0.75rem;
  padding: 0.65rem 0.875rem;
  background: #eff6ff;
  border: 1px solid #bfdbfe;
  border-radius: 8px;
}

.rb-shift-edit-info::before {
  content: "ℹ";
  font-size: 0.875rem;
  line-height: 1.5;
  flex-shrink: 0;
}

.rb-shift-edit-info:empty {
  display: none;
}

.rb-extra-shift-modal form {
  padding: 1.25rem 1.5rem 1.5rem;
}

.rb-extra-shift-modal .rb-shift-type-toggle {
  margin: 0.75rem 1.5rem 0;
  padding-top: 0;
  padding-bottom: 0;
}

.rb-shift-edit-field-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
}


#shift-edit-pauze-wrap {
  margin-left: auto;
}

.rb-shift-pauze-input {
  display: flex;
  align-items: center;
  gap: 0.35rem;
}

.rb-shift-pauze-input input {
  width: 4rem;
  height: 2.25rem;
  padding: var(--rb-space-2) var(--rb-space-3);
  border: 1px solid var(--rb-border);
  border-radius: var(--rb-radius-btn);
  font-size: var(--rb-text-body);
  font-weight: 600;
  color: var(--rb-text);
  text-align: center;
  background: #fff;
  box-sizing: border-box;
  transition: border-color 0.15s, box-shadow 0.15s;
}

.rb-shift-pauze-input input:focus {
  outline: none;
  border-color: var(--rb-primary);
  box-shadow: 0 0 0 1px rgba(59,130,246,0.35);
}

.rb-shift-pauze-input span {
  font-size: var(--rb-text-small);
  color: var(--rb-text-muted);
  white-space: nowrap;
}

.rb-extra-shift-modal .rb-modal-actions {
  margin: 0 -1.5rem -1.5rem;
  padding: 1rem 1.5rem;
  border-top: 1px solid var(--rb-border);
}

.rb-extra-shift-modal .rb-modal-actions .rb-btn {
  padding: 0.7rem 1.5rem;
}

.rb-btn-danger {
  background: transparent;
  color: #dc2626;
  border: 1px solid #fca5a5;
}

.rb-btn-danger:hover {
  background: #fef2f2;
  border-color: #f87171;
}

.rb-btn-sm {
  padding: 4px 10px;
  font-size: 0.78rem;
  min-height: unset;
  height: auto;
}

.rb-btn-warning {
  background: transparent;
  color: #92400E;
  border: 1px solid #FCD34D;
}

.rb-btn-warning:hover:not(:disabled) {
  background: #FEF3C7;
  border-color: #F59E0B;
}

.rb-extra-shift-modal .rb-shift-type-toggle {
  display: flex;
  gap: 0;
  background: rgb(15 23 42 / 0.07);
  border-radius: calc(var(--rb-radius-btn) + 2px);
  padding: 3px;
  margin-bottom: var(--rb-space-6);
}

.rb-extra-shift-modal .rb-shift-type-toggle button {
  flex: 1;
  padding: var(--rb-space-2) var(--rb-space-4);
  border: none;
  background: transparent;
  border-radius: var(--rb-radius-btn);
  font-size: var(--rb-text-small);
  font-weight: 500;
  color: var(--rb-text-muted);
  cursor: pointer;
  transition: background 0.18s ease, color 0.18s ease, box-shadow 0.18s ease;
}

.rb-extra-shift-modal .rb-shift-type-toggle button.rb-active {
  background: var(--rb-bg);
  color: var(--rb-text);
  box-shadow: var(--rb-shadow-sm);
}

.rb-extra-shift-modal .rb-date-row {
  display: flex;
  gap: var(--rb-space-2);
}

.rb-extra-shift-modal .rb-date-row select {
  flex: 1;
  padding: var(--rb-space-2) var(--rb-space-3);
  border: 1px solid var(--rb-border);
  border-radius: var(--rb-radius-btn);
  font-size: var(--rb-text-small);
  background: var(--rb-bg);
  color: var(--rb-text);
}

/* Tijdvelden: Start en Einde (HH:MM), label boven. */
.rb-time-two-fields {
  display: flex;
  align-items: flex-end;
  gap: 0.35rem;
}
.rb-time-single-block { display: flex; flex-direction: column; align-items: center; gap: 0.2rem; }
.rb-time-two-fields .rb-time-block-label { font-size: var(--rb-text-small); font-weight: 500; color: var(--rb-text-muted); }
/* Zelfde styling voor desktop (na RB_initTimeInputs → .rb-time-field) en mobile (type="time") */
.rb-time-two-fields .rb-time-field,
.rb-time-two-fields input[type="time"] {
  width: 5rem !important; min-width: 5rem !important; height: 2.25rem;
  padding: var(--rb-space-2) var(--rb-space-3);
  border: 1px solid var(--rb-border); border-radius: var(--rb-radius-btn);
  font-size: var(--rb-text-body); font-weight: 600; color: var(--rb-text);
  text-align: center; cursor: text; box-sizing: border-box; line-height: 1;
  display: inline-flex; align-items: center; justify-content: center;
  font-variant-numeric: tabular-nums;
  transition: border-color 0.15s, box-shadow 0.15s;
  background: #fff;
}
.rb-time-two-fields .rb-time-field:focus,
.rb-time-two-fields input[type="time"]:focus {
  outline: none; border-color: var(--rb-primary); box-shadow: 0 0 0 1px rgba(59,130,246,0.35);
}
.rb-time-two-fields .rb-time-field::placeholder { color: rgba(107,114,128,0.35); font-weight: 500; }
.rb-time-two-fields .rb-time-field:placeholder-shown,
.rb-time-two-fields .rb-time-field.empty-like {
  border-color: rgba(229,231,235,0.6); background: rgba(249,250,251,0.8); color: rgba(107,114,128,0.4);
}


.rb-extra-shift-modal #field-datum-structureel select {
  width: 100%;
  padding: var(--rb-space-3) var(--rb-space-4);
  border: 1px solid var(--rb-border);
  border-radius: var(--rb-radius-btn);
  font-size: var(--rb-text-body);
  background: var(--rb-bg);
  color: var(--rb-text);
}

.rb-extra-shift-modal .rb-dag-pill {
  display: inline-block;
  padding: var(--rb-space-2) var(--rb-space-4);
  border-radius: 999px;
  background: var(--rb-bg);
  border: 1px solid var(--rb-border);
  font-size: var(--rb-text-small);
}

.rb-extra-shift-modal .rb-form-error {
  color: #DC2626;
  font-size: var(--rb-text-small);
  margin: 0 0 var(--rb-space-4);
}

.rb-extra-shift-modal .rb-form-error[hidden] {
  display: none;
}

.rb-extra-shift-modal .rb-form-warning {
  color: #b45309;
  background: #fffbeb;
  border: 1px solid #fde68a;
  padding: var(--rb-space-3);
  border-radius: var(--rb-radius-btn);
  font-size: var(--rb-text-small);
  line-height: 1.4;
  margin: var(--rb-space-2) 0 var(--rb-space-4);
  display: flex;
  align-items: flex-start;
  gap: var(--rb-space-2);
}

.rb-extra-shift-modal .rb-form-warning::before {
  content: "⚠️";
  font-size: 1rem;
  line-height: 1;
}

.rb-extra-shift-modal .rb-form-warning[hidden] {
  display: none !important;
}

.rb-checkbox-label {
  display: flex;
  align-items: center;
  gap: var(--rb-space-2);
  font-size: var(--rb-text-small);
  color: var(--rb-text);
  cursor: pointer;
}

.rb-checkbox-label input[type="checkbox"] {
  width: 1.125rem;
  height: 1.125rem;
  accent-color: var(--rb-primary);
}

.rb-extra-shift-modal .rb-field select {
  width: 100%;
  padding: var(--rb-space-3) var(--rb-space-4);
  border: 1px solid var(--rb-border);
  border-radius: var(--rb-radius-btn);
  font-size: var(--rb-text-body);
  background: var(--rb-bg);
  color: var(--rb-text);
}

/* --- Roosters pagina: intro, lege staat, read-only shiftkaarten --- */
.rb-roosters-intro {
  font-size: var(--rb-text-body);
  color: var(--rb-text-muted);
  margin: 0 0 var(--rb-space-6);
}

.rb-roosters-published-badge {
  display: inline-flex;
  align-items: center;
  min-height: 1.75rem;
  padding: 0.28rem 0.7rem;
  border: 1px solid #d1d5db;
  border-radius: 999px;
  background: #f3f4f6;
  color: #111827;
  font-size: 0.78rem;
  font-weight: 650;
  line-height: 1.2;
  white-space: nowrap;
}

.rb-roosters-published-badge[hidden] {
  display: none;
}

.rb-roosters-published-badge--archive {
  border-color: #d1d5db;
  background: #f3f4f6;
  color: #111827;
}

.rb-roosters-empty {
  padding: var(--rb-space-10);
  text-align: center;
  background: var(--rb-bg-highlight);
  border: 1px solid var(--rb-border);
  border-radius: var(--rb-radius-card);
}

.rb-roosters-empty p {
  margin: 0 0 var(--rb-space-2);
  font-size: var(--rb-text-body);
  color: var(--rb-text);
}

.rb-roosters-empty-hint {
  font-size: var(--rb-text-small) !important;
  color: var(--rb-text-muted) !important;
}

.rb-roosters-empty-hint a {
  color: var(--rb-primary);
  text-decoration: none;
}

.rb-roosters-empty-hint a:hover {
  text-decoration: underline;
}

.rb-roosters-no-published {
  padding: var(--rb-space-8);
  color: var(--rb-text-muted);
  font-style: italic;
}

/* Scrim achter de uitgeklapte sidebar op mobiel */
.rb-sidebar-scrim {
  display: none;
}

/* Responsive: mobiel — hamburger opent de volledige sidebar als drawer */
@media (max-width: 768px) {
  .rb-dashboard-sidebar {
    position: fixed;
    left: 0;
    top: 0;
    height: 4rem;
    width: 100%;
    z-index: 1100;
    padding: var(--rb-space-3) max(var(--rb-space-4), env(safe-area-inset-left)) var(--rb-space-3) max(var(--rb-space-4), env(safe-area-inset-right));
    flex-direction: column;
    overflow: visible;
    border-right: none;
    border-bottom: 1px solid var(--rb-border);
    box-shadow: var(--rb-shadow-sm);
    transition: transform 0.22s ease, opacity 0.22s ease;
  }

  .rb-dashboard-layout.rb-sidebar-collapsed .rb-dashboard-sidebar {
    transform: none;
  }
  .rb-dashboard-layout.rb-sidebar-collapsed .rb-dashboard-sidebar {
    width: 100%;
    height: 4rem;
    padding: var(--rb-space-3) max(var(--rb-space-4), env(safe-area-inset-left)) var(--rb-space-3) max(var(--rb-space-4), env(safe-area-inset-right));
    border-right: none;
    border-bottom: 1px solid var(--rb-border);
  }
  .rb-dashboard-layout:not(.rb-sidebar-collapsed) .rb-dashboard-sidebar {
    left: 50%;
    top: max(var(--rb-space-5), env(safe-area-inset-top));
    transform: translateX(-50%);
    width: min(320px, 90vw);
    height: auto;
    max-height: 85vh;
    border-radius: 16px;
    border: 1px solid var(--rb-border);
    border-bottom: 1px solid var(--rb-border);
    box-shadow: 0 24px 64px -12px rgb(15 23 42 / 0.35);
    padding: var(--rb-space-6) var(--rb-space-5) var(--rb-space-5);
    overflow-y: auto;
    z-index: 1100;
  }

  .rb-dashboard-layout:not(.rb-sidebar-collapsed) .rb-sidebar-footer {
    display: none;
  }
  .rb-dashboard-layout.rb-sidebar-collapsed .rb-dashboard-sidebar-nav {
    display: none;
  }
  .rb-dashboard-layout .rb-sidebar-toggle {
    position: fixed;
    display: flex;
    width: var(--rb-tap-min);
    height: var(--rb-tap-min);
    left: auto;
    right: calc(max(var(--rb-space-4), env(safe-area-inset-right)) + var(--rb-tap-min) + var(--rb-space-2));
    top: max(var(--rb-space-3), env(safe-area-inset-top));
    border-radius: var(--rb-radius-btn);
    color: var(--rb-text);
    z-index: 1201;
  }
  .rb-sidebar-toggle svg {
    display: none;
  }
  .rb-sidebar-toggle::before {
    content: "";
    width: 18px;
    height: 2px;
    border-radius: 999px;
    background: currentColor;
    box-shadow: 0 -6px 0 currentColor, 0 6px 0 currentColor;
  }
  .rb-logo.rb-logo-with-tagline {
    margin-bottom: var(--rb-space-5);
    max-width: calc(100% - 64px);
  }
  .rb-dashboard-layout.rb-sidebar-collapsed .rb-logo {
    justify-content: flex-start;
    margin-bottom: 0;
  }
  .rb-dashboard-layout.rb-sidebar-collapsed .rb-logo-brand {
    width: auto;
    opacity: 1;
    pointer-events: auto;
  }
  .rb-dashboard-layout.rb-sidebar-collapsed .rb-sidebar-footer {
    position: fixed;
    right: max(var(--rb-space-4), env(safe-area-inset-right));
    top: max(var(--rb-space-3), env(safe-area-inset-top));
    margin-top: 0;
    padding-top: 0;
    z-index: 1201;
  }
  .rb-dashboard-layout.rb-sidebar-collapsed .rb-sidebar-profile {
    width: var(--rb-tap-min);
    min-width: var(--rb-tap-min);
    height: var(--rb-tap-min);
    justify-content: center;
    padding: 0;
    background: var(--rb-bg);
    border: 1px solid var(--rb-border);
    box-shadow: var(--rb-shadow-sm);
  }
  .rb-dashboard-sidebar-nav { gap: var(--rb-space-1); }
  .rb-dashboard-sidebar-nav a { min-height: var(--rb-tap-min); }
  .rb-sidebar-profile { min-height: var(--rb-tap-min); }

  .rb-sidebar-scrim {
    display: block;
    position: fixed;
    inset: 0;
    background: var(--rb-overlay-scrim);
    z-index: 1099;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.22s ease;
  }
  .rb-dashboard-layout:not(.rb-sidebar-collapsed) .rb-sidebar-scrim {
    opacity: 1;
    pointer-events: auto;
  }

  .rb-dashboard-main {
    margin-left: 0;
    padding: calc(4rem + var(--rb-space-3)) max(var(--rb-space-4), env(safe-area-inset-left)) var(--rb-space-6) max(var(--rb-space-4), env(safe-area-inset-right));
    min-width: 0;
  }
  /* ── Week bar ── */
  .rb-weekrooster-week-bar {
    display: grid;
    grid-template-areas:
      "versie  dezeweek"
      "nav     nav";
    grid-template-columns: auto 1fr;
    gap: var(--rb-space-2);
    margin-bottom: var(--rb-space-4);
    align-items: center;
  }
  .rb-weekrooster-week-bar-spacer { grid-area: versie; }
  .rb-weekrooster-week-bar-right  { grid-area: dezeweek; display: flex; justify-content: flex-end; }
  .rb-weekrooster-nav {
    grid-area: nav;
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: var(--rb-bg);
    border: 1px solid var(--rb-border);
    border-radius: var(--rb-radius-card);
    padding: var(--rb-space-1) var(--rb-space-2);
    box-shadow: var(--rb-shadow-sm);
  }
  .rb-weekrooster-nav-range { font-size: 0.9375rem; font-weight: 700; }
  .rb-weekrooster-nav-dates { font-size: 0.8rem; color: var(--rb-text-muted); }
  .rb-weekrooster-nav-btn { min-width: var(--rb-tap-min); min-height: var(--rb-tap-min); border: none; background: transparent; font-size: 1.25rem; }
  .rb-restore-btn { width: auto !important; font-size: 0.8rem; padding: 4px 10px; min-height: 0; }
  .rb-btn-deze-week { font-size: 0.8rem; padding: 4px 10px; box-shadow: none; }

  /* ── Controls rij: view switch bovenaan, dept filter eronder ── */
  .rb-dashboard-controls-row {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: var(--rb-space-2) !important;
    margin-bottom: var(--rb-space-3) !important;
  }
  .rb-dashboard-controls-row > div:first-child { order: 2; }
  .rb-dashboard-view-switch-wrap { order: 1; margin-bottom: 0 !important; }
  .rb-dashboard-view-switch { width: 100%; }
  .rb-dashboard-view-tab { flex: 1; text-align: center; padding: 6px 4px; font-size: 0.75rem; }
  .rb-dashboard-controls-row > div:last-child { display: none !important; }
  .rb-dept-filter-desktop { display: none !important; }
  .rb-mobile-dept-filter { display: flex; align-items: center; margin-bottom: var(--rb-space-3); }
  .rb-mobile-dept-filter .rb-weekrooster-alle-select { width: 100%; }

  .rb-mobile-day-strip-wrap {
    display: flex;
    align-items: center;
    gap: var(--rb-space-2);
    margin-top: var(--rb-space-4);
    margin-bottom: var(--rb-space-4);
  }
  .rb-mobile-day-strip-wrap .rb-mobile-day-strip {
    flex: 1;
    margin-bottom: 0;
  }
  .rb-mobile-dept-arrow {
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--rb-border);
    border-radius: var(--rb-radius-btn);
    background: var(--rb-bg);
    color: var(--rb-text);
    font-size: 1.25rem;
    cursor: pointer;
    transition: background 0.15s, border-color 0.15s;
    box-shadow: var(--rb-shadow-sm);
  }
  .rb-mobile-dept-arrow:hover {
    background: #F8FAFC;
    border-color: #DDE3EB;
  }

  .rb-weekrooster-title { font-size: 1.25rem; }
  .rb-weekrooster-header { margin-bottom: var(--rb-space-3); }
  .rb-restore-btn { font-size: 0.875rem !important; padding: 8px 14px !important; min-height: 36px !important; }
  .rb-btn-deze-week { font-size: 0.875rem !important; padding: 8px 14px !important; }
  .rb-weekrooster-actions { gap: var(--rb-space-3); margin-top: var(--rb-space-8); }
  .rb-weekrooster-actions .rb-btn-genereer,
  .rb-weekrooster-actions .rb-btn-publiceer { flex: 1; min-width: 0; padding: var(--rb-space-3) var(--rb-space-4); }
  .rb-roosteroverzicht-header { flex-direction: column; align-items: stretch; gap: var(--rb-space-3); }
  .rb-roosteroverzicht-toggle { width: 100%; }
  .rb-roosteroverzicht-filters { width: 100%; flex-direction: column; align-items: stretch; }
  .rb-roosteroverzicht-alle { width: 100%; min-width: 0; }

  .rb-shift-detail-modal { max-width: none; }
  .rb-shift-detail-close { min-width: var(--rb-tap-min); min-height: var(--rb-tap-min); }
  .rb-extra-shift-modal { max-width: none; }
  .rb-privacy-modal { max-width: none; }

  /* Verborgen avail kolom op mobiel */
  .rb-avail-col-hidden { display: none; }

  /* Mobile day strip — zelfde stijl als view-switch */
  .rb-mobile-day-strip {
    display: flex;
    width: 100%;
    background: rgb(15 23 42 / 0.06);
    border-radius: 12px;
    padding: 4px;
    gap: 0;
    margin-bottom: var(--rb-space-4);
    box-sizing: border-box;
  }
  .rb-mobile-day-btn {
    flex: 1;
    padding: 5px 4px;
    border: none;
    background: transparent;
    border-radius: 9px;
    font-size: 0.8125rem;
    font-weight: 500;
    color: rgb(71 85 105 / 0.85);
    cursor: pointer;
    transition: background 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
    white-space: nowrap;
    font-family: var(--rb-font-sans);
  }
  .rb-mobile-day-btn:hover {
    color: var(--rb-text);
  }
  .rb-mobile-day-btn--active {
    background: #fff;
    color: var(--rb-text);
    font-weight: 600;
    box-shadow: 0 1px 3px rgb(15 23 42 / 0.08), 0 1px 2px rgb(15 23 42 / 0.04);
  }

  /* Dagweergave terug-knop verbergen op mobiel (navigatie via day strip) */
  .rb-dagweergave-back { display: none; }

  /* Dagweergave title prominent op mobiel */
  .rb-dagweergave-header {
    margin-bottom: var(--rb-space-4);
  }
  .rb-dagweergave-title {
    font-size: 1.125rem;
  }
}
@media (max-width: 480px) {
  .rb-dashboard-main { padding: calc(4rem + var(--rb-space-2)) max(var(--rb-space-3), env(safe-area-inset-left)) var(--rb-space-3) max(var(--rb-space-3), env(safe-area-inset-right)); }
  .rb-wr-th-label, .rb-wr-td-label { width: 70px; min-width: 70px; padding: var(--rb-space-2); font-size: 0.75rem; }
  .rb-wr-td { min-width: 90px; padding: var(--rb-space-2); }
  .rb-wr-shift-card { padding: var(--rb-space-2); font-size: 0.75rem; }
}

/* ── Shift detail modal (dienst inzicht) ───────────────────────────────── */
.rb-shift-detail-modal {
  max-width: 400px;
  width: 100%;
  padding: 0;
  overflow: hidden;
}

.rb-shift-detail-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--rb-space-6) var(--rb-space-6) var(--rb-space-4);
  border-bottom: 1px solid var(--rb-border);
  background: color-mix(in srgb, var(--rb-bg-highlight) 40%, var(--rb-bg));
}

.rb-shift-detail-title {
  font-size: var(--rb-text-title);
  font-weight: var(--rb-text-title-weight);
  color: var(--rb-text);
  margin: 0;
}

.rb-shift-detail-close {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
  background: transparent;
  color: var(--rb-text-muted);
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
  border-radius: var(--rb-radius-btn);
  transition: background 0.15s, color 0.15s;
}

.rb-shift-detail-close:hover {
  background: #F1F5F9;
  color: var(--rb-text);
}

.rb-shift-detail-close:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px var(--rb-primary-ring);
}

.rb-shift-detail-body {
  padding: var(--rb-space-5) var(--rb-space-6);
  display: flex;
  flex-direction: column;
  gap: 0;
}

.rb-shift-detail-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--rb-space-4);
  padding: var(--rb-space-3) 0;
  border-bottom: 1px solid var(--rb-border);
}

.rb-shift-detail-row:last-child {
  border-bottom: none;
}

.rb-shift-detail-label {
  font-size: var(--rb-text-small);
  font-weight: 500;
  color: var(--rb-text-muted);
  flex-shrink: 0;
}

.rb-shift-detail-value {
  font-size: var(--rb-text-body);
  color: var(--rb-text);
  text-align: right;
  word-break: break-word;
}

.rb-shift-detail-actions {
  display: flex;
  gap: var(--rb-space-4);
  justify-content: flex-end;
  padding: var(--rb-space-4) var(--rb-space-6) var(--rb-space-6);
  border-top: 1px solid var(--rb-border);
  background: var(--rb-bg);
}

/* ── Per-medewerker roosterview ────────────────────────────────────────── */
.rb-medw-table-wrap {
  overflow-x: auto;
  background: var(--rb-bg);
  border: 1px solid var(--rb-border);
  border-radius: var(--rb-radius-card);
  box-shadow: 0 1px 2px rgb(0 0 0 / 0.04);
}

.rb-medw-table {
  width: max-content;
  min-width: 100%;
  border-collapse: collapse;
  font-size: var(--rb-text-small);
  white-space: nowrap;
}

/* Level-1 header: dag (spans over afdeling-kolommen) */
.rb-medw-th-day {
  text-align: center;
  padding: var(--rb-space-2) var(--rb-space-3);
  font-weight: 600;
  font-size: 0.75rem;
  color: var(--rb-text);
  background: var(--rb-bg-highlight);
  border-bottom: 1px solid var(--rb-border);
  border-right: 2px solid var(--rb-border);
}

.rb-medw-th-day:last-child {
  border-right: none;
}

/* Level-2 header: afdeling */
.rb-medw-th-dept {
  padding: var(--rb-space-2) var(--rb-space-3);
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--rb-text-muted);
  background: var(--rb-bg);
  border-bottom: 3px solid var(--rb-medw-dept-color, var(--rb-border));
  border-right: 1px solid var(--rb-border);
  min-width: 7rem;
  text-align: center;
}

.rb-medw-th-dept:last-child {
  border-right: none;
}

/* Einde van elke dag: scheidende border */
.rb-medw-th-dept.rb-medw-dept-last {
  border-right: 2px solid var(--rb-border);
}

/* Naamkolom header */
.rb-medw-th-name {
  padding: var(--rb-space-2) var(--rb-space-4);
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--rb-text-muted);
  background: var(--rb-bg);
  border-bottom: 3px solid var(--rb-border);
  border-right: 2px solid var(--rb-border);
  position: sticky;
  left: 0;
  z-index: 2;
  min-width: 9rem;
}

/* Datarijen */
.rb-medw-tr {
  border-bottom: 1px solid var(--rb-border);
}

.rb-medw-tr:last-child {
  border-bottom: none;
}

.rb-medw-tr:hover {
  background: #f8fafc;
}

/* Naamcel */
.rb-medw-td-name {
  padding: var(--rb-space-3) var(--rb-space-4);
  font-weight: 500;
  color: var(--rb-text);
  border-right: 2px solid var(--rb-border);
  background: var(--rb-bg);
  position: sticky;
  left: 0;
  z-index: 1;
  vertical-align: middle;
}

/* Medewerker zonder diensten: gedimde naam */
.rb-medw-tr--no-shifts .rb-medw-td-name {
  color: var(--rb-text-muted);
}

/* Datakcel */
.rb-medw-td {
  padding: var(--rb-space-2);
  vertical-align: top;
  border-right: 1px solid var(--rb-border);
}

.rb-medw-td:last-child {
  border-right: none;
}

/* Lege cel: subtiel gestreept */
.rb-medw-td--empty {
  background-image: repeating-linear-gradient(
    -45deg,
    transparent,
    transparent 5px,
    rgba(148, 163, 184, 0.12) 5px,
    rgba(148, 163, 184, 0.12) 6px
  );
}

/* Scheidende border na elke dag */
.rb-medw-td.rb-medw-dept-last {
  border-right: 2px solid var(--rb-border);
}

/* Dienst-pill in een cel */
.rb-medw-cell-item {
  display: flex;
  flex-direction: column;
  gap: 1px;
  padding: 0.28rem 0.55rem;
  border-radius: 6px;
  border: 1.5px solid var(--rb-medw-skill-color, var(--rb-border));
  background: color-mix(in srgb, var(--rb-medw-skill-color, var(--rb-border)) 8%, var(--rb-bg));
  min-width: 5rem;
}

.rb-medw-cell-vaardigheid {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--rb-text);
  line-height: 1.2;
}

.rb-medw-cell-tijden {
  font-size: 0.6875rem;
  color: var(--rb-text-muted);
  line-height: 1.2;
  font-variant-numeric: tabular-nums;
}

/* Laadindicator */
.rb-medw-loading {
  padding: var(--rb-space-8) var(--rb-space-5);
  color: var(--rb-text-muted);
  font-size: var(--rb-text-small);
  text-align: center;
}

/* =========================================================
   ACTIVITEITENSTROOM  (Activity Log)
   ========================================================= */

.rb-actlog-section {
  margin-top: var(--rb-space-6);
  border-top: 1px solid var(--rb-border);
  padding: var(--rb-space-5) var(--rb-space-6) var(--rb-space-6) var(--rb-space-6);
}

.rb-actlog-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--rb-space-3);
  margin-bottom: var(--rb-space-4);
}

.rb-actlog-title {
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--rb-text-muted);
  margin: 0;
}

.rb-actlog-count-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.4rem;
  height: 1.25rem;
  padding: 0 0.4rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--rb-primary) 12%, var(--rb-bg));
  color: var(--rb-primary);
  font-size: 0.6875rem;
  font-weight: 700;
  line-height: 1;
}

.rb-actlog-timeline {
  list-style: none;
  margin: 0;
  padding: 0;
  position: relative;
}

.rb-actlog-timeline::before {
  content: '';
  position: absolute;
  left: 14px;
  top: 6px;
  bottom: 6px;
  width: 2px;
  background: linear-gradient(to bottom, var(--rb-border) 0%, transparent 100%);
  border-radius: 1px;
}

.rb-actlog-item {
  display: flex;
  gap: var(--rb-space-3);
  position: relative;
  padding-bottom: var(--rb-space-4);
}

.rb-actlog-item:last-child {
  padding-bottom: 0;
}

.rb-actlog-avatar {
  flex-shrink: 0;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--rb-primary) 0%, #7c3aed 100%);
  color: white;
  font-size: 0.6875rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  letter-spacing: 0.02em;
  box-shadow: 0 2px 6px rgb(59 130 246 / 0.25);
  position: relative;
  z-index: 1;
}

.rb-actlog-avatar--manager {
  background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);
}

.rb-actlog-avatar--employee {
  background: linear-gradient(135deg, #8b5cf6 0%, #6d28d9 100%);
}

.rb-actlog-body {
  flex: 1;
  min-width: 0;
}

.rb-actlog-meta {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 0.25em 0.5em;
  margin-bottom: var(--rb-space-1);
  line-height: 1.3;
}

.rb-actlog-who {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--rb-text);
}

.rb-actlog-verb {
  font-size: 0.8125rem;
  color: var(--rb-text-muted);
  font-weight: 400;
}

.rb-actlog-when {
  font-size: 0.75rem;
  color: var(--rb-text-muted);
  margin-left: auto;
  white-space: nowrap;
  cursor: default;
}

.rb-actlog-diff {
  display: flex;
  align-items: center;
  gap: var(--rb-space-2);
  flex-wrap: wrap;
  margin-top: var(--rb-space-1);
}

.rb-actlog-diff-old {
  font-size: 0.75rem;
  font-weight: 500;
  color: #b91c1c;
  background: #fee2e2;
  padding: 0.18em 0.5em;
  border-radius: 4px;
  text-decoration: line-through;
  opacity: 0.85;
}

.rb-actlog-diff-old--available {
  color: #15803d;
  background: #dcfce7;
}

.rb-actlog-diff-old--sick {
  color: #92400e;
  background: #fef3c7;
}

.rb-actlog-diff-arrow {
  font-size: 0.7rem;
  color: var(--rb-text-muted);
}

.rb-actlog-diff-new {
  font-size: 0.75rem;
  font-weight: 600;
  color: #15803d;
  background: #dcfce7;
  padding: 0.18em 0.5em;
  border-radius: 4px;
}

.rb-actlog-diff-new--unavailable {
  color: #b91c1c;
  background: #fee2e2;
}

.rb-actlog-diff-new--sick {
  color: #92400e;
  background: #fef3c7;
}

.rb-actlog-diff-context {
  font-size: 0.75rem;
  color: var(--rb-text-muted);
}

.rb-actlog-skeleton {
  display: flex;
  gap: var(--rb-space-3);
  padding-bottom: var(--rb-space-4);
}

.rb-actlog-skeleton-avatar {
  flex-shrink: 0;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: linear-gradient(90deg, #edf2f7 0%, #f8fafc 45%, #edf2f7 90%);
  background-size: 220% 100%;
  animation: rbSkeletonShimmer 1.15s ease-in-out infinite;
}

.rb-actlog-skeleton-lines {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  padding-top: 0.2rem;
}

.rb-actlog-skeleton-line {
  height: 12px;
  border-radius: 6px;
  background: linear-gradient(90deg, #edf2f7 0%, #f8fafc 45%, #edf2f7 90%);
  background-size: 220% 100%;
  animation: rbSkeletonShimmer 1.15s ease-in-out infinite;
}

.rb-actlog-show-all {
  display: flex;
  justify-content: center;
  margin-top: var(--rb-space-3);
}

.rb-actlog-show-all-btn {
  background: none;
  border: 1px solid var(--rb-border);
  border-radius: var(--rb-radius-btn);
  color: var(--rb-text-muted);
  font-size: 0.8125rem;
  font-weight: 500;
  padding: 0.4rem var(--rb-space-4);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: var(--rb-space-2);
  transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}

.rb-actlog-show-all-btn:hover {
  background: var(--rb-bg-highlight);
  border-color: var(--rb-primary);
  color: var(--rb-primary);
}

.rb-actlog-empty {
  font-size: 0.8125rem;
  color: var(--rb-text-muted);
  font-style: italic;
  text-align: center;
  padding: var(--rb-space-4) 0 var(--rb-space-2);
}

/* Drawer (slide-over) voor volledige geschiedenis */
.rb-actlog-drawer-backdrop {
  position: fixed;
  inset: 0;
  background: var(--rb-overlay-scrim);
  z-index: 20000;
  opacity: 0;
  transition: opacity 0.25s ease;
  pointer-events: none;
  display: flex;
  justify-content: flex-end;
}

.rb-actlog-drawer-backdrop.rb-actlog-drawer-open {
  opacity: 1;
  pointer-events: auto;
}

.rb-actlog-drawer {
  width: min(480px, 100vw);
  height: 100%;
  background: var(--rb-bg);
  box-shadow: -8px 0 40px -4px rgb(15 23 42 / 0.16);
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.rb-actlog-drawer-backdrop.rb-actlog-drawer-open .rb-actlog-drawer {
  transform: translateX(0);
}

.rb-actlog-drawer-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--rb-space-5) var(--rb-space-6);
  border-bottom: 1px solid var(--rb-border);
  flex-shrink: 0;
}

.rb-actlog-drawer-title {
  font-size: 1rem;
  font-weight: 700;
  color: var(--rb-text);
  margin: 0;
}

.rb-actlog-drawer-close {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  border: 1px solid var(--rb-border);
  background: var(--rb-bg);
  color: var(--rb-text-muted);
  font-size: 1.25rem;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s ease, color 0.15s ease;
}

.rb-actlog-drawer-close:hover {
  background: #fee2e2;
  color: #b91c1c;
  border-color: #fecaca;
}

.rb-actlog-drawer-body {
  flex: 1;
  overflow-y: auto;
  padding: var(--rb-space-6);
}

.rb-actlog-drawer-employee {
  font-size: 0.8125rem;
  color: var(--rb-text-muted);
  margin-bottom: var(--rb-space-5);
  font-weight: 500;
}

.rb-actlog-drawer-employee strong {
  color: var(--rb-text);
}

/* --- PDF Export Button Styles --- */
.rb-btn-export-pdf {
  display: inline-flex;
  align-items: center;
  gap: var(--rb-space-2);
  padding: var(--rb-space-2) var(--rb-space-4);
  border: 1px solid var(--rb-primary, #2563eb);
  border-radius: var(--rb-radius-btn);
  background: #fff;
  font-size: var(--rb-text-small);
  font-weight: 600;
  color: var(--rb-primary, #2563eb);
  cursor: pointer;
  box-shadow: var(--rb-shadow-sm);
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  margin-left: var(--rb-space-3);
}

.rb-btn-export-pdf .rb-btn-icon {
  width: 1.15rem;
  height: 1.15rem;
  stroke-width: 2.2px;
  transition: transform 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

.rb-btn-export-pdf:hover {
  background: var(--rb-primary, #2563eb);
  color: #fff;
  border-color: var(--rb-primary, #2563eb);
  box-shadow: 0 4px 12px rgba(37, 99, 235, 0.2);
}

.rb-btn-export-pdf:hover .rb-btn-icon {
  transform: translateY(2px); /* Micro-animation: down-bounce on hover */
}

.rb-btn-export-pdf:focus-visible {
  outline: none;
  box-shadow: var(--rb-shadow-sm), 0 0 0 3px var(--rb-primary-ring);
}

/* --- PDF Print Media Optimization --- */
@media print {
  @page {
    size: A4 landscape;
    margin: 0;
  }

  html, body {
    background: #fff !important;
    color: #0f172a !important;
    min-width: 0 !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    min-height: 0 !important;
    height: auto !important;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif !important;
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
  }
  body {
    padding: 12mm !important;
    box-sizing: border-box !important;
  }
  .rb-weekrooster-table-wrap {
    page-break-after: avoid !important;
    break-after: avoid !important;
  }
  .rb-weekrooster-table {
    page-break-after: avoid !important;
    break-after: avoid !important;
  }

  .rb-dashboard-sidebar,
  .rb-weekrooster-header,
  .rb-weekrooster-week-bar,
  .rb-weekrooster-alle-bar,
  .rb-modal-backdrop,
  .rb-profile-popover,
  .rb-roosters-intro,
  .rb-sidebar-toggle,
  .rb-roosters-empty-hint,
  #rb-sidebar-toggle {
    display: none !important;
  }

  .rb-dashboard-layout {
    display: block !important;
    padding: 0 !important;
    margin: 0 !important;
    min-height: 0 !important;
    height: auto !important;
    background: transparent !important;
  }
  .rb-dashboard-main {
    margin: 0 !important;
    padding: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    min-height: 0 !important;
    height: auto !important;
    background: transparent !important;
  }
  .rb-roosters-empty,
  #roosters-empty {
    display: none !important;
  }

  .rb-weekrooster-table-wrap {
    border: none !important;
    box-shadow: none !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
    width: 100% !important;
    background: transparent !important;
  }

  /* Header */
  .rb-weekrooster-table-wrap::before {
    content: attr(data-print-title);
    display: block;
    font-size: 16pt;
    font-weight: 700;
    letter-spacing: -0.01em;
    margin: 0 0 10mm;
    color: #000 !important;
    padding-bottom: 3mm;
    border-bottom: 1pt solid #000 !important;
  }

  /* Table grid: label column fixed, 7 day columns equal width */
  .rb-weekrooster-table {
    width: 100% !important;
    table-layout: fixed !important;
    min-width: 0 !important;
    max-width: 100% !important;
    border-collapse: collapse !important;
    border: 0.75pt solid #000 !important;
  }
  .rb-wr-th-label,
  .rb-wr-row .rb-wr-td-label {
    width: 9% !important;
    min-width: 0 !important;
    max-width: 9% !important;
  }
  .rb-wr-th,
  .rb-wr-row .rb-wr-td {
    width: 13% !important;
    min-width: 0 !important;
    max-width: 13% !important;
  }

  .rb-wr-th-label,
  .rb-wr-th {
    background: #fff !important;
    border: 0.5pt solid #000 !important;
    padding: 2.5mm 2mm !important;
    font-size: 9pt !important;
    color: #000 !important;
    text-align: left !important;
    vertical-align: top !important;
  }
  .rb-wr-day {
    display: block !important;
    font-size: 9pt !important;
    font-weight: 700 !important;
    color: #000 !important;
    line-height: 1.2 !important;
  }
  .rb-wr-date {
    display: block !important;
    font-size: 7.5pt !important;
    font-weight: 400 !important;
    color: #000 !important;
    line-height: 1.2 !important;
    margin-top: 0.5mm !important;
  }

  .rb-wr-row {
    page-break-inside: avoid;
  }
  .rb-wr-row .rb-wr-td-label,
  .rb-wr-row .rb-wr-td {
    border: 0.5pt solid #000 !important;
    background: #fff !important;
    padding: 2mm !important;
    font-size: 8pt !important;
    color: #000 !important;
    vertical-align: top !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
  }
  .rb-wr-row .rb-wr-td-label {
    background: #fff !important;
    font-weight: 700 !important;
    color: #000 !important;
    font-size: 9pt !important;
  }

  .rb-wr-row-spacer {
    display: none !important;
  }

  .rb-wr-cell-inner {
    display: flex !important;
    flex-direction: column !important;
    gap: 1.5mm !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }

  /* Shift card */
  .rb-wr-shift-card {
    border: 0.5pt solid #000 !important;
    background: #fff !important;
    box-shadow: none !important;
    padding: 1.5mm 2mm !important;
    margin: 0 !important;
    border-radius: 1mm !important;
    page-break-inside: avoid;
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
    color: #000 !important;
  }
  .rb-wr-shift-card-header {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    margin-bottom: 0.5mm !important;
  }
  .rb-wr-shift-time {
    font-size: 8.5pt !important;
    font-weight: 700 !important;
    color: #000 !important;
    letter-spacing: 0 !important;
  }
  .rb-wr-shift-name {
    display: block !important;
    font-size: 8pt !important;
    color: #000 !important;
    font-weight: 500 !important;
    line-height: 1.2 !important;
    word-break: break-word !important;
    margin: 0 0 0.8mm !important;
  }
  /* Vaardigheid-tag: enige plek met kleur (border = skill color) */
  .rb-wr-shift-vaardigheid {
    display: inline-block !important;
    font-size: 6.5pt !important;
    font-weight: 600 !important;
    padding: 0.3mm 1.5mm !important;
    border: 0.75pt solid var(--rb-vaardigheid-color, #000) !important;
    border-radius: 0.8mm !important;
    color: #000 !important;
    background: transparent !important;
    line-height: 1.3 !important;
  }
  .rb-wr-shift-vaardigheid--muted {
    color: #000 !important;
    border-color: #000 !important;
  }

  /* Hide interactive bits */
  .rb-wr-shift-check,
  .rb-wr-shift-lock,
  .rb-wr-shift-card-clickable::after,
  .rb-wr-shift-card--with-lock .rb-wr-shift-lock {
    display: none !important;
  }
  .rb-wr-shift-card-body {
    padding-right: 0 !important;
  }

  /* Open slot (geen medewerker) */
  .rb-wr-shift-card--open-slot {
    background: #fff !important;
    border-style: dashed !important;
    color: #000 !important;
  }
}

.rb-cao-publicatie-waarschuwing {
  display: flex;
  align-items: center;
  gap: var(--rb-space-2);
  margin-bottom: var(--rb-space-3);
  padding: var(--rb-space-2) var(--rb-space-4);
  background: #fffbeb;
  border: 1px solid #fde68a;
  border-radius: var(--rb-radius-btn);
  font-size: var(--rb-text-small);
  color: #92400e;
}
