:root {
  color-scheme: light;
  /* Charte dérivée du logo logo_planning_biologistes_chms.svg */
  --brand-blue: #75a1d1;
  --brand-red: #d4021d;
  --brand-gray: #b1b3b4;
  --brand-ink: #4a4a4a;
  --brand-tint: #e8f2f9;
  --header-bg: #5f87b0;
  --bg: #f2f7fb;
  --surface: #ffffff;
  --surface2: var(--brand-tint);
  --border: #c8d4e0;
  --navy: #3d5669;
  --blue: var(--brand-blue);
  --blue-light: var(--brand-tint);
  --text: var(--brand-ink);
  --text-dim: #6e7378;
  --danger: var(--brand-red);
  /* Tons contextuels planning: plus doux, accordés au thème bleu/gris global */
  --tone-warm-soft: #f6efe1;
  --tone-cool-soft: #e8eef9;
  --tone-rose-soft: #f4e9f2;
  --tone-green-soft: #e7f2e9;
  --tone-amber-soft: #f5ead8;
  --tone-neutral-soft: #edf2f7;
  --tone-warn-soft: #f3ebc9;
  --tone-ok-soft: #dfeee3;
  --tone-outline-warn: #d2bf7b;
  --tone-outline-ok: #93be9f;
  --header-btn-bg: rgba(255, 255, 255, 0.12);
  --header-btn-bg-hover: rgba(255, 255, 255, 0.2);
  --header-btn-bg-active: rgba(255, 255, 255, 0.24);
  --header-btn-border: rgba(255, 255, 255, 0.3);
  --header-btn-border-strong: rgba(255, 255, 255, 0.46);
  --header-btn-text: #f7fbff;
  --header-chip-height: 30px;
  --header-chip-radius: 999px;
  --header-chip-px: 12px;
}
body { font-family: system-ui, -apple-system, Segoe UI, Roboto, sans-serif; margin: 0; background: var(--bg); color: var(--text); }
header { background: var(--header-bg); border-bottom: 1px solid rgba(255,255,255,0.22); box-shadow: 0 2px 12px rgba(61, 86, 105, 0.18); }
.wrap { max-width: min(98vw, 1880px); margin: 0 auto; padding: 16px; }
nav {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  column-gap: 12px;
  row-gap: 8px;
  align-items: start;
}
.nav-app {
  display: flex;
  flex-direction: column;
  gap: 0;
  width: 100%;
}
.nav-app-top {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  width: 100%;
}
.nav-app .nav-left {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 10px;
}
.nav-primary {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: 0;
  width: auto;
}
.nav-tab {
  display: inline-flex;
  align-items: center;
  min-height: var(--header-chip-height);
  padding: 4px var(--header-chip-px);
  border-radius: var(--header-chip-radius);
  font-weight: 700;
  font-size: 12px;
  line-height: 1;
  color: var(--header-btn-text);
  text-decoration: none;
  border: 1px solid transparent;
  background: var(--header-btn-bg);
  transition: background-color 0.15s ease, border-color 0.15s ease, transform 0.12s ease;
}
.nav-tab:hover {
  background: var(--header-btn-bg-hover);
  color: #fff;
  border-color: var(--header-btn-border);
}
.nav-tab.is-active {
  background: var(--header-btn-bg-active);
  border-color: var(--header-btn-border-strong);
  color: #fff;
  box-shadow: 0 2px 8px rgba(19, 41, 64, 0.2);
}
.nav-autres-wrap { display: none; position: relative; }
.nav-autres-btn { gap: 4px; }
.nav-autres-menu {
  display: none;
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  min-width: 160px;
  background: #fff;
  border: 1px solid var(--mp-border, #d8e0ec);
  border-radius: 10px;
  box-shadow: 0 4px 20px rgba(15,27,45,.14);
  z-index: 400;
  padding: 4px;
  flex-direction: column;
  gap: 2px;
}
.nav-autres-menu.is-open { display: flex; }
.nav-autres-item {
  display: block;
  padding: 9px 14px;
  font-size: 13px;
  font-weight: 600;
  color: var(--mp-text, #1a2233);
  border-radius: 7px;
  text-decoration: none;
  transition: background .12s;
}
.nav-autres-item:hover { background: var(--mp-bg-deep, #eef2f8); color: var(--mp-blue, #1e3a6e); }
.nav-autres-item.is-active { background: var(--mp-blue, #1e3a6e); color: #fff; }
.nav-app-actions {
  flex-shrink: 0;
  min-width: 0;
  display: flex;
  flex-wrap: nowrap;
  justify-content: flex-end;
  align-items: flex-start;
  gap: 10px;
  padding-top: 1px;
}
.app-version-pill {
  font-weight: 700;
  font-size: 12px;
  line-height: 1;
  padding: 4px var(--header-chip-px);
}
header .pill.app-version-pill {
  gap: 5px;
}
.app-version-pill__version {
  white-space: nowrap;
}
.app-version-pill__sep {
  color: rgba(255, 255, 255, 0.45);
  font-weight: 800;
  user-select: none;
}
.header-nouveautes-link {
  border: none;
  background: transparent;
  color: #fecaca;
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
  padding: 0;
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 2px;
  text-decoration-thickness: 1px;
  animation: header-nouveautes-blink 1.15s ease-in-out infinite;
}
.header-nouveautes-link:hover {
  color: #fff;
}
.header-nouveautes-link:focus-visible {
  outline: 2px solid #fecaca;
  outline-offset: 2px;
}
@keyframes header-nouveautes-blink {
  0%,
  100% {
    opacity: 1;
    color: #fecaca;
  }
  50% {
    opacity: 0.55;
    color: #f9a8a4;
  }
}
@media (prefers-reduced-motion: reduce) {
  .header-nouveautes-link {
    animation: none;
    opacity: 1;
    color: #fecaca;
  }
}
.global-auth-stack {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 8px;
  min-width: 0;
  max-width: 100%;
  position: relative;
}
#globalAuthBadge { display: none; }
.auth-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: 1px solid rgba(255,255,255,.35);
  background: rgba(255,255,255,.12);
  color: #fff;
  border-radius: 999px;
  padding: 4px 10px 4px 6px;
  cursor: pointer;
  touch-action: manipulation;
}
.auth-chip__avatar {
  width: 24px; height: 24px; border-radius: 999px;
  display: inline-flex; align-items: center; justify-content: center;
  background: #1e3a8a; color: #fff; font-weight: 800; font-size: 11px;
}
/* Déconnecté : pas d’initiales factices ; icône « session invitée » (cadenas) */
.auth-chip__avatar--guest {
  font-size: 0;
  line-height: 0;
}
.auth-chip__avatar--guest::before {
  content: "";
  display: block;
  width: 12px;
  height: 12px;
  background: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M18 8h-1V6a5 5 0 1 0-10 0v2H6a2 2 0 0 0-2 2v10a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V10a2 2 0 0 0-2-2zm-6-2a3 3 0 0 1 6 0v2h-6V6z'/%3E%3C/svg%3E") center / contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M18 8h-1V6a5 5 0 1 0-10 0v2H6a2 2 0 0 0-2 2v10a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V10a2 2 0 0 0-2-2zm-6-2a3 3 0 0 1 6 0v2h-6V6z'/%3E%3C/svg%3E") center / contain no-repeat;
}
.auth-chip__meta { display: flex; flex-direction: column; text-align: left; line-height: 1.05; min-width: 0; }
.auth-chip__name { font-size: 11px; font-weight: 700; color: #fff; max-width: 18ch; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.auth-chip__role { font-size: 10px; color: #dbeafe; max-width: 22ch; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.auth-chip__caret { color: #dbeafe; font-size: 11px; }
.auth-chip__menu {
  position: absolute; top: calc(100% + 6px); right: 0; z-index: 20;
  background: #fff; border: 1px solid #d1d5db; border-radius: 10px; padding: 6px;
  min-width: 150px; box-shadow: 0 8px 24px rgba(15, 23, 42, .22); display: none;
}
.auth-chip__menu.open { display: block; }
.auth-chip__menu button {
  width: 100%; border: 0; background: transparent; text-align: left; border-radius: 8px;
  padding: 8px 10px; font-size: 12px; font-weight: 700; cursor: pointer;
}
.auth-chip__menu #globalAuthLoginBtn { color: #1e3a8a; }
.auth-chip__menu #globalAuthLogoutBtn { color: #b91c1c; }
.auth-chip__menu button:hover { background: #f8fafc; }
#globalAuthBadge {
  max-width: min(36ch, 42vw);
  white-space: nowrap;
  line-height: 1.1;
  overflow: hidden;
  text-overflow: ellipsis;
}
.nav-secondary {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 14px;
  align-items: center;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid rgba(255, 255, 255, 0.2);
  width: 100%;
}
/* Sous-barre : liens (auto) + bandeau = 2e colonne = tout l’espace libre ; le bandeau fait max 80 % de cette colonne. */
.nav-secondary.nav-secondary--split {
  display: grid;
  grid-template-columns: minmax(0, max-content) minmax(0, 1fr);
  align-items: center;
  gap: 12px;
}
.nav-secondary-links {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 14px;
  flex: 1 1 auto;
  min-width: 0;
}
.nav-secondary.nav-secondary--split .header-marquee-wrap {
  justify-self: end;
  width: 80%;
  min-width: 0;
  max-width: 100%;
}
.header-marquee-wrap {
  align-self: center;
}
.header-marquee-mask {
  overflow: hidden;
  width: 100%;
  border-radius: 6px;
  line-height: 1.25;
}
.header-marquee-track {
  display: inline-flex;
  flex-direction: row;
  white-space: nowrap;
  will-change: transform;
  animation: header-marquee-scroll 22s linear infinite;
}
.header-marquee-text {
  display: inline-block;
  padding-right: 2.75rem;
  font-size: clamp(14px, 0.75vw + 12px, 19px);
  font-weight: 800;
  color: #fff;
  letter-spacing: 0.02em;
  text-shadow: 0 1px 3px rgba(15, 23, 42, 0.35);
}
@keyframes header-marquee-scroll {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}
@media (prefers-reduced-motion: reduce) {
  .header-marquee-track {
    animation: none;
    transform: none;
    justify-content: flex-end;
  }
}
.nav-sub {
  font-size: 13px;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.9);
  text-decoration: none;
  padding: 4px 2px;
  border-bottom: 2px solid transparent;
  transition: color 0.15s ease, border-color 0.15s ease;
}
.nav-sub:hover {
  color: #fff;
  border-bottom-color: rgba(255, 255, 255, 0.55);
}
.nav-sub.is-active {
  color: #fff;
  border-bottom-color: #fff;
}
.nav-openrouter-form {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 10px;
  margin-left: auto;
}
@media (max-width: 960px) {
  .nav-openrouter-form {
    margin-left: 0;
    width: 100%;
  }
}
.nav-openrouter-label {
  font-size: 12px;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.88);
  white-space: nowrap;
}
.nav-openrouter-select {
  font-size: 12px;
  font-weight: 600;
  max-width: min(18rem, 46vw);
  padding: 5px 8px;
  border-radius: 6px;
  border: 1px solid rgba(255, 255, 255, 0.35);
  background: rgba(255, 255, 255, 0.12);
  color: #fff;
}
.nav-openrouter-select option {
  color: #1a2a3a;
  background: #fff;
}
.nav-openrouter-custom-wrap {
  display: inline-flex;
  align-items: center;
}
.nav-openrouter-custom {
  font-size: 12px;
  padding: 5px 8px;
  border-radius: 6px;
  border: 1px solid rgba(255, 255, 255, 0.35);
  background: rgba(255, 255, 255, 0.95);
  color: #1a2a3a;
  min-width: 10rem;
  max-width: 16rem;
}
.nav-openrouter-btn {
  font-size: 12px;
  padding: 5px 12px;
  border-radius: 6px;
}
.nav-left {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  flex-wrap: wrap;
  min-width: 0;
}
.nav-left .links {
  width: 100%;
}
nav a { color: #fff; text-decoration: none; font-weight: 600; }
.links { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }
.pill { display:inline-flex; gap:8px; align-items:center; padding: 6px 10px; border:1px solid var(--border); border-radius: 999px; background:var(--surface2); color: var(--navy); }
main .card { background: var(--surface); border: 1px solid var(--border); border-radius: 12px; padding: 16px; box-shadow: 0 2px 8px rgba(93, 129, 161, 0.08); }
h1 { font-size: 20px; margin: 0 0 12px; }
table { width: 100%; border-collapse: collapse; }
th, td { border-bottom: 1px solid var(--border); padding: 10px 8px; text-align: left; vertical-align: top; }
th { font-size: 12px; text-transform: uppercase; letter-spacing: .04em; color: var(--text-dim); }
.muted { color:var(--text-dim); font-size: 13px; }
.code { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 12px; }
.badge { display:inline-flex; align-items:center; gap:6px; padding: 2px 8px; border-radius: 999px; background:var(--surface2); border:1px solid var(--border); }
.row { display:flex; gap: 12px; flex-wrap: wrap; align-items: center; justify-content: space-between; }
form.inline { display:inline; }
button { background:var(--navy); color:white; border:0; padding:8px 12px; border-radius:10px; cursor:pointer; }
button.secondary { background:var(--blue); }
input { padding:10px 12px; border-radius: 10px; border:1px solid var(--border); width: 100%; }
.grid { display:grid; gap: 12px; }
.grid.two { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid.cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid.cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid.cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.stack {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
main .card .stack label,
main .card form.stack label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-weight: 600;
  font-size: 13px;
  color: var(--navy);
  min-width: 0;
}
main .card select {
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid var(--border);
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  background: var(--surface);
  color: var(--text);
}
textarea {
  max-width: 100%;
  box-sizing: border-box;
}
/* Liens « secondaires » dans le contenu : même gabarit tactile que les boutons */
main .card a.secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 12px;
  border-radius: 10px;
  background: var(--blue);
  color: #fff !important;
  text-decoration: none;
  font-weight: 600;
  font-size: 14px;
  box-sizing: border-box;
  min-height: 40px;
  max-width: 100%;
}
main .card a.secondary:hover {
  filter: brightness(0.97);
}
/* Tableaux larges : défilement horizontal sans casser le desktop */
.table-scroll {
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin: 12px 0;
}
.table-scroll table {
  width: 100%;
  border-collapse: collapse;
}
.table-scroll table.table-wide {
  min-width: 640px;
}
.table-scroll td,
.table-scroll th {
  word-break: break-word;
  overflow-wrap: anywhere;
}
.admin-decl-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 10px;
  margin-bottom: 12px;
}
.admin-decl-toolbar form {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 8px;
}
.legacy-db-input {
  min-width: min(100%, 22rem);
  max-width: 100%;
  flex: 1 1 12rem;
}
.decl-page-head {
  align-items: flex-start;
}
.decl-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.admin-decl-row-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
}

/* ── Nouvelle déclaration card ───────────────────────────── */
.decl-new-card { margin-top: 16px; }
.decl-new-title { font-size: 14px; font-weight: 700; color: var(--navy); margin: 0 0 14px; text-transform: uppercase; letter-spacing: .04em; opacity: .7; }
.decl-form-grid { grid-template-columns: repeat(3, minmax(0,1fr)); gap: 10px 14px; }
.decl-time-wrap { display: flex; gap: 10px; }
.decl-time-wrap label { flex: 1; }
.decl-comment-field { grid-column: 1 / -1; }

/* ── Table déclarations ──────────────────────────────────── */
.decl-table { font-size: 13px; }
.decl-table th { white-space: nowrap; font-size: 11px; }
.decl-td-date { white-space: nowrap; font-weight: 600; }
.decl-td-hours { white-space: nowrap; font-size: 12px; color: var(--text-dim); }
.decl-td-comment { color: var(--text-dim); font-size: 12px; max-width: 18rem; }
.decl-row--done td { opacity: .65; }
.decl-row--done .decl-td-date { opacity: 1; }

.decl-type-badge { font-size: 11px; background: var(--surface2); border: 1px solid var(--border); border-radius: 4px; padding: 2px 6px; white-space: nowrap; }

.decl-dam-cell { min-width: 0; vertical-align: middle; }
.decl-dam-wrap { display: flex; align-items: center; gap: 6px; }
.decl-dam-wrap select { flex: 1; min-width: 0; font-size: 12px; padding: 5px 8px; }
.decl-dam-btn { font-size: 11px; padding: 5px 8px; white-space: nowrap; flex-shrink: 0; }

.decl-status-badge { display: inline-block; font-size: 11px; font-weight: 600; border-radius: 4px; padding: 2px 7px; }
.decl-status-badge--pending { background: #fff3cd; color: #856404; border: 1px solid #ffc107; }
.decl-status-badge--done { background: #d1e7dd; color: #0f5132; border: 1px solid #a3cfbb; }

.decl-delete-btn { font-size: 11px; padding: 5px 8px; background: transparent; color: var(--danger); border: 1px solid currentColor; }
.me-ics-qr-panel {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  flex-wrap: wrap;
  border: 1px solid #d7deeb;
  border-radius: 12px;
  background: #f5f9fd;
  padding: 10px 12px;
  margin-top: 10px;
}
.me-ics-qr-panel img {
  flex-shrink: 0;
  max-width: 100%;
  height: auto;
}
.stats-summary-table {
  width: 100%;
  max-width: 36rem;
  margin-top: 14px;
}
.stats-summary-table th,
.stats-summary-table td {
  vertical-align: middle;
}
.decl-edit-form {
  max-width: min(48rem, 100%);
}
.danger { color: var(--danger); font-weight: 600; }

.login-modes { align-items: stretch; }
.login-mode-card {
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  padding: 14px 16px;
  background: #fafbfc;
}
.login-mode-title {
  font-size: 16px;
  margin: 0 0 4px;
  font-weight: 700;
}
.login-mode-form {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 8px;
}
.login-mode-form label {
  font-size: 12px;
}
.login-mode-form select {
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid #cbd5e1;
  width: 100%;
  background: #fff;
}
.login-mode-extra {
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid #e2e8f0;
}
.login-mode-form.inline-row {
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
}
.login-mode-form.inline-row input {
  width: auto;
  flex: 1;
  min-width: 140px;
}

/* Palette codes (pinceau) */
.code-palette {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin-top: 8px;
}
.code-palette-title { margin-right: 4px; }
.code-palette-hint {
  margin-top: 6px;
  font-size: 12px;
  max-width: 52em;
}
button.code-palette-btn {
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--surface2);
  color: var(--text);
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  touch-action: manipulation;
}
button.code-palette-btn:hover {
  background: var(--blue-light);
}
button.code-palette-btn.is-selected {
  background: var(--navy);
  border-color: var(--navy);
  color: #fff;
}
button.code-palette-clear {
  font-family: system-ui, sans-serif;
  font-weight: 600;
}

/* Grille type feuille de calcul (planning presence) */
.spreadsheet {
  --date-column-width: 16.8ch;
  /* Hauteur approx. de la 1re ligne d’en-tête pour caler la 2e ligne en sticky (sinon tout reste à top:0 et se chevauche). */
  --ss-head-row2-top: 2.45rem;
}
.spreadsheet-hint { margin-top: 8px; font-size: 13px; }
.spreadsheet-scroll {
  margin-top: 12px;
  overflow: auto;
  max-height: 78vh;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--surface);
}
.spreadsheet-scroll--fonctionnel {
  margin-top: 6px;
}
.fonc-planning-month-hint {
  margin-top: 4px;
  margin-bottom: 0;
}
main .card table.spreadsheet {
  width: max-content;
  min-width: 100%;
  font-size: 12px;
  border-collapse: collapse;
  table-layout: fixed;
}
main .card table.spreadsheet thead th {
  position: sticky;
  z-index: 2;
  background: var(--surface2);
  border: 1px solid var(--border);
  padding: 4px 1px;
  text-align: center;
  font-size: 11px;
  line-height: 1.2;
}
main .card table.spreadsheet thead tr:first-child > th {
  top: 0;
  z-index: 3;
}
main .card table.spreadsheet thead tr:nth-child(2) > th {
  top: var(--ss-head-row2-top);
  z-index: 3;
}
main .card table.spreadsheet thead th.corner {
  left: 0;
  z-index: 5;
  width: var(--date-column-width);
  min-width: var(--date-column-width);
  max-width: var(--date-column-width);
  background: var(--blue-light);
  box-shadow: 1px 0 0 rgba(15, 23, 42, 0.08);
}
main .card table.spreadsheet tbody th.date-cell {
  position: sticky;
  left: 0;
  z-index: 2;
  background: var(--surface2);
  border: 1px solid var(--border);
  padding: 3px 5px;
  font-weight: 500;
  vertical-align: middle;
  width: var(--date-column-width);
  min-width: var(--date-column-width);
  max-width: var(--date-column-width);
  white-space: nowrap;
  box-shadow: 1px 0 0 rgba(15, 23, 42, 0.06);
}
main .card table.spreadsheet .date-fr {
  font-size: 11px;
  line-height: 1.25;
  display: inline-block;
}
main .card table.spreadsheet tbody tr.weekend th.date-cell,
main .card table.spreadsheet tbody tr.weekend td.sheet-cell {
  background: #eef2f7;
}
main .card table.spreadsheet tbody tr.jour-ferie th.date-cell,
main .card table.spreadsheet tbody tr.jour-ferie td.sheet-cell,
main .card table.spreadsheet tbody tr.jour-ferie th.plage-row-label {
  background: #e4e4e7;
}
main .card table.spreadsheet tbody tr.jour-ferie td.divers-cell,
main .card table.spreadsheet tbody tr.jour-ferie td.divers-cell textarea,
main .card table.spreadsheet tbody tr.jour-ferie td.divers-cell .fonc-divers-read {
  background: #e4e4e7;
}
main .card table.spreadsheet tbody tr.weekend.jour-ferie th.date-cell,
main .card table.spreadsheet tbody tr.weekend.jour-ferie td.sheet-cell,
main .card table.spreadsheet tbody tr.weekend.jour-ferie th.plage-row-label {
  background: #d4d4d8;
}
main .card table.spreadsheet td.sheet-cell {
  border: 1px solid var(--border);
  padding: 0;
  vertical-align: middle;
  background: var(--surface);
  width: 30px;
}
main .card table.spreadsheet .cell-form {
  margin: 0;
  padding: 0;
  display: block;
}
main .card table.spreadsheet input.cell-input {
  width: 100%;
  box-sizing: border-box;
  border: none;
  margin: 0;
  padding: 2px 1px;
  text-align: center;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 10px;
  text-transform: uppercase;
  background: transparent;
  min-height: 20px;
}
main .card table.spreadsheet input.cell-input:focus {
  outline: 2px solid #3b82f6;
  outline-offset: -2px;
  background: #eff6ff;
}
main .card table.spreadsheet input.cell-input.is-saving {
  background: #fef3c7;
}
main .card table.spreadsheet input.cell-input.is-error {
  background: #fee2e2;
}
main .card table.spreadsheet td.sheet-cell--planning-out {
  background: #eef1f4;
  opacity: 0.92;
}
main .card table.spreadsheet td.sheet-cell--planning-out input.cell-input {
  color: var(--text-dim);
  cursor: not-allowed;
}
main .card table.spreadsheet.brush-mode {
  cursor: crosshair;
}
main .card table.spreadsheet.brush-mode td.sheet-cell {
  user-select: none;
}

.read-only-banner {
  margin-top: 10px;
  padding: 10px 12px;
  background: #eff6ff;
  border: 1px solid #bfdbfe;
  border-radius: 10px;
  font-size: 13px;
}
.read-only-banner a { font-weight: 600; }

.admin-h2 {
  font-size: 16px;
  margin: 24px 0 8px;
}
.admin-table-wrap {
  overflow-x: auto;
  margin-top: 10px;
}
table.admin-table {
  font-size: 13px;
}
table.admin-table.compact th,
table.admin-table.compact td {
  padding: 6px 8px;
  font-size: 12px;
}

/* Admin — affectation astreintes par dimanche (bloc compact) */
.admin-astreinte-assign-fold {
  margin-bottom: 10px !important;
  padding: 8px 10px !important;
  max-width: 100% !important;
}
.admin-astreinte-assign-summary {
  cursor: pointer;
  font-size: 0.98rem;
  font-weight: 700;
  margin: 0;
  list-style-position: outside;
}
.admin-astreinte-assign-intro {
  margin: 4px 0 6px !important;
  font-size: 0.8rem !important;
  line-height: 1.25 !important;
}
.admin-astreinte-assign-form {
  margin-top: 0;
}
.admin-astreinte-assign-scroll {
  overflow: auto;
  max-width: 100%;
}
.admin-astreinte-assign-table.admin-table.compact th,
.admin-astreinte-assign-table.admin-table.compact td {
  padding: 3px 5px;
  font-size: 11px;
  vertical-align: middle;
}
.admin-astreinte-assign-table .admin-astreinte-assign-col-date {
  min-width: 9.5rem;
  max-width: 12rem;
}
.admin-astreinte-assign-date-cell {
  line-height: 1.15;
}
.admin-astreinte-assign-dim {
  display: block;
  font-weight: 600;
  font-size: 10px;
}
.admin-astreinte-assign-sam {
  display: block;
  font-size: 9px;
  color: var(--muted, #64748b);
  margin-top: 1px;
}
.admin-astreinte-assign-ferie {
  display: block;
  font-size: 8px;
  line-height: 1.2;
  margin-top: 2px;
  color: var(--warn-fg, #a16207);
}
.admin-astreinte-assign-select.admin-form-control {
  max-width: 8.5em;
  font-size: 11px;
  padding: 2px 4px;
  min-height: 24px;
  line-height: 1.2;
}
.admin-astreinte-assign-actions {
  margin-top: 8px;
  padding-top: 6px;
  border-top: 1px solid var(--border, #e2e8f0);
}
.admin-astreinte-assign-actions .primary {
  font-size: 12px;
  padding: 6px 12px;
}

.admin-jours-feries-table .admin-jours-feries-date {
  vertical-align: top;
  white-space: nowrap;
  max-width: 14rem;
}
.admin-jours-feries-weekday {
  display: block;
  font-size: 0.88rem;
}
.admin-jours-feries-badge {
  display: inline-block;
  margin-top: 4px;
  font-size: 0.72rem;
  font-weight: 600;
  padding: 2px 6px;
  border-radius: 4px;
  background: var(--warn-bg, #fef3c7);
  color: var(--warn-fg, #92400e);
}
.admin-jours-feries-row-priority td {
  background: rgba(254, 243, 199, 0.35);
}
.admin-jours-feries-slots {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 14px;
  align-items: flex-end;
}
.admin-jours-feries-slot {
  display: flex;
  flex-direction: column;
  gap: 3px;
  margin: 0;
  min-width: 10rem;
}
.admin-jours-feries-slot-label {
  font-size: 0.78rem;
}
.admin-jours-feries-select.admin-form-control {
  font-size: 0.88rem;
  min-width: 11rem;
}

.admin-actions {
  vertical-align: top;
  min-width: 220px;
}
form.admin-referentiel-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
}
form.admin-referentiel-row input,
form.admin-referentiel-row select {
  width: auto;
}

/* Tables admin : une cellule = une colonne (alignement) */
table.admin-table-form tbody td {
  vertical-align: middle;
}
.admin-form-control {
  width: 100%;
  max-width: 10em;
  box-sizing: border-box;
  font-size: 13px;
  padding: 6px 8px;
  border-radius: 8px;
  border: 1px solid #cbd5e1;
}
.admin-form-control-wide {
  max-width: 22em;
}
.fj-date-title {
  font-size: 1.35rem;
  line-height: 1.2;
}
.fj-card {
  margin-bottom: 14px;
}
.fj-table {
  margin-top: 8px;
}
.fj-table tbody tr td,
.fj-table tbody tr th {
  padding-top: 8px !important;
  padding-bottom: 8px !important;
}
.fj-bio {
  color: #1d4ed8;
  font-weight: 600;
}
.fj-phone {
  color: #15803d;
  font-weight: 600;
}
.admin-color-cell {
  white-space: nowrap;
}
.admin-couleur-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}
.admin-color-swatch {
  display: inline-block;
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border-radius: 8px;
  border: 1px solid #cbd5e1;
  vertical-align: middle;
}
.admin-couleur-open {
  font-size: 13px;
  padding: 6px 10px;
}
.admin-code-color-dialog {
  border: none;
  border-radius: 12px;
  padding: 16px 18px;
  max-width: calc(100vw - 24px);
  box-shadow: 0 12px 40px rgba(15, 23, 42, 0.18);
}
.admin-code-color-dialog::backdrop {
  background: rgba(15, 23, 42, 0.35);
}
.admin-code-color-dialog-title {
  font-size: 17px;
  margin: 0 0 4px;
}
.admin-code-color-grid {
  display: grid;
  grid-template-columns: repeat(8, minmax(0, 1fr));
  gap: 6px;
  width: min(320px, 85vw);
  margin-bottom: 14px;
}
.admin-code-color-swatch-btn {
  width: 100%;
  aspect-ratio: 1;
  max-height: 36px;
  padding: 0;
  border-radius: 8px;
  border: 1px solid rgba(15, 23, 42, 0.12);
  cursor: pointer;
  box-sizing: border-box;
}
.admin-code-color-swatch-btn:hover {
  outline: 2px solid #2563eb;
  outline-offset: 1px;
}
.admin-code-color-dialog-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
}
.admin-actif-label {
  display: flex;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
  font-size: 13px;
}
.admin-actions-cell {
  min-width: 8.5em;
}
.admin-inline-actions {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
}
.admin-inline-actions button {
  width: 100%;
}
.stack-form {
  margin: 0 0 8px;
}
/* Texte lisible : la classe .danger seule colore le texte en rouge, ce qui masquait le libellé sur fond rouge. */
button.danger {
  background: var(--danger);
  color: #fff;
  font-weight: 600;
}
button.danger:hover:not(:disabled) {
  background: #991b1b;
}
.admin-hab-scroll {
  overflow-x: auto;
  max-width: 100%;
}
.admin-hab-matrix th.admin-hab-sticky-col,
.admin-hab-matrix td.admin-hab-sticky-col {
  position: sticky;
  left: 0;
  z-index: 1;
  background: #fff;
  box-shadow: 4px 0 8px -4px rgba(15, 23, 42, 0.15);
  text-align: left;
  min-width: 10em;
}
.admin-hab-tache-head {
  vertical-align: bottom;
  min-width: 4.5em;
  max-width: 7em;
  font-size: 11px;
  line-height: 1.25;
}
.admin-hab-tache-code {
  display: block;
  font-weight: 700;
  color: #334155;
}
.admin-hab-tache-label {
  display: block;
  font-weight: 500;
  color: #64748b;
}
.admin-hab-cell {
  text-align: center;
  vertical-align: middle;
}
.admin-hab-check-label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  padding: 4px;
}
.file-path {
  font-size: 11px;
  word-break: break-all;
  margin-top: 4px;
}
.badge.warn {
  background: #fef3c7;
  border-color: #fcd34d;
  color: #92400e;
  font-size: 11px;
  font-weight: 600;
}
.ok-banner {
  padding: 10px 12px;
  background: #ecfdf5;
  border: 1px solid #a7f3d0;
  border-radius: 10px;
  color: #065f46;
}
.ok { color: #059669; font-weight: 600; }

.brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-right: 10px;
  white-space: nowrap;
}
/* Logo lisible sur le bandeau bleu : fond clair type carte */
.brand--on-header {
  background: #fff;
  padding: 1px;
  border-radius: 12px;
  border: 1px solid rgba(61, 86, 105, 0.14);
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
  align-self: flex-start;
}
.brand--on-header:hover {
  border-color: rgba(61, 86, 105, 0.22);
  box-shadow: 0 3px 14px rgba(0, 0, 0, 0.12);
}
.brand-logo {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  flex-shrink: 0;
}
.brand-logo--wordmark {
  width: auto;
  height: 56px;
  max-width: min(420px, 62vw);
  border-radius: 0;
  object-fit: contain;
  object-position: left center;
}
.brand-logos {
  display: inline-flex;
  align-items: center;
  gap: 2px;
}
.brand-logo--compact {
  width: auto;
  height: 56px;
  max-width: min(88px, 18vw);
  border-radius: 0;
  object-fit: contain;
}
.brand-logo--mascot {
  width: auto;
  height: 48px;
  max-width: min(56px, 14vw);
  border-radius: 8px;
  object-fit: contain;
  flex-shrink: 0;
}
.brand-logo-title--booktime {
  text-transform: none;
  letter-spacing: 0.01em;
}
.brand-logo-title .brand-book {
  color: #1e3a6e;
  font-weight: 800;
}
.brand-logo-title .brand-time-red {
  color: var(--brand-red);
  font-weight: 800;
}
.brand-logo-title .brand-tagline {
  color: #1e3a6e;
  font-weight: 700;
  font-size: 0.88em;
}
.brand-logo-title {
  display: inline-block;
  font-size: 19px;
  font-weight: 800;
  line-height: 1.02;
  letter-spacing: 0.02em;
  color: #1e3a6e;
  text-transform: uppercase;
  white-space: nowrap;
  padding: 0 4px 0 2px;
}
.brand-logo-title .lia-word {
  color: var(--brand-red);
}
.brand-logo-title .module-word {
  color: #1e3a6e;
}
.brand-logo--chms {
  width: auto;
  height: 42px;
  max-width: min(240px, 38vw);
  border-radius: 0;
  object-fit: contain;
  display: none;
}
.brand-title {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

header .muted {
  color: rgba(255, 255, 255, 0.72);
}
header .pill {
  border-color: var(--header-btn-border);
  background: var(--header-btn-bg);
  color: #fff;
  border-radius: var(--header-chip-radius);
  min-height: var(--header-chip-height);
  display: inline-flex;
  align-items: center;
  padding: 4px var(--header-chip-px);
  font-size: 12px;
  line-height: 1;
}
header .badge {
  background: var(--header-btn-bg);
  border-color: var(--header-btn-border);
  color: #fff;
}
header button.secondary {
  background: #f8fbff;
  color: #1f3f5d;
  border: 1px solid #cbdced;
  font-weight: 600;
  box-shadow: 0 1px 3px rgba(19, 41, 64, 0.12);
  border-radius: var(--header-chip-radius);
  min-height: var(--header-chip-height);
  padding: 4px var(--header-chip-px);
  font-size: 12px;
  line-height: 1;
}
header button.secondary:hover {
  background: #ffffff;
  border-color: #b5cde6;
  transform: translateY(-1px);
}
header button.secondary:active {
  transform: translateY(0);
  box-shadow: 0 1px 2px rgba(19, 41, 64, 0.14);
}

.planning-page-title-h1 {
  margin: 0 0 6px;
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--navy);
  line-height: 1.35;
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.25em 0.45em;
}
.planning-page-title-kicker {
  font-weight: 600;
  color: #3d4d60;
}
.planning-page-title-month {
  font-size: 1.05rem;
  font-weight: 600;
  letter-spacing: 0;
  color: #5a6d82;
}

/* Aide repliée : sous le titre, chevron + libellé discret */
.page-intro-details {
  margin: 0 0 12px;
}
.page-intro-details--below-title:not([open]) {
  margin-bottom: 8px;
}
.page-intro-details--below-title[open] {
  border: 1px solid #e4eaf3;
  border-radius: 8px;
  background: #fafbfc;
  padding: 8px 10px 10px;
}
.page-intro-summary--help-toggle {
  cursor: pointer;
  list-style: none;
  display: inline-flex;
  align-items: center;
  gap: 0.3em;
  padding: 0;
  margin: 0;
  user-select: none;
  font-size: 0.78rem;
  font-weight: 400;
  color: #8b98a8;
}
.page-intro-summary--help-toggle:hover {
  color: #6b7b8f;
}
.page-intro-summary--help-toggle::-webkit-details-marker {
  display: none;
}
.page-intro-summary--help-toggle::before {
  content: "▸";
  font-size: 0.62rem;
  opacity: 0.45;
  line-height: 1;
}
.page-intro-details--below-title[open] > .page-intro-summary--help-toggle::before {
  content: "▾";
  opacity: 0.5;
}
.page-intro-help-label {
  text-transform: lowercase;
}
.page-intro-details--below-title[open] .page-intro-body {
  margin-top: 6px;
  padding-top: 8px;
  border-top: 1px solid #e8edf4;
  font-size: 0.88rem;
  line-height: 1.45;
  color: #4b5a70;
}
.page-intro-body p {
  margin: 10px 0 0;
}
.page-intro-body p:first-child {
  margin-top: 0;
}

.planning-title {
  color: var(--navy);
  margin-bottom: 8px;
}
.praticien-head {
  color: var(--navy);
  font-weight: 700;
}
.praticien-head .bio-name-code {
  display: none;
}
.praticien-head .initials {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 24px;
  height: 20px;
  border-radius: 999px;
  border: 1px solid #b7d6eb;
  background: var(--blue-light);
  font-size: 10px;
  letter-spacing: 0.02em;
  line-height: 1;
}

.planning-mobile {
  display: none;
  margin-top: 12px;
}
.planning-mobile-day {
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--surface);
  margin-bottom: 10px;
  overflow: hidden;
}
.planning-mobile-day.is-weekend { background: #eef2f7; }
.planning-mobile-day.is-holiday { background: #e4e4e7; }
.planning-mobile-date {
  padding: 8px 10px;
  font-size: 12px;
  font-weight: 700;
  color: var(--navy);
  border-bottom: 1px solid var(--border);
}
.planning-mobile-date--compact {
  display: none;
}
/* Sélecteurs de date explicites : format long par défaut, compact masqué. */
.date-fr--full {
  display: inline !important;
}
.date-fr--compact {
  display: none !important;
}
.planning-mobile-grid {
  display: grid;
  grid-template-columns: 52px 1fr 1fr;
  gap: 0;
}
.planning-mobile--show-night .planning-mobile-grid {
  grid-template-columns: 52px 1fr 1fr 1fr;
}
.planning-mobile-grid .presence-mobile-night {
  display: none;
}
.planning-mobile--show-night .planning-mobile-grid .presence-mobile-night {
  display: block;
}
.planning-mobile-grid-head,
.planning-mobile-grid-cell {
  padding: 7px 8px;
  border-bottom: 1px solid var(--border);
  font-size: 12px;
}
.planning-mobile-grid-head {
  font-size: 10px;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  background: var(--surface2);
}
.planning-mobile-grid-name {
  font-weight: 700;
  color: var(--navy);
}

/* Présence : colonnes « nuit » par praticien — masquées par défaut (display + colspan JS, pas d'espace fantôme) */
.planning-presence-table:not(.planning-presence-table--show-night) col.presence-col-night {
  display: none;
}
.planning-presence-table:not(.planning-presence-table--show-night) th.presence-plage-night,
.planning-presence-table:not(.planning-presence-table--show-night) td.presence-cell-night {
  display: none;
}
/* Astreinte nuit sans codes présence jour « nuit » : saisir FAO2 manuellement sur la colonne N */
.presence-cell-night--needs-manual-fao2 {
  background: var(--tone-warn-soft) !important;
  box-shadow: inset 0 0 0 1px var(--tone-outline-warn);
}
.presence-mobile-night--needs-manual-fao2 {
  background: var(--tone-warn-soft);
  box-shadow: inset 0 0 0 1px var(--tone-outline-warn);
}
.presence-night-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: 3px;
  margin-left: 10px;
  cursor: pointer;
  user-select: none;
  width: max-content;
  max-width: 100%;
  flex: 0 0 auto;
}
.presence-night-toggle input[type="checkbox"] {
  margin: 0;
  flex-shrink: 0;
}
.presence-night-toggle__text {
  margin: 0;
  padding: 0;
  white-space: nowrap;
}

.density-toolbar {
  margin-top: 8px;
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}
.density-toolbar--presence {
  width: 100%;
  flex-wrap: nowrap;
  gap: 12px;
  align-items: center;
}
.density-toolbar--presence .density-toolbar__cluster {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  flex: 1 1 auto;
  min-width: 0;
  justify-content: flex-start;
}
.density-toolbar--presence .planning-save-status {
  margin-left: 0;
  flex-shrink: 0;
}
.density-label {
  font-size: 12px;
}
.planning-save-status {
  margin-left: 6px;
  font-size: 11px;
  line-height: 1;
  color: #64748b;
  padding: 2px 6px;
  border-radius: 999px;
  border: 1px solid #d7deeb;
  background: #f8fafc;
}
.planning-save-status.is-saving,
.planning-save-status.is-dirty {
  color: #355f8d;
  border-color: #bfd4e8;
  background: #edf5fc;
}
.planning-save-status.is-error {
  color: #b02222;
  border-color: #fecaca;
  background: #fff1f2;
}
button.density-btn {
  background: var(--surface2);
  color: var(--text);
  border: 1px solid var(--border);
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 12px;
  min-height: 36px;
  min-width: 4.5rem;
}
.density-toolbar--presence .density-btn {
  min-height: 44px;
  padding: 10px 16px;
  font-size: 14px;
  font-weight: 600;
}
button.density-btn.is-active {
  background: var(--navy);
  color: #fff;
  border-color: var(--navy);
}

:root[data-density="comfort"] .spreadsheet {
  --date-column-width: 17.6ch;
  --ss-head-row2-top: 2.72rem;
}
:root[data-density="comfort"] main .card table.spreadsheet td.sheet-cell { width: 36px; }
:root[data-density="comfort"] main .card table.spreadsheet input.cell-input {
  min-height: 24px;
  font-size: 11px;
  padding: 3px 2px;
}
/* Présence — mode Confort : cibles tactiles plus larges, séparation visuelle entre biologistes */
:root[data-density="comfort"] body.planning-look-presence main .card table.planning-presence-table td.sheet-cell {
  width: 46px;
}
:root[data-density="comfort"] body.planning-look-presence main .card table.planning-presence-table input.cell-input,
:root[data-density="comfort"] body.planning-look-presence main .card table.planning-presence-table td.ast-col select.cell-input {
  min-height: 38px;
  font-size: 14px;
  padding: 8px 4px;
}
:root[data-density="comfort"] body.planning-look-presence .praticien-head .initials {
  min-width: 28px;
  height: 26px;
  font-size: 12px;
}
:root[data-density="comfort"] body.planning-look-presence main .card table.planning-presence-table thead th.presence-praticien-start,
:root[data-density="comfort"] body.planning-look-presence main .card table.planning-presence-table tbody td.sheet-cell.presence-praticien-start {
  border-left: 3px solid #94a3b8;
  box-shadow: inset 3px 0 0 rgba(148, 163, 184, 0.35);
}
:root[data-density="comfort"] body.planning-look-presence main .card table.planning-presence-table thead tr:first-child > th.praticien-head.presence-praticien-start,
:root[data-density="comfort"] body.planning-look-presence main .card table.planning-presence-table thead tr:nth-child(2) > th.presence-praticien-start {
  border-left: 3px solid #64748b;
}

:root[data-density="compact"] .spreadsheet {
  --date-column-width: 16.8ch;
  --ss-head-row2-top: 2.45rem;
}
:root[data-density="compact"] main .card table.spreadsheet td.sheet-cell { width: 30px; }

:root[data-density="ultra"] .spreadsheet {
  --date-column-width: 16ch;
  --ss-head-row2-top: 2.12rem;
}
:root[data-density="ultra"] main .card table.spreadsheet thead th {
  font-size: 10px;
  padding: 3px 1px;
}
:root[data-density="ultra"] main .card table.spreadsheet .date-fr { font-size: 10px; }
:root[data-density="ultra"] main .card table.spreadsheet tbody th.date-cell { padding: 2px 4px; }
:root[data-density="ultra"] main .card table.spreadsheet td.sheet-cell { width: 24px; }
:root[data-density="ultra"] main .card table.spreadsheet input.cell-input {
  min-height: 18px;
  font-size: 9px;
  padding: 1px 0;
}
:root[data-density="ultra"] .praticien-head .initials {
  min-width: 20px;
  height: 18px;
  font-size: 9px;
}

/* Smartphones / petites largeurs : formulaires et tableaux métier (hors grille présence desktop) */
@media (max-width: 720px) {
  .wrap {
    padding: 12px 10px;
  }
  main .card {
    padding: 12px 10px;
  }
  h1 {
    font-size: 18px;
  }
  .grid.cols-2,
  .grid.cols-3,
  .grid.cols-4 {
    grid-template-columns: minmax(0, 1fr);
  }
  .decl-page-head {
    flex-direction: column;
    align-items: stretch;
  }
  .decl-page-head .muted {
    max-width: 100%;
  }
  .decl-actions {
    flex-direction: column;
    align-items: stretch;
  }
  .decl-actions form,
  .decl-actions button {
    width: 100%;
  }
  .decl-form-grid { grid-template-columns: minmax(0,1fr); }
  .decl-time-wrap { flex-direction: column; }
  .decl-dam-wrap { flex-wrap: wrap; }
  .admin-decl-toolbar {
    flex-direction: column;
    align-items: stretch;
  }
  .admin-decl-toolbar form {
    flex-direction: column;
    align-items: stretch;
  }
  .admin-decl-toolbar a.secondary {
    width: 100%;
    justify-content: center;
  }
  .admin-decl-row-actions {
    flex-direction: column !important;
    align-items: stretch !important;
  }
  .admin-decl-row-actions a.secondary,
  .admin-decl-row-actions form,
  .admin-decl-row-actions button {
    width: 100%;
  }
  .nav-secondary {
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    gap: 8px 14px;
    padding-bottom: 6px;
    margin-left: -2px;
    margin-right: -2px;
    scrollbar-width: thin;
  }
  .nav-secondary.nav-secondary--split {
    grid-template-columns: minmax(0, 1fr);
    gap: 10px;
  }
  .nav-secondary.nav-secondary--split .header-marquee-wrap {
    justify-self: stretch;
    width: 100%;
    min-width: min(100%, 11.5rem);
    max-width: none;
    order: 3;
  }
  .header-marquee-mask {
    overflow: visible;
  }
  .header-marquee-track {
    animation: none;
    transform: none;
    white-space: normal;
    flex-wrap: wrap;
    justify-content: flex-start;
  }
  .header-marquee-text {
    white-space: normal;
    word-break: break-word;
    padding-right: 0;
    width: 100%;
    font-size: clamp(13px, 2.6vw, 16px);
  }
  .header-marquee-text ~ .header-marquee-text {
    display: none;
  }
  .nav-secondary .nav-sub {
    flex: 0 0 auto;
    white-space: nowrap;
  }
  .nav-secondary .nav-openrouter-form {
    flex: 0 0 auto;
    min-width: min(100%, 18rem);
  }
  .me-ics-qr-panel {
    flex-direction: column;
  }
  .table-scroll form.decl-actions {
    flex-direction: column;
    align-items: stretch;
    max-width: 100%;
  }
  .table-scroll table.table-wide {
    min-width: 560px;
  }
  main .card button:not(.code-palette-btn):not(.code-palette-clear),
  main .card a.secondary {
    min-height: 44px;
  }
  header button.secondary {
    min-height: 36px;
  }
}

@media (max-width: 900px) {
  nav {
    grid-template-columns: 1fr;
  }
  .brand-title {
    display: none;
  }
  .brand-logo--wordmark {
    height: 48px;
    max-width: min(340px, 85vw);
  }
  .brand-logos {
    gap: 1px;
  }
  .brand-logo--compact {
    height: 48px;
    max-width: min(82px, 24vw);
  }
  .brand-logo--mascot {
    height: 44px;
    max-width: min(50px, 20vw);
  }
  .brand-logo-title {
    font-size: 16px;
  }
  .brand-logo--chms {
    height: 34px;
    max-width: min(190px, 42vw);
  }
  .brand--on-header {
    padding: 1px;
    max-width: 100%;
  }
  .nav-app-top {
    gap: 10px;
  }
  .nav-app-actions {
    width: 100%;
    justify-content: flex-start;
    flex-wrap: wrap;
    gap: 8px;
  }
  .global-auth-stack {
    width: 100%;
    align-items: center;
    flex-wrap: wrap;
    gap: 6px 8px;
  }
  #globalAuthBadge {
    max-width: min(100%, 620px);
    white-space: normal;
    line-height: 1.25;
  }
  .nav-primary {
    margin-top: 6px;
    gap: 6px;
  }
  .nav-tab {
    padding: 7px 12px;
  }
  .spreadsheet-scroll--presence {
    display: block;
    overflow: auto;
    -webkit-overflow-scrolling: touch;
  }
  .density-toolbar--presence {
    flex-wrap: wrap;
  }
  .density-toolbar--presence .planning-save-status {
    margin-left: auto;
  }
  .planning-mobile {
    display: none;
  }
  .fonctionnel-table .date-cell .date-fr--full,
  .planning-presence-table .date-cell .date-fr--full,
  .planning-mobile-date--full {
    display: none !important;
  }
  .fonctionnel-table .date-cell .date-fr--compact,
  .planning-presence-table .date-cell .date-fr--compact,
  .planning-mobile-date--compact {
    display: inline !important;
    font-size: 10px;
    letter-spacing: 0.01em;
  }
  .fonctionnel-table .date-cell,
  .planning-presence-table .date-cell {
    min-width: 3.7rem !important;
    width: 3.7rem !important;
    max-width: 3.7rem !important;
  }
  .planning-presence-table .praticien-head .bio-name-full {
    display: none;
  }
  .planning-presence-table .praticien-head .bio-name-code {
    display: inline;
  }
  /* Hauteur réelle de la 1re ligne d’en-tête plus basse qu’en desktop : sinon la 2e ligne (M/AM) reste trop bas → « trou » visuel. */
  .planning-presence-table.spreadsheet {
    --ss-head-row2-top: 1.62rem;
  }
}

/* Planning fonctionnel */
/* En-têtes plus hauts (titres tâches + compteurs) : décaler la 2e ligne sticky. */
/* Ligne compteurs + sticky plage : uniquement en mode édition (classe posée côté EJS). */
main .card table.spreadsheet.fonctionnel-table.fonctionnel-table--edit {
  --ss-head-row2-top: 3.05rem;
  --fonc-plage-col-w: 6.9rem;
  --fonc-aj-col-w: 5rem;
  --fonc-an-col-w: 5rem;
}
main .card table.spreadsheet.fonctionnel-table {
  --fonc-plage-col-w: 6.9rem;
  --fonc-aj-col-w: 5rem;
  --fonc-an-col-w: 5rem;
}
main .card table.spreadsheet.fonctionnel-table.fonctionnel-table--edit thead tr:first-child th.plage-head:nth-child(2),
main .card table.spreadsheet.fonctionnel-table.fonctionnel-table--edit thead tr.fonctionnel-count-row th:nth-child(2) {
  position: sticky;
  left: var(--date-column-width);
  z-index: 4;
  width: var(--fonc-plage-col-w);
  min-width: var(--fonc-plage-col-w);
  max-width: var(--fonc-plage-col-w);
  box-sizing: border-box;
  box-shadow: 1px 0 0 rgba(15, 23, 42, 0.08);
}
main .card table.spreadsheet.fonctionnel-table.fonctionnel-table--edit thead tr:first-child th.plage-head:nth-child(2) {
  background: var(--surface2);
}
main .card table.spreadsheet.fonctionnel-table.fonctionnel-table--edit thead tr.fonctionnel-count-row th.plage-head:nth-child(2) {
  background: #f4f8fc;
}
main .card table.spreadsheet.fonctionnel-table.fonctionnel-table--edit thead tr:first-child th.fonc-ast-aj-head,
main .card table.spreadsheet.fonctionnel-table.fonctionnel-table--edit thead tr.fonctionnel-count-row th.fonc-ast-aj-head {
  position: sticky;
  left: calc(var(--date-column-width) + var(--fonc-plage-col-w));
  z-index: 4;
  width: var(--fonc-aj-col-w);
  min-width: var(--fonc-aj-col-w);
  max-width: var(--fonc-aj-col-w);
  box-sizing: border-box;
  box-shadow: 1px 0 0 rgba(15, 23, 42, 0.08);
  text-align: left;
}
main .card table.spreadsheet.fonctionnel-table.fonctionnel-table--edit thead tr:first-child th.fonc-ast-aj-head {
  background: var(--surface2);
}
main .card table.spreadsheet.fonctionnel-table.fonctionnel-table--edit thead tr.fonctionnel-count-row th.fonc-ast-aj-head {
  background: #f4f8fc;
}
main .card table.spreadsheet.fonctionnel-table.fonctionnel-table--edit thead tr:first-child th.fonc-ast-an-head,
main .card table.spreadsheet.fonctionnel-table.fonctionnel-table--edit thead tr.fonctionnel-count-row th.fonc-ast-an-head {
  position: sticky;
  left: calc(var(--date-column-width) + var(--fonc-plage-col-w) + var(--fonc-aj-col-w));
  z-index: 4;
  width: var(--fonc-an-col-w);
  min-width: var(--fonc-an-col-w);
  max-width: var(--fonc-an-col-w);
  box-sizing: border-box;
  box-shadow: 1px 0 0 rgba(15, 23, 42, 0.08);
}
main .card table.spreadsheet.fonctionnel-table.fonctionnel-table--edit thead tr:first-child th.fonc-ast-an-head {
  background: var(--surface2);
}
main .card table.spreadsheet.fonctionnel-table.fonctionnel-table--edit thead tr.fonctionnel-count-row th.fonc-ast-an-head {
  background: #f4f8fc;
}
/* Ne pas figer la ligne "Compteurs": sinon elle masque la première ligne éditable. */
main .card table.spreadsheet.fonctionnel-table.fonctionnel-table--edit thead tr.fonctionnel-count-row > th {
  position: static !important;
  top: auto !important;
  z-index: 1;
}
main .card table.spreadsheet.fonctionnel-table:not(.astreinte-table-global) tbody th.plage-row-label {
  position: sticky;
  left: var(--date-column-width);
  z-index: 2;
  width: var(--fonc-plage-col-w);
  min-width: var(--fonc-plage-col-w);
  max-width: var(--fonc-plage-col-w);
  box-sizing: border-box;
  box-shadow: 1px 0 0 rgba(15, 23, 42, 0.06);
}
main .card table.spreadsheet.fonctionnel-table:not(.astreinte-table-global) tbody td.fonc-ast-aj-cell {
  position: sticky;
  left: calc(var(--date-column-width) + var(--fonc-plage-col-w));
  z-index: 2;
  width: var(--fonc-aj-col-w);
  min-width: var(--fonc-aj-col-w);
  max-width: var(--fonc-aj-col-w);
  box-sizing: border-box;
  box-shadow: 1px 0 0 rgba(15, 23, 42, 0.06);
  background: var(--surface2);
  text-align: left;
}
.fonctionnel-table td.fonc-ast-aj-cell select.fonc-select {
  margin-left: 0;
  margin-right: 0;
}
main .card table.spreadsheet.fonctionnel-table:not(.astreinte-table-global) tbody td.fonc-ast-an-cell {
  position: sticky;
  left: calc(var(--date-column-width) + var(--fonc-plage-col-w) + var(--fonc-aj-col-w));
  z-index: 2;
  width: var(--fonc-an-col-w);
  min-width: var(--fonc-an-col-w);
  max-width: var(--fonc-an-col-w);
  box-sizing: border-box;
  box-shadow: 1px 0 0 rgba(15, 23, 42, 0.06);
  background: var(--surface2);
}
main .card table.spreadsheet tbody tr.weekend td.fonc-ast-aj-cell,
main .card table.spreadsheet tbody tr.weekend td.fonc-ast-an-cell {
  background: #eef2f7;
}
main .card table.spreadsheet tbody tr.jour-ferie td.fonc-ast-aj-cell,
main .card table.spreadsheet tbody tr.jour-ferie td.fonc-ast-an-cell {
  background: #e4e4e7;
}
main .card table.spreadsheet tbody tr.weekend.jour-ferie td.fonc-ast-aj-cell,
main .card table.spreadsheet tbody tr.weekend.jour-ferie td.fonc-ast-an-cell {
  background: #e4e4e7;
}
.fonctionnel-table .tache-head {
  font-size: 10px;
  line-height: 1.2;
  text-align: center;
  vertical-align: bottom;
  min-width: 2.8em;
  padding: 3px 2px !important;
}
.fonctionnel-table .tache-head-code {
  display: block;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.03em;
  color: var(--navy);
}
.fonctionnel-table .tache-head .muted {
  display: block;
  font-weight: 400;
  text-transform: none;
  letter-spacing: normal;
  margin-top: 1px;
  font-size: 9px;
}
.fonctionnel-table .tache-head-hint {
  display: block;
  font-size: 10px;
  margin-top: 4px;
  font-weight: 500;
  text-transform: none;
  letter-spacing: normal;
}
/* 2e ligne d’en-tête : top calé via --ss-head-row2-top (règle globale thead tr:nth-child(2)). */
.fonctionnel-table thead tr.fonctionnel-count-row th {
  background: #f4f8fc;
  vertical-align: top;
  padding-top: 3px;
  padding-bottom: 4px;
}
main .card table.fonctionnel-table--edit thead tr:first-child > th {
  padding-bottom: 2px;
}
main .card table.fonctionnel-table--edit thead tr.fonctionnel-count-row > th {
  border-top: 1px solid var(--border);
}
.fonctionnel-count-badge {
  display: inline-block;
  min-width: 1.6rem;
  padding: 1px 6px;
  border-radius: 999px;
  border: 1px solid #d3deea;
  background: #fff;
  font-weight: 700;
  font-size: 11px;
  color: #27435e;
}
.fonctionnel-count-badge--per-bio {
  max-width: 7.5rem;
  white-space: pre-line;
  line-height: 1.2;
  font-size: 9px;
  font-weight: 700;
  text-align: center;
  hyphens: none;
  word-break: keep-all;
}
.fonctionnel-table .plage-row-label {
  text-transform: none;
  letter-spacing: normal;
  font-size: 11px;
  white-space: nowrap;
  font-weight: 600;
  color: #334155;
  padding: 2px 4px !important;
  vertical-align: middle !important;
}
.fonctionnel-table .date-cell .date-fr {
  font-size: 10px;
  font-weight: 700;
}
.fonctionnel-table .date-cell .date-fr--compact {
  display: none;
}
.planning-presence-table .date-cell .date-fr--compact {
  display: none;
}
.fonctionnel-table .sheet-cell {
  width: 70px !important;
  padding: 0 !important;
  vertical-align: middle !important;
  line-height: 1;
}
.fonctionnel-table .fonc-stack {
  min-width: 62px;
  gap: 1px;
  margin: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: stretch;
  min-height: 100%;
}
.fonctionnel-table select.fonc-select {
  max-width: 84px;
  font-size: 11px;
  padding: 0 2px;
  min-height: 18px;
  height: 18px;
  line-height: 1;
  border-radius: 6px;
  margin: 0 auto;
  display: block;
}
.fonctionnel-table .fonc-ast-sam-matin-inline {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  gap: 1px;
  padding: 1px 2px 1px 0;
  min-width: 0;
  white-space: nowrap;
}
.fonctionnel-table .fonc-ast-sam-sep {
  flex: 0 0 auto;
  font-weight: 800;
  font-size: 11px;
  color: #64748b;
  padding: 0 1px;
  line-height: 1;
}
.fonctionnel-table .fonc-ast-sam-matin-read {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: var(--navy);
  display: block;
  text-align: left;
}
.fonctionnel-table select.fonc-select--ast-bio-inline {
  flex: 1 1 0;
  min-width: 0;
  max-width: none;
  width: auto;
  margin: 0;
  display: block;
  font-size: 10px;
  padding: 0 1px;
}
.fonctionnel-table td.fonc-ast-aj-cell--sam-matin {
  vertical-align: middle !important;
}
.fonctionnel-table td.sheet-cell.fonctionnel-cell,
.fonctionnel-table td.sheet-cell.fonctionnel-cell select {
  margin: 0;
}
.fonctionnel-table td.fonctionnel-cell--post-validation-change {
  background: #fff8db !important;
}
.fonctionnel-table td.fonctionnel-cell--post-validation-change select.fonc-select {
  color: #b02222;
  border-color: #f2c38b;
  background: #fffdf4;
}
.planning-presence-table td.planning-presence-cell--post-validation-change {
  background: #fff8db !important;
}
.planning-presence-table td.planning-presence-cell--post-validation-change input.cell-input {
  color: #b02222;
  border-color: #f2c38b;
  background: #fffdf4;
}
.fonctionnel-table .fonc-cell {
  padding: 0;
  min-height: 100%;
  display: flex;
  align-items: center;
}
.fonctionnel-table .divers-head {
  min-width: 120px;
}
.fonctionnel-table .divers-cell {
  min-width: 130px;
  max-width: 180px;
}
.fonctionnel-table textarea.fonc-divers {
  font-size: 11px;
  padding: 3px;
}
.fonctionnel-table tr td,
.fonctionnel-table tr th {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  vertical-align: middle !important;
}
.fonctionnel-table tbody tr {
  height: 24px;
}

/* Astreinte: compact et lisible (moins de vide) */
.astreinte-table-global .date-cell .date-fr {
  font-size: 11px;
}
.astreinte-table-global .plage-row-label {
  font-size: 11px;
  padding: 0 4px !important;
  white-space: nowrap;
  width: 14ch;
  min-width: 14ch;
  max-width: 14ch;
  overflow: hidden;
  text-overflow: ellipsis;
}
table.astreinte-table-global:not(.me-astreinte-desiderata-table) td.sheet-cell.fonctionnel-cell {
  width: 84px !important;
  padding: 0 !important;
}
.astreinte-table-global select.fonc-select {
  max-width: 82px;
  min-height: 18px;
  height: 18px;
  font-size: 11px;
  padding: 0 2px;
  line-height: 1;
}
.astreinte-table-global tbody tr {
  height: 22px;
}
table.astreinte-table-global:not(.me-astreinte-desiderata-table) {
  --date-column-width: 21ch;
  width: max-content !important;
  min-width: 0 !important;
  table-layout: auto !important;
}
table.astreinte-table-global:not(.me-astreinte-desiderata-table) thead th,
table.astreinte-table-global:not(.me-astreinte-desiderata-table) tbody th,
table.astreinte-table-global:not(.me-astreinte-desiderata-table) tbody td {
  width: fit-content;
}
table.astreinte-table-global:not(.me-astreinte-desiderata-table) .corner {
  width: 21ch;
  min-width: 21ch;
}
table.astreinte-table-global:not(.me-astreinte-desiderata-table) .date-cell {
  width: 21ch;
  min-width: 21ch;
}
table.astreinte-table-global:not(.me-astreinte-desiderata-table) .date-cell .date-fr {
  white-space: nowrap;
}
table.astreinte-table-global:not(.me-astreinte-desiderata-table) .plage-head {
  width: 14ch;
  min-width: 14ch;
}
table.astreinte-table-global:not(.me-astreinte-desiderata-table) thead th.plage-head:nth-child(2) {
  position: sticky;
  left: var(--date-column-width);
  z-index: 4;
  background: var(--surface2);
  box-shadow: 1px 0 0 rgba(15, 23, 42, 0.08);
}
table.astreinte-table-global:not(.me-astreinte-desiderata-table) tbody th.plage-row-label {
  position: sticky;
  left: var(--date-column-width);
  z-index: 2;
  box-shadow: 1px 0 0 rgba(15, 23, 42, 0.06);
}
table.astreinte-table-global:not(.me-astreinte-desiderata-table) .tache-head {
  width: 9ch;
  min-width: 9ch;
}
table.astreinte-table-global:not(.me-astreinte-desiderata-table) td.sheet-cell.fonctionnel-cell {
  width: 9ch !important;
  min-width: 9ch;
}

/* Desiderata praticien : largeur colonne date = contenu (hors règles compactes astreinte-table-global) */
main .card table.spreadsheet.me-astreinte-desiderata-table {
  table-layout: auto !important;
  width: max-content !important;
}
main .card table.spreadsheet.me-astreinte-desiderata-table thead th.corner,
main .card table.spreadsheet.me-astreinte-desiderata-table tbody th.date-cell,
main .card table.spreadsheet.me-astreinte-desiderata-table tbody tr.weekend th.date-cell {
  width: max-content !important;
  min-width: max-content !important;
  max-width: none !important;
  white-space: nowrap !important;
  box-sizing: border-box !important;
}
main .card table.spreadsheet.me-astreinte-desiderata-table thead th.plage-head,
main .card table.spreadsheet.me-astreinte-desiderata-table thead th.tache-head {
  width: max-content !important;
  min-width: 10rem !important;
  max-width: none !important;
  white-space: normal !important;
}
main .card table.spreadsheet.me-astreinte-desiderata-table td.sheet-cell.fonctionnel-cell {
  width: auto !important;
  min-width: 3.25rem !important;
  max-width: none !important;
  text-align: center !important;
  vertical-align: middle !important;
}
main .card table.spreadsheet.me-astreinte-desiderata-table .date-fr {
  display: block !important;
  width: max-content !important;
  max-width: none !important;
  white-space: nowrap !important;
}

:root[data-density="comfort"] main .card table.spreadsheet.me-astreinte-desiderata-table td.sheet-cell.fonctionnel-cell,
:root[data-density="compact"] main .card table.spreadsheet.me-astreinte-desiderata-table td.sheet-cell.fonctionnel-cell,
:root[data-density="ultra"] main .card table.spreadsheet.me-astreinte-desiderata-table td.sheet-cell.fonctionnel-cell {
  width: auto !important;
  min-width: 3rem !important;
}

/* Astreintes globales : effacements locaux + enregistrement unique */
.astreinte-edit-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px 16px;
  margin-top: 14px;
  margin-bottom: 10px;
}
.astreinte-clear-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 10px;
  flex: 1;
  min-width: min(100%, 20rem);
}
.astreinte-clear-btn {
  font-size: 12px;
  padding: 6px 10px;
  white-space: nowrap;
}
.astreinte-save-btn {
  flex-shrink: 0;
  align-self: center;
  font-weight: 600;
}

/* Astreintes globales : toute la période visible (pas de zone scroll interne) */
.astreinte-global-sheet {
  margin-top: 4px;
  overflow: visible;
  max-height: none;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--surface);
}
/* Fonds doux par créneau (colonnes créneau + astreinte ; date reste neutre).
   Spécificité au-dessus des styles weekend / jour férié du tableau générique. */
main .card .astreinte-global-sheet table.spreadsheet tbody tr.astreinte-tone-jour th.plage-row-label,
main .card .astreinte-global-sheet table.spreadsheet tbody tr.astreinte-tone-jour td.sheet-cell {
  background: var(--tone-warm-soft);
}
main .card .astreinte-global-sheet table.spreadsheet tbody tr.astreinte-tone-nuit th.plage-row-label,
main .card .astreinte-global-sheet table.spreadsheet tbody tr.astreinte-tone-nuit td.sheet-cell {
  background: var(--tone-cool-soft);
}
main .card .astreinte-global-sheet table.spreadsheet tbody tr.astreinte-tone-sam-micro th.plage-row-label,
main .card .astreinte-global-sheet table.spreadsheet tbody tr.astreinte-tone-sam-micro td.sheet-cell {
  background: var(--tone-rose-soft);
}
main .card .astreinte-global-sheet table.spreadsheet tbody tr.astreinte-tone-sam-biochim th.plage-row-label,
main .card .astreinte-global-sheet table.spreadsheet tbody tr.astreinte-tone-sam-biochim td.sheet-cell {
  background: var(--tone-green-soft);
}
main .card .astreinte-global-sheet table.spreadsheet tbody tr.astreinte-tone-sam-aprem th.plage-row-label,
main .card .astreinte-global-sheet table.spreadsheet tbody tr.astreinte-tone-sam-aprem td.sheet-cell {
  background: var(--tone-amber-soft);
}
main .card .astreinte-global-sheet table.spreadsheet tbody tr.astreinte-tone-other th.plage-row-label,
main .card .astreinte-global-sheet table.spreadsheet tbody tr.astreinte-tone-other td.sheet-cell {
  background: var(--tone-neutral-soft);
}

/* Admin — matrice désidérata : même couple spreadsheet-scroll + table.spreadsheet que le planning fonctionnel (sticky thead fiable) */
.admin-desiderata-matrix-outer {
  margin-top: 8px;
  margin-bottom: 14px;
  padding: 10px 12px;
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 8px;
  max-width: 100%;
}
.admin-desiderata-matrix-help {
  margin: 0 0 8px 0;
  font-size: 0.88rem;
}
.admin-desiderata-matrix-outer .spreadsheet-scroll.admin-desiderata-matrix-scroll {
  margin-top: 0;
}
.admin-desiderata-matrix-scroll {
  resize: vertical;
  min-height: 120px;
}
.admin-desiderata-matrix-scroll:focus-visible {
  outline: 2px solid rgba(37, 99, 235, 0.45);
  outline-offset: 2px;
}

main .card table.spreadsheet.admin-desiderata-matrix {
  table-layout: auto;
  font-size: 11px;
}

main .card table.spreadsheet.admin-desiderata-matrix thead th.admin-desiderata-matrix-bio {
  white-space: nowrap;
}

main .card table.spreadsheet.admin-desiderata-matrix thead th.admin-desiderata-matrix-date {
  left: 0;
  z-index: 5;
  text-align: left;
  box-shadow: 1px 0 0 rgba(15, 23, 42, 0.08), inset 0 -1px 0 var(--border, #e2e8f0);
}

main .card table.spreadsheet.admin-desiderata-matrix tbody th.admin-desiderata-matrix-date {
  position: sticky;
  left: 0;
  z-index: 2;
  padding: 2px 5px;
  font-size: 10px;
  font-weight: 600;
  vertical-align: middle;
  white-space: nowrap;
  width: auto;
  min-width: unset;
  max-width: none;
  text-align: left;
  box-shadow: 1px 0 0 rgba(15, 23, 42, 0.06);
}

main .card table.spreadsheet.admin-desiderata-matrix tr.admin-desiderata-matrix-totals th.admin-desiderata-matrix-date {
  position: sticky;
  left: 0;
  z-index: 3;
  background: var(--surface2, #f8fafc);
  box-shadow: 1px 0 0 rgba(15, 23, 42, 0.06);
}

main .card table.spreadsheet.admin-desiderata-matrix td.admin-desiderata-matrix-cell {
  border: 1px solid var(--border);
  padding: 2px 5px;
  background: var(--surface);
  vertical-align: middle;
  min-width: 1.5rem;
  width: auto;
}

.admin-desiderata-matrix-bio {
  max-width: 4.2rem;
  overflow: hidden;
  text-overflow: ellipsis;
}
.admin-desiderata-matrix-date {
  text-align: left;
  font-weight: 600;
  font-size: 10px;
  white-space: nowrap;
  padding-right: 6px !important;
}
.admin-desiderata-matrix-dim {
  display: block;
}
.admin-desiderata-matrix-sam {
  display: block;
  font-weight: 400;
  color: var(--muted, #64748b);
  font-size: 9px;
}
.admin-desiderata-matrix-cell {
  text-align: center;
  font-family: ui-monospace, monospace;
  font-weight: 600;
  min-width: 1.5rem;
}
main .card table.spreadsheet.admin-desiderata-matrix tr.admin-desiderata-matrix-totals th,
main .card table.spreadsheet.admin-desiderata-matrix tr.admin-desiderata-matrix-totals td {
  border-top: 2px solid var(--border, #e2e8f0);
  font-weight: 800;
  background: var(--surface2, #f8fafc);
}

.admin-hab-cell-triple {
  vertical-align: middle;
  text-align: center;
}
.admin-hab-triple {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}
.admin-hab-mini {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  font-weight: 600;
  color: #475569;
}
.admin-hab-mini--date {
  gap: 3px;
  font-size: 10px;
}
.admin-hab-mini--date input[type="date"] {
  width: 8.25rem;
  max-width: 100%;
  font-size: 10px;
  padding: 2px 4px;
  min-height: 24px;
  border-radius: 6px;
}
.admin-hab-mini--date input[type="date"]:disabled {
  opacity: 0.55;
}
.admin-hab-mini-lbl {
  width: 1em;
  text-align: right;
}

.fonc-bulk-wrap {
  display: block;
}
.fonc-bulk-bar {
  margin: 12px 0;
  display: flex;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 8px;
}
.fonc-bulk-bar-top {
  margin-top: 0;
}
.fonc-stack {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 140px;
}
.fonc-sup-wrap--hidden {
  display: none !important;
}
.fonc-sup-wrap .fonc-sup-hint {
  display: none;
  font-size: 10px;
  font-weight: 600;
  color: #b91c1c;
  margin: 0 0 2px;
  line-height: 1.2;
}
.fonc-sup-wrap.is-sup-required:not(.is-titulaire-habilite) .fonc-sup-hint {
  display: block;
}
.fonc-sup-wrap.is-sup-active:not(.is-titulaire-habilite) select.fonc-select-sup {
  color: #b91c1c;
  border-color: #b91c1c;
  font-weight: 600;
  background: #fef2f2;
}
.fonc-sup-wrap.is-sup-missing select.fonc-select-sup {
  border-color: #b91c1c;
  box-shadow: 0 0 0 2px rgba(185, 28, 28, 0.2);
}
.fonc-readonly .fonc-sup-name-red {
  color: #b91c1c;
  font-weight: 700;
}
.fonc-select {
  width: 100%;
  max-width: 220px;
  font-size: 12px;
  padding: 4px 6px;
  border-radius: 8px;
  border: 1px solid #cbd5e1;
  background: #fff;
}
.fonc-readonly {
  font-weight: 600;
  font-size: 13px;
}
.divers-head {
  min-width: 160px;
}
.divers-cell {
  min-width: 180px;
  max-width: 320px;
  background: #fafbfc;
  vertical-align: top;
}
.fonc-divers-form textarea.fonc-divers,
textarea.fonc-divers {
  width: 100%;
  margin-top: 4px;
  font-size: 12px;
  padding: 8px;
  border-radius: 8px;
  border: 1px solid #cbd5e1;
  resize: vertical;
  box-sizing: border-box;
}
.small-btn {
  margin-top: 6px;
  padding: 4px 10px;
  font-size: 12px;
}
.small-label {
  font-size: 11px;
  display: block;
}
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}
.fonc-divers-read {
  font-size: 13px;
  white-space: pre-wrap;
  color: #334155;
}

/* Retours bêta Planning : lien discret dans le header + fenêtre dédiée */
.planning-beta-header-btn {
  margin-left: 0;
  padding: 4px var(--header-chip-px);
  font-size: 12px;
  white-space: nowrap;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: rgba(255, 255, 255, 0.78);
  background: transparent;
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: var(--header-chip-radius);
  cursor: pointer;
  line-height: 1;
  vertical-align: middle;
  transition: color 0.15s, border-color 0.15s, background 0.15s, transform 0.12s ease;
  min-height: var(--header-chip-height);
}
.planning-beta-header-btn:hover {
  color: #fff;
  border-color: rgba(255, 255, 255, 0.45);
  background: rgba(255, 255, 255, 0.1);
}
.planning-beta-header-btn:active {
  background: rgba(255, 255, 255, 0.14);
}
.planning-beta-header-btn:focus-visible {
  outline: 2px solid rgba(255, 255, 255, 0.85);
  outline-offset: 2px;
}

/* Fenêtre retour bêta : carte centrée (esprit modal LIA) */
.planning-beta-win-body {
  margin: 0;
  min-height: 100vh;
  color: var(--text);
  background: radial-gradient(120% 80% at 50% 0%, #e8f2f9 0%, var(--bg) 52%);
}
.planning-beta-win-shell {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px 16px 28px;
  box-sizing: border-box;
}
.planning-beta-card {
  width: 100%;
  max-width: 440px;
  margin: 0 auto;
  padding: 22px 22px 18px;
  box-sizing: border-box;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  box-shadow: 0 8px 32px rgba(61, 86, 105, 0.14);
}
.planning-beta-card__title {
  margin: 0 0 4px;
  font-size: 15px;
  font-weight: 600;
  color: #1e3a5c;
  letter-spacing: -0.01em;
}
.planning-beta-card__micro {
  margin: 0 0 8px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #7b8aa3;
}
.planning-beta-card__intro {
  margin: 0 0 14px;
  font-size: 13px;
  line-height: 1.45;
  color: var(--text-dim);
}
.planning-beta-card__version {
  margin: 14px 0 0;
  padding-top: 10px;
  border-top: 1px solid #e6edf8;
  font-size: 10px;
  color: #94a3b8;
  text-align: center;
}
.planning-beta-field {
  margin-bottom: 12px;
}
.planning-beta-field label {
  display: block;
  font-size: 12px;
  font-weight: 600;
  margin-bottom: 4px;
  color: #4d607a;
}
.planning-beta-field input {
  width: 100%;
  box-sizing: border-box;
  padding: 8px 10px;
  border: 1px solid var(--border);
  border-radius: 8px;
  font-size: 13px;
  font-family: inherit;
  background: var(--surface);
  color: var(--text);
}
.planning-beta-field input:focus {
  outline: none;
  border-color: var(--header-bg);
  box-shadow: 0 0 0 2px rgba(95, 135, 176, 0.2);
}
.planning-beta-textarea {
  width: 100%;
  box-sizing: border-box;
  min-height: 140px;
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: 8px;
  font-size: 13px;
  font-family: inherit;
  line-height: 1.45;
  resize: vertical;
  background: var(--surface);
  color: var(--text);
}
.planning-beta-textarea:focus {
  outline: none;
  border-color: var(--header-bg);
  box-shadow: 0 0 0 2px rgba(95, 135, 176, 0.2);
}
.planning-beta-msg {
  min-height: 18px;
  font-size: 11.5px;
  margin-top: 6px;
  line-height: 1.4;
}
.planning-beta-msg--err {
  color: var(--danger);
}
.planning-beta-msg--ok {
  color: #166534;
}
.planning-beta-actions {
  margin-top: 18px;
  display: flex;
  justify-content: flex-end;
  gap: 9px;
  flex-wrap: wrap;
}
.planning-beta-btn {
  padding: 7px 14px;
  border-radius: 7px;
  font-size: 12.5px;
  font-family: inherit;
  cursor: pointer;
  line-height: 1.25;
}
.planning-beta-btn--ghost {
  border: 1px solid #c8d4e0;
  background: transparent;
  color: #4d607a;
}
.planning-beta-btn--ghost:hover {
  background: var(--surface2);
  border-color: #b6c5d8;
}
.planning-beta-btn--primary {
  border: none;
  background: var(--header-bg);
  color: #fff;
  font-weight: 500;
  padding-left: 16px;
  padding-right: 16px;
  box-shadow: 0 1px 4px rgba(61, 86, 105, 0.22);
}
.planning-beta-btn--primary:hover {
  filter: brightness(1.06);
}
.planning-beta-btn--primary:active {
  transform: scale(0.98);
}
.planning-beta-btn:focus-visible {
  outline: 2px solid var(--header-bg);
  outline-offset: 2px;
}

.planning-nouveautes-modal {
  position: fixed;
  inset: 0;
  z-index: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(15, 23, 42, 0.45);
  padding: 14px;
}
.planning-nouveautes-card {
  width: min(760px, 100%);
  max-height: 88vh;
  overflow: auto;
  position: relative;
  border-radius: 14px;
  border: 1px solid #d7deeb;
  background: #fff;
  box-shadow: 0 18px 44px rgba(15, 23, 42, 0.25);
  padding: 18px 18px 14px;
}
.planning-nouveautes-card h2 {
  margin: 0 26px 8px 0;
  font-size: 22px;
  color: #24415f;
}
.planning-nouveautes-body {
  font-size: 14px;
  color: #334155;
}
.planning-nouveautes-body ul {
  margin: 8px 0 0 18px;
  padding: 0;
}
.planning-nouveautes-body li {
  margin: 6px 0;
}
.planning-nouveautes-close {
  position: absolute;
  top: 8px;
  right: 10px;
  border: none;
  background: transparent;
  color: #334155;
  font-size: 26px;
  line-height: 1;
  cursor: pointer;
  padding: 4px 6px;
}
.planning-nouveautes-close:hover {
  color: #0f172a;
}

/* —— Impression planning mensuel (A4) —— */
.print-month-wrap {
  margin-top: 4px;
}
.print-month-title {
  margin: 0 0 4px;
  font-size: 1.25rem;
}
.print-range-hint {
  margin: 0 0 10px;
  font-size: 12px;
}
.print-month-table {
  font-size: 12px;
}
.print-month-table th,
.print-month-table td {
  vertical-align: top;
  word-break: break-word;
}
.print-date-cell {
  white-space: nowrap;
  font-weight: 600;
}

@media print {
  @page {
    size: A4 portrait;
    margin: 10mm;
  }
  body {
    background: #fff !important;
    color: #000 !important;
    font-size: 9pt;
  }
  header,
  .no-print,
  #globalAuthModal,
  .planning-beta-header-btn,
  .app-version-pill {
    display: none !important;
  }
  main.wrap {
    max-width: none !important;
    padding: 0 !important;
  }
  main.wrap > .card {
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    background: #fff !important;
  }
  main .card table.spreadsheet thead th,
  main .card table.spreadsheet tbody th.date-cell,
  main .card table.spreadsheet tbody th.plage-row-label {
    position: static !important;
    left: auto !important;
    top: auto !important;
    box-shadow: none !important;
    z-index: auto !important;
  }
  .print-month-wrap {
    break-inside: avoid;
    page-break-after: auto;
  }
  .print-month-title {
    font-size: 14pt;
    color: #000;
  }
  .print-range-hint {
    color: #222 !important;
    font-size: 9pt;
  }
  .table-scroll {
    overflow: visible !important;
  }
  .print-month-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 7.5pt;
  }
  .print-month-table th,
  .print-month-table td {
    border: 1px solid #222;
    padding: 2px 3px;
    color: #000;
    background: #fff !important;
  }
  .print-month-table thead th {
    background: #eee !important;
    font-weight: 700;
  }
  a[href]::after {
    content: "";
  }
}

/* Navigation mois (présence / astreinte / fonctionnel) */
.row > .links.planning-toolbar-month {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
}
.row > .links.planning-toolbar-month .pill {
  border: 1px solid #d1deec;
  background: #f4f8fd;
  color: #23435f;
  font-weight: 600;
  box-shadow: 0 1px 4px rgba(19, 41, 64, 0.08);
  transition: background-color 0.15s ease, border-color 0.15s ease, transform 0.12s ease, box-shadow 0.15s ease;
}
.row > .links.planning-toolbar-month .pill:hover {
  background: #ffffff;
  border-color: #bccfe4;
  transform: translateY(-1px);
  box-shadow: 0 2px 8px rgba(19, 41, 64, 0.12);
}
.row > .links.planning-toolbar-month .pill:active {
  transform: translateY(0);
  box-shadow: 0 1px 3px rgba(19, 41, 64, 0.1);
}
select.planning-month-jump-select {
  font: inherit;
  padding: 0.38rem 0.68rem;
  border-radius: 8px;
  border: 1px solid #d1deec;
  background: #f9fbfe;
  color: #23435f;
  font-weight: 600;
  min-width: 10.5rem;
  max-width: 15rem;
  cursor: pointer;
  box-shadow: 0 1px 4px rgba(19, 41, 64, 0.08);
  transition: background-color 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
}
select.planning-month-jump-select:hover {
  background: #fff;
  border-color: #bccfe4;
}
select.planning-month-jump-select:focus {
  outline: none;
  border-color: #8fb1d2;
  box-shadow: 0 0 0 2px rgba(117, 161, 209, 0.28), 0 1px 4px rgba(19, 41, 64, 0.1);
}

.planning-astreinte-panel {
  margin-top: 2rem;
  padding-top: 1rem;
  border-top: 1px solid var(--border, #c8d4e0);
}
.planning-astreinte-heading {
  font-size: 1.2rem;
  font-weight: 700;
  margin: 0 0 0.35rem;
  color: var(--navy, #3d5669);
}
.astreinte-cell-coherence--warn {
  background: var(--tone-warn-soft) !important;
  box-shadow: inset 0 0 0 1px var(--tone-outline-warn);
}
.astreinte-cell-coherence--ok {
  background: var(--tone-ok-soft) !important;
  box-shadow: inset 0 0 0 1px var(--tone-outline-ok);
}
.astreinte-cell--post-publication-change,
.astreinte-cell--post-publication-change .cell-input,
.astreinte-cell--post-publication-change .fonc-select,
.astreinte-cell--post-publication-change .fonc-readonly {
  color: #0b1f4d !important;
  font-weight: 800 !important;
}
.astreinte-cell--post-publication-change {
  box-shadow: inset 0 0 0 2px #0b1f4d !important;
}
.astreinte-cell--post-publication-change .cell-input,
.astreinte-cell--post-publication-change .fonc-select {
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 3px;
}
.astreinte-coherence-legend {
  display: inline-block;
  padding: 0 6px;
  border-radius: 4px;
  font-weight: 600;
}
/* Colonnes figées : WebKit (Safari) + table-layout:fixed — <col> est plus fiable que width sur td */
main .card table.spreadsheet col.spreadsheet-col-date {
  width: var(--date-column-width);
}
main .card table.spreadsheet col.spreadsheet-col-ast {
  width: 3.45rem;
}
:root[data-density="comfort"] main .card table.spreadsheet col.spreadsheet-col-ast {
  width: 3.7rem;
}
:root[data-density="compact"] main .card table.spreadsheet col.spreadsheet-col-ast {
  width: 3.45rem;
}
:root[data-density="ultra"] main .card table.spreadsheet col.spreadsheet-col-ast {
  width: 3.2rem;
}

/* Présence : colonnes Astreinte jour / nuit (initiales) — plus larges que M/AM */
main .card table.spreadsheet th.ast-col,
main .card table.spreadsheet td.ast-col {
  min-width: 3.45rem;
  width: 3.45rem;
  box-sizing: border-box;
  padding: 1px 3px;
}
main .card table.spreadsheet th.ast-col {
  font-size: 0.72rem;
  line-height: 1.15;
  white-space: normal;
}
main .card table.spreadsheet td.ast-col select.cell-input {
  width: 100%;
  min-width: 0;
  padding: 2px 12px 2px 4px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0;
  text-align: center;
  border: 1px solid transparent;
  border-radius: 4px;
  background-color: transparent;
  min-height: 24px;
  font-family: ui-sans-serif, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
  text-transform: uppercase;
  cursor: pointer;
  box-sizing: border-box;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background-image:
    linear-gradient(45deg, transparent 50%, #64748b 50%),
    linear-gradient(135deg, #64748b 50%, transparent 50%);
  background-position:
    calc(100% - 8px) calc(50% - 1px),
    calc(100% - 4px) calc(50% - 1px);
  background-size: 4px 4px, 4px 4px;
  background-repeat: no-repeat;
}
main .card table.spreadsheet td.ast-col select.cell-input:focus {
  outline: 2px solid #3b82f6;
  outline-offset: -2px;
  background-color: #eff6ff;
}
:root[data-density="comfort"] main .card table.spreadsheet td.sheet-cell.ast-col {
  width: 3.7rem;
  min-width: 3.7rem;
}
:root[data-density="comfort"] main .card table.spreadsheet td.ast-col select.cell-input {
  font-size: 10px;
  padding: 3px 12px 3px 4px;
  min-height: 21px;
}
:root[data-density="compact"] main .card table.spreadsheet td.sheet-cell.ast-col {
  width: 3.45rem;
  min-width: 3.45rem;
}
:root[data-density="ultra"] main .card table.spreadsheet td.sheet-cell.ast-col {
  width: 3.2rem;
  min-width: 3.2rem;
}
:root[data-density="ultra"] main .card table.spreadsheet td.ast-col select.cell-input {
  font-size: 10px;
  padding: 2px 11px 2px 3px;
  min-height: 18px;
}

/* Look clair global rapproche du Manuel de prelevement */
body.planning-look-presence {
  --mp-bg: #f4f6fa;
  --mp-bg-deep: #eef2f8;
  --mp-surface: #ffffff;
  --mp-border: #d8e0ec;
  --mp-border-2: #c0ccde;
  --mp-text: #1a2233;
  --mp-text-2: #4a5568;
  --mp-text-3: #8a97aa;
  --mp-blue: #1e3a6e;
  --mp-blue-dk: #12254a;
  --mp-blue-lt: #e8eff9;
  --mp-blue-accent: #2b7bc8;
  --mp-red: #c41e5a;
  --mp-green: #0f7a4b;
  --mp-green-lt: #e3f5ec;
  --mp-amber: #b06a00;
  --mp-amber-lt: #fff4de;
  --mp-shadow-1: 0 1px 0 rgba(15, 27, 45, 0.02);
  --mp-shadow-2: 0 1px 3px rgba(15, 27, 45, 0.06), 0 2px 8px rgba(15, 27, 45, 0.04);
  --bg: var(--mp-bg);
  --surface: var(--mp-surface);
  --surface2: var(--mp-bg-deep);
  --border: var(--mp-border);
  --navy: var(--mp-blue);
  --blue: var(--mp-blue-accent);
  --blue-light: var(--mp-blue-lt);
  --text: var(--mp-text);
  --text-dim: var(--mp-text-3);
  --danger: var(--mp-red);
  --header-bg: var(--mp-surface);
  --header-btn-bg: var(--mp-bg);
  --header-btn-bg-hover: var(--mp-blue-lt);
  --header-btn-bg-active: var(--mp-blue);
  --header-btn-border: var(--mp-border);
  --header-btn-border-strong: rgba(30, 58, 110, 0.28);
  --header-btn-text: var(--mp-blue);
  background:
    radial-gradient(900px 260px at 50% -160px, rgba(30, 58, 110, 0.1), transparent 70%),
    var(--mp-bg);
  color: var(--mp-text);
  font-family: "Segoe UI", system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
}
body.planning-look-presence header {
  position: sticky;
  top: 0;
  z-index: 120;
  background: var(--mp-surface);
  border-bottom: 1px solid var(--mp-border);
  box-shadow: 0 1px 4px rgba(15, 27, 45, 0.07);
}
body.planning-look-presence header .wrap {
  padding-top: 11px;
  padding-bottom: 11px;
}
body.planning-look-presence .brand-logo--compact {
  height: 48px;
  max-width: min(82px, 16vw);
}
body.planning-look-presence .brand-logo--mascot {
  height: 48px;
  max-width: min(52px, 13vw);
}
body.planning-look-presence .brand-logo-title--booktime .brand-book {
  color: var(--mp-blue);
}
body.planning-look-presence .brand-logo-title--booktime .brand-time-red {
  color: var(--mp-red);
}
body.planning-look-presence .brand-logo-title--booktime .brand-tagline {
  color: var(--mp-blue);
  font-weight: 600;
}
body.planning-look-presence .brand-logo--chms {
  height: 36px;
  max-width: min(210px, 34vw);
}
body.planning-look-presence .brand-logo-title {
  font-size: 18px;
}
body.planning-look-presence .brand-logo-title .lia-word {
  color: var(--mp-red);
}
body.planning-look-presence .brand-logo-title .module-word {
  color: var(--mp-blue);
}
body.planning-look-presence .nav-primary {
  gap: 5px;
}
body.planning-look-presence .nav-tab {
  min-height: 32px;
  padding: 6px 12px;
  border-radius: 8px;
  background: var(--mp-bg);
  border-color: transparent;
  color: var(--mp-text-2);
  font-size: 12.5px;
  font-weight: 600;
  box-shadow: none;
}
body.planning-look-presence .nav-tab:hover {
  background: var(--mp-blue-lt);
  border-color: rgba(30, 58, 110, 0.14);
  color: var(--mp-blue);
}
body.planning-look-presence .nav-tab.is-active {
  background: var(--mp-blue);
  border-color: var(--mp-blue);
  color: #fff;
  box-shadow: 0 1px 3px rgba(30, 58, 110, 0.18);
}
body.planning-look-presence .nav-secondary {
  margin-top: 9px;
  padding-top: 9px;
  border-top-color: var(--mp-border);
}
body.planning-look-presence .nav-sub {
  color: var(--mp-text-2);
  font-size: 12.5px;
  font-weight: 600;
  border-bottom-color: transparent;
}
body.planning-look-presence .nav-sub:hover,
body.planning-look-presence .nav-sub.is-active {
  color: var(--mp-blue);
  border-bottom-color: var(--mp-blue);
}
body.planning-look-presence header .pill,
body.planning-look-presence .app-version-pill {
  background: var(--mp-bg);
  border-color: var(--mp-border);
  color: var(--mp-text-2);
}
body.planning-look-presence header .pill,
body.planning-look-presence .app-version-pill,
body.planning-look-presence .planning-beta-header-btn,
body.planning-look-presence header button.secondary {
  min-height: 0;
  padding: 3px 8px;
  border-radius: 7px;
  border: 1px solid rgba(192, 204, 222, 0.85);
  background: rgba(255, 255, 255, 0.72);
  color: var(--mp-text-2);
  font-size: 10.5px;
  font-weight: 600;
  line-height: 1.15;
  box-shadow: none;
}
body.planning-look-presence .nav-app-actions {
  align-items: center;
  gap: 5px;
}
body.planning-look-presence .app-version-pill__sep {
  color: var(--mp-text-3);
}
body.planning-look-presence .app-version-pill__version {
  white-space: nowrap;
}
body.planning-look-presence .header-nouveautes-link {
  color: var(--mp-red);
  font-size: 10.5px;
  font-weight: 600;
  animation: none;
  opacity: 0.42;
}
body.planning-look-presence .header-nouveautes-link:hover {
  opacity: 0.85;
  color: #9f1239;
}
body.planning-look-presence .planning-beta-header-btn,
body.planning-look-presence header button.secondary {
  white-space: nowrap;
}
body.planning-look-presence .planning-beta-header-btn:hover,
body.planning-look-presence header button.secondary:hover,
body.planning-look-presence header .pill:hover {
  background: rgba(232, 239, 249, 0.72);
  border-color: rgba(30, 58, 110, 0.24);
  color: var(--mp-blue);
}
body.planning-look-presence .global-auth-stack #globalAuthBadge {
  color: var(--mp-text-2);
}
/* Bandeau connexion (Manuel / LIA) : chip lisible sur fond clair */
body.planning-look-presence header .auth-chip {
  background: rgba(255, 255, 255, 0.78);
  border: 1px solid rgba(192, 204, 222, 0.88);
  color: var(--mp-text-2);
  box-shadow: 0 1px 2px rgba(15, 27, 45, 0.06);
}
body.planning-look-presence header .auth-chip:hover {
  background: #fff;
  border-color: rgba(30, 58, 110, 0.22);
  color: var(--mp-blue);
}
body.planning-look-presence header .auth-chip__name {
  color: var(--mp-text-2);
  font-weight: 700;
}
body.planning-look-presence header .auth-chip__role {
  color: var(--mp-text-3);
}
body.planning-look-presence header .auth-chip__caret {
  color: var(--mp-text-3);
}
body.planning-look-presence header .auth-chip__avatar {
  background: var(--mp-blue);
  color: #fff;
  border: 1px solid rgba(30, 58, 110, 0.2);
}
body.planning-look-presence header .auth-chip__avatar--guest::before {
  background: #fff;
}
body.planning-look-presence header .auth-chip__menu {
  border-color: var(--mp-border);
  box-shadow: 0 10px 28px rgba(15, 27, 45, 0.12);
}
body.planning-look-presence header .auth-chip__menu button {
  width: 100%;
  border: 1px solid var(--mp-border);
  background: #fff;
  border-radius: 8px;
  padding: 8px 10px;
  margin: 0 0 6px;
  font-size: 12px;
  font-weight: 600;
  text-align: center;
}
body.planning-look-presence header .auth-chip__menu button:last-child {
  margin-bottom: 0;
}
body.planning-look-presence header .auth-chip__menu #globalAuthLoginBtn {
  color: var(--mp-blue);
}
body.planning-look-presence header .auth-chip__menu #globalAuthLogoutBtn {
  color: #b91c1c;
}
body.planning-look-presence header .auth-chip__menu button:hover {
  background: var(--mp-blue-lt);
  border-color: rgba(30, 58, 110, 0.22);
}
body.planning-look-presence .header-marquee-text {
  color: var(--mp-blue);
  text-shadow: none;
}
body.planning-look-presence main.wrap {
  padding-top: 14px;
}
body.planning-look-presence main .card {
  background: var(--mp-surface);
  border-color: var(--mp-border);
  border-radius: 12px;
  box-shadow: var(--mp-shadow-2);
  padding: 16px;
}
body.planning-look-presence main .card table:not(.spreadsheet):not(.admin-desiderata-matrix) {
  border: 1px solid var(--mp-border);
  border-radius: 10px;
  overflow: hidden;
  background: #fff;
}
body.planning-look-presence main .card table:not(.spreadsheet):not(.admin-desiderata-matrix) th {
  background: var(--mp-bg-deep);
  color: var(--mp-text-3);
  border-bottom-color: var(--mp-border);
}
body.planning-look-presence main .card table:not(.spreadsheet):not(.admin-desiderata-matrix) td {
  border-bottom-color: var(--mp-border);
}
body.planning-look-presence main .card table:not(.spreadsheet):not(.admin-desiderata-matrix) tbody tr:hover td {
  background: #f8fbff;
}
body.planning-look-presence main .card table:not(.spreadsheet):not(.admin-desiderata-matrix) tbody tr:nth-child(even) td,
body.planning-look-presence main .card table:not(.spreadsheet):not(.admin-desiderata-matrix) tbody tr:nth-child(even) th {
  background-color: rgba(248, 250, 252, 0.95);
}
body.planning-look-presence main .card table:not(.spreadsheet):not(.admin-desiderata-matrix) tbody tr:nth-child(even):hover td,
body.planning-look-presence main .card table:not(.spreadsheet):not(.admin-desiderata-matrix) tbody tr:nth-child(even):hover th {
  background: #eef6ff;
}
body.planning-look-presence .table-scroll,
body.planning-look-presence .admin-table-wrap {
  border-radius: 10px;
}
body.planning-look-presence .login-mode-card,
body.planning-look-presence .me-ics-qr-panel,
body.planning-look-presence .read-only-banner,
body.planning-look-presence .ok-banner {
  border-color: var(--mp-border);
  border-radius: 10px;
  background: #fafbfe;
}
body.planning-look-presence main .card input:not(.cell-input),
body.planning-look-presence main .card select:not(.cell-input),
body.planning-look-presence main .card textarea {
  border: 1px solid var(--mp-border-2);
  border-radius: 8px;
  background: #fff;
  color: var(--mp-text);
  box-sizing: border-box;
  font-family: inherit;
}
body.planning-look-presence main .card input:not(.cell-input):focus,
body.planning-look-presence main .card select:not(.cell-input):focus,
body.planning-look-presence main .card textarea:focus {
  outline: none;
  border-color: var(--mp-blue-accent);
  box-shadow: 0 0 0 2px rgba(43, 123, 200, 0.16);
}
body.planning-look-presence main .card textarea {
  width: 100%;
  min-width: min(100%, 22rem);
  max-width: 100%;
  min-height: 7rem;
  padding: 10px 12px;
  line-height: 1.45;
  resize: vertical;
}
body.planning-look-presence main .card textarea.admin-form-control {
  max-width: min(100%, 48rem);
}
body.planning-look-presence main .card textarea.code,
body.planning-look-presence main .card textarea[id*="json"],
body.planning-look-presence main .card textarea[name*="json"] {
  min-height: 16rem;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
}
body.planning-look-presence main .card .admin-form-control-wide {
  max-width: min(100%, 24rem);
}
body.planning-look-presence main .card textarea.fonc-divers {
  min-height: 6.5rem;
}
body.planning-look-presence main .card .stack label,
body.planning-look-presence main .card form.stack label {
  color: var(--mp-blue);
}
body.planning-look-presence .planning-page-title-h1 {
  margin-bottom: 4px;
  color: var(--mp-text);
  letter-spacing: -0.01em;
}
body.planning-look-presence .planning-page-title-kicker {
  color: var(--mp-blue);
  font-weight: 700;
}
body.planning-look-presence .planning-page-title-month {
  color: var(--mp-text-3);
}
body.planning-look-presence .page-intro-summary--help-toggle {
  color: var(--mp-text-3);
}
body.planning-look-presence .page-intro-summary--help-toggle:hover {
  color: var(--mp-blue);
}
body.planning-look-presence .page-intro-details--below-title[open] {
  background: #fafbfe;
  border-color: var(--mp-border);
  border-radius: 10px;
}
body.planning-look-presence .pill,
body.planning-look-presence .planning-toolbar-month .pill,
body.planning-look-presence button.density-btn,
body.planning-look-presence button.code-palette-btn,
body.planning-look-presence main .card button.secondary,
body.planning-look-presence main .card a.secondary {
  background: #fff;
  border: 1px solid var(--mp-border);
  border-radius: 7px;
  color: var(--mp-text-2);
  box-shadow: var(--mp-shadow-1);
}
body.planning-look-presence .pill:hover,
body.planning-look-presence .planning-toolbar-month .pill:hover,
body.planning-look-presence button.density-btn:hover,
body.planning-look-presence button.code-palette-btn:hover,
body.planning-look-presence main .card button.secondary:hover,
body.planning-look-presence main .card a.secondary:hover {
  background: var(--mp-blue-lt);
  border-color: rgba(30, 58, 110, 0.2);
  color: var(--mp-blue);
}
body.planning-look-presence main .card button:not(.secondary):not(.density-btn):not(.code-palette-btn):not(.danger) {
  background: var(--mp-blue);
  color: #fff;
  border: 1px solid var(--mp-blue);
  border-radius: 8px;
  box-shadow: 0 1px 3px rgba(30, 58, 110, 0.18);
}
body.planning-look-presence main .card button:not(.secondary):not(.density-btn):not(.code-palette-btn):not(.danger):hover {
  background: var(--mp-blue-dk);
  border-color: var(--mp-blue-dk);
}
body.planning-look-presence button.density-btn.is-active,
body.planning-look-presence button.code-palette-btn.is-selected {
  background: var(--mp-blue);
  border-color: var(--mp-blue);
  color: #fff;
}
body.planning-look-presence .code-palette,
body.planning-look-presence .density-toolbar--presence {
  gap: 7px;
}
body.planning-look-presence .code-palette-title,
body.planning-look-presence .density-label {
  color: var(--mp-text-3);
  font-weight: 600;
}
body.planning-look-presence .planning-save-status {
  border-color: var(--mp-border);
  background: #fff;
  color: var(--mp-text-3);
}
body.planning-look-presence .planning-save-status.is-saving,
body.planning-look-presence .planning-save-status.is-dirty {
  background: var(--mp-blue-lt);
  border-color: rgba(30, 58, 110, 0.18);
  color: var(--mp-blue);
}
body.planning-look-presence .planning-save-status.is-error {
  background: #fff1f4;
  border-color: #f4b8c8;
  color: var(--mp-red);
}
body.planning-look-presence .read-only-banner {
  background: var(--mp-blue-lt);
  border-color: rgba(30, 58, 110, 0.18);
  border-radius: 10px;
  color: var(--mp-blue-dk);
}
body.planning-look-presence .spreadsheet-scroll--presence {
  margin-top: 12px;
  border-color: var(--mp-border);
  border-radius: 10px;
  box-shadow: var(--mp-shadow-2);
  background: #fff;
}
body.planning-look-presence main .card table.planning-presence-table thead th {
  background: var(--mp-bg-deep);
  border-color: var(--mp-border);
  color: var(--mp-text-3);
  font-weight: 700;
  letter-spacing: 0.03em;
}
body.planning-look-presence main .card table.planning-presence-table thead th.corner,
body.planning-look-presence main .card table.planning-presence-table tbody th.date-cell {
  background: #f8fafc;
  color: var(--mp-blue);
  border-color: var(--mp-border);
  box-shadow: 1px 0 0 rgba(15, 27, 45, 0.06);
}
body.planning-look-presence main .card table.planning-presence-table thead tr:first-child > th {
  box-shadow: 0 1px 0 rgba(15, 27, 45, 0.06);
}
body.planning-look-presence .praticien-head {
  color: var(--mp-blue);
}
body.planning-look-presence .praticien-head .initials {
  background: var(--mp-blue-lt);
  border-color: rgba(30, 58, 110, 0.18);
  color: var(--mp-blue);
}
body.planning-look-presence main .card table.planning-presence-table td.sheet-cell {
  background: #fff;
  border-color: #e3e9f2;
}
body.planning-look-presence main .card table.planning-presence-table tbody tr:nth-child(even) td.sheet-cell:not(.astreinte-cell-coherence--warn):not(.astreinte-cell-coherence--ok):not(.presence-cell-night--needs-manual-fao2),
body.planning-look-presence main .card table.planning-presence-table tbody tr:nth-child(even) th.date-cell {
  background: rgba(246, 249, 253, 0.88);
}
body.planning-look-presence main .card table.planning-presence-table tbody tr:hover td.sheet-cell:not(.planning-presence-cell--post-validation-change):not(.astreinte-cell-coherence--warn):not(.astreinte-cell-coherence--ok):not(.presence-cell-night--needs-manual-fao2),
body.planning-look-presence main .card table.planning-presence-table tbody tr:hover th.date-cell {
  background: #f8fbff;
}
body.planning-look-presence main .card table.planning-presence-table tbody tr.weekend th.date-cell,
body.planning-look-presence main .card table.planning-presence-table tbody tr.weekend td.sheet-cell {
  background: #f1f5f9;
}
body.planning-look-presence main .card table.planning-presence-table tbody tr.jour-ferie th.date-cell,
body.planning-look-presence main .card table.planning-presence-table tbody tr.jour-ferie td.sheet-cell,
body.planning-look-presence main .card table.planning-presence-table tbody tr.jour-ferie th.plage-row-label {
  background: #e8edf4;
}
body.planning-look-presence main .card table.planning-presence-table tbody tr.weekend.jour-ferie th.date-cell,
body.planning-look-presence main .card table.planning-presence-table tbody tr.weekend.jour-ferie td.sheet-cell,
body.planning-look-presence main .card table.planning-presence-table tbody tr.weekend.jour-ferie th.plage-row-label {
  background: #dbe3ee;
}
body.planning-look-presence main .card table.planning-presence-table input.cell-input,
body.planning-look-presence main .card table.planning-presence-table td.ast-col select.cell-input {
  color: var(--mp-text);
}
body.planning-look-presence main .card table.planning-presence-table td.ast-col select.cell-input {
  background-image:
    linear-gradient(45deg, transparent 50%, var(--mp-text-3) 50%),
    linear-gradient(135deg, var(--mp-text-3) 50%, transparent 50%);
}
body.planning-look-presence main .card table.planning-presence-table input.cell-input:focus,
body.planning-look-presence main .card table.planning-presence-table td.ast-col select.cell-input:focus {
  outline: 2px solid var(--mp-blue-accent);
  outline-offset: -2px;
  background: var(--mp-blue-lt);
}
body.planning-look-presence main .card table.planning-presence-table input.cell-input.is-saving {
  /* Bleu discret : éviter de confondre avec le surlignage jaune « changement post-validation » */
  background: #e0f2fe;
}
body.planning-look-presence main .card table.planning-presence-table input.cell-input.is-error {
  background: #fff1f4;
  color: var(--mp-red);
}
body.planning-look-presence main .card table.planning-presence-table td.sheet-cell--planning-out,
body.planning-look-presence main .card table.planning-presence-table td.sheet-cell--planning-out input.cell-input {
  background: #f1f4f8;
  color: var(--mp-text-3);
}
body.planning-look-presence main .card table.planning-presence-table td.sheet-cell.astreinte-cell-coherence--ok {
  background: var(--mp-green-lt);
}
body.planning-look-presence main .card table.planning-presence-table td.sheet-cell.astreinte-cell-coherence--warn {
  background: var(--mp-amber-lt);
}
body.planning-look-presence main .card table.planning-presence-table td.sheet-cell.presence-cell-night--needs-manual-fao2 {
  background: var(--mp-amber-lt);
  box-shadow: inset 0 0 0 1px rgba(217, 119, 6, 0.22);
}
body.planning-look-presence .fonc-bulk-bar {
  gap: 6px;
  margin: 10px 0;
}
body.planning-look-presence .fonctionnel-table .tache-head {
  background: var(--mp-bg-deep);
  color: var(--mp-text-3);
  font-size: 10px;
  font-weight: 700;
}
body.planning-look-presence .fonctionnel-table .tache-head-code {
  color: var(--mp-blue);
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.01em;
}
body.planning-look-presence .fonctionnel-table thead tr.fonctionnel-count-row th {
  background: #f3f7fc;
  border-top-color: var(--mp-border);
  color: var(--mp-text-3);
}
body.planning-look-presence .fonctionnel-count-badge {
  color: var(--mp-text-2);
  font-size: 10px;
  line-height: 1.25;
}
body.planning-look-presence .fonctionnel-table .plage-row-label {
  background: #f8fafc;
  color: var(--mp-blue);
  font-size: 10.5px;
  font-weight: 700;
}
body.planning-look-presence .fonctionnel-table .sheet-cell {
  border-color: #e3e9f2;
  background: #fff;
}
body.planning-look-presence .fonctionnel-table tbody tr:nth-child(even) td.sheet-cell:not(.fonctionnel-cell--post-validation-change),
body.planning-look-presence .fonctionnel-table tbody tr:nth-child(even) th.plage-row-label,
body.planning-look-presence .fonctionnel-table tbody tr:nth-child(even) th.date-cell {
  background: rgba(246, 249, 253, 0.88);
}
body.planning-look-presence main .card table.astreinte-table-global:not(.me-astreinte-desiderata-table) tbody tr:nth-child(even) td.sheet-cell,
body.planning-look-presence main .card table.astreinte-table-global:not(.me-astreinte-desiderata-table) tbody tr:nth-child(even) th {
  background: rgba(246, 249, 253, 0.88);
}
body.planning-look-presence .fonctionnel-table .divers-cell {
  background: #fafcff;
  border-left: 1px solid var(--mp-border);
}
body.planning-look-presence .fonctionnel-table select.fonc-select {
  border: 1px solid transparent;
  border-radius: 4px;
  background: transparent;
  color: var(--mp-text);
  font-size: 10px;
  font-family: "Segoe UI", system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
  min-height: 20px;
}
body.planning-look-presence .fonctionnel-table select.fonc-select:focus {
  border-color: var(--mp-blue-accent);
  box-shadow: 0 0 0 2px rgba(43, 123, 200, 0.14);
  background: var(--mp-blue-lt);
}
body.planning-look-presence .fonctionnel-table textarea.fonc-divers,
body.planning-look-presence .fonc-divers-form textarea.fonc-divers,
body.planning-look-presence textarea.fonc-divers {
  border-color: var(--mp-border);
  background: #fff;
  color: var(--mp-text);
  font-size: 11px;
  line-height: 1.35;
}
body.planning-look-presence .fonctionnel-table .fonc-divers-read {
  color: var(--mp-text-2);
  font-size: 11px;
}
body.planning-look-presence .fonctionnel-table td.fonctionnel-cell--post-validation-change {
  background: #fff8db !important;
}
body.planning-look-presence .fonctionnel-table td.fonctionnel-cell--post-validation-change select.fonc-select {
  color: #b02222;
  border-color: #f2c38b;
  background: #fffdf4;
}
body.planning-look-presence main .card table.planning-presence-table td.planning-presence-cell--post-validation-change {
  background: #fff8db !important;
}
body.planning-look-presence main .card table.planning-presence-table td.planning-presence-cell--post-validation-change input.cell-input {
  color: #b02222;
  border-color: #f2c38b;
  background: #fffdf4;
}
body.planning-look-presence .fonctionnel-table tbody tr:hover td.sheet-cell:not(.fonctionnel-cell--post-validation-change),
body.planning-look-presence .fonctionnel-table tbody tr:hover th.plage-row-label {
  background: #f8fbff;
}

@media (max-width: 1100px) {
  body.planning-look-presence .nav-app-top {
    align-items: flex-start;
  }
  body.planning-look-presence .nav-app .nav-left {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }
  body.planning-look-presence .nav-primary {
    width: 100%;
  }
  body.planning-look-presence .nav-app-actions {
    align-items: flex-start;
    justify-content: flex-start;
    max-width: min(100%, 32rem);
    flex-wrap: wrap;
  }
  body.planning-look-presence .nav-secondary.nav-secondary--split {
    grid-template-columns: minmax(0, 1fr);
    gap: 6px;
  }
  body.planning-look-presence .nav-secondary.nav-secondary--split .header-marquee-wrap {
    justify-self: stretch;
    width: 100%;
    order: 3;
  }
  body.planning-look-presence .header-marquee-mask {
    overflow: visible;
  }
  body.planning-look-presence .header-marquee-track {
    animation: none;
    transform: none;
    white-space: normal;
    flex-wrap: wrap;
  }
  body.planning-look-presence .header-marquee-text {
    width: 100%;
    padding-right: 0;
    white-space: normal;
    word-break: break-word;
    font-size: clamp(12px, 1.2vw + 10px, 16px);
  }
  body.planning-look-presence .header-marquee-text ~ .header-marquee-text {
    display: none;
  }
}

@media (min-width: 901px) and (max-width: 1100px) {
  body.planning-look-presence .nav-app-top {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(22rem, auto);
    align-items: start;
    gap: 8px 12px;
  }
  body.planning-look-presence .nav-app .nav-left {
    min-width: 0;
  }
  body.planning-look-presence .nav-app-actions {
    justify-self: end;
    max-width: 34rem;
    gap: 6px;
  }
}

@media (max-width: 900px) {
  body.planning-look-presence header .wrap {
    padding-top: 10px;
    padding-bottom: 10px;
  }
  body.planning-look-presence .nav-app-top {
    display: block;
  }
  body.planning-look-presence .nav-app .nav-left {
    width: 100%;
  }
  body.planning-look-presence .nav-app-actions {
    width: 100%;
    max-width: 100%;
    justify-content: flex-start;
    flex-wrap: wrap;
    overflow-x: visible;
    gap: 6px;
    padding-top: 6px;
    scrollbar-width: none;
  }
  body.planning-look-presence .nav-app-actions::-webkit-scrollbar {
    display: none;
  }
  body.planning-look-presence .global-auth-stack {
    width: auto;
    flex: 0 0 auto;
    flex-wrap: nowrap;
    gap: 6px;
    position: relative;
    z-index: 20;
  }
  body.planning-look-presence #globalAuthBadge {
    max-width: none;
    white-space: nowrap;
  }
  body.planning-look-presence .brand-logo--compact {
    height: 42px;
  }
  body.planning-look-presence .brand-logo--mascot {
    height: 42px;
    max-width: min(46px, 12vw);
  }
  body.planning-look-presence .nav-tab {
    padding: 7px 11px;
  }
  body.planning-look-presence .nav-secondary {
    border-top-color: var(--mp-border);
  }
}

@media (max-width: 720px) {
  body.planning-look-presence .wrap {
    padding: 8px 7px;
  }
  body.planning-look-presence header .wrap {
    padding-top: 6px;
    padding-bottom: 5px;
  }
  body.planning-look-presence .nav-app-top {
    gap: 4px;
  }
  body.planning-look-presence .nav-app .nav-left {
    gap: 4px;
  }
  body.planning-look-presence .brand--on-header {
    padding: 0;
    border-radius: 10px;
  }
  body.planning-look-presence .brand-logos {
    gap: 0;
  }
  body.planning-look-presence .brand-logo--compact {
    height: 28px;
    max-width: min(52px, 18vw);
  }
  body.planning-look-presence .brand-logo--mascot {
    height: 30px;
    max-width: min(40px, 15vw);
  }
  body.planning-look-presence .brand-logo-title {
    font-size: 11px;
    line-height: 1.05;
    padding-right: 2px;
  }
  body.planning-look-presence .brand-logo--chms {
    height: 20px;
    max-width: min(110px, 28vw);
  }
  body.planning-look-presence .nav-primary {
    width: 100%;
    display: flex;
    flex-wrap: nowrap;
    gap: 3px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 2px;
    scrollbar-width: none;
  }
  body.planning-look-presence .nav-primary::-webkit-scrollbar {
    display: none;
  }
  body.planning-look-presence .nav-tab {
    flex: 0 0 auto;
    min-height: 25px;
    padding: 4px 7px;
    border-radius: 6px;
    font-size: 10.5px;
  }
  body.planning-look-presence .nav-secondary {
    margin-top: 4px;
    padding-top: 4px;
    padding-bottom: 2px;
    gap: 4px 7px;
  }
  body.planning-look-presence .nav-secondary-links {
    flex-wrap: nowrap;
    overflow-x: auto;
    gap: 4px 8px;
    padding-bottom: 2px;
    scrollbar-width: none;
  }
  body.planning-look-presence .nav-secondary-links::-webkit-scrollbar {
    display: none;
  }
  body.planning-look-presence .nav-sub {
    flex: 0 0 auto;
    padding: 1px 1px 2px;
    font-size: 10.5px;
  }
  body.planning-look-presence .nav-app-actions {
    gap: 4px;
    padding-top: 5px;
    flex-wrap: wrap;
    overflow-x: visible;
  }
  body.planning-look-presence header .pill,
  body.planning-look-presence .app-version-pill,
  body.planning-look-presence .planning-beta-header-btn,
  body.planning-look-presence header button.secondary {
    min-height: 0;
    padding: 2px 6px;
    border-radius: 6px;
    font-size: 9.5px;
  }
  body.planning-look-presence .global-auth-stack {
    gap: 4px;
  }
  body.planning-look-presence #globalAuthBadge {
    max-width: min(100%, 18rem);
    line-height: 1.1;
  }
  body.planning-look-presence .header-marquee-text {
    font-size: 12px;
  }
  body.planning-look-presence main.wrap {
    padding-top: 8px;
  }
  body.planning-look-presence main .card {
    padding: 10px 8px;
    border-radius: 10px;
  }
  body.planning-look-presence .planning-page-title-h1 {
    font-size: 0.96rem;
    line-height: 1.25;
  }
  body.planning-look-presence .planning-toolbar-month {
    gap: 5px;
  }
  body.planning-look-presence .pill,
  body.planning-look-presence .planning-toolbar-month .pill,
  body.planning-look-presence button.density-btn,
  body.planning-look-presence button.code-palette-btn,
  body.planning-look-presence main .card button.secondary,
  body.planning-look-presence main .card a.secondary {
    min-height: 30px;
    padding: 5px 8px;
    border-radius: 7px;
    font-size: 11.5px;
  }
  body.planning-look-presence main .card table:not(.spreadsheet):not(.admin-desiderata-matrix) th,
  body.planning-look-presence main .card table:not(.spreadsheet):not(.admin-desiderata-matrix) td {
    padding: 6px 7px;
    font-size: 11.5px;
  }
  body.planning-look-presence .spreadsheet-scroll {
    margin-top: 8px;
    border-radius: 8px;
  }
  body.planning-look-presence main .card table.spreadsheet {
    font-size: 10px;
  }
  body.planning-look-presence main .card table.spreadsheet thead th {
    padding: 2px 1px;
    font-size: 9.5px;
    line-height: 1.12;
  }
  body.planning-look-presence main .card table.planning-presence-table.spreadsheet {
    --ss-head-row2-top: 1.42rem;
  }
  body.planning-look-presence main .card table.spreadsheet.fonctionnel-table.fonctionnel-table--edit thead tr:first-child th.plage-head:nth-child(2),
  body.planning-look-presence main .card table.spreadsheet.fonctionnel-table.fonctionnel-table--edit thead tr:first-child th.fonc-ast-aj-head,
  body.planning-look-presence main .card table.spreadsheet.fonctionnel-table.fonctionnel-table--edit thead tr:first-child th.fonc-ast-an-head,
  body.planning-look-presence main .card table.spreadsheet.fonctionnel-table.fonctionnel-table--edit thead tr.fonctionnel-count-row th.fonc-ast-aj-head,
  body.planning-look-presence main .card table.spreadsheet.fonctionnel-table.fonctionnel-table--edit thead tr.fonctionnel-count-row th.fonc-ast-an-head {
    position: static !important;
    left: auto !important;
    box-shadow: none;
    z-index: auto;
  }
  body.planning-look-presence main .card table.spreadsheet.fonctionnel-table:not(.astreinte-table-global) tbody th.plage-row-label,
  body.planning-look-presence main .card table.spreadsheet.fonctionnel-table:not(.astreinte-table-global) tbody td.fonc-ast-aj-cell,
  body.planning-look-presence main .card table.spreadsheet.fonctionnel-table:not(.astreinte-table-global) tbody td.fonc-ast-an-cell {
    position: static !important;
    left: auto !important;
    box-shadow: none;
    z-index: auto;
  }
  body.planning-look-presence main .card table.spreadsheet .date-fr {
    font-size: 9px;
  }
  body.planning-look-presence .fonctionnel-table .date-cell,
  body.planning-look-presence .planning-presence-table .date-cell,
  body.planning-look-presence main .card table.spreadsheet tbody th.date-cell {
    min-width: 3.15rem !important;
    width: 3.15rem !important;
    max-width: 3.15rem !important;
    padding: 2px 3px;
  }
  body.planning-look-presence main .card table.spreadsheet td.sheet-cell {
    width: 24px;
    min-width: 24px;
  }
  body.planning-look-presence main .card table.spreadsheet input.cell-input,
  body.planning-look-presence main .card table.spreadsheet select.cell-input {
    min-height: 18px;
    font-size: 9px;
    padding: 1px 0;
  }
  body.planning-look-presence main .card table.spreadsheet th.ast-col,
  body.planning-look-presence main .card table.spreadsheet td.ast-col {
    width: 2.75rem;
    min-width: 2.75rem;
    padding: 1px 2px;
  }
  body.planning-look-presence main .card table.spreadsheet td.ast-col select.cell-input {
    min-height: 18px;
    font-size: 9px;
    padding: 1px 10px 1px 2px;
  }
  body.planning-look-presence .fonctionnel-table .sheet-cell {
    width: 46px !important;
    min-width: 46px !important;
  }
  body.planning-look-presence table.astreinte-table-global:not(.me-astreinte-desiderata-table) td.sheet-cell.fonctionnel-cell {
    width: 7ch !important;
    min-width: 7ch !important;
  }
  body.planning-look-presence .praticien-head .initials {
    min-width: 19px;
    height: 17px;
    font-size: 8.5px;
  }
}

@media (max-width: 520px) {
  body.planning-look-presence .brand-logo--compact {
    height: 24px;
    max-width: min(44px, 18vw);
  }
  body.planning-look-presence .brand-logo--mascot {
    height: 26px;
    max-width: min(36px, 16vw);
  }
  body.planning-look-presence .brand-logo-title {
    font-size: 10px;
    line-height: 1.05;
    padding-right: 0;
  }
  body.planning-look-presence .brand-logo--chms {
    display: none;
  }
  body.planning-look-presence .nav-tab {
    min-height: 24px;
    padding: 4px 6px;
    font-size: 10px;
  }
  body.planning-look-presence header .pill,
  body.planning-look-presence .app-version-pill,
  body.planning-look-presence .planning-beta-header-btn,
  body.planning-look-presence header button.secondary {
    min-height: 0;
    padding: 2px 5px;
    font-size: 9px;
  }
  body.planning-look-presence .nav-secondary {
    margin-top: 3px;
    padding-top: 3px;
  }
}

/* Vue combinée */
.combined-panel {
  background: #fff;
  border: 1px solid #d7deeb;
  border-radius: 12px;
  margin-bottom: 1.5rem;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0,0,0,.05);
}
.combined-panel-summary {
  padding: 1rem 1.25rem;
  background: #f8fafc;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-weight: 700;
  border-bottom: 1px solid transparent;
  list-style: none;
}
.combined-panel-summary::-webkit-details-marker { display: none; }
.combined-panel[open] .combined-panel-summary {
  border-bottom-color: #e2e8f0;
}
.combined-panel-title {
  color: #355f8d;
  font-size: 1.1rem;
}
.combined-panel-body {
  padding: 1.25rem;
}
.combined-panel-hint {
  font-size: 0.85rem;
  font-weight: 400;
}

/* ═══════════════════════════════════════════════════════════════════════════
   PLANNER COMBINÉ — remplace les panneaux desktop sur /combined
   ═══════════════════════════════════════════════════════════════════════════ */

/* Panneaux desktop masqués — le planner combiné prend toute la place */
.combined-panel { display: none !important; }

.mplanner {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-top: 8px;
}

@media (max-width: 720px) {
  .planning-page-title-h1 { font-size: 16px; margin-bottom: 4px; }
  .planning-page-title-kicker { font-size: 11px; }
  .planning-page-title-month { font-size: 15px; }
}

/* ── Tab bar ─────────────────────────────────────────────────────────────── */
.mplanner-tabbar {
  display: flex;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 4px;
  margin-bottom: 10px;
  box-shadow: 0 1px 4px rgba(0,0,0,.07);
}
.mplanner-tab {
  flex: 1;
  padding: 9px 4px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-dim);
  background: none;
  border: none;
  border-radius: 10px;
  cursor: pointer;
  text-align: center;
  transition: background 0.15s, color 0.15s, box-shadow 0.15s;
  min-height: 38px;
  line-height: 1.1;
}
.mplanner-tab.is-active {
  background: var(--navy);
  color: #fff;
  box-shadow: 0 2px 8px rgba(61,86,105,.28);
}

/* ── Nav bars (Jour / Semaine / Mois) ────────────────────────────────────── */
.mplanner-navbars {
  margin-bottom: 2px;
}
/* Une seule barre visible à la fois */
.mplanner-navbars > .mplanner-monthnav { display: none; }
.mplanner-navbars > .mplanner-monthnav.is-active { display: flex; }

.mplanner-monthnav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
  gap: 8px;
}
.mplanner-monthnav-label {
  font-size: 15px;
  font-weight: 700;
  color: var(--navy);
  text-transform: capitalize;
  flex: 1;
  text-align: center;
}
.mplanner-monthnav-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 999px;
  background: var(--surface);
  border: 1px solid var(--border);
  color: var(--navy);
  text-decoration: none;
  font-size: 18px;
  font-weight: 700;
  box-shadow: 0 1px 3px rgba(0,0,0,.08);
  flex-shrink: 0;
  transition: background 0.12s;
}
.mplanner-monthnav-btn:hover { background: var(--surface2); }
.mplanner-monthnav-btn:disabled {
  opacity: 0.35;
  cursor: default;
  pointer-events: none;
}

/* ── Day cards ───────────────────────────────────────────────────────────── */
.mplanner-days {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

/* Month view: 2 colonnes compactes */
.mplanner-days[data-view="month"] {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 7px;
}

.mplanner-day {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0,0,0,.05);
}
.mplanner-day--weekend { background: #edf3f9; border-color: #c0d3e8; }
.mplanner-day--holiday { background: #f2ecfa; border-color: #c8b8e0; }
.mplanner-day--today {
  border-color: var(--navy);
  border-width: 2px;
  box-shadow: 0 3px 14px rgba(61,86,105,.22);
}

/* ── Day header ──────────────────────────────────────────────────────────── */
.mplanner-day-header {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 13px;
  background: var(--navy);
  color: #fff;
}
.mplanner-day--weekend .mplanner-day-header { background: #6b849e; }
.mplanner-day--holiday .mplanner-day-header { background: #7e60b5; }
.mplanner-day--today:not(.mplanner-day--weekend):not(.mplanner-day--holiday) .mplanner-day-header { background: #2b4459; }
.mplanner-day-label {
  font-size: 13px;
  font-weight: 700;
  flex: 1;
  text-transform: capitalize;
  line-height: 1.2;
}
.mplanner-day-badge {
  font-size: 10px;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 999px;
  letter-spacing: 0.04em;
  flex-shrink: 0;
}
.mplanner-day-badge--weekend { background: rgba(255,255,255,.22); color: #fff; }
.mplanner-day-badge--holiday { background: #e8d4ff; color: #5e2a96; }
.mplanner-day-badge--today { background: rgba(255,255,255,.9); color: var(--navy); }

/* ── Sections ────────────────────────────────────────────────────────────── */
.mplanner-section {
  padding: 10px 13px;
  border-top: 1px solid var(--border);
}
.mplanner-section-title {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-dim);
  margin-bottom: 8px;
}

/* ── Astreinte chips ─────────────────────────────────────────────────────── */
.mplanner-ast-row {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.mplanner-ast-chip {
  flex: 1;
  min-width: 64px;
  border-radius: 8px;
  padding: 7px 9px;
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.mplanner-ast-chip--jour { background: #e4edf8; border: 1px solid #b8cfea; }
.mplanner-ast-chip--nuit { background: #e3e5f4; border: 1px solid #b4badc; }
.mplanner-ast-chip-label {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-dim);
}
.mplanner-ast-chip-val {
  font-size: 15px;
  font-weight: 700;
  color: var(--navy);
  line-height: 1;
}
.mplanner-ast-chip-val.is-empty { color: #bbc7d4; font-weight: 400; font-size: 13px; }

/* ── Fonctionnel ─────────────────────────────────────────────────────────── */
.mplanner-fonc-plage { margin-bottom: 8px; }
.mplanner-fonc-plage:last-child { margin-bottom: 0; }
.mplanner-fonc-plage-label {
  font-size: 11px;
  font-weight: 700;
  color: #3a7a3a;
  margin-bottom: 5px;
  padding-bottom: 4px;
  border-bottom: 1px solid #cce8cc;
}
.mplanner-fonc-row {
  display: grid;
  grid-template-columns: 1fr auto 56px;
  gap: 3px 8px;
  align-items: center;
  padding: 5px 0;
  border-bottom: 1px solid #f0f4f8;
  font-size: 13px;
}
.mplanner-fonc-row:last-child { border-bottom: none; }
.mplanner-fonc-row.is-unassigned { opacity: 0.55; }
.mplanner-fonc-tache {
  font-weight: 600;
  color: var(--text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.mplanner-fonc-site { font-size: 11px; white-space: nowrap; }
.mplanner-fonc-person { font-weight: 700; color: var(--navy); text-align: right; white-space: nowrap; }
.mplanner-fonc-sup { color: #c0001a; font-weight: 700; }

/* ── Month view overrides (cartes compactes) ────────────────────────────── */
.mplanner-days[data-view="month"] .mplanner-day { border-radius: 9px; }
.mplanner-days[data-view="month"] .mplanner-day-header { padding: 8px 10px; }
.mplanner-days[data-view="month"] .mplanner-day-label { font-size: 12px; }
.mplanner-days[data-view="month"] .mplanner-section { padding: 7px 10px; }
.mplanner-days[data-view="month"] .mplanner-section-title { font-size: 9px; margin-bottom: 5px; }
.mplanner-days[data-view="month"] .mplanner-ast-chip {
  flex-direction: row;
  align-items: center;
  gap: 5px;
  padding: 4px 7px;
  min-width: 0;
}
.mplanner-days[data-view="month"] .mplanner-ast-chip-val { font-size: 12px; }
.mplanner-days[data-view="month"] .mplanner-ast-chip-label { display: none; }
.mplanner-days[data-view="month"] .mplanner-fonc-row { font-size: 11px; padding: 3px 0; }
.mplanner-days[data-view="month"] .mplanner-fonc-tache { font-size: 11px; }
.mplanner-days[data-view="month"] .mplanner-fonc-plage-label { font-size: 10px; margin-bottom: 3px; }

/* ── Week view overrides ─────────────────────────────────────────────────── */
.mplanner-days[data-view="week"] .mplanner-section { padding: 8px 12px; }

/* ── Empty state ─────────────────────────────────────────────────────────── */
.mplanner-empty {
  text-align: center;
  padding: 40px 16px;
  color: var(--text-dim);
  font-style: italic;
  font-size: 14px;
}
.mplanner-out-of-range {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 20px 16px;
  text-align: center;
  font-size: 13px;
  color: var(--text-dim);
}
.mplanner-out-of-range a { color: var(--navy); font-weight: 600; }

/* ═══════════════════════════════════════════════════════════════════════════
   AGENDA VIEW  (/agenda)
   ═══════════════════════════════════════════════════════════════════════════ */
.agenda-page {}

/* ── Header ────────────────────────────────────────────────────────────── */
.agenda-hdr { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px; margin-bottom: 16px; }
.agenda-hdr-kicker { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--text-dim); margin-bottom: 2px; }
.agenda-hdr-month  { font-size: 20px; font-weight: 800; color: var(--navy); }
.agenda-hdr-controls { display: flex; gap: 12px; align-items: center; }

/* ── Month navigation ──────────────────────────────────────────────────── */
.agenda-monthnav { display: flex; align-items: center; gap: 4px; }
.agenda-monthnav-btn { display: flex; align-items: center; justify-content: center; width: 32px; height: 32px; border-radius: 999px; background: var(--surface); border: 1px solid var(--border); color: var(--navy); font-size: 15px; font-weight: 700; text-decoration: none; cursor: pointer; }
.agenda-monthnav-btn:hover { background: var(--surface2); }
.agenda-monthnav-label { font-size: 13px; font-weight: 700; color: var(--navy); padding: 0 6px; }

/* ── View tabs ──────────────────────────────────────────────────────────── */
.agenda-tabs { display: flex; gap: 4px; background: var(--surface2); border: 1px solid var(--border); border-radius: 8px; padding: 3px; }
.agenda-tab { padding: 5px 14px; border-radius: 6px; background: transparent; border: none; -webkit-appearance: none; appearance: none; cursor: pointer; font-size: 13px; font-weight: 600; color: var(--text-dim); transition: background .15s, color .15s; }
.agenda-tab.is-active { background: #fff; color: var(--navy); box-shadow: 0 1px 4px rgba(0,0,0,.10); }
.agenda-tab--link { text-decoration: none; display: inline-flex; align-items: center; justify-content: center; align-self: stretch; background: var(--navy); color: white; }

/* ── Month calendar ─────────────────────────────────────────────────────── */
.agenda-cal-head { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; margin-bottom: 4px; }
.agenda-cal-head-cell { text-align: center; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--text-dim); padding: 4px 0; }
.agenda-cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; }
.agenda-cal-cell { min-height: 110px; background: var(--surface); border: 1px solid var(--border); border-radius: 8px; overflow: hidden; font-size: 12px; }
.agenda-cal-cell--empty { background: var(--surface2); border: none; min-height: 110px; }
.agenda-cal-cell--we { background: #edf3f9; border-color: #c0d3e8; }
.agenda-cal-cell--ferie { background: #f2ecfa; border-color: #c8b8e0; }
.agenda-cal-cell--today { border: 2px solid var(--navy); }
/* --changed retiré du niveau cellule : seule la ligne modifiée est jaune */
.agenda-cal-cell--conflict { box-shadow: inset 0 0 0 2px var(--tone-outline-warn); }

.agenda-cal-top { background: var(--navy); color: #fff; padding: 6px 8px; display: flex; align-items: center; gap: 4px; }
.agenda-cal-cell--we .agenda-cal-top { background: #6b849e; }
.agenda-cal-cell--ferie .agenda-cal-top { background: #7e60b5; }
.agenda-cal-cell--today:not(.agenda-cal-cell--we):not(.agenda-cal-cell--ferie) .agenda-cal-top { background: #1e3448; }
.agenda-cal-dow { display: none; font-size: 11px; font-weight: 600; white-space: nowrap; opacity: .85; }
.agenda-cal-dn { font-size: 16px; font-weight: 800; flex: 1; }
.agenda-cal-badge { font-size: 9px; font-weight: 700; padding: 1px 5px; border-radius: 99px; }
.agenda-cal-badge--today { background: rgba(255,255,255,.9); color: var(--navy); }
.agenda-cal-badge--ferie { background: #e8d4ff; color: #5e2a96; }

.agenda-cal-astr { padding: 4px 6px; display: flex; flex-wrap: wrap; gap: 3px; border-bottom: 1px solid var(--border); }
.agenda-cal-ast { font-size: 11px; padding: 2px 5px; border-radius: 4px; background: #e4edf8; border: 1px solid #b8cfea; white-space: nowrap; }
.agenda-cal-ast--nuit { background: #e3e5f4; border-color: #b4badc; }
.agenda-cal-ast.is-warn { background: var(--tone-warn-soft); border-color: var(--tone-outline-warn); }

.agenda-cal-frow { display: grid; grid-template-columns: minmax(0,1fr) auto minmax(32px,1fr); gap: 2px 4px; align-items: center; padding: 2px 6px; border-bottom: 1px solid #f0f4f8; font-size: 11px; }
.agenda-cal-frow.is-changed { background: var(--tone-warn-soft); }
.agenda-cal-frow.is-empty { opacity: 0.4; }
.agenda-cal-ftask { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-weight: 600; }
.agenda-cal-fplage { color: var(--text-dim); font-size: 10px; text-align: center; }
.agenda-cal-fperson { font-weight: 700; color: var(--navy); text-align: right; }

/* ── Week view ───────────────────────────────────────────────────────────── */
.agenda-wknav { display: flex; align-items: center; gap: 8px; margin-bottom: 12px; }
.agenda-wknav-btn { width: 36px; height: 36px; border-radius: 999px; background: var(--surface); border: 1px solid var(--border); color: var(--navy); font-size: 16px; font-weight: 700; cursor: pointer; display: flex; align-items: center; justify-content: center; }
.agenda-wknav-btn:hover { background: var(--surface2); }
.agenda-wknav-btn:disabled { opacity: .35; cursor: default; pointer-events: none; }
.agenda-wknav-label { font-size: 14px; font-weight: 700; color: var(--navy); flex: 1; text-align: center; }

.agenda-wk-cols { display: grid; grid-template-columns: repeat(7, 1fr); gap: 6px; }
.agenda-wk-col { background: var(--surface); border: 1px solid var(--border); border-radius: 10px; overflow: hidden; }
.agenda-wk-col--we { background: #edf3f9; border-color: #c0d3e8; }
.agenda-wk-col--ferie { background: #f2ecfa; border-color: #c8b8e0; }
.agenda-wk-col--today { border: 2px solid var(--navy); }

.agenda-wk-col-hdr { background: var(--navy); color: #fff; padding: 8px 10px; display: flex; align-items: baseline; gap: 5px; }
.agenda-wk-col--we .agenda-wk-col-hdr { background: #6b849e; }
.agenda-wk-col--ferie .agenda-wk-col-hdr { background: #7e60b5; }
.agenda-wk-col--today:not(.agenda-wk-col--we):not(.agenda-wk-col--ferie) .agenda-wk-col-hdr { background: #1e3448; }
.agenda-wk-col-day { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; opacity: .8; }
.agenda-wk-col-num { font-size: 22px; font-weight: 800; line-height: 1; }
.agenda-wk-badge { font-size: 9px; font-weight: 700; padding: 1px 5px; border-radius: 99px; margin-left: auto; }
.agenda-wk-badge--today { background: rgba(255,255,255,.9); color: var(--navy); }
.agenda-wk-badge--ferie { background: #e8d4ff; color: #5e2a96; }

.agenda-wk-section { padding: 6px 10px; border-top: 1px solid var(--border); }
.agenda-wk-section-title { font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; color: var(--text-dim); margin-bottom: 5px; }

.agenda-wk-astr-row { display: block; padding: 3px 0; border-bottom: 1px solid #f0f4f8; font-size: 11px; color: var(--text-dim); line-height: 1.4; }
.agenda-wk-astr-row:last-child { border-bottom: none; }
.agenda-wk-astr-row.is-warn { background: var(--tone-warn-soft); margin: 0 -10px; padding: 3px 10px; }
.agenda-wk-astr-row strong { font-size: 13px; font-weight: 700; color: var(--navy); }

.agenda-wk-fonc-row { display: flex; align-items: center; gap: 4px; padding: 3px 0; border-bottom: 1px solid #f0f4f8; font-size: 12px; }
.agenda-wk-fonc-row:last-child { border-bottom: none; }
.agenda-wk-fonc-row.is-changed { background: var(--tone-warn-soft); margin: 0 -10px; padding: 3px 10px; }
.agenda-wk-fonc-row.is-empty { opacity: 0.45; }
.agenda-wk-fonc-task { font-size: 11px; font-weight: 600; flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.agenda-wk-fonc-person { font-weight: 700; color: var(--navy); white-space: nowrap; }
.agenda-wk-fonc-sup { color: #c0001a; font-weight: 700; }
.agenda-wk-fonc-plage {
  font-size: 10px; font-weight: 700; color: var(--text-dim);
  background: var(--surface2); border-radius: 3px;
  padding: 1px 4px; white-space: nowrap; flex-shrink: 0;
}
.agenda-wk-section--special .agenda-wk-section-title {
  color: #5e35b1; font-size: 10px;
}
.agenda-wk-section--special.is-changed { background: var(--tone-warn-soft); }
.agenda-wk-team-row {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.agenda-wk-team-pill {
  display: block;
  font-size: 12px;
  font-weight: 700;
  color: var(--navy);
  background: #eef3fa;
  border: 1px solid #c0d3e8;
  border-radius: 6px;
  padding: 4px 8px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.agenda-wk-empty { padding: 10px; color: var(--text-dim); font-size: 12px; font-style: italic; text-align: center; }

/* ── Présences recap (vue semaine) ───────────────────────────────────────── */
/* Utilisateur connecté : toute la ligne en gras souligné */
.agenda-cal-ast.is-me,
.agenda-cal-ast.is-me *,
.agenda-cal-frow.is-me,
.agenda-cal-frow.is-me *,
.agenda-wk-astr-row.is-me,
.agenda-wk-astr-row.is-me *,
.agenda-wk-fonc-row.is-me,
.agenda-wk-fonc-row.is-me *,
.agenda-wk-team-pill.is-me { font-weight: 700; text-decoration: underline; text-underline-offset: 2px; }
/* Dans le récap présences, seul le nom individuel est marqué */
.agenda-wk-pres-people .is-me { font-weight: 700; text-decoration: underline; text-underline-offset: 2px; }

.agenda-wk-section--pres { background: #f7f9fb; border-top: 2px solid var(--border); }
.agenda-wk-pres-row { display: flex; align-items: baseline; gap: 5px; padding: 2px 0; line-height: 1.35; }
.agenda-wk-pres-row:last-child { padding-bottom: 0; }
.agenda-wk-pres-code { font-size: 10px; font-weight: 700; color: #fff; background: var(--navy); border-radius: 3px; padding: 1px 4px; flex-shrink: 0; min-width: 22px; text-align: center; }
.agenda-wk-pres-people { font-size: 11px; color: var(--text-dim); font-weight: 500; }

/* ── Responsive ──────────────────────────────────────────────────────────── */
@media (max-width: 1100px) {
  .agenda-cal-grid { gap: 3px; }
  .agenda-cal-cell { min-height: 90px; }
}
@media (max-width: 850px) {
  .agenda-wk-cols { grid-template-columns: repeat(4, 1fr); }
}
@media (max-width: 600px) {
  /* Global header mobile — ligne unique : [logo][agenda][astreinte][autres][user] */
  .brand-logo-title--booktime { display: none; }
  .nav-tab--secondary { display: none; }
  .nav-autres-wrap { display: flex !important; align-items: stretch; }
  /* Cacher les chips version et bug suggestion */
  body.planning-look-presence .app-version-pill,
  body.planning-look-presence .planning-beta-header-btn { display: none !important; }
  .header-nouveautes-link { display: none; }
  /* Ligne unique flex — écrase display:block de ≤900px et display:grid de ≤1100px */
  body.planning-look-presence .nav-app-top {
    display: flex !important;
    flex-direction: row;
    align-items: center;
    flex-wrap: nowrap;
    gap: 4px;
    padding: 0 4px;
  }
  body.planning-look-presence .nav-app .nav-left {
    display: flex !important;
    flex-direction: row;
    align-items: center;
    flex: 0 0 auto;
    gap: 4px;
    width: auto;
  }
  /* Logo : pas de align-self:flex-start, taille réduite */
  .brand--on-header { flex-shrink: 0; align-self: center !important; }
  body.planning-look-presence .brand-logo--mascot { width: 28px; height: 28px; }
  body.planning-look-presence .nav-primary {
    display: flex !important;
    flex-direction: row;
    flex-wrap: nowrap;
    overflow: visible !important;
    width: auto !important;
    flex: 0 0 auto;
    gap: 4px;
  }
  /* nav-app-actions : margin-left:auto pousse JG à droite, écrase width:100% de ≤900px */
  body.planning-look-presence .nav-app-actions {
    flex-shrink: 0;
    flex-direction: row;
    align-items: center;
    width: auto !important;
    max-width: none;
    flex-wrap: nowrap;
    padding-top: 0;
    margin-left: auto;
    gap: 4px;
  }
  /* User : initiales seules + même style rect que nav-tab */
  .auth-chip__meta, .auth-chip__caret { display: none; }
  body.planning-look-presence .auth-chip {
    min-height: 32px;
    padding: 4px 10px;
    border-radius: 8px;
  }
  body.planning-look-presence .auth-chip__avatar {
    width: auto;
    height: auto;
    min-width: 0;
    border-radius: 4px;
    background: transparent;
    font-size: 13px;
    font-weight: 700;
  }
  /* Agenda header */
  .agenda-hdr { flex-direction: column; align-items: stretch; gap: 8px; }
  .agenda-hdr > div:first-child { display: none; }
  .agenda-hdr-controls { flex-direction: column; align-items: stretch; gap: 6px; }
  .agenda-monthnav { justify-content: center; }
  .agenda-monthnav-label { font-size: 15px; font-weight: 800; }
  .agenda-tabs { justify-content: stretch; }
  .agenda-tab { flex: 1; text-align: center; }
  /* Month view : 3 colonnes, scroll vertical, pas de header DOW ni offset cells */
  .agenda-cal-head { display: none; }
  .agenda-cal-cell--empty { display: none; }
  .agenda-cal-grid { grid-template-columns: repeat(3, 1fr); gap: 4px; }
  .agenda-cal-cell { min-height: 70px; font-size: 12px; }
  .agenda-cal-dow { display: inline; }
  .agenda-cal-dn { font-size: 14px; }
  /* Week view : 2 colonnes */
  .agenda-wk-cols { grid-template-columns: repeat(2, 1fr); gap: 4px; }
  .agenda-wk-weekend { display: contents; }
  .agenda-wk-col { border-radius: 8px; }
  .agenda-wk-col-num { font-size: 18px; }
  .agenda-wk-section { padding: 5px 8px; }
}
@media (max-width: 340px) {
  .agenda-wk-cols { grid-template-columns: 1fr; }
}

/* ── Smartphone paysage (iPhone 15, Galaxy S…) ────────────────────────────
   max-height:500px exclut les tablettes (≥768px) tout en ciblant les phones
   (~390-430px de hauteur en landscape). */
@media (orientation: landscape) and (max-height: 500px) {
  /* Header : ligne unique identique au portrait mobile */
  .brand-logo-title--booktime { display: none; }
  .nav-tab--secondary { display: none; }
  .nav-autres-wrap { display: flex !important; align-items: stretch; }
  body.planning-look-presence .app-version-pill,
  body.planning-look-presence .planning-beta-header-btn { display: none !important; }
  .header-nouveautes-link { display: none; }
  body.planning-look-presence .nav-app-top {
    display: flex !important;
    flex-direction: row;
    align-items: center;
    flex-wrap: nowrap;
    gap: 4px;
    padding: 0 4px;
  }
  body.planning-look-presence .nav-app .nav-left {
    display: flex !important;
    flex-direction: row;
    align-items: center;
    flex: 0 0 auto;
    gap: 4px;
    width: auto;
  }
  .brand--on-header { flex-shrink: 0; align-self: center !important; }
  body.planning-look-presence .brand-logo--mascot { width: 28px; height: 28px; }
  body.planning-look-presence .nav-primary {
    display: flex !important;
    flex-direction: row;
    flex-wrap: nowrap;
    overflow: visible !important;
    width: auto !important;
    flex: 0 0 auto;
    gap: 4px;
  }
  body.planning-look-presence .nav-app-actions {
    flex-shrink: 0;
    flex-direction: row;
    align-items: center;
    width: auto !important;
    max-width: none;
    flex-wrap: nowrap;
    padding-top: 0;
    margin-left: auto;
    gap: 4px;
  }
  .auth-chip__meta, .auth-chip__caret { display: none; }
  body.planning-look-presence .auth-chip {
    min-height: 32px;
    padding: 4px 10px;
    border-radius: 8px;
  }
  body.planning-look-presence .auth-chip__avatar {
    width: auto; height: auto; min-width: 0;
    border-radius: 4px; background: transparent;
    font-size: 13px; font-weight: 700;
  }
  /* Vue semaine : toute la semaine sur 7 colonnes */
  .agenda-wk-cols { grid-template-columns: repeat(7, 1fr) !important; gap: 3px; }
  .agenda-wk-weekend { display: contents !important; }
  .agenda-wk-col { border-radius: 6px; }
  .agenda-wk-col-num { font-size: 15px; }
  .agenda-wk-section { padding: 4px 5px; font-size: 11px; }
  /* Vue mois : 7 colonnes (1 semaine par ligne), avec header DOW */
  .agenda-cal-head { display: grid !important; grid-template-columns: repeat(7, 1fr); }
  .agenda-cal-cell--empty { display: block !important; }
  .agenda-cal-grid { grid-template-columns: repeat(7, 1fr) !important; gap: 2px; }
  .agenda-cal-cell { min-height: 55px; font-size: 11px; }
  .agenda-cal-dow { display: none; }
  .agenda-cal-dn { font-size: 13px; }
}
