/* Planning Cardinale v17.2.4 - CSS centralise depuis index.html (ancien bloc <style>). */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');

:root{
  /* Palette neutre, sobre, une teinte d'accent */
  --bg: #fafaf9;
  --surface: #ffffff;
  --surface-alt: #f5f5f4;
  --border: #e7e5e4;
  --border-strong: #d6d3d1;
  --text: #0c0a09;
  --text-muted: #57534e;
  --text-soft: #a8a29e;
  --accent: #0f0f0f;
  --accent-text: #ffffff;
  --success: #15803d;
  --success-bg: #dcfce7;
  --warn: #b45309;
  --warn-bg: #fef3c7;
  --error: #b91c1c;
  --error-bg: #fee2e2;
  --info: #1e40af;
  --info-bg: #dbeafe;
  --violet: #6d28d9;
  --violet-bg: #ede9fe;

  --radius: 6px;
  --radius-lg: 10px;
  --radius-xl: 14px;
  --shadow-sm: 0 1px 2px rgba(0,0,0,0.04);
  --shadow: 0 2px 6px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04);
  --shadow-lg: 0 12px 32px rgba(0,0,0,0.12);
  --safe-top: env(safe-area-inset-top, 0);
  --safe-bot: env(safe-area-inset-bottom, 0);
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  background:var(--bg);
  color:var(--text);
  font-size:14px;
  line-height:1.45;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overscroll-behavior-y:none;
}

/* ───────── LOGIN SCREEN ───────── */
.login-screen{
  position:fixed;inset:0;z-index:9999;
  background:var(--bg);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:24px;
  padding-top:calc(48px + var(--safe-top));
  padding-bottom:calc(48px + var(--safe-bot));
  pointer-events:auto; /* v15.0.7 : garantit que le login est toujours cliquable */
}
.login-screen.hidden{display:none !important} /* v15.0.7 : !important pour éviter tout conflit de spécificité */
.login-card{
  width:100%;max-width:360px;
  text-align:center;
  pointer-events:auto; /* v15.0.7 : jamais bloqué par un parent */
}
.login-logo{
  width:64px;height:64px;border-radius:16px;
  background:var(--accent);color:var(--accent-text);
  display:flex;align-items:center;justify-content:center;
  font-size:28px;margin:0 auto 20px;
  box-shadow:var(--shadow);
}
.login-logo img{width:64px;height:64px;border-radius:16px;object-fit:cover}
.login-title{font-size:22px;font-weight:700;margin-bottom:6px;letter-spacing:-0.02em}
.login-subtitle{color:var(--text-muted);font-size:13px;margin-bottom:28px}
.login-input{
  width:100%;padding:14px 16px;
  border:1px solid var(--border-strong);border-radius:var(--radius-lg);
  font-family:inherit;font-size:16px;
  background:var(--surface);color:var(--text);
  margin-bottom:12px;
  -webkit-appearance:none;
  transition:border-color .15s;
  position:relative;z-index:1; /* v15.0.7 : élève au-dessus de tout élément parasite */
}
.login-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(0,0,0,0.05)}
.login-btn{
  width:100%;padding:14px;
  background:var(--accent);color:var(--accent-text);
  border:none;border-radius:var(--radius-lg);
  font-family:inherit;font-size:15px;font-weight:600;
  cursor:pointer;transition:opacity .15s;
  position:relative;z-index:1;
}
.login-btn:hover:not(:disabled){opacity:.88}
.login-btn:disabled{opacity:.5;cursor:not-allowed}
.login-error{color:var(--error);font-size:13px;margin-top:10px;min-height:18px}
.login-hint{font-size:11.5px;color:var(--text-soft);margin-top:20px;line-height:1.5}
/* v15.0.7 : bouton panique accessible même si l'app est totalement plantée */
.panic-btn{
  margin-top:24px;padding:8px 14px;
  background:transparent;color:var(--text-soft);
  border:1px dashed var(--border-strong);border-radius:var(--radius);
  font-family:inherit;font-size:11.5px;
  cursor:pointer;opacity:.7;
}
.panic-btn:hover{opacity:1;color:var(--error);border-color:var(--error)}

/* ───────── APP LAYOUT ───────── */
.app{
  display:none;
  min-height:100vh;
}
.app.active{display:block}

/* ───────── TOP BAR ───────── */
.topbar{
  position:sticky;top:0;z-index:50;
  background:var(--surface);
  border-bottom:1px solid var(--border);
  padding:0 16px;
  padding-top:var(--safe-top);
  height:calc(52px + var(--safe-top));
  display:flex;align-items:center;
  gap:12px;
}
.topbar-brand{
  display:flex;align-items:center;gap:10px;
  flex:1;min-width:0;
  cursor:pointer;
  background:none;border:none;padding:0;
  color:inherit;
  text-align:left;
}
.brand-logo{
  width:32px;height:32px;border-radius:8px;
  background:var(--accent);color:var(--accent-text);
  display:flex;align-items:center;justify-content:center;
  font-size:16px;flex-shrink:0;
}
.brand-logo img{width:32px;height:32px;border-radius:8px;object-fit:cover}
#brandLogoImg{width:32px;height:32px;border-radius:8px;object-fit:cover;flex-shrink:0}
.brand-text{min-width:0}
.brand-name{
  font-size:14px;font-weight:600;letter-spacing:-0.01em;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.brand-sub{
  font-size:11px;color:var(--text-soft);font-weight:500;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.brand-sub:empty{display:none}

/* Nav desktop */
.topnav{
  display:flex;gap:2px;flex:2;overflow-x:auto;scrollbar-width:none;
  padding:0 4px;
}
.topnav::-webkit-scrollbar{display:none}
.topnav-btn{
  padding:8px 14px;
  border:none;background:none;
  font-family:inherit;font-size:13px;font-weight:500;
  color:var(--text-muted);cursor:pointer;
  border-radius:var(--radius);
  white-space:nowrap;
  transition:background .15s;
  position:relative;
}
.topnav-btn:hover{background:var(--surface-alt);color:var(--text)}
.topnav-btn.active{background:var(--accent);color:var(--accent-text)}
.topnav-btn-badge{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:16px;height:16px;padding:0 5px;margin-left:5px;
  background:var(--error);color:#fff;border-radius:8px;
  font-size:10px;font-weight:700;
}

/* Actions à droite */
.topbar-actions{
  display:flex;align-items:center;gap:8px;flex-shrink:0;
}
.sync-indicator{
  display:flex;align-items:center;gap:5px;
  padding:5px 10px;border-radius:var(--radius);
  background:var(--surface-alt);
  font-size:11.5px;color:var(--text-muted);
  white-space:nowrap;
  cursor:pointer;
  border:1px solid transparent;
  transition:all .15s;
}
.sync-indicator:hover{border-color:var(--border)}
.sync-indicator.error{background:var(--error-bg);color:var(--error)}
.sync-indicator.warn{background:var(--warn-bg);color:var(--warn)}
.sync-dot{width:6px;height:6px;border-radius:50%;background:var(--success);flex-shrink:0}
.sync-indicator.error .sync-dot{background:var(--error)}
.sync-indicator.warn .sync-dot{background:var(--warn)}
.sync-indicator.loading .sync-dot{animation:pulse 1.2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

.icon-btn{
  background:none;border:none;
  width:34px;height:34px;
  display:flex;align-items:center;justify-content:center;
  border-radius:var(--radius);
  color:var(--text-muted);cursor:pointer;
  transition:all .15s;
}
.icon-btn:hover:not(:disabled){background:var(--surface-alt);color:var(--text)}
.icon-btn:disabled{opacity:.3;cursor:not-allowed}
.icon-btn svg{width:18px;height:18px}

/* ───────── MAIN ───────── */
main{
  padding:16px;
  max-width:1600px;
  margin:0 auto;
  padding-bottom:calc(16px + var(--safe-bot));
}

/* ───────── TAB BAR MOBILE ───────── */
.tabbar{
  display:none;
  position:fixed;bottom:0;left:0;right:0;z-index:40;
  background:var(--surface);
  border-top:1px solid var(--border);
  padding:6px 4px calc(6px + var(--safe-bot));
  justify-content:space-around;
  box-shadow:0 -2px 10px rgba(0,0,0,0.04);
}
.tabbar-btn{
  flex:1;
  display:flex;flex-direction:column;align-items:center;gap:2px;
  padding:6px 3px;
  background:none;border:none;
  color:var(--text-soft);
  cursor:pointer;
  font-family:inherit;font-size:10px;font-weight:500;
  border-radius:var(--radius);
  transition:color .15s;
  position:relative;
  min-width:0;
}
.tabbar-btn.active{color:var(--text)}
.tabbar-btn svg{width:21px;height:21px;stroke-width:2;margin-bottom:1px}
.tabbar-badge{
  position:absolute;top:2px;right:calc(50% - 18px);
  min-width:14px;height:14px;padding:0 4px;
  background:var(--error);color:#fff;
  border-radius:7px;font-size:9px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
}

/* ───────── TAB PANELS ───────── */
.panel{display:none}
.panel.active{display:block}

/* ───────── CARDS / SURFACES ───────── */
.card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);
  overflow:hidden;
}
.card-body{padding:14px 16px}
.section-title{
  font-size:12px;font-weight:700;text-transform:uppercase;
  letter-spacing:0.05em;color:var(--text-soft);
  margin-bottom:10px;
}
.section-heading{
  font-size:15px;font-weight:600;
  letter-spacing:-0.01em;margin:0;
}

/* ───────── WEEK TOOLBAR ───────── */
.toolbar{
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;
  padding:10px 12px;margin-bottom:12px;
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-lg);
}
.toolbar-group{display:flex;align-items:center;gap:4px}
.toolbar-sep{width:1px;height:20px;background:var(--border);margin:0 4px}

.nav-arrow{
  width:30px;height:30px;
  border:1px solid var(--border);background:var(--surface);
  border-radius:var(--radius);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  color:var(--text-muted);font-size:15px;
}
.nav-arrow:hover{background:var(--surface-alt);color:var(--text)}
.period-label{
  font-weight:600;font-size:13px;padding:0 8px;
  text-align:center;min-width:180px;
}
.period-num{
  font-size:11px;font-weight:600;color:var(--text-muted);
  padding:3px 8px;background:var(--surface-alt);
  border-radius:5px;border:1px solid var(--border);
}
.btn-today{
  padding:5px 10px;border:1px solid var(--border);
  background:var(--surface);border-radius:var(--radius);
  font-family:inherit;font-size:11.5px;color:var(--text-muted);
  cursor:pointer;
}
.btn-today:hover{background:var(--surface-alt);color:var(--text)}

/* ───────── BUTTONS ───────── */
.btn{
  font-family:inherit;font-weight:500;
  cursor:pointer;border:1px solid var(--border);
  border-radius:var(--radius);
  display:inline-flex;align-items:center;gap:5px;
  transition:all .12s;
  background:var(--surface);color:var(--text);
  padding:6px 12px;font-size:12.5px;
}
.btn:hover{background:var(--surface-alt)}
.btn-sm{padding:5px 10px;font-size:11.5px}
.btn-xs{padding:3px 8px;font-size:11px;border-radius:5px}
.btn-primary{background:var(--accent);color:var(--accent-text);border-color:var(--accent)}
.btn-primary:hover{background:#000;color:#fff}
.btn-danger{background:var(--error-bg);color:#991b1b;border-color:#fecaca}
.btn-danger:hover{background:#fecaca}
.btn-warn{background:var(--warn-bg);color:var(--warn);border-color:#fde68a}
.btn-warn:hover{background:#fde68a}

/* ───────── TABLES (DESKTOP) ───────── */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.data-table{
  width:100%;border-collapse:separate;border-spacing:0;
  font-size:12.5px;
}
.data-table th,.data-table td{
  padding:10px 8px;
  border-right:1px solid var(--border);
  border-bottom:1px solid var(--border);
  vertical-align:top;
  background:var(--surface);
  line-height:1.35;
}
.data-table tbody td{min-height:74px}
.data-table tbody td:not(:first-child){min-width:118px}
.data-table td > div{line-height:1.4}
body.compact-view .data-table th,body.compact-view .data-table td{padding:7px 6px;line-height:1.25}
body.compact-view .data-table tbody td{min-height:58px}
body.compact-view .data-table tbody td:not(:first-child){min-width:104px}
.data-table thead th{
  background:var(--surface-alt);
  color:var(--text-muted);
  font-weight:600;font-size:11px;
  text-transform:uppercase;letter-spacing:0.03em;
  padding:9px 6px;text-align:center;
  position:sticky;top:0;z-index:5;
}
.data-table thead th small{font-weight:500;color:var(--text-soft);text-transform:none;letter-spacing:0;font-size:10.5px}
.data-table th.today-th{background:var(--warn-bg);color:var(--warn)}
.data-table th.ferie-th{
  background:#f5f3ff;
  color:#6d28d9;
  border-bottom:2px solid #a78bfa;
}
.data-table th.ferie-th.today-th{
  background:#ede9fe;
  color:#6d28d9;
  border-bottom:2px solid #8b5cf6;
}
/* Colonne férié : fond léger violet sur toutes les TD de la colonne */
.data-table td.ferie-cell{
  background:rgba(245, 243, 255, 0.35);
}
.data-table tbody tr td:first-child{
  position:sticky;left:0;z-index:4;background:var(--surface);
}
.data-table .cell-repos{background:#f0f9ff}
.data-table .cell-conges{background:#f0fdf4}
.data-table .cell-maladie{background:#fffbeb}
.data-table .cell-formation{background:#f5f3ff}
.data-table .cell-motif{background:#fef2f2}
.data-table .cell-conflict{box-shadow:inset 0 0 0 2px #f87171}
.data-table .totals-row td{font-weight:700;background:var(--surface-alt)}
.data-table .comment-row td{background:#fffdf5}

/* Plages inputs (desktop) */
.plage-row{display:flex;align-items:center;gap:3px}
.plage-input{
  width:56px;padding:4px 5px;
  border:1px solid var(--border);border-radius:4px;
  font-family:inherit;font-size:12.5px;
  text-align:center;background:#fff;
  font-weight:600;
}
.plage-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px rgba(0,0,0,0.04)}
.plage-input.invalid{border-color:var(--error);background:var(--error-bg)}
.plage-sep{color:var(--text-soft);font-size:11px}
.plage-remove{background:none;border:none;color:var(--error);cursor:pointer;padding:2px 4px;font-size:11px}
.add-plage-btn{
  padding:2px 8px;border:1px dashed var(--border-strong);
  background:none;border-radius:4px;cursor:pointer;
  font-size:10.5px;color:var(--text-soft);font-family:inherit;
}
.add-plage-btn:hover{border-color:var(--accent);color:var(--accent)}
.add-plage-btn.active-copy{background:var(--warn-bg);border-color:#fbbf24;color:var(--warn)}
.plage-issue{color:var(--error);font-size:10px;margin-top:2px}
.plage-total{font-weight:600;font-size:11px;color:var(--text-muted)}

/* Motif */
.motif-bar{margin-top:4px;position:relative}
.motif-trigger{
  font-size:10.5px;padding:3px 8px;
  border:1px dashed var(--border-strong);
  background:none;border-radius:10px;cursor:pointer;
  font-family:inherit;color:var(--text-soft);
}
.motif-trigger.motif-repos{background:var(--info-bg);color:var(--info);border-color:#bfdbfe;border-style:solid}
.motif-trigger.motif-conges{background:var(--success-bg);color:var(--success);border-color:#86efac;border-style:solid}
.motif-trigger.motif-formation{background:var(--violet-bg);color:var(--violet);border-color:#c4b5fd;border-style:solid}
.motif-trigger.motif-maladie{background:var(--warn-bg);color:var(--warn);border-color:#fde68a;border-style:solid}
.motif-trigger.motif-autre{background:var(--error-bg);color:var(--error);border-color:#fecaca;border-style:solid}
.motif-dropdown{
  display:none;position:absolute;top:calc(100% + 3px);left:0;
  background:var(--surface);
  border:1px solid var(--border);border-radius:var(--radius);
  box-shadow:var(--shadow-lg);z-index:20;
  min-width:160px;overflow:hidden;
}
.motif-dropdown.open{display:block}
.motif-option{
  display:block;width:100%;padding:7px 12px;
  border:none;background:none;text-align:left;cursor:pointer;
  font-family:inherit;font-size:12.5px;color:var(--text);
}
.motif-option:hover{background:var(--surface-alt)}
.motif-option.active{background:var(--accent);color:var(--accent-text)}
.motif-libre{
  width:100%;padding:4px 8px;
  border:1px solid var(--border);border-radius:4px;
  font-family:inherit;font-size:11px;
  margin-top:3px;background:#fff;
}

.comment-input{
  width:100%;padding:4px 8px;
  border:1px solid var(--border);border-radius:4px;
  font-family:inherit;font-size:11.5px;
  resize:vertical;background:#fff;
}

/* ───────── EMP CHIPS FILTER ───────── */
.chips-bar{
  display:flex;flex-wrap:wrap;gap:6px;padding:10px 0;align-items:center;
}
.chips-label{font-size:11px;color:var(--text-soft);margin-right:4px;text-transform:uppercase;letter-spacing:0.04em;font-weight:600}
.chip{
  display:inline-flex;align-items:center;gap:5px;
  padding:5px 11px;border-radius:20px;
  background:var(--surface);border:1px solid var(--border);
  font-size:11.5px;font-weight:500;
  cursor:pointer;color:var(--text-muted);
  user-select:none;
  transition:all .15s;
}
.chip:hover{border-color:var(--border-strong)}
.chip.active{background:var(--accent);color:var(--accent-text);border-color:var(--accent)}
.chip-dot{width:7px;height:7px;border-radius:50%;background:var(--text-soft)}
.chip.active .chip-dot{background:#fff}
.chip-dot.alt{background:var(--violet)}

/* ───────── EMPLOYEES LIST ───────── */
.emp-list{display:flex;flex-direction:column;gap:6px}
.emp-item{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  padding:12px 14px;
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-lg);
}
.emp-item input[type="text"],.emp-item input[type="number"]{
  padding:7px 10px;border:1px solid var(--border);border-radius:var(--radius);
  font-family:inherit;font-size:13px;background:#fff;
}
.emp-item input:focus{outline:none;border-color:var(--accent)}
.emp-item label{
  font-size:12px;color:var(--text-muted);
  display:flex;align-items:center;gap:4px;
}
.emp-avatar{
  width:34px;height:34px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:600;flex-shrink:0;
}
.search-box{
  padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius);
  font-family:inherit;font-size:13px;background:#fff;
  min-width:180px;
}
.search-box:focus{outline:none;border-color:var(--accent)}

/* ───────── STATUS (pointage) ───────── */
.status-select{
  padding:4px 6px;border:1px solid var(--border);
  border-radius:4px;font-family:inherit;font-size:11.5px;
  background:#fff;max-width:100%;font-weight:500;
}
.status-select.status-present,.status-select.status-entreprise{background:var(--success-bg);color:var(--success);border-color:#86efac}
.status-select.status-repos{background:var(--info-bg);color:var(--info);border-color:#bfdbfe}
.status-select.status-absent{background:var(--error-bg);color:var(--error);border-color:#fecaca}
.status-select.status-cp{background:var(--success-bg);color:var(--success);border-color:#86efac}
.status-select.status-maladie{background:var(--warn-bg);color:var(--warn);border-color:#fde68a}
.status-select.status-formation{background:var(--violet-bg);color:var(--violet);border-color:#c4b5fd}
.status-select.status-autre{background:var(--error-bg);color:var(--error);border-color:#fecaca}
.pointage-input{
  width:52px;padding:4px 5px;
  border:1px solid var(--border);border-radius:4px;
  font-family:inherit;font-size:11.5px;
  text-align:center;background:#fff;font-weight:600;
}
.pointage-input:focus{outline:none;border-color:var(--accent)}
.diff-pos{color:var(--success);font-weight:700}
.diff-neg{color:var(--error);font-weight:700}
.diff-zero{color:var(--text-muted)}

/* KPI stats */
.stats-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;margin-top:16px;
}
.stat-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:14px 16px;
}
.stat-value{font-size:22px;font-weight:700;letter-spacing:-0.02em}
.stat-label{font-size:11.5px;color:var(--text-muted);margin-top:3px}

/* ───────── SETTINGS ───────── */

.diag-card{border:1px solid var(--line);border-radius:14px;padding:10px 12px;background:var(--surface-alt)}
.diag-card span{display:block;font-size:10.8px;color:var(--text-soft);margin-bottom:3px}
.diag-card strong{display:block;font-size:12.5px;color:var(--text)}

.settings-section{
  margin-bottom:24px;padding-bottom:20px;
  border-bottom:1px solid var(--border);
}
.settings-section:last-child{border-bottom:none}
.settings-section h3{
  font-size:13px;font-weight:600;margin:0 0 12px;
  letter-spacing:-0.01em;
}
.form-group{margin-bottom:12px}
.form-group label{
  display:block;font-size:11.5px;color:var(--text-muted);
  margin-bottom:4px;font-weight:500;
}
.form-input{
  width:100%;max-width:360px;padding:9px 12px;
  border:1px solid var(--border);border-radius:var(--radius);
  font-family:inherit;font-size:13px;background:#fff;
}
.form-input:focus{outline:none;border-color:var(--accent)}
.logo-upload{
  width:120px;height:60px;
  border:2px dashed var(--border-strong);
  border-radius:var(--radius-lg);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;background:var(--surface-alt);
  position:relative;overflow:hidden;
  padding:6px;
}
.logo-upload:hover{border-color:var(--accent)}
.logo-preview{max-width:100%;max-height:100%;object-fit:contain}

.template-list{display:flex;flex-direction:column;gap:6px}
.template-item{
  display:flex;justify-content:space-between;align-items:center;gap:10px;
  padding:12px 14px;background:var(--surface-alt);
  border:1px solid var(--border);border-radius:var(--radius-lg);
  flex-wrap:wrap;
}

/* ───────── MODAL ───────── */
.modal-overlay{
  display:none;position:fixed;inset:0;z-index:200;
  background:rgba(0,0,0,0.45);
  align-items:center;justify-content:center;padding:16px;
  backdrop-filter:blur(2px);
}
.modal-overlay.open{display:flex}
.modal{
  background:var(--surface);
  border-radius:var(--radius-xl);
  padding:20px 22px;max-width:480px;width:100%;
  box-shadow:var(--shadow-lg);
  max-height:92vh;overflow-y:auto;
}
.modal h2{font-size:17px;margin:0 0 14px;letter-spacing:-0.01em}
.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}
.info-box{
  padding:10px 12px;background:var(--surface-alt);
  border-radius:var(--radius);font-size:12px;color:var(--text-muted);
  margin-bottom:12px;
}

/* ───────── EMPTY STATE ───────── */
.empty{text-align:center;padding:40px 20px;color:var(--text-soft)}
.empty-icon{font-size:32px;margin-bottom:10px;opacity:.6}

/* ───────── ALERTS PANEL ───────── */
.alerts-panel{
  display:none;
  background:var(--error-bg);
  border:1px solid #fecaca;
  border-radius:var(--radius-lg);
  padding:12px 14px;margin-bottom:12px;
}
.alerts-panel.visible{display:block}
.alerts-panel ul{list-style:none;padding:0;margin:6px 0 0;font-size:12px}
.alerts-panel li{padding:3px 0}

/* ───────── LEGEND ───────── */
.legend{display:flex;flex-wrap:wrap;gap:14px;padding:12px 4px 0;font-size:11px;color:var(--text-muted)}
.legend-item{display:flex;align-items:center;gap:5px}
.legend-dot{width:10px;height:10px;border-radius:3px}

/* ───────── TOAST ───────── */
#toast{
  position:fixed;bottom:calc(80px + var(--safe-bot));right:16px;
  padding:11px 18px;border-radius:var(--radius-lg);
  font-size:12.5px;font-weight:500;z-index:9999;
  box-shadow:var(--shadow-lg);
  transition:opacity .3s, transform .3s;
  max-width:300px;pointer-events:none;
  opacity:0;transform:translateY(10px);
}
#toast.visible{opacity:1;transform:translateY(0)}

/* ───────── MOBILE CARDS (planning / décompte / mensuel) ───────── */
.mobile-view{display:none}
.mob-week-nav{
  display:flex;align-items:center;gap:8px;
  padding:10px 12px;background:var(--accent);color:var(--accent-text);
  border-radius:var(--radius-lg);margin-bottom:8px;
}
.mob-week-nav .mob-nav-arrow{
  width:32px;height:32px;border-radius:var(--radius);
  border:none;background:rgba(255,255,255,0.12);
  color:#fff;font-size:15px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
}
.mob-week-label{
  flex:1;text-align:center;font-size:13px;font-weight:600;letter-spacing:-0.01em;
}

.mob-day-chips{
  display:flex;gap:5px;overflow-x:auto;
  padding:6px 0 10px;scrollbar-width:none;
}
.mob-day-chips::-webkit-scrollbar{display:none}
.mob-day-chip{
  padding:8px 14px;border-radius:22px;
  border:1px solid var(--border);background:var(--surface);
  font-size:12px;font-weight:500;
  cursor:pointer;font-family:inherit;color:var(--text-muted);
  white-space:nowrap;flex-shrink:0;
  min-width:58px;text-align:center;
}
.mob-day-chip.active{background:var(--accent);color:var(--accent-text);border-color:var(--accent);font-weight:600}
.mob-day-chip.today{border-color:var(--warn)}
.mob-day-chip.has-data::after{
  content:"";display:inline-block;
  width:5px;height:5px;border-radius:50%;
  background:var(--success);margin-left:5px;vertical-align:middle;
}
.mob-day-chip.active.has-data::after{background:#fff}

.mob-day-header{
  background:var(--accent);color:var(--accent-text);
  padding:10px 14px;border-radius:var(--radius-lg);
  margin-bottom:10px;
  display:flex;justify-content:space-between;align-items:center;
  font-size:13px;
}
.mob-day-header strong{font-weight:600}
.mob-day-header-meta{font-size:11.5px;opacity:.8}

/* Barre d'actions (PDF/Excel/Copier/Anomalies) sur mobile */
.mob-actions-bar{
  display:flex;gap:6px;overflow-x:auto;
  padding:4px 0 12px;
  scrollbar-width:none;
  -webkit-overflow-scrolling:touch;
}
.mob-actions-bar::-webkit-scrollbar{display:none}
.mob-action-btn{
  flex-shrink:0;
  padding:8px 12px;
  border:1px solid var(--border);
  background:var(--surface);
  border-radius:var(--radius);
  font-family:inherit;font-size:12px;font-weight:500;
  color:var(--text-muted);
  cursor:pointer;
  white-space:nowrap;
  transition:all .12s;
}
.mob-action-btn:hover,.mob-action-btn:active{
  background:var(--surface-alt);
  color:var(--text);
  border-color:var(--border-strong);
}

.mob-emp-card{
  background:var(--surface);
  border:1px solid var(--border-strong);
  border-radius:var(--radius-lg);
  padding:12px 14px;margin-bottom:10px;
  box-shadow:var(--shadow-sm);
}
.mob-emp-card.motif-repos{background:#f0f9ff;border-color:#bae6fd}
.mob-emp-card.motif-conges{background:#f0fdf4;border-color:#86efac}
.mob-emp-card.motif-maladie{background:#fffbeb;border-color:#fde047}
.mob-emp-card.motif-formation{background:#f5f3ff;border-color:#c4b5fd}
.mob-emp-card.motif-autre{background:#fef2f2;border-color:#fecaca}
.mob-emp-header{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:10px;gap:8px;
  padding-bottom:8px;border-bottom:1px solid var(--border);
}
.mob-emp-name{
  font-weight:700;font-size:15px;letter-spacing:-0.01em;
  flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.mob-emp-total{font-size:13px;color:var(--text);font-weight:700;white-space:nowrap}
.mob-emp-night{font-size:10px;color:#5b4736;background:#fff3e0;padding:2px 6px;border-radius:4px;white-space:nowrap;border:1px solid #f5e3b8}

.mob-card{
  background:var(--surface);
  border:1px solid var(--border-strong);
  border-radius:var(--radius-lg);
  margin-bottom:12px;
  box-shadow:var(--shadow-sm);
  overflow:hidden;
}
.mob-card.motif-repos{background:#f0f9ff;border-color:#bae6fd}
.mob-card.motif-conges{background:#f0fdf4;border-color:#86efac}
.mob-card.motif-maladie{background:#fffbeb;border-color:#fde047}
.mob-card.motif-formation{background:#f5f3ff;border-color:#c4b5fd}
.mob-card.motif-autre{background:#fef2f2;border-color:#fecaca}
.mob-card-strong-header{
  display:flex;align-items:center;gap:10px;
  padding:12px 14px;
  background:var(--surface-alt);
  border-bottom:1px solid var(--border);
}
.mob-card-emp-name{
  font-weight:700;font-size:15px;letter-spacing:-0.01em;
  color:var(--text);line-height:1.2;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.mob-card-emp-status{
  font-size:11.5px;color:var(--text-muted);
  margin-top:2px;font-weight:500;
}
.mob-card-body{padding:14px 16px;line-height:1.4}
.mob-total{font-size:12px;color:var(--text-muted);font-weight:600}
.mob-total.good{color:var(--success)}
.mob-night{
  font-size:10px;color:#5b4736;background:#fff3e0;
  padding:2px 6px;border-radius:4px;
  border:1px solid #f5e3b8;white-space:nowrap;
}

.mob-plage-row{
  display:flex;align-items:center;gap:6px;margin-bottom:6px;
}
.mob-input{
  flex:1;min-width:0;
  padding:9px 10px;
  border:1px solid var(--border);border-radius:var(--radius);
  font-family:inherit;font-size:15px;
  background:#fff;text-align:center;font-weight:600;
}
.mob-input:focus{outline:none;border-color:var(--accent)}
.mob-sep{color:var(--text-soft);font-size:13px;flex-shrink:0}
.mob-rm{
  background:none;border:none;color:var(--error);
  cursor:pointer;font-size:15px;padding:4px 8px;flex-shrink:0;
}
.mob-add{
  font-size:12px;padding:7px 14px;
  border:1px dashed var(--border-strong);border-radius:var(--radius);
  background:none;cursor:pointer;
  color:var(--text-soft);font-family:inherit;margin-top:4px;
}
.mob-add:hover{border-color:var(--accent);color:var(--accent)}
.mob-motif-row{
  display:flex;gap:6px;flex-wrap:wrap;margin-top:10px;
}
.mob-motif-btn{
  font-size:11.5px;padding:6px 11px;border-radius:20px;
  border:1px solid var(--border);background:var(--surface-alt);
  cursor:pointer;font-family:inherit;color:var(--text-muted);
  white-space:nowrap;font-weight:500;
}
.mob-motif-btn.on-repos{background:var(--info-bg);color:var(--info);border-color:#bfdbfe}
.mob-motif-btn.on-conges{background:var(--success-bg);color:var(--success);border-color:#86efac}
.mob-motif-btn.on-formation{background:var(--violet-bg);color:var(--violet);border-color:#c4b5fd}
.mob-motif-btn.on-maladie{background:var(--warn-bg);color:var(--warn);border-color:#fde68a}
.mob-motif-btn.on-autre{background:var(--error-bg);color:var(--error);border-color:#fecaca}
.mob-status-label{
  padding:12px 0;font-weight:500;font-size:13px;text-align:center;
}

.mob-comment{
  background:#fffdf5;border:1px solid var(--warn-bg);
  border-radius:var(--radius);padding:8px 12px;margin-top:10px;
}
.mob-comment textarea{
  width:100%;border:none;background:none;resize:none;
  font-family:inherit;font-size:12px;color:var(--warn);min-height:32px;
}

/* Mobile: pointage & mensuel card */
.mob-stat-row{
  display:grid;grid-template-columns:1fr auto;gap:8px;
  padding:7px 0;border-bottom:1px solid var(--border);
  font-size:12.5px;
}
.mob-stat-row:last-child{border-bottom:none}
.mob-stat-label{color:var(--text-muted);font-weight:500}
.mob-stat-value{font-weight:600;text-align:right}

/* Vue mensuel mobile: résumé par employé */
.mob-mensuel-row{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:14px;margin-bottom:8px;
}
.mob-mensuel-header{
  display:flex;align-items:center;gap:10px;margin-bottom:10px;
}

/* ───────── FOCUS STATE ───────── */
button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{
  outline:2px solid #60a5fa;outline-offset:2px;
}

/* ───────── RESPONSIVE BREAKPOINTS ───────── */
@media(max-width:880px){
  .topbar{height:calc(48px + var(--safe-top));padding:0 12px}
  .topnav{display:none}
  .tabbar{display:flex}
  main{padding:12px 12px 90px;padding-bottom:calc(90px + var(--safe-bot))}
  .brand-sub{display:none}
  .sync-indicator{padding:4px 8px;font-size:10.5px}

  /* Cacher tableaux desktop, afficher vues mobile */
  .desktop-view{display:none}
  .mobile-view{display:block}

  .toolbar{flex-direction:row;flex-wrap:wrap;gap:6px;padding:8px 10px}
  .period-label{min-width:auto;font-size:12.5px;flex:1}
  .stat-value{font-size:18px}
  .stats-grid{grid-template-columns:repeat(2,1fr)}

  #toast{bottom:calc(80px + var(--safe-bot));left:16px;right:16px;max-width:none}
}

@media(min-width:881px){
  .tabbar{display:none}
  .mobile-view{display:none}
}

@media print{
  .topbar,.tabbar,.toolbar,.chips-bar,.alerts-panel,.motif-bar,.add-plage-btn,#toast{display:none !important}
  .mobile-view{display:none !important}
  .desktop-view{display:block !important}
  body{background:#fff}
}


/* ───────── V16 MODERN PRO REDESIGN ─────────
   Refonte visuelle sans changer le moteur métier : hiérarchie plus claire,
   cartes plus premium, tableaux plus lisibles, actions mieux groupées. */
:root{
  --bg:#f3f6fb;
  --surface:#ffffff;
  --surface-alt:#f8fafc;
  --surface-soft:#f1f5f9;
  --border:#e2e8f0;
  --border-strong:#cbd5e1;
  --text:#0f172a;
  --text-muted:#475569;
  --text-soft:#94a3b8;
  --accent:#111827;
  --accent-text:#ffffff;
  --brand:#2563eb;
  --brand-bg:#eff6ff;
  --success:#15803d;
  --success-bg:#dcfce7;
  --warn:#b45309;
  --warn-bg:#fef3c7;
  --error:#b91c1c;
  --error-bg:#fee2e2;
  --info:#1d4ed8;
  --info-bg:#dbeafe;
  --violet:#7c3aed;
  --violet-bg:#ede9fe;
  --radius:10px;
  --radius-lg:14px;
  --radius-xl:20px;
  --shadow-sm:0 1px 2px rgba(15,23,42,.05);
  --shadow:0 10px 30px rgba(15,23,42,.06),0 2px 8px rgba(15,23,42,.04);
  --shadow-lg:0 24px 70px rgba(15,23,42,.18);
}
body{
  background:
    radial-gradient(circle at 8% -10%, rgba(37,99,235,.10), transparent 34rem),
    radial-gradient(circle at 92% 0%, rgba(14,165,233,.10), transparent 30rem),
    var(--bg);
  color:var(--text);
}
.app.active{animation:v16FadeIn .18s ease-out both}
@keyframes v16FadeIn{from{opacity:.72;transform:translateY(2px)}to{opacity:1;transform:none}}
.topbar{
  height:calc(64px + var(--safe-top));
  padding:0 18px;
  padding-top:var(--safe-top);
  background:rgba(255,255,255,.86);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(226,232,240,.9);
  box-shadow:0 1px 0 rgba(255,255,255,.8);
}
.brand-logo,#brandLogoImg{
  width:40px;height:40px;border-radius:12px;
  box-shadow:0 6px 18px rgba(15,23,42,.15);
}
.brand-name{font-size:16px;font-weight:800;letter-spacing:-.025em}
.brand-sub{font-size:12px;color:var(--text-soft);font-weight:600;margin-top:1px}
.topnav{
  flex:0 1 auto;
  justify-content:center;
  background:rgba(248,250,252,.72);
  border:1px solid rgba(226,232,240,.9);
  border-radius:999px;
  padding:4px;
  gap:2px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.85);
}
.topnav-btn{
  border-radius:999px;
  padding:9px 16px;
  font-weight:650;
  color:#334155;
}
.topnav-btn:hover{background:#fff;color:var(--text);box-shadow:var(--shadow-sm)}
.topnav-btn.active{
  background:var(--accent);
  color:#fff;
  box-shadow:0 10px 18px rgba(15,23,42,.18);
}
.sync-indicator{
  background:#fff;
  border:1px solid var(--border);
  border-radius:999px;
  padding:7px 12px;
  font-weight:650;
  box-shadow:var(--shadow-sm);
}
.sync-dot{width:7px;height:7px;box-shadow:0 0 0 3px rgba(22,163,74,.10)}
.icon-btn,.nav-arrow,.btn,.small-btn,.seg-btn,.toolbar button,.toolbar select,.toolbar input,.employee-filter,.chip{
  border-radius:12px;
}
.icon-btn:hover,.nav-arrow:hover,.btn:hover,.small-btn:hover,.seg-btn:hover{
  transform:translateY(-1px);
  box-shadow:var(--shadow-sm);
}
.main{padding:22px 20px 38px;}
.toolbar{
  margin:0 0 18px;
  padding:12px;
  background:rgba(255,255,255,.82);
  border:1px solid rgba(226,232,240,.95);
  border-radius:20px;
  box-shadow:var(--shadow);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
}
.toolbar-title{font-size:16px;font-weight:800;letter-spacing:-.02em;color:var(--text)}
.toolbar .divider{background:linear-gradient(to bottom,transparent,var(--border),transparent)}
.btn,.small-btn,.seg-btn,.toolbar button{
  font-weight:700;
  border-color:var(--border);
  background:#fff;
  color:#111827;
  box-shadow:0 1px 0 rgba(255,255,255,.85),0 1px 2px rgba(15,23,42,.04);
}
.btn.primary,.small-btn.primary,.seg-btn.active,.toolbar button.primary{
  background:linear-gradient(180deg,#1f2937,#111827);
  color:#fff;
  border-color:#111827;
  box-shadow:0 8px 18px rgba(15,23,42,.18);
}
.btn.warn,.small-btn.warn{background:var(--warn-bg);border-color:#fde68a;color:#92400e}
.btn.danger,.small-btn.danger{background:#fff1f2;border-color:#fecdd3;color:#9f1239}
.chips-bar,.motif-bar{
  padding:10px 2px 13px;
  gap:8px;
}
.chip,.filter-chip{
  background:#fff;
  border:1px solid var(--border);
  border-radius:999px;
  padding:5px 12px;
  font-weight:650;
  color:#475569;
  box-shadow:var(--shadow-sm);
}
.chip.active,.filter-chip.active{background:#111827;color:#fff;border-color:#111827}
.card,.table-wrap,.settings-section,.employees-list,.alerts-panel{
  background:rgba(255,255,255,.88);
  border:1px solid rgba(226,232,240,.95);
  border-radius:20px;
  box-shadow:var(--shadow);
  overflow:hidden;
}
.alerts-panel{
  padding:16px 18px;
  border-color:#fecaca;
  background:linear-gradient(180deg,#fff7f7,#fff);
}
.alerts-panel.success,.alert-ok{border-color:#bbf7d0;background:linear-gradient(180deg,#f0fdf4,#fff)}
.data-table{
  border-collapse:separate;
  border-spacing:0;
  background:transparent;
}
.data-table th{
  background:#f8fafc;
  color:#475569;
  text-transform:uppercase;
  letter-spacing:.07em;
  font-size:11px;
  font-weight:800;
  border-bottom:1px solid var(--border);
  position:sticky;top:calc(64px + var(--safe-top));z-index:10;
}
.data-table td{
  border-color:#e5e7eb;
  background:#fff;
  transition:background .12s ease;
}
.data-table tbody tr:nth-child(even) td{background:#fbfdff}
.data-table tbody tr:hover td{background:#f8fbff}
.data-table tbody tr:hover td:first-child{box-shadow:inset 4px 0 0 rgba(37,99,235,.45)}
.data-table tbody td:first-child{
  background:linear-gradient(90deg,#fff,#fcfdff);
  position:sticky;left:0;z-index:8;
  box-shadow:1px 0 0 var(--border);
}
.data-table tbody tr:nth-child(even) td:first-child{background:linear-gradient(90deg,#fbfdff,#f8fafc)}
.emp-avatar,.avatar{
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.7),0 5px 14px rgba(15,23,42,.10);
}
.emp-name{font-weight:850;letter-spacing:-.015em;color:#111827}
.emp-role,.emp-meta{color:#94a3b8;font-weight:550}
.time-input,input[type="time"],input[type="text"],input[type="number"],select,textarea{
  border:1px solid var(--border);
  border-radius:10px;
  background:#fff;
  box-shadow:inset 0 1px 0 rgba(15,23,42,.02);
  transition:border-color .15s,box-shadow .15s,background .15s;
}
.time-input:focus,input:focus,select:focus,textarea:focus{
  outline:none;
  border-color:#93c5fd;
  box-shadow:0 0 0 4px rgba(59,130,246,.12);
}
.shift-cell.rest,.day-rest,.status-rest{background:linear-gradient(180deg,#eaf7ff,#dff2ff) !important}
.shift-cell.cp,.day-cp,.status-cp{background:linear-gradient(180deg,#fff7ed,#ffedd5) !important}
.shift-cell.sick,.day-sick,.status-sick{background:linear-gradient(180deg,#fef2f2,#fee2e2) !important}
.status-pill,.pill,.badge{
  border-radius:999px;
  font-weight:750;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.65);
}
.add-plage-btn,.motif-add{
  border-radius:999px;
  border-style:dashed;
  background:rgba(255,255,255,.74);
}
.modal,.dialog,.pdf-preview-panel{
  border-radius:24px !important;
  box-shadow:var(--shadow-lg) !important;
}
#toast{
  border-radius:16px;
  box-shadow:var(--shadow-lg);
  border:1px solid rgba(255,255,255,.4);
}
.settings-grid,.form-grid{gap:18px}
.section-title,h2,h3{letter-spacing:-.025em;color:#0f172a}
.login-screen{
  background:
    radial-gradient(circle at 30% 0%, rgba(37,99,235,.18), transparent 34rem),
    radial-gradient(circle at 72% 18%, rgba(14,165,233,.16), transparent 28rem),
    #f8fafc;
}
.login-card{
  background:rgba(255,255,255,.86);
  border:1px solid rgba(226,232,240,.95);
  border-radius:28px;
  padding:30px;
  box-shadow:var(--shadow-lg);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
}
.login-logo{border-radius:18px;background:linear-gradient(145deg,#111827,#334155)}
@media(max-width:760px){
  .topbar{height:calc(56px + var(--safe-top));padding-left:12px;padding-right:12px}
  .brand-logo,#brandLogoImg{width:36px;height:36px;border-radius:11px}
  .main{padding:14px 10px calc(84px + var(--safe-bot))}
  .toolbar{border-radius:18px;padding:10px;margin-bottom:12px}
  .topnav{display:none}
  .tabbar{
    background:rgba(255,255,255,.9);
    backdrop-filter:blur(18px);
    -webkit-backdrop-filter:blur(18px);
    border-top:1px solid rgba(226,232,240,.95);
  }
  .tabbar-btn.active{background:#111827;color:#fff;border-radius:16px;box-shadow:0 8px 18px rgba(15,23,42,.18)}
}
@media(print){
  body{background:#fff !important}
  .topbar,.toolbar{box-shadow:none !important;backdrop-filter:none !important}
}




/* v17.1.0 — Réglages layout stable (nettoyage complet des anciens overrides) */
#tab-reglages{padding:28px 22px 36px!important;}
#tab-reglages > .card.card-body{
  display:grid!important;
  grid-template-columns:repeat(12,minmax(0,1fr))!important;
  gap:18px!important;
  align-items:start!important;
  padding:0!important;
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  overflow:visible!important;
}
#tab-reglages .settings-hero,
#tab-reglages .settings-quicknav{display:none!important;}
#tab-reglages .settings-section{
  margin:0!important;
  padding:18px!important;
  border:1px solid #dce5f1!important;
  border-radius:21px!important;
  background:linear-gradient(180deg,#fff 0%,#fbfdff 100%)!important;
  box-shadow:0 10px 26px rgba(16,24,40,.055)!important;
  overflow:hidden!important;
  min-width:0!important;
  position:relative!important;
}
#tab-reglages .settings-section h3{
  display:flex!important;
  align-items:center!important;
  gap:8px!important;
  margin:0 0 14px!important;
  font-size:16px!important;
  line-height:1.2!important;
  font-weight:950!important;
  color:#111827!important;
  white-space:normal!important;
}
#settings-identite h3:before{content:'🏷️'}
#settings-horaires h3:before{content:'🌙'}
#settings-session h3:before{content:'🔐'}
#settings-sync h3:before{content:'☁️'}
#settings-sante h3:before{content:'🩺'}
#settings-restore h3:before{content:'↩️'}
#settings-data h3:before{content:'🧰'}
#settings-log h3:before{content:'🧾'}
#settings-about h3:before{content:'ℹ️'}

#settings-identite{grid-column:1 / span 4!important;grid-row:1!important;min-height:330px!important;}
#settings-top-side{grid-column:5 / span 8!important;grid-row:1!important;display:grid!important;grid-template-rows:auto auto!important;gap:18px!important;min-height:330px!important;align-self:stretch!important;}
#settings-top-side .settings-top-row{display:grid!important;grid-template-columns:1fr 1fr!important;gap:18px!important;align-items:stretch!important;}
#settings-horaires,#settings-session,#settings-sync{height:auto!important;min-height:0!important;}
#settings-sync{align-self:start!important;}

#settings-sante{grid-column:1 / span 4!important;grid-row:2!important;min-height:320px!important;max-height:320px!important;display:flex!important;flex-direction:column!important;}
#settings-restore{grid-column:5 / span 8!important;grid-row:2!important;min-height:320px!important;max-height:320px!important;display:flex!important;flex-direction:column!important;}
#settings-modeles{display:none!important;}
#settings-data{grid-column:1 / span 4!important;grid-row:3!important;}
#settings-log{grid-column:5 / span 8!important;grid-row:3!important;min-height:300px!important;max-height:300px!important;display:flex!important;flex-direction:column!important;}
#settings-log .template-list{flex:1 1 auto!important;min-height:0!important;overflow:auto!important;padding-right:4px!important;}
#settings-about{grid-column:1 / span 12!important;grid-row:4!important;}

#tab-reglages .diag-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:9px!important;margin-bottom:12px!important;}
#tab-reglages .diag-card{min-height:54px!important;padding:10px 11px!important;overflow:hidden!important;border-radius:13px!important;}
#tab-reglages .diag-card span{display:block!important;font-size:11px!important;line-height:1.15!important;margin-bottom:5px!important;white-space:normal!important;color:#8a99ad!important;}
#tab-reglages .diag-card strong{display:block!important;font-size:13px!important;line-height:1.18!important;overflow-wrap:anywhere!important;}
#settings-sante > div:last-child{margin-top:auto!important;}

#settings-restore > p{margin-bottom:8px!important;}
#settings-restore > div[style*="margin-bottom"]{margin-bottom:8px!important;}
#settings-restore .template-list{flex:1 1 auto!important;min-height:0!important;max-height:none!important;overflow:auto!important;padding-right:4px!important;border-radius:14px!important;}
#settings-restore .template-item,#settings-modeles .template-item{min-height:52px!important;padding:10px 12px!important;background:#f8fbff!important;border-radius:13px!important;}
#settings-restore .template-item h4{font-size:14px!important;margin:0 0 2px!important;}
#settings-restore .template-item p{font-size:12px;margin:0!important;}

#tab-reglages .form-group{margin-bottom:13px!important;}
#tab-reglages label{font-size:12px;color:#64748b!important;font-weight:850!important;}
#tab-reglages .form-input{max-width:none!important;width:100%!important;}
#settings-identite .logo-upload{width:94px!important;height:70px!important;background:#f8fafc!important;}
#settings-sync .btn,#settings-sante .btn,#settings-restore .btn,#settings-data .btn{min-height:32px!important;}

@media (max-width:1250px){
  #tab-reglages > .card.card-body{grid-template-columns:1fr!important;gap:12px!important;}
  #settings-identite,#settings-top-side,#settings-sante,#settings-restore,#settings-data,#settings-log,#settings-about{grid-column:1/-1!important;grid-row:auto!important;min-height:auto!important;max-height:none!important;}
  #settings-top-side{display:grid!important;grid-template-rows:auto!important;min-height:0!important;}
  #settings-sante,#settings-restore{display:block!important;}
  #settings-restore .template-list{max-height:220px!important;}
  #tab-reglages .diag-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))!important;}
}
@media (max-width:760px){
  #tab-reglages{padding:14px 10px 86px!important;}
  #settings-top-side .settings-top-row{grid-template-columns:1fr!important;}
  #tab-reglages .settings-section{padding:16px!important;border-radius:17px!important;}
}


/* v17.1.0 — harmonisation Planning / Décompte : même échelle visuelle */
.topbar{justify-content:flex-start!important;gap:20px!important;}
.topbar-brand{flex:0 0 auto!important;}
.topnav{margin-left:12px!important;margin-right:auto!important;justify-content:flex-start!important;}
.topbar-actions{margin-left:auto!important;}
.brand-logo{display:flex;align-items:center;justify-content:center;background:#111827;color:#fff;}
.brand-logo-placeholder{font-weight:950;font-size:12px;letter-spacing:.02em;}
.login-logo{display:flex!important;align-items:center!important;justify-content:center!important;overflow:hidden!important;}
.login-logo-placeholder{display:flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:16px;background:#111827;color:#fff;font-weight:950;font-size:18px;letter-spacing:.03em;}

/* Planning : léger gain de lisibilité */
#semaineTable.data-table{font-size:13.8px!important;}
#semaineTable.data-table th{font-size:11.7px!important;padding:10px 8px!important;}
#semaineTable.data-table td{padding:10px 8px!important;line-height:1.34!important;}
#semaineTable .plage-row{gap:5px!important;margin:3px 0!important;}
#semaineTable .plage-input{width:64px!important;min-height:29px!important;padding:5px 7px!important;font-size:14.4px!important;border-radius:9px!important;font-weight:850!important;}
#semaineTable .plage-sep{font-size:13px!important;font-weight:700!important;}
#semaineTable .plage-remove{font-size:12px;padding:3px 5px!important;}
#semaineTable .add-plage-btn{font-size:11.8px!important;padding:4px 9px!important;min-height:25px!important;}
#semaineTable .plage-total{font-size:13px!important;font-weight:850!important;margin-top:4px!important;color:#475569!important;}
#semaineTable .motif-trigger,#semaineTable .motif-bar button{font-size:11.8px!important;padding:4px 9px!important;}
#semaineTable .badge,#semaineTable .pill,#semaineTable .status-pill{font-size:12.6px!important;padding:5px 12px!important;}
#semaineTable .emp-name{font-size:13.7px!important;}
#semaineTable .emp-role,#semaineTable .emp-meta{font-size:11.6px!important;}

/* Décompte : réduit pour matcher le planning, sans revenir trop petit */
#pointageTable.data-table{font-size:13.8px!important;}
#pointageTable.data-table th{font-size:11.7px!important;padding:10px 8px!important;}
#pointageTable.data-table td{padding:10px 8px!important;line-height:1.34!important;}
#pointageTable.data-table tbody td:not(:first-child){min-width:132px!important;}
#pointageTable .pointage-input{width:64px!important;min-height:29px!important;padding:5px 7px!important;font-size:14.4px!important;border-radius:9px!important;font-weight:850!important;text-align:center!important;}
#pointageTable .status-select{min-height:29px!important;font-size:12.6px!important;font-weight:800!important;border-radius:8px!important;padding:4px 8px!important;}
#pointageTable .add-plage-btn{font-size:11.8px!important;padding:4px 9px!important;min-height:25px!important;}
#pointageTable .emp-name{font-size:13.7px!important;}
#pointageTable .emp-role,#pointageTable .emp-meta{font-size:11.6px!important;}
#pointageTable td[style*="font-size:10px"], #pointageTable div[style*="font-size:10px"]{font-size:12.1px!important;}
@media(max-width:1280px){#semaineTable .plage-input,#pointageTable .pointage-input{width:60px!important;font-size:13.8px!important;}#pointageTable.data-table tbody td:not(:first-child){min-width:126px!important;}}


/* v17.1.0 — ancien correctif sticky supprimé : la barre mobile est forcée en fixed bottom. */

/* v17.1.0 — même échelle visuelle pour Planning et Décompte */
#planningTable.data-table,#pointageTable.data-table{font-size:14px!important;}
#planningTable.data-table th,#pointageTable.data-table th{font-size:11.8px!important;padding:10px 8px!important;}
#planningTable.data-table td,#pointageTable.data-table td{padding:10px 8px!important;line-height:1.32!important;}
#planningTable.data-table tbody td:not(:first-child),#pointageTable.data-table tbody td:not(:first-child){min-width:122px!important;}
#planningTable .plage-row,#pointageTable .plage-row{gap:5px!important;margin:3px 0!important;}
#planningTable .plage-input,#pointageTable .pointage-input{width:63px!important;min-height:29px!important;padding:5px 7px!important;font-size:14.2px!important;border-radius:9px!important;font-weight:850!important;text-align:center!important;}
#planningTable .plage-sep,#pointageTable .plage-sep{font-size:13px!important;font-weight:800!important;color:#94a3b8!important;}
#planningTable .plage-remove,#pointageTable .plage-remove{font-size:12px;padding:3px 5px!important;}
#planningTable .add-plage-btn,#pointageTable .add-plage-btn{font-size:11.7px!important;padding:4px 9px!important;min-height:25px!important;}
#planningTable .plage-total,#pointageTable .plage-total{font-size:13px!important;font-weight:850!important;margin-top:4px!important;color:#475569!important;}
#pointageTable .status-select{width:100%!important;max-width:126px!important;min-height:29px!important;font-size:12.4px!important;font-weight:800!important;border-radius:8px!important;padding:4px 8px!important;}
#planningTable .emp-name,#pointageTable .emp-name{font-size:13.7px!important;}
#planningTable .emp-role,#planningTable .emp-meta,#pointageTable .emp-role,#pointageTable .emp-meta{font-size:11.6px!important;}
#pointageTable td[style*="font-size:10px"],#pointageTable div[style*="font-size:10px"]{font-size:11.9px!important;}
@media(max-width:1280px){
  #planningTable .plage-input,#pointageTable .pointage-input{width:60px!important;font-size:13.7px!important;}
  #planningTable.data-table tbody td:not(:first-child),#pointageTable.data-table tbody td:not(:first-child){min-width:118px!important;}
  #pointageTable .status-select{max-width:122px!important;}
}


/* v17.1.0 — harmonisation mobile Planning / Décompte */
@media(max-width:880px){
  #planningMobile .mob-card,#pointageMobile .mob-card{padding:12px!important;margin-bottom:9px!important;border-radius:18px!important;}
  #planningMobile .mob-card-strong-header,#pointageMobile .mob-card-strong-header{gap:9px!important;margin-bottom:9px!important;}
  #planningMobile .mob-card-emp-name,#pointageMobile .mob-card-emp-name{font-size:14px!important;font-weight:900!important;}
  #planningMobile .mob-card-emp-status,#pointageMobile .mob-card-emp-status{font-size:11.5px!important;}
  #planningMobile .emp-avatar,#pointageMobile .emp-avatar{width:36px!important;height:36px!important;font-size:12px;}
  #planningMobile .mob-input,#pointageMobile .mob-input{min-height:34px!important;font-size:15px!important;font-weight:850!important;padding:6px 8px!important;border-radius:10px;}
  #planningMobile .mob-add,#pointageMobile .mob-add,
  #planningMobile .mob-action-btn,#pointageMobile .mob-action-btn{min-height:32px!important;font-size:12px;font-weight:850!important;padding:7px 9px!important;border-radius:11px!important;}
  #pointageMobile .status-select{min-height:34px!important;font-size:13.2px!important;font-weight:850!important;padding:7px 9px!important;border-radius:10px;margin-bottom:8px!important;}
  #pointageMobile .card.card-body{margin-top:10px!important;padding:12px!important;border-radius:16px!important;}
  #pointageMobile .mob-stat-row{font-size:12.2px!important;padding:6px 0!important;}
  #pointageMobile .mob-actions-bar,#planningMobile .mob-actions-bar{gap:6px!important;margin:8px 0 10px!important;}
}

/* v17.1.0 — login : aucun ancien pictogramme forcé, seul le logo réglages est injecté */
.login-logo{background:#111827!important;}
.login-logo:empty{display:none!important;}
.login-logo-placeholder{display:flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:16px;background:#111827;color:#fff;font-weight:950;font-size:18px;letter-spacing:.03em;}




/* v17.1.0 — NAV MOBILE HAUTE COMPACTE : icônes seules, fixée sous l'entête */
@media(max-width:880px){
  :root{--mobile-iconnav-h:44px;--mobile-topbar-h:calc(56px + env(safe-area-inset-top,0px));}
  html,body{overflow-x:hidden!important;}
  body{padding-bottom:12px!important;}
  .app.active{min-height:100dvh!important;}
  .topbar{position:sticky!important;top:0!important;z-index:120!important;}
  main{padding:calc(12px + var(--mobile-iconnav-h)) 10px 22px!important;max-width:none!important;}
  body .tabbar{
    display:flex!important;position:fixed;top:var(--mobile-topbar-h)!important;left:10px!important;right:10px!important;bottom:auto!important;
    width:auto!important;height:var(--mobile-iconnav-h)!important;min-height:var(--mobile-iconnav-h)!important;max-height:var(--mobile-iconnav-h)!important;
    padding:4px!important;margin:0!important;z-index:119!important;gap:4px!important;justify-content:space-between!important;align-items:center!important;overflow:hidden!important;
    border:1px solid rgba(226,232,240,.96)!important;border-radius:17px!important;background:rgba(255,255,255,.94)!important;
    box-shadow:0 8px 22px rgba(15,23,42,.12)!important;backdrop-filter:blur(18px)!important;-webkit-backdrop-filter:blur(18px)!important;
    transform:none!important;-webkit-transform:none!important;pointer-events:auto!important;
  }
  body .tabbar .tabbar-btn{
    flex:1 1 0!important;min-width:0!important;height:36px!important;padding:0!important;margin:0!important;display:flex!important;
    align-items:center!important;justify-content:center!important;border-radius:13px!important;font-size:0!important;line-height:0!important;color:#64748b!important;background:transparent!important;
  }
  body .tabbar .tabbar-btn svg{width:22px!important;height:22px!important;margin:0!important;display:block!important;}
  body .tabbar .tabbar-btn.active{background:#111827!important;color:#fff!important;box-shadow:0 5px 12px rgba(15,23,42,.18)!important;}
  #toast{bottom:16px!important;}
}
@media(min-width:881px){body .tabbar{display:none!important;}}


/* v17.1.0 — zone mobile FIXE : icônes + période + jours restent visibles pendant la saisie */
@media(max-width:880px){
  :root{
    --mobile-topbar-h:calc(56px + env(safe-area-inset-top,0px));
    --mobile-iconnav-h:44px;
    --mobile-sticky-top:calc(var(--mobile-topbar-h) + var(--mobile-iconnav-h) + 6px);
    --mobile-weekhead-h:168px;
    --mobile-simplehead-h:62px;
  }
  .topbar{position:fixed;top:0!important;left:0!important;right:0!important;z-index:130!important;}
  body .tabbar{position:fixed;top:var(--mobile-topbar-h)!important;left:10px!important;right:10px!important;bottom:auto!important;width:auto!important;z-index:129!important;}
  main{padding:calc(var(--mobile-topbar-h) + var(--mobile-iconnav-h) + 12px) 10px 22px!important;}
  #planningMobile,#pointageMobile{padding-top:var(--mobile-weekhead-h)!important;}
  #mensuelMobile,#congesMobile{padding-top:var(--mobile-simplehead-h)!important;}
  .mobile-view .mob-sticky-head{
    position:fixed;
    top:var(--mobile-sticky-top)!important;
    left:10px!important;
    right:10px!important;
    width:auto!important;
    z-index:128!important;
    margin:0!important;
    padding:4px 0 8px!important;
    background:linear-gradient(180deg,rgba(239,247,255,.99) 0%,rgba(239,247,255,.96) 82%,rgba(239,247,255,0) 100%)!important;
    backdrop-filter:blur(12px)!important;
    -webkit-backdrop-filter:blur(12px)!important;
    transform:translateZ(0)!important;
    -webkit-transform:translateZ(0)!important;
  }
  .mobile-view .mob-sticky-head .mob-week-nav{margin-bottom:6px!important;}
  .mobile-view .mob-sticky-head .mob-day-chips{padding:4px 0 6px!important;}
  .mob-day-total{
    display:flex!important;align-items:center!important;justify-content:space-between!important;gap:10px!important;
    margin:0!important;padding:9px 12px!important;border-radius:16px!important;
    background:#111827!important;color:#fff!important;font-size:13px!important;font-weight:800!important;
    box-shadow:0 8px 18px rgba(15,23,42,.12)!important;
  }
  .mob-day-total span:last-child{font-weight:750!important;opacity:.9!important;}
  .mobile-view .mob-sticky-head .mob-day-header{margin-bottom:0!important;}
}




/* v17.1.0 — MOBILE : barre flottante sans entête (logo NORDEV non figé)
   La barre figée contient uniquement les icônes + période/jours/total.
   L'entête NORDEV reste dans la page normale et disparaît au scroll. */
@media(max-width:880px){
  :root{--mobile-iconnav-h:44px;}
  #app > .topbar{visibility:visible!important;pointer-events:auto!important;position:relative!important;top:auto!important;left:auto!important;right:auto!important;z-index:10!important;display:flex!important;background:rgba(255,255,255,.94)!important;}
  #app > .tabbar{visibility:visible!important;pointer-events:auto!important;display:flex!important;position:relative!important;width:auto!important;height:var(--mobile-iconnav-h)!important;min-height:var(--mobile-iconnav-h)!important;max-height:var(--mobile-iconnav-h)!important;margin:6px 10px!important;padding:4px!important;z-index:9!important;gap:4px!important;justify-content:space-between!important;align-items:center!important;overflow:hidden!important;border:1px solid rgba(226,232,240,.96)!important;border-radius:17px!important;background:rgba(255,255,255,.96)!important;box-shadow:0 8px 22px rgba(15,23,42,.12)!important;backdrop-filter:blur(18px)!important;-webkit-backdrop-filter:blur(18px)!important;transform:none!important;-webkit-transform:none!important;bottom:auto!important;left:auto!important;right:auto!important;top:auto!important;}
  #app > .tabbar .tabbar-btn{flex:1 1 0!important;min-width:0!important;height:36px!important;padding:0!important;margin:0!important;display:flex!important;align-items:center!important;justify-content:center!important;border-radius:13px!important;font-size:0!important;line-height:0!important;color:#64748b!important;background:transparent!important;}
  #app > .tabbar .tabbar-btn svg{width:22px!important;height:22px!important;margin:0!important;display:block!important;}
  #app > .tabbar .tabbar-btn.active{background:#111827!important;color:#fff!important;box-shadow:0 5px 12px rgba(15,23,42,.18)!important;}
  main{padding:10px 10px 22px!important;max-width:none!important;}
  #planningMobile,#pointageMobile,#mensuelMobile,#congesMobile{padding-top:0!important;}
  .mobile-view .mob-sticky-head{visibility:visible!important;pointer-events:auto!important;position:relative!important;top:auto!important;left:auto!important;right:auto!important;width:auto!important;z-index:8!important;margin:0 0 10px!important;transform:none!important;-webkit-transform:none!important;background:transparent!important;}
  #mobileFloatingShell{display:none;position:fixed;left:0!important;right:0!important;top:0!important;z-index:2147483000;pointer-events:none;box-sizing:border-box!important;margin:0!important;padding:0!important;transform:translate3d(0,0,0)!important;-webkit-transform:translate3d(0,0,0)!important;will-change:auto!important;contain:layout style paint!important;}
  #mobileFloatingShell .mf-inner{pointer-events:auto!important;box-sizing:border-box!important;padding:6px 10px 8px!important;background:linear-gradient(180deg,rgba(248,251,255,.99) 0%,rgba(239,247,255,.97) 88%,rgba(239,247,255,0) 100%)!important;}
  #mobileFloatingShell .topbar,#mobileFloatingShell .topbar-brand,#mobileFloatingShell .brand-logo,#mobileFloatingShell .brand-logo-placeholder,#mobileFloatingShell .brand-name,#mobileFloatingShell .brand-sub{display:none!important;visibility:hidden!important;width:0!important;height:0!important;overflow:hidden!important;}
  #mobileFloatingShell .topnav{display:none!important;}
  #mobileFloatingShell .tabbar{visibility:visible!important;pointer-events:auto!important;display:flex!important;position:static!important;width:auto!important;height:var(--mobile-iconnav-h)!important;min-height:var(--mobile-iconnav-h)!important;max-height:var(--mobile-iconnav-h)!important;margin:0 0 6px!important;padding:4px!important;z-index:auto!important;gap:4px!important;justify-content:space-between!important;align-items:center!important;overflow:hidden!important;border:1px solid rgba(226,232,240,.96)!important;border-radius:17px!important;background:rgba(255,255,255,.96)!important;box-shadow:0 8px 22px rgba(15,23,42,.12)!important;backdrop-filter:blur(18px)!important;-webkit-backdrop-filter:blur(18px)!important;transform:none!important;-webkit-transform:none!important;bottom:auto!important;left:auto!important;right:auto!important;top:auto!important;}
  #mobileFloatingShell .tabbar .tabbar-btn{flex:1 1 0!important;min-width:0!important;height:36px!important;padding:0!important;margin:0!important;display:flex!important;align-items:center!important;justify-content:center!important;border-radius:13px!important;font-size:0!important;line-height:0!important;color:#64748b!important;background:transparent!important;}
  #mobileFloatingShell .tabbar .tabbar-btn svg{width:22px!important;height:22px!important;margin:0!important;display:block!important;}
  #mobileFloatingShell .tabbar .tabbar-btn.active{background:#111827!important;color:#fff!important;box-shadow:0 5px 12px rgba(15,23,42,.18)!important;}
  #mobileFloatingShell .mob-sticky-head{visibility:visible!important;pointer-events:auto!important;position:static!important;display:block!important;top:auto!important;left:auto!important;right:auto!important;width:auto!important;margin:0!important;padding:0 0 6px!important;z-index:auto!important;background:transparent!important;box-shadow:none!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important;transform:none!important;-webkit-transform:none!important;}
  #mobileFloatingShell .mob-week-nav{margin-bottom:6px!important;}
  #mobileFloatingShell .mob-day-chips{padding:4px 0 6px!important;}
  #mobileFloatingShell .mob-day-header,#mobileFloatingShell .mob-day-total{margin-bottom:0!important;}
}
@media(min-width:881px){#mobileFloatingShell{display:none!important;}}


/* v17.1.0 — Ajustement barre flottante mobile : overlay masqué en haut de page + total masqué dans l’overlay */
@media(max-width:880px){
  #mobileFloatingShell{display:none;top:0!important;}
  #mobileFloatingShell .mob-day-total,
  #mobileFloatingShell .mob-day-header{display:none!important;}
  #mobileFloatingShell .mob-sticky-head{padding-bottom:0!important;}
  #mobileFloatingShell .mob-day-chips{padding-bottom:2px!important;}
}


/* v17.1.0 — desktop confort de saisie */
.desktop-view .plage-edit{display:flex;flex-direction:column;gap:3px;align-items:center;margin:2px 0 5px}
.desktop-view .alert-jump{all:unset;cursor:pointer;text-decoration:underline;text-underline-offset:2px}
.desktop-view .alert-jump:hover{color:#0f172a}
.desktop-view tr.row-highlight{outline:3px solid rgba(245,158,11,.45);outline-offset:-3px;animation:rowPulse165 1.8s ease-out}
@keyframes rowPulse165{0%,100%{background:transparent}20%,70%{background:#fff7ed}}
.desktop-view #planningTable .plage-input:focus{border-color:#2563eb!important;box-shadow:0 0 0 3px rgba(37,99,235,.14)!important;background:#fff!important}


/* v17.1.0 — scroll horizontal desktop rétabli pour les grands tableaux */
@media (min-width: 881px){
  .desktop-view .table-wrap{
    display:block!important;
    width:100%!important;
    max-width:100%!important;
    overflow-x:auto!important;
    overflow-y:visible!important;
    -webkit-overflow-scrolling:touch!important;
    overscroll-behavior-x:contain!important;
    scrollbar-gutter:stable both-edges;
  }
  .desktop-view .table-wrap .data-table{
    width:max-content!important;
    min-width:100%!important;
    table-layout:auto!important;
  }
  #planningTable.data-table th:first-child,
  #pointageTable.data-table th:first-child,
  #mensuelTable.data-table th:first-child,
  #congesSoldeTable.data-table th:first-child{
    position:sticky!important;
    left:0!important;
    z-index:12!important;
    box-shadow:1px 0 0 var(--border);
  }
  #planningTable.data-table tbody td:first-child,
  #pointageTable.data-table tbody td:first-child,
  #mensuelTable.data-table tbody td:first-child,
  #congesSoldeTable.data-table tbody td:first-child{
    left:0!important;
    z-index:9!important;
  }
  #planningTable.data-table tbody td:not(:first-child),
  #pointageTable.data-table tbody td:not(:first-child){
    min-width:142px!important;
  }
  #mensuelTable.data-table tbody td:not(:first-child),
  #congesSoldeTable.data-table tbody td:not(:first-child){
    min-width:116px!important;
  }
}


/* v17.1.0 — sauvegardes, journal, validation semaine */
.week-locked{background:#fee2e2!important;color:#991b1b!important;border-color:#fecaca!important}
.change-log-item{border-left:3px solid #dbeafe;padding-left:10px}
#localBackupList .template-item,#changeLogList .template-item{background:#fff;border:1px solid var(--border);border-radius:12px;padding:10px;margin-bottom:8px}


/* v17.1.0 — sélection/verrou cellule visible + heures moins grasses */
@media (min-width:881px){
  #planningTable .shift-cell{position:relative!important;}
  body.cell-select-mode #planningTable .shift-cell{cursor:pointer!important;}
  #planningTable .shift-cell.cell-selected{
    outline:3px solid #2563eb!important;
    outline-offset:-3px!important;
    background:rgba(37,99,235,.08)!important;
    box-shadow:inset 0 0 0 999px rgba(37,99,235,.035)!important;
  }
  #planningTable .shift-cell.cell-selected::after{
    content:'✓';
    position:absolute;top:6px;right:7px;
    width:20px;height:20px;border-radius:999px;
    display:flex;align-items:center;justify-content:center;
    background:#2563eb;color:#fff;font-size:12px;font-weight:900;
    box-shadow:0 2px 8px rgba(37,99,235,.35);
    z-index:6;pointer-events:none;
  }
  #planningTable .shift-cell.cell-locked{
    background-image:linear-gradient(135deg,rgba(15,23,42,.035),rgba(15,23,42,0))!important;
  }
  #planningTable .cell-lock-icon{
    position:absolute;top:6px;right:7px;z-index:7;
    width:21px;height:21px;border-radius:999px;
    display:flex;align-items:center;justify-content:center;
    background:#111827;color:#fff;font-size:11px;line-height:1;
    box-shadow:0 2px 8px rgba(15,23,42,.22);
    pointer-events:none;
  }
  #planningTable .shift-cell.cell-selected .cell-lock-icon{right:31px;}
  #planningTable .locked-cell-note{display:none!important;}
  #planningTable .plage-input,#semaineTable .plage-input{
    font-size:13.1px!important;font-weight:720!important;letter-spacing:0!important;
  }
  #pointageTable .pointage-input{
    font-size:13.1px!important;font-weight:720!important;letter-spacing:0!important;
  }
  #planningTable .plage-total,#pointageTable .plage-total{font-weight:700!important;}
}
@media(max-width:880px){
  #planningMobile .mob-input,#pointageMobile .mob-input{font-size:14px!important;font-weight:760!important;}
}

/* v17.1.0 — réglages : journal placé en carte large + heures plus fines */
#settings-log{grid-column:5 / span 8!important;grid-row:3!important;min-width:0!important;min-height:300px!important;max-height:300px!important;display:flex!important;flex-direction:column!important;}
#settings-log .template-list{flex:1 1 auto!important;min-height:0!important;overflow:auto!important;padding-right:4px!important;}
#settings-log .template-item{display:block!important;min-width:0!important;overflow-wrap:anywhere!important;}
@media(max-width:1250px){#settings-log{grid-column:1/-1!important;grid-row:auto!important;min-height:auto!important;max-height:none!important;display:block!important;}#settings-log .template-list{max-height:260px!important;}}
@media (min-width:881px){
  #planningTable .plage-input,#semaineTable .plage-input,#pointageTable .pointage-input{
    font-size:12.4px!important;
    font-weight:650!important;
    min-height:27px!important;
    padding:4px 6px!important;
  }
  #planningTable .plage-total,#pointageTable .plage-total{font-size:12.4px!important;font-weight:650!important;}
}



/* v17.1.0 — Accueil dashboard + thème graphite/ivoire sans marron lourd */
:root{
  --bg:#f6f7f4; --surface:#fffef9; --surface-alt:#f1f3f0;
  --border:#dfe3dc; --border-strong:#cbd3c8;
  --text:#161719; --text-muted:#50565f; --text-soft:#8a928b;
  --accent:#161719; --accent-text:#fff;
  --gold:#c8a667; --gold-bg:#f6efe1; --gold-border:#e3cf9f;
  --radius:8px; --radius-lg:14px; --radius-xl:20px;
  --shadow-sm:0 1px 2px rgba(21,24,28,.04);
  --shadow:0 8px 24px rgba(22,23,25,.07),0 1px 3px rgba(22,23,25,.04);
  --shadow-lg:0 18px 48px rgba(22,23,25,.13);
}
body{background:radial-gradient(circle at 14% 0%, rgba(200,166,103,.14), transparent 34%),linear-gradient(180deg,#fbfaf5 0%,#f6f7f4 42%,#f2f4f1 100%)!important;}
.topbar{top:12px!important;margin:14px 18px 10px!important;border:1px solid rgba(203,211,200,.72)!important;border-radius:24px!important;height:64px!important;padding:0 16px!important;background:rgba(255,254,249,.9)!important;backdrop-filter:blur(18px)!important;box-shadow:0 12px 28px rgba(18,20,24,.09)!important;}
.brand-name{font-size:17px!important;font-weight:800!important;letter-spacing:.02em!important;text-transform:uppercase!important;}.brand-sub{font-size:11px!important;letter-spacing:.13em!important;text-transform:uppercase!important;color:#747b72!important;}
.topnav{background:#eef1ec!important;border:1px solid var(--border)!important;border-radius:999px!important;padding:4px!important;flex:0 1 auto!important;}.topnav-btn{border-radius:999px!important;padding:9px 18px!important;color:#29303a!important;font-weight:700!important;}.topnav-btn.active{background:#161719!important;color:#fff!important;box-shadow:0 10px 18px rgba(22,23,25,.15)!important;}
.sync-indicator{border-radius:999px!important;background:#fff!important;border:1px solid var(--border)!important;box-shadow:var(--shadow-sm)!important;}main{padding:28px 22px 88px!important;max-width:100%!important;}
.toolbar,.alerts-panel,.card,.settings-section,.employees-list,.stats-grid .stat-card,.dashboard-card{background:rgba(255,254,249,.9)!important;border:1px solid rgba(203,211,200,.75)!important;border-radius:22px!important;box-shadow:var(--shadow)!important;}.toolbar{padding:12px 14px!important;gap:8px!important;margin-bottom:18px!important;}.period-label{font-family:Georgia,'Times New Roman',serif!important;font-size:20px!important;font-weight:800!important;letter-spacing:-.02em!important;}.btn,.btn-sm,.btn-today,.nav-arrow,.chip,.status-select{border-radius:999px!important;border-color:#d8ded5!important;}.btn-primary,.btn.active,.btn-warn.active{background:#161719!important;color:#fff!important;border-color:#161719!important;}.btn-warn{background:#fff!important;color:#9a5c00!important;border-color:#e4c783!important;}
.data-table thead th{background:#eef0ea!important;color:#585d58!important;letter-spacing:.14em!important;text-transform:uppercase!important;font-size:11px!important;}.data-table td,.data-table th{border-color:#dde2d9!important;}.plage-input,.pointage-input{font-weight:620!important;}.alerts-panel{border-color:#efc4b8!important;background:linear-gradient(180deg,#fffaf6,#fffef9)!important;}.chips-bar{margin-bottom:16px!important;}.chip{background:#fff!important;border:1px solid #dbe1d7!important;color:#4e555f!important;font-size:11px!important;}.chip.active{background:#161719!important;color:#fff!important;border-color:#161719!important;}
.home-shell{display:grid;gap:18px;max-width:1480px;margin:0 auto;}.home-hero{display:grid;grid-template-columns:1.4fr .9fr;gap:16px;align-items:stretch;}.home-panel{background:rgba(255,254,249,.94);border:1px solid rgba(203,211,200,.78);border-radius:26px;box-shadow:var(--shadow);padding:22px;}.home-title{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:8px;}.home-title h1{font-family:Georgia,'Times New Roman',serif;font-size:30px;line-height:1.05;margin:0;color:#17191c;letter-spacing:-.03em;}.home-title p{margin:6px 0 0;color:var(--text-muted);font-size:13px;}.home-pill{display:inline-flex;align-items:center;gap:7px;padding:8px 12px;border-radius:999px;background:#f4f6f2;border:1px solid var(--border);font-size:12px;font-weight:700;color:#333840;white-space:nowrap;}
.home-kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-top:16px;}.home-kpi{border:1px solid var(--border);border-radius:18px;background:linear-gradient(180deg,#fff,#f8f9f5);padding:14px;min-height:92px;}.home-kpi .ico{width:34px;height:34px;border-radius:12px;background:#161719;color:#fff;display:flex;align-items:center;justify-content:center;margin-bottom:10px;font-size:16px;}.home-kpi.warn .ico{background:#b45309}.home-kpi.good .ico{background:#15803d}.home-kpi.gold .ico{background:#c8a667;color:#171717}.home-kpi strong{display:block;font-size:24px;line-height:1.05;letter-spacing:-.03em;}.home-kpi span{display:block;color:var(--text-muted);font-size:11.5px;margin-top:5px;}
.home-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}.dashboard-card{padding:18px!important;min-height:190px;}.dashboard-card h2{margin:0 0 12px;font-size:16px;letter-spacing:-.01em;display:flex;align-items:center;gap:8px;}.todo-list,.home-list{display:flex;flex-direction:column;gap:9px;margin:0;padding:0;list-style:none;}.todo-item,.home-row{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid var(--border);background:#fff;border-radius:14px;padding:11px 12px;font-size:13px;}.todo-item small,.home-row small{display:block;color:var(--text-soft);font-size:11px;margin-top:2px;}.todo-badge{display:inline-flex;min-width:28px;height:28px;align-items:center;justify-content:center;border-radius:999px;background:#f6efe1;color:#8a5a12;font-weight:800;font-size:12px;}.quick-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;}.quick-btn{display:flex;align-items:center;gap:10px;border:1px solid var(--border);background:#fff;border-radius:16px;padding:14px;text-align:left;font-family:inherit;color:var(--text);cursor:pointer;font-weight:800;box-shadow:var(--shadow-sm);}.quick-btn:hover{border-color:#bfc7bc;transform:translateY(-1px)}.quick-btn .qico{width:32px;height:32px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:#161719;color:#fff;flex-shrink:0;}.decompte-row strong{font-size:13px}.delta-neg{color:#b91c1c}.delta-ok{color:#15803d}.delta-warn{color:#b45309}.home-footer-card{display:flex;align-items:center;justify-content:space-between;gap:14px;background:#161719!important;color:#fff!important;border-color:#161719!important;}.home-footer-card p{margin:4px 0 0;color:rgba(255,255,255,.72);font-size:12px;}.home-footer-card .btn{background:#fff!important;color:#161719!important;border-color:#fff!important;}
@media(max-width:1050px){.home-hero,.home-grid{grid-template-columns:1fr}.home-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:880px){main{padding:14px 12px calc(78px + var(--safe-bot))!important;}.topbar{margin:0!important;top:0!important;border-radius:0!important;height:calc(56px + var(--safe-top))!important;padding-top:var(--safe-top)!important;}.home-title h1{font-size:24px}.home-kpis{grid-template-columns:1fr 1fr}.quick-grid{grid-template-columns:1fr}.home-shell{gap:12px}.home-panel,.dashboard-card{border-radius:18px!important;padding:16px!important;}}


/* v17.1.0 — filtre employés clean : 1 ligne scrollable + sélection noire + pastille rouge seulement */
#empFilterBar.chips-bar{
  display:flex!important;align-items:center!important;gap:8px!important;
  flex-wrap:nowrap!important;overflow-x:auto!important;overflow-y:hidden!important;
  white-space:nowrap!important;padding:2px 2px 9px!important;
  scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
#empFilterBar.chips-bar::-webkit-scrollbar{display:none}
.filter-label{font-size:13px;color:#2f343b;margin-right:4px;font-weight:650;flex:0 0 auto}
.emp-chip{
  display:inline-flex;align-items:center;justify-content:center;gap:7px;flex:0 0 auto;scroll-snap-align:start;
  min-height:28px;padding:6px 13px;border-radius:999px;
  border:1px solid #dbe1d7;background:#fff;color:#4e555f;
  font-family:inherit;font-size:11px;font-weight:700;line-height:1;
  cursor:pointer;user-select:none;box-shadow:var(--shadow-sm);
  transition:background .15s ease,color .15s ease,border-color .15s ease,box-shadow .15s ease,transform .15s ease;
}
.emp-chip:hover{border-color:#bfc7bc;transform:translateY(-1px)}
.emp-chip.active{background:#161719!important;color:#fff!important;border-color:#161719!important;box-shadow:0 7px 16px rgba(22,23,25,.18)}
.emp-chip.chip-all.active::before,.smart-filter-chip.active::before{content:"✓";font-weight:900;font-size:10px}
.chip-alert-dot{width:7px;height:7px;border-radius:50%;background:#ef4444;flex:0 0 auto;box-shadow:0 0 0 2px rgba(239,68,68,.14)}
.emp-chip.active .chip-alert-dot{background:#fff;box-shadow:0 0 0 2px rgba(255,255,255,.22)}


/* v17.1.0 — tooltip anomalies hors flux : affichage sous le prénom, jamais coupé */
#empFilterBar{position:relative!important;z-index:80!important;}
#empFilterBar.chips-bar{overflow-x:auto!important;overflow-y:hidden!important;padding-top:2px!important;padding-bottom:9px!important;margin-top:0!important;}
.emp-chip.has-alert{position:relative!important;}
.emp-chip.has-alert::before,.emp-chip.has-alert::after{content:none!important;display:none!important;}
#empAnomalyTooltip{
  position:fixed;
  display:none;
  z-index:2147483000;
  white-space:pre-line;
  text-align:left;
  background:#f1f2f4;
  color:#34383f;
  border:1px solid #cfd4da;
  border-radius:10px;
  box-shadow:0 10px 26px rgba(20,24,30,.18);
  padding:9px 11px;
  font-size:12px;
  font-weight:500;
  line-height:1.35;
  pointer-events:none;
}
#empAnomalyTooltip.show{display:block;}
/* v17.1.0 — ajustements après test : pas d'accueil, header plus compact, repères sticky utiles */
@media(min-width:881px){
  .topbar{position:relative!important;top:auto!important;margin:10px 18px 6px!important;height:56px!important;min-height:56px!important;padding:0 14px!important;border-radius:20px!important;}
  main{padding:12px 22px 72px!important;max-width:100%!important;}
  .desktop-view>.toolbar{position:sticky!important;top:8px!important;z-index:45!important;padding:8px 12px!important;gap:7px!important;margin-bottom:14px!important;border-radius:18px!important;min-height:auto!important;}
  .toolbar-group{gap:5px!important}
  .nav-arrow{width:30px!important;height:30px!important;border-radius:11px!important;}
  .period-label{font-size:18px!important;min-width:260px!important;padding:0 4px!important;line-height:1.15!important;}
  .period-num{padding:4px 9px!important;font-size:11px!important;}
  #weekLockBadge:not(.week-locked){display:none!important;}
  #weekLockBadge.week-locked{display:inline-flex!important;background:#dcfce7!important;color:#166534!important;border-color:#86efac!important;}
  .btn,.btn-sm,.btn-today{padding:5px 10px!important;font-size:12px;min-height:28px!important;}
  .toolbar-sep{height:18px!important;margin:0 3px!important;}
  .chips-bar{margin-top:0!important;margin-bottom:12px!important;}
  .card .table-wrap{max-height:none!important;}
  .data-table thead th{top:64px!important;z-index:38!important;}
  .data-table thead th:first-child{z-index:41!important;}
}


/* v17.1.0 — correctif sticky desktop : barre semaine compacte + jours visibles sans trou graphique */
@media (min-width:881px){
  .desktop-view > .toolbar{
    position:sticky!important;top:6px!important;z-index:70!important;display:flex!important;flex-wrap:nowrap!important;align-items:center!important;overflow-x:auto!important;overflow-y:hidden!important;white-space:nowrap!important;padding:7px 10px!important;gap:6px!important;margin-bottom:10px!important;min-height:44px!important;max-height:54px!important;scrollbar-width:thin;
  }
  .desktop-view > .toolbar .toolbar-group{flex:0 0 auto!important;flex-wrap:nowrap!important;min-width:0!important;}
  .desktop-view > .toolbar .btn,.desktop-view > .toolbar .btn-sm,.desktop-view > .toolbar .btn-today{flex:0 0 auto!important;padding:4px 9px!important;font-size:11.5px!important;min-height:26px!important;line-height:1.1!important;}
  .desktop-view > .toolbar .nav-arrow{flex:0 0 auto!important;width:28px!important;height:28px!important;}
  .desktop-view > .toolbar .period-label{flex:0 0 auto!important;min-width:230px!important;max-width:420px!important;font-size:17px!important;line-height:1.05!important;}
  .desktop-view > .toolbar .period-num{flex:0 0 auto!important;padding:4px 8px!important;}
  .desktop-view .card{overflow:visible!important;}
  .desktop-view .card .table-wrap{overflow-x:auto!important;overflow-y:visible!important;border-radius:18px!important;background:rgba(255,254,249,.92)!important;}
  .desktop-view #planningTable thead,.desktop-view #pointageTable thead,.desktop-view #mensuelTable thead,.desktop-view #congesSoldeTable thead{position:sticky!important;top:66px!important;z-index:60!important;box-shadow:0 2px 0 rgba(214,220,210,.9),0 10px 20px rgba(22,23,25,.06)!important;}
  .desktop-view #planningTable thead th,.desktop-view #pointageTable thead th,.desktop-view #mensuelTable thead th,.desktop-view #congesSoldeTable thead th{position:static!important;z-index:auto!important;}
  .desktop-view #planningTable thead th:first-child,.desktop-view #pointageTable thead th:first-child,.desktop-view #mensuelTable thead th:first-child,.desktop-view #congesSoldeTable thead th:first-child{position:sticky!important;left:0!important;z-index:62!important;}
  .desktop-view .chips-bar{margin-bottom:10px!important;}
  .desktop-view .data-table{background:rgba(255,254,249,.92)!important;}
}

/* v17.1.0 — sticky jours fiable desktop : clone fixe, original non-sticky */
@media (min-width:881px){
  .desktop-view .data-table thead,
  .desktop-view #planningTable thead,
  .desktop-view #pointageTable thead,
  .desktop-view #mensuelTable thead,
  .desktop-view #congesSoldeTable thead{
    position:static!important;
    top:auto!important;
    z-index:auto!important;
    box-shadow:none!important;
  }
  .desktop-view .data-table thead th,
  .desktop-view #planningTable thead th,
  .desktop-view #pointageTable thead th,
  .desktop-view #mensuelTable thead th,
  .desktop-view #congesSoldeTable thead th{
    position:static!important;
    top:auto!important;
    left:auto!important;
    z-index:auto!important;
  }
  .desktop-weekday-sticky-clone{
    position:fixed;
    left:0;
    top:0;
    width:0;
    overflow:hidden;
    z-index:95;
    pointer-events:none;
    opacity:0;
    transform:translateY(-8px);
    transition:opacity .12s ease, transform .12s ease;
    border-radius:0 0 14px 14px;
    box-shadow:0 10px 22px rgba(22,23,25,.10);
    background:rgba(238,240,234,.98);
    backdrop-filter:blur(10px);
    -webkit-backdrop-filter:blur(10px);
  }
  .desktop-weekday-sticky-clone.is-visible{opacity:1;transform:translateY(0);}
  .desktop-weekday-sticky-clone table{border-collapse:separate;border-spacing:0;table-layout:auto;background:rgba(238,240,234,.98);}
  .desktop-weekday-sticky-clone th{
    background:#eef0ea!important;
    color:#585d58!important;
    letter-spacing:.14em!important;
    text-transform:uppercase!important;
    font-size:11px!important;
    font-weight:800!important;
    padding:10px 8px!important;
    text-align:center!important;
    border-right:1px solid #dde2d9!important;
    border-bottom:1px solid #d6dcd2!important;
    min-height:44px!important;
    white-space:nowrap!important;
  }
  .desktop-weekday-sticky-clone th small{display:block;font-weight:500;color:#858c84!important;text-transform:none!important;letter-spacing:0!important;font-size:10.5px!important;margin-top:1px!important;}
  .desktop-weekday-sticky-clone th:first-child{
    position:sticky!important;
    left:0!important;
    z-index:2!important;
    box-shadow:1px 0 0 #dde2d9!important;
  }
}


/* v17.1.0 — saisie planning : les messages d'anomalie ne redimensionnent plus les cellules */
#planningTable .shift-cell{position:relative!important;}
#planningTable .plages-cell{position:relative!important;padding-bottom:18px!important;}
#planningTable .planning-live-issue{
  position:absolute!important;
  left:0!important;
  bottom:0!important;
  max-width:calc(100% - 4px)!important;
  display:block!important;
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
  font-size:11px!important;
  line-height:1.1!important;
  color:#9f1239!important;
  pointer-events:none;
}


/* v17.1.0 — saisie Tab stable : éviter les sauts de scroll pendant le rerender */
#planningTableWrap, .planning-table-wrap, .table-wrap, #planningTable, #planningPanel{
  overflow-anchor:none!important;
}
#planningTable .plages-cell{min-height:96px!important;}
#planningTable .planning-live-issue{max-width:calc(100% - 10px)!important;}

/* v17.1.0 — panneau Anomalies stable : 3 lignes visibles sans saut de page */
.alerts-panel.visible{
  display:block!important;
  height:118px!important;
  min-height:118px!important;
  max-height:118px!important;
  box-sizing:border-box!important;
  overflow:hidden!important;
}
.alerts-panel > div:first-child{
  min-height:20px!important;
  flex-shrink:0!important;
}
.alerts-panel #alertsList{
  max-height:64px!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  scrollbar-width:thin!important;
  padding-right:6px!important;
}
.alerts-panel #alertsList li{
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
}
.alerts-panel .alert-jump{
  max-width:100%!important;
  display:inline-block!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
  white-space:nowrap!important;
  vertical-align:bottom!important;
}
@media (max-width: 820px){
  .alerts-panel.visible{height:auto!important;min-height:0!important;max-height:none!important;overflow:visible!important;}
  .alerts-panel #alertsList{max-height:none!important;overflow:visible!important;}
  .alerts-panel #alertsList li,.alerts-panel .alert-jump{white-space:normal!important;}
}

/* ---- Styles additionnels versionnes existants ---- */
/* Planning Cardinale v17.2.4 UI refresh.
   Presentation-only layer: it overrides the legacy inline stylesheet while
   keeping the existing DOM, IDs and data-app hooks intact. */

:root{
  --bg:#eef3f7;
  --surface:#ffffff;
  --surface-raised:#fbfdff;
  --surface-muted:#f5f8fb;
  --line:#d8e2ec;
  --line-strong:#b6c5d6;
  --text:#102033;
  --text-muted:#526476;
  --text-soft:#8494a6;
  --accent:#1f6feb;
  --accent-strong:#174ea6;
  --accent-soft:#e8f1ff;
  --ink:#182230;
  --ink-soft:#26364a;
  --success:#147a45;
  --success-bg:#e8f7ef;
  --warn:#a55f12;
  --warn-bg:#fff5df;
  --error:#b4232f;
  --error-bg:#fff0f1;
  --info:#0b699f;
  --info-bg:#e8f5fb;
  --violet:#6e42c1;
  --violet-bg:#f0ecfb;
  --radius:6px;
  --radius-lg:8px;
  --radius-xl:8px;
  --shadow-sm:0 1px 2px rgba(16,32,51,.05);
  --shadow:0 8px 22px rgba(16,32,51,.08);
  --shadow-lg:0 20px 60px rgba(16,32,51,.20);
  --topbar-h:64px;
  --safe-top:env(safe-area-inset-top,0px);
  --safe-bot:env(safe-area-inset-bottom,0px);
}

*,*::before,*::after{box-sizing:border-box}
html{background:var(--bg)!important}
html,body{min-width:0;overflow-x:hidden}
body{
  margin:0!important;
  background:linear-gradient(180deg,#f8fbfe 0%,var(--bg) 260px,var(--bg) 100%)!important;
  color:var(--text)!important;
  font-family:Inter,ui-sans-serif,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif!important;
  font-size:14px!important;
  line-height:1.45!important;
  letter-spacing:0!important;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

button,input,select,textarea{font:inherit;letter-spacing:0}
button{touch-action:manipulation}
button:disabled,input:disabled,select:disabled,textarea:disabled{cursor:not-allowed!important;opacity:.55!important}
button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,[role="button"]:focus-visible{
  outline:2px solid var(--accent)!important;
  outline-offset:2px!important;
}

.app{display:none;min-height:100dvh!important}
.app.active{display:block!important}
.panel{display:none!important}
.panel.active{display:block!important}
.desktop-view{display:block}
.mobile-view{display:none!important}

/* Login */
.login-screen{
  background:linear-gradient(180deg,#f8fbfe 0%,#eef3f7 100%)!important;
  padding:calc(40px + var(--safe-top)) 20px calc(40px + var(--safe-bot))!important;
}
.login-card{
  width:min(100%,390px)!important;
  max-width:390px!important;
  padding:28px!important;
  text-align:left!important;
  background:rgba(255,255,255,.94)!important;
  border:1px solid var(--line)!important;
  border-radius:var(--radius-lg)!important;
  box-shadow:var(--shadow-lg)!important;
}
.login-logo,.login-logo-placeholder{
  width:54px!important;
  height:54px!important;
  margin:0 0 22px!important;
  border-radius:var(--radius-lg)!important;
  background:var(--ink)!important;
  color:#fff!important;
  box-shadow:none!important;
}
.login-title{
  margin:0 0 6px!important;
  font-size:25px!important;
  line-height:1.08!important;
  font-weight:800!important;
  color:var(--text)!important;
  letter-spacing:0!important;
}
.login-subtitle{
  margin:0 0 22px!important;
  color:var(--text-muted)!important;
  font-size:13px!important;
}
.login-input,.login-btn{
  width:100%!important;
  min-height:46px!important;
  border-radius:var(--radius)!important;
  font-size:15px!important;
}
.login-input{
  padding:12px 13px!important;
  border:1px solid var(--line-strong)!important;
  background:#fff!important;
  color:var(--text)!important;
  margin-bottom:10px!important;
}
.login-input:focus{
  border-color:var(--accent)!important;
  box-shadow:0 0 0 3px rgba(31,111,235,.14)!important;
}
.login-btn{
  border:1px solid var(--accent)!important;
  background:var(--accent)!important;
  color:#fff!important;
  font-weight:750!important;
}
.login-btn:hover:not(:disabled){background:var(--accent-strong)!important}
.login-hint{margin-top:16px!important;color:var(--text-soft)!important;text-align:left!important}
.panic-btn{
  margin-top:18px!important;
  border-radius:var(--radius)!important;
  border-color:var(--line-strong)!important;
  color:var(--text-soft)!important;
}

/* Global shell */
.topbar{
  position:sticky!important;
  top:0!important;
  z-index:120!important;
  height:calc(var(--topbar-h) + var(--safe-top))!important;
  min-height:calc(var(--topbar-h) + var(--safe-top))!important;
  margin:0!important;
  padding:var(--safe-top) 18px 0!important;
  display:flex!important;
  align-items:center!important;
  gap:16px!important;
  border:0!important;
  border-bottom:1px solid rgba(216,226,236,.95)!important;
  border-radius:0!important;
  background:rgba(255,255,255,.96)!important;
  box-shadow:0 1px 0 rgba(16,32,51,.04)!important;
  backdrop-filter:blur(16px)!important;
  -webkit-backdrop-filter:blur(16px)!important;
}
.topbar-brand{
  flex:0 1 260px!important;
  min-width:180px!important;
  padding:0!important;
  gap:10px!important;
}
.brand-logo,#brandLogoImg{
  width:38px!important;
  height:38px!important;
  border-radius:var(--radius-lg)!important;
  flex:0 0 38px!important;
  background:var(--ink)!important;
  color:#fff!important;
  box-shadow:none!important;
}
.brand-logo-placeholder{
  font-size:12px!important;
  font-weight:850!important;
  letter-spacing:.03em!important;
}
.brand-name{
  font-size:15px!important;
  line-height:1.15!important;
  font-weight:800!important;
  color:var(--text)!important;
  text-transform:none!important;
  letter-spacing:0!important;
}
.brand-sub{
  margin-top:2px!important;
  font-size:11px!important;
  font-weight:650!important;
  color:var(--text-soft)!important;
  text-transform:none!important;
  letter-spacing:0!important;
}
.topnav{
  flex:1 1 auto!important;
  min-width:0!important;
  display:flex!important;
  justify-content:flex-start!important;
  gap:4px!important;
  padding:0!important;
  margin:0!important;
  overflow-x:auto!important;
  overflow-y:hidden!important;
  background:transparent!important;
  border:0!important;
  border-radius:0!important;
  box-shadow:none!important;
  scrollbar-width:none!important;
}
.topnav::-webkit-scrollbar{display:none}
.topnav-btn{
  flex:0 0 auto!important;
  min-height:36px!important;
  padding:8px 11px!important;
  border:1px solid transparent!important;
  border-radius:var(--radius)!important;
  background:transparent!important;
  color:var(--text-muted)!important;
  font-size:13px!important;
  font-weight:720!important;
  letter-spacing:0!important;
  box-shadow:none!important;
}
.topnav-btn:hover{
  background:var(--surface-muted)!important;
  border-color:var(--line)!important;
  color:var(--text)!important;
}
.topnav-btn.active{
  background:var(--ink)!important;
  border-color:var(--ink)!important;
  color:#fff!important;
  box-shadow:none!important;
}
.topbar-actions{
  flex:0 0 auto!important;
  margin-left:auto!important;
  gap:8px!important;
}
.icon-btn{
  width:36px!important;
  height:36px!important;
  border:1px solid var(--line)!important;
  border-radius:var(--radius)!important;
  background:#fff!important;
  color:var(--text-muted)!important;
}
.icon-btn:hover:not(:disabled){background:var(--accent-soft)!important;color:var(--accent)!important}
.sync-indicator{
  min-height:36px!important;
  padding:7px 10px!important;
  border:1px solid var(--line)!important;
  border-radius:var(--radius)!important;
  background:#fff!important;
  color:var(--text-muted)!important;
  font-size:12px!important;
  font-weight:700!important;
  box-shadow:none!important;
}
.sync-indicator:hover{border-color:var(--accent)!important;color:var(--accent)!important}
.sync-dot{width:7px!important;height:7px!important;background:var(--success)!important;box-shadow:none!important}
.sync-indicator.error{background:var(--error-bg)!important;color:var(--error)!important;border-color:#f3b4ba!important}
.sync-indicator.warn{background:var(--warn-bg)!important;color:var(--warn)!important;border-color:#f1cf8e!important}

main{
  width:100%!important;
  max-width:1760px!important;
  margin:0 auto!important;
  padding:18px 20px 44px!important;
}

/* Surfaces */
.card,.table-wrap,.settings-section,.stat-card,.dashboard-card,.alerts-panel,.emp-item,.mob-card,.mob-emp-card,.mob-mensuel-row,.template-item,.modal{
  border-radius:var(--radius-lg)!important;
}
.card{
  background:var(--surface)!important;
  border:1px solid var(--line)!important;
  box-shadow:var(--shadow-sm)!important;
  overflow:hidden!important;
}
.card-body{padding:16px!important}
.section-heading{
  font-size:18px!important;
  line-height:1.2!important;
  font-weight:800!important;
  margin:0!important;
  color:var(--text)!important;
}
.section-title{
  margin:0 0 8px!important;
  color:var(--text-soft)!important;
  font-size:11px!important;
  font-weight:800!important;
  letter-spacing:.05em!important;
  text-transform:uppercase!important;
}

/* Toolbars and actions */
.desktop-view>.toolbar,.toolbar{
  position:sticky!important;
  top:calc(var(--topbar-h) + var(--safe-top) + 10px)!important;
  z-index:80!important;
  display:flex!important;
  align-items:center!important;
  flex-wrap:nowrap!important;
  gap:7px!important;
  min-height:46px!important;
  max-height:none!important;
  margin:0 0 12px!important;
  padding:8px!important;
  overflow-x:auto!important;
  overflow-y:hidden!important;
  white-space:nowrap!important;
  background:rgba(255,255,255,.96)!important;
  border:1px solid var(--line)!important;
  border-radius:var(--radius-lg)!important;
  box-shadow:var(--shadow)!important;
  backdrop-filter:blur(14px)!important;
  -webkit-backdrop-filter:blur(14px)!important;
  scrollbar-width:thin!important;
}
.toolbar-group{display:flex!important;align-items:center!important;gap:5px!important;flex:0 0 auto!important}
.toolbar-sep{width:1px!important;height:24px!important;flex:0 0 1px!important;margin:0 3px!important;background:var(--line)!important}
.period-label{
  flex:0 0 auto!important;
  min-width:220px!important;
  max-width:440px!important;
  padding:0 6px!important;
  color:var(--text)!important;
  font-size:16px!important;
  line-height:1.15!important;
  font-weight:800!important;
  font-family:inherit!important;
  letter-spacing:0!important;
  text-align:center!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
}
.period-num{
  display:inline-flex!important;
  align-items:center!important;
  min-height:28px!important;
  padding:4px 9px!important;
  border:1px solid var(--line)!important;
  border-radius:var(--radius)!important;
  background:var(--surface-muted)!important;
  color:var(--text-muted)!important;
  font-size:11px!important;
  font-weight:800!important;
}
#weekLockBadge:not(.week-locked){display:none!important}
.week-locked{
  display:inline-flex!important;
  background:var(--success-bg)!important;
  color:var(--success)!important;
  border-color:#a8dec1!important;
}
.nav-arrow,.btn,.btn-sm,.btn-xs,.btn-today,.mob-action-btn,.mob-add,.add-plage-btn,.motif-trigger,.quick-btn{
  border-radius:var(--radius)!important;
  font-weight:750!important;
  letter-spacing:0!important;
  box-shadow:none!important;
  transform:none!important;
}
.nav-arrow{
  width:30px!important;
  height:30px!important;
  min-width:30px!important;
  border:1px solid var(--line)!important;
  background:#fff!important;
  color:var(--text-muted)!important;
}
.nav-arrow:hover{border-color:var(--accent)!important;color:var(--accent)!important;background:var(--accent-soft)!important}
.btn,.btn-sm,.btn-xs,.btn-today,.mob-action-btn{
  min-height:30px!important;
  padding:6px 10px!important;
  border:1px solid var(--line)!important;
  background:#fff!important;
  color:var(--text)!important;
  font-size:12px!important;
}
.btn:hover,.btn-sm:hover,.btn-xs:hover,.btn-today:hover,.mob-action-btn:hover{
  border-color:var(--accent)!important;
  color:var(--accent)!important;
  background:var(--accent-soft)!important;
}
.btn-primary,.btn.active{
  background:var(--accent)!important;
  border-color:var(--accent)!important;
  color:#fff!important;
}
.btn-primary:hover,.btn.active:hover{background:var(--accent-strong)!important;color:#fff!important}
.btn-danger{
  background:var(--error-bg)!important;
  border-color:#f2b6bd!important;
  color:var(--error)!important;
}
.btn-warn{
  background:var(--warn-bg)!important;
  border-color:#edcd8d!important;
  color:var(--warn)!important;
}

/* Alerts and employee filters */
.alerts-panel{
  height:auto!important;
  min-height:0!important;
  max-height:150px!important;
  margin:0 0 12px!important;
  padding:12px!important;
  overflow:hidden!important;
  background:var(--error-bg)!important;
  border:1px solid #f2b6bd!important;
  box-shadow:var(--shadow-sm)!important;
}
.alerts-panel.visible{display:block!important}
.alerts-panel #alertsList{
  max-height:92px!important;
  margin:8px 0 0!important;
  padding-right:6px!important;
  overflow:auto!important;
}
.alerts-panel li,.alerts-panel .alert-jump{
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
}
#empFilterBar.chips-bar,.chips-bar{
  display:flex!important;
  align-items:center!important;
  flex-wrap:nowrap!important;
  gap:7px!important;
  margin:0 0 10px!important;
  padding:1px 1px 8px!important;
  overflow-x:auto!important;
  overflow-y:hidden!important;
  scrollbar-width:none!important;
}
#empFilterBar.chips-bar::-webkit-scrollbar,.chips-bar::-webkit-scrollbar{display:none}
.filter-label,.chips-label{
  flex:0 0 auto!important;
  margin-right:2px!important;
  color:var(--text-muted)!important;
  font-size:12px!important;
  font-weight:800!important;
  text-transform:none!important;
  letter-spacing:0!important;
}
.chip,.emp-chip,.smart-filter-chip{
  flex:0 0 auto!important;
  min-height:30px!important;
  padding:7px 10px!important;
  border:1px solid var(--line)!important;
  border-radius:var(--radius)!important;
  background:#fff!important;
  color:var(--text-muted)!important;
  font-size:12px!important;
  font-weight:760!important;
  box-shadow:none!important;
}
.chip:hover,.emp-chip:hover,.smart-filter-chip:hover{border-color:var(--accent)!important;color:var(--accent)!important}
.chip.active,.emp-chip.active,.smart-filter-chip.active{
  background:var(--ink)!important;
  border-color:var(--ink)!important;
  color:#fff!important;
}
.emp-chip.chip-all.active::before,.smart-filter-chip.active::before{content:none!important}
.chip-alert-dot{width:7px!important;height:7px!important;background:var(--error)!important;box-shadow:none!important}
#empAnomalyTooltip{
  border-radius:var(--radius)!important;
  border:1px solid var(--line-strong)!important;
  background:#fff!important;
  color:var(--text)!important;
  box-shadow:var(--shadow-lg)!important;
}

/* Tables */
.desktop-view .card{overflow:visible!important}
.desktop-view .table-wrap{
  width:100%!important;
  max-width:100%!important;
  display:block!important;
  overflow-x:auto!important;
  overflow-y:visible!important;
  overscroll-behavior-x:contain!important;
  border:1px solid var(--line)!important;
  background:#fff!important;
  scrollbar-gutter:stable both-edges!important;
}
.desktop-view .card .table-wrap{border-radius:var(--radius-lg)!important}
.data-table{
  width:max-content!important;
  min-width:100%!important;
  border-collapse:separate!important;
  border-spacing:0!important;
  table-layout:auto!important;
  background:#fff!important;
  color:var(--text)!important;
  font-size:13px!important;
}
.data-table thead,.desktop-view .data-table thead{
  position:static!important;
  top:auto!important;
  box-shadow:none!important;
}
.data-table th,.data-table td{
  padding:9px 8px!important;
  border-right:1px solid var(--line)!important;
  border-bottom:1px solid var(--line)!important;
  background:#fff!important;
  line-height:1.35!important;
  vertical-align:top!important;
}
.data-table thead th,.desktop-view .data-table thead th{
  position:static!important;
  top:auto!important;
  left:auto!important;
  z-index:auto!important;
  min-height:42px!important;
  background:#f1f5f9!important;
  color:var(--text-muted)!important;
  font-size:11px!important;
  font-weight:850!important;
  text-align:center!important;
  text-transform:uppercase!important;
  letter-spacing:.06em!important;
}
.data-table thead th small{display:block!important;margin-top:2px!important;color:var(--text-soft)!important;font-size:10px!important;font-weight:650!important;text-transform:none!important;letter-spacing:0!important}
.data-table tbody tr:nth-child(even) td{background:var(--surface-raised)!important}
.data-table tbody tr:hover td{background:#f8fbff!important}
.data-table tbody td:not(:first-child),#planningTable.data-table tbody td:not(:first-child),#pointageTable.data-table tbody td:not(:first-child){
  min-width:138px!important;
}
#mensuelTable.data-table tbody td:not(:first-child),#congesSoldeTable.data-table tbody td:not(:first-child){min-width:112px!important}
.data-table th:first-child,.data-table tbody td:first-child{
  position:sticky!important;
  left:0!important;
  z-index:12!important;
  min-width:150px!important;
  max-width:220px!important;
  background:#fff!important;
  box-shadow:1px 0 0 var(--line)!important;
}
.data-table tbody tr:nth-child(even) td:first-child{background:var(--surface-raised)!important}
.data-table .totals-row td,.data-table tr[style*="background:var(--surface-alt)"] td{
  background:#edf4fb!important;
  font-weight:800!important;
}
.data-table .comment-row td{background:#fffdf5!important}
.day-th.today-th,.data-table th.today-th{background:#fff5df!important;color:var(--warn)!important}
.data-table th.ferie-th{background:var(--violet-bg)!important;color:var(--violet)!important}
.data-table td.ferie-cell{background:#fbf9ff!important}
.cell-repos,.data-table .cell-repos{background:var(--info-bg)!important}
.cell-conges,.data-table .cell-conges{background:var(--success-bg)!important}
.cell-maladie,.data-table .cell-maladie{background:var(--warn-bg)!important}
.cell-formation,.data-table .cell-formation{background:var(--violet-bg)!important}
.cell-motif,.data-table .cell-motif{background:var(--error-bg)!important}
.cell-conflict{box-shadow:inset 0 0 0 2px var(--error)!important}

.desktop-weekday-sticky-clone{
  z-index:110!important;
  border:1px solid var(--line)!important;
  border-radius:0 0 var(--radius-lg) var(--radius-lg)!important;
  background:#f1f5f9!important;
  box-shadow:0 12px 24px rgba(16,32,51,.12)!important;
}
.desktop-weekday-sticky-clone table{background:#f1f5f9!important}
.desktop-weekday-sticky-clone th{
  background:#f1f5f9!important;
  color:var(--text-muted)!important;
  border-color:var(--line)!important;
  padding:9px 8px!important;
  font-size:11px!important;
  letter-spacing:.06em!important;
}
.desktop-weekday-sticky-clone th small{color:var(--text-soft)!important}

/* Time editing */
.plage-edit{display:flex!important;flex-direction:column!important;align-items:center!important;gap:4px!important;margin:2px 0 5px!important}
.plage-row{display:flex!important;align-items:center!important;justify-content:center!important;gap:4px!important;margin:2px 0!important}
.plage-input,.pointage-input,.mob-input{
  border:1px solid var(--line-strong)!important;
  border-radius:var(--radius)!important;
  background:#fff!important;
  color:var(--text)!important;
  font-weight:680!important;
  letter-spacing:0!important;
  text-align:center!important;
  box-shadow:none!important;
}
.plage-input,.pointage-input{
  width:62px!important;
  min-height:29px!important;
  padding:5px 6px!important;
  font-size:12.8px!important;
}
.plage-input:focus,.pointage-input:focus,.mob-input:focus,.form-input:focus,.search-box:focus,.status-select:focus,textarea:focus,input:focus,select:focus{
  border-color:var(--accent)!important;
  box-shadow:0 0 0 3px rgba(31,111,235,.13)!important;
  outline:none!important;
}
.plage-input.invalid,.plage-input.plage-invalid{border-color:var(--error)!important;background:var(--error-bg)!important}
.plage-sep{color:var(--text-soft)!important;font-size:12px!important;font-weight:800!important}
.plage-remove{
  padding:3px 6px!important;
  border:0!important;
  background:transparent!important;
  color:var(--error)!important;
  font-weight:850!important;
}
.add-plage-btn,.mob-add{
  min-height:26px!important;
  padding:4px 8px!important;
  border:1px dashed var(--line-strong)!important;
  background:#fff!important;
  color:var(--text-muted)!important;
  font-size:11px!important;
}
.add-plage-btn:hover,.mob-add:hover{border-color:var(--accent)!important;color:var(--accent)!important;background:var(--accent-soft)!important}
.plage-total{color:var(--text-muted)!important;font-size:12px!important;font-weight:750!important}
#planningTable .plages-cell{min-height:94px!important;padding-bottom:18px!important}
#planningTable .planning-live-issue{
  color:var(--error)!important;
  font-size:10.5px!important;
  font-weight:650!important;
}
.motif-bar{margin-top:5px!important}
.motif-trigger{
  min-height:24px!important;
  padding:4px 8px!important;
  border:1px dashed var(--line-strong)!important;
  background:#fff!important;
  color:var(--text-muted)!important;
  font-size:11px!important;
}
.motif-trigger.motif-repos{background:var(--info-bg)!important;color:var(--info)!important;border-color:#b3d8ea!important}
.motif-trigger.motif-conges{background:var(--success-bg)!important;color:var(--success)!important;border-color:#a8dec1!important}
.motif-trigger.motif-formation{background:var(--violet-bg)!important;color:var(--violet)!important;border-color:#cabbea!important}
.motif-trigger.motif-maladie{background:var(--warn-bg)!important;color:var(--warn)!important;border-color:#edcd8d!important}
.motif-trigger.motif-autre{background:var(--error-bg)!important;color:var(--error)!important;border-color:#f2b6bd!important}
.motif-dropdown{
  border:1px solid var(--line)!important;
  border-radius:var(--radius)!important;
  box-shadow:var(--shadow-lg)!important;
  overflow:hidden!important;
}
.motif-option{font-size:12px!important;padding:8px 10px!important}
.motif-option:hover{background:var(--surface-muted)!important}
.motif-option.opt-active,.motif-option.active{background:var(--ink)!important;color:#fff!important}
.comment-input{
  border:1px solid var(--line)!important;
  border-radius:var(--radius)!important;
  background:#fff!important;
  font-size:12px!important;
}

/* State chips and badges */
.status-select{
  min-height:30px!important;
  width:100%!important;
  max-width:132px!important;
  padding:5px 7px!important;
  border:1px solid var(--line-strong)!important;
  border-radius:var(--radius)!important;
  background:#fff!important;
  color:var(--text)!important;
  font-size:12px!important;
  font-weight:750!important;
}
.status-select.status-present,.status-select.status-entreprise{background:var(--success-bg)!important;color:var(--success)!important;border-color:#a8dec1!important}
.status-select.status-repos{background:var(--info-bg)!important;color:var(--info)!important;border-color:#b3d8ea!important}
.status-select.status-absent,.status-select.status-autre{background:var(--error-bg)!important;color:var(--error)!important;border-color:#f2b6bd!important}
.status-select.status-cp{background:var(--success-bg)!important;color:var(--success)!important;border-color:#a8dec1!important}
.status-select.status-maladie{background:var(--warn-bg)!important;color:var(--warn)!important;border-color:#edcd8d!important}
.status-select.status-formation{background:var(--violet-bg)!important;color:var(--violet)!important;border-color:#cabbea!important}
.diff-pos{color:var(--success)!important;font-weight:800!important}
.diff-neg{color:var(--error)!important;font-weight:800!important}
.diff-zero{color:var(--text-muted)!important;font-weight:750!important}
.emp-avatar{
  border-radius:50%!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  font-weight:800!important;
  box-shadow:none!important;
}
.emp-name{font-weight:800!important;color:var(--text)!important}
.emp-role,.emp-meta{color:var(--text-soft)!important;font-weight:650!important}
.emp-badge{
  display:inline-flex!important;
  align-items:center!important;
  min-height:18px!important;
  padding:2px 6px!important;
  border-radius:var(--radius)!important;
  background:var(--violet-bg)!important;
  color:var(--violet)!important;
  font-size:10px!important;
  font-weight:800!important;
}

/* Employee list and forms */
.emp-list{display:flex!important;flex-direction:column!important;gap:8px!important}
.emp-item{
  display:grid!important;
  grid-template-columns:auto minmax(110px,1fr) minmax(120px,1fr) minmax(140px,1.2fr) auto auto auto auto!important;
  align-items:center!important;
  gap:9px!important;
  padding:12px!important;
  border:1px solid var(--line)!important;
  background:#fff!important;
  box-shadow:var(--shadow-sm)!important;
}
.drag-handle,.row-drag-handle{color:var(--text-soft)!important;cursor:grab!important}
.emp-item input[type="text"],.emp-item input[type="number"],.search-box,.form-input,.motif-libre{
  min-height:36px!important;
  padding:8px 10px!important;
  border:1px solid var(--line-strong)!important;
  border-radius:var(--radius)!important;
  background:#fff!important;
  color:var(--text)!important;
  font-size:13px!important;
  box-shadow:none!important;
}
.emp-item label,.form-group label{
  color:var(--text-muted)!important;
  font-size:12px!important;
  font-weight:750!important;
}
.search-box{min-width:220px!important}
.empty,.empty-state{
  padding:34px 18px!important;
  text-align:center!important;
  color:var(--text-soft)!important;
  background:#fff!important;
}
.empty-icon,.empty-state .icon{opacity:.75!important}

/* Stats */
.stats-grid{
  display:grid!important;
  grid-template-columns:repeat(auto-fit,minmax(170px,1fr))!important;
  gap:10px!important;
  margin-top:14px!important;
}
.stat-card{
  padding:14px!important;
  background:#fff!important;
  border:1px solid var(--line)!important;
  box-shadow:var(--shadow-sm)!important;
}
.stat-value{font-size:24px!important;font-weight:850!important;color:var(--text)!important;letter-spacing:0!important}
.stat-label{font-size:12px!important;font-weight:650!important;color:var(--text-muted)!important}

/* Settings */
#tab-reglages{
  padding:0!important;
}
#tab-reglages>.card.card-body{
  display:grid!important;
  grid-template-columns:repeat(12,minmax(0,1fr))!important;
  gap:12px!important;
  padding:0!important;
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  overflow:visible!important;
}
#tab-reglages .settings-section{
  margin:0!important;
  padding:16px!important;
  background:#fff!important;
  border:1px solid var(--line)!important;
  box-shadow:var(--shadow-sm)!important;
  overflow:hidden!important;
  min-width:0!important;
}
#tab-reglages .settings-section h3{
  margin:0 0 12px!important;
  display:flex!important;
  align-items:center!important;
  gap:7px!important;
  color:var(--text)!important;
  font-size:15px!important;
  line-height:1.2!important;
  font-weight:850!important;
  letter-spacing:0!important;
}
#tab-reglages .settings-section h3::before{display:none!important}
#settings-identite{grid-column:1 / span 4!important;grid-row:1!important}
#settings-top-side{grid-column:5 / span 8!important;grid-row:1!important;display:grid!important;gap:12px!important}
#settings-top-side .settings-top-row{display:grid!important;grid-template-columns:1fr 1fr!important;gap:12px!important}
#settings-sante{grid-column:1 / span 5!important;grid-row:2!important;display:flex!important;flex-direction:column!important;max-height:none!important}
#settings-restore{grid-column:6 / span 7!important;grid-row:2!important;display:flex!important;flex-direction:column!important;max-height:none!important}
#settings-data{grid-column:1 / span 5!important;grid-row:3!important}
#settings-log{grid-column:6 / span 7!important;grid-row:3!important;display:flex!important;flex-direction:column!important;min-height:300px!important;max-height:300px!important}
#settings-about{grid-column:1 / span 12!important;grid-row:4!important}
#settings-modeles{display:none!important}
#tab-reglages .diag-grid{
  display:grid!important;
  grid-template-columns:repeat(auto-fit,minmax(145px,1fr))!important;
  gap:8px!important;
}
.diag-card{
  min-height:58px!important;
  padding:10px!important;
  background:var(--surface-muted)!important;
  border:1px solid var(--line)!important;
  border-radius:var(--radius)!important;
}
.diag-card span{display:block!important;margin-bottom:4px!important;color:var(--text-soft)!important;font-size:11px!important;line-height:1.2!important}
.diag-card strong{display:block!important;color:var(--text)!important;font-size:13px!important;line-height:1.2!important;overflow-wrap:anywhere!important}
.logo-upload{
  width:112px!important;
  height:74px!important;
  border:1px dashed var(--line-strong)!important;
  border-radius:var(--radius)!important;
  background:var(--surface-muted)!important;
}
.template-list{display:flex!important;flex-direction:column!important;gap:8px!important}
#settings-log .template-list,#settings-restore .template-list{
  flex:1 1 auto!important;
  min-height:0!important;
  overflow:auto!important;
}
.template-item{
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:10px!important;
  padding:11px!important;
  background:var(--surface-raised)!important;
  border:1px solid var(--line)!important;
}

/* Modals and toast */
.modal-overlay{
  background:rgba(16,32,51,.48)!important;
  backdrop-filter:blur(4px)!important;
  -webkit-backdrop-filter:blur(4px)!important;
}
.modal{
  max-width:520px!important;
  padding:20px!important;
  background:#fff!important;
  border:1px solid var(--line)!important;
  box-shadow:var(--shadow-lg)!important;
}
.modal h2{margin:0 0 14px!important;color:var(--text)!important;font-size:18px!important;font-weight:850!important}
.modal-actions{display:flex!important;justify-content:flex-end!important;gap:8px!important;margin-top:16px!important}
.info-box{
  background:var(--surface-muted)!important;
  border:1px solid var(--line)!important;
  color:var(--text-muted)!important;
  border-radius:var(--radius)!important;
}
#toast{
  right:18px!important;
  bottom:calc(22px + var(--safe-bot))!important;
  max-width:340px!important;
  padding:12px 14px!important;
  border:1px solid rgba(255,255,255,.65)!important;
  border-radius:var(--radius-lg)!important;
  box-shadow:var(--shadow-lg)!important;
  font-weight:750!important;
}

/* Mobile cards */
.mob-week-nav{
  display:flex!important;
  align-items:center!important;
  gap:8px!important;
  margin:0 0 8px!important;
  padding:8px!important;
  border:1px solid var(--line)!important;
  border-radius:var(--radius-lg)!important;
  background:var(--ink)!important;
  color:#fff!important;
  box-shadow:none!important;
}
.mob-nav-arrow{
  width:34px!important;
  height:34px!important;
  min-width:34px!important;
  border:1px solid rgba(255,255,255,.18)!important;
  border-radius:var(--radius)!important;
  background:rgba(255,255,255,.10)!important;
  color:#fff!important;
}
.mob-week-label{font-size:13px!important;font-weight:800!important;line-height:1.2!important;text-align:center!important}
.mob-day-chips{
  display:flex!important;
  gap:7px!important;
  overflow-x:auto!important;
  padding:2px 0 9px!important;
  scrollbar-width:none!important;
}
.mob-day-chips::-webkit-scrollbar{display:none}
.mob-day-chip{
  flex:0 0 auto!important;
  min-width:58px!important;
  min-height:36px!important;
  padding:8px 10px!important;
  border:1px solid var(--line)!important;
  border-radius:var(--radius)!important;
  background:#fff!important;
  color:var(--text-muted)!important;
  font-size:12px!important;
  font-weight:800!important;
}
.mob-day-chip.active{background:var(--accent)!important;border-color:var(--accent)!important;color:#fff!important}
.mob-day-chip.today{border-color:var(--warn)!important}
.mob-day-header,.mob-day-total{
  margin:0 0 10px!important;
  padding:10px 12px!important;
  border:1px solid var(--line)!important;
  border-radius:var(--radius-lg)!important;
  background:#fff!important;
  color:var(--text)!important;
}
.mob-actions-bar{
  display:flex!important;
  gap:7px!important;
  margin:0 0 10px!important;
  padding:0 0 4px!important;
  overflow-x:auto!important;
  scrollbar-width:none!important;
}
.mob-actions-bar::-webkit-scrollbar{display:none}
.mob-card,.mob-emp-card,.mob-mensuel-row{
  margin:0 0 10px!important;
  padding:0!important;
  overflow:hidden!important;
  background:#fff!important;
  border:1px solid var(--line)!important;
  box-shadow:var(--shadow-sm)!important;
}
.mob-card-strong-header,.mob-emp-header{
  padding:12px!important;
  border-bottom:1px solid var(--line)!important;
  background:var(--surface-muted)!important;
}
.mob-card-body{padding:12px!important}
.mob-card-emp-name,.mob-emp-name{font-size:15px!important;font-weight:850!important;color:var(--text)!important}
.mob-card-emp-status{font-size:12px!important;color:var(--text-muted)!important}
.mob-input{
  min-height:38px!important;
  padding:8px 10px!important;
  font-size:15px!important;
}
.mob-motif-row{display:flex!important;gap:7px!important;flex-wrap:wrap!important;margin-top:10px!important}
.mob-motif-btn{
  min-height:30px!important;
  padding:6px 9px!important;
  border:1px solid var(--line)!important;
  border-radius:var(--radius)!important;
  background:#fff!important;
  color:var(--text-muted)!important;
  font-size:12px!important;
  font-weight:760!important;
}
.mob-stat-row{
  display:grid!important;
  grid-template-columns:minmax(0,1fr) auto!important;
  gap:8px!important;
  padding:8px 0!important;
  border-bottom:1px solid var(--line)!important;
}
.mob-stat-row:last-child{border-bottom:0!important}

/* Mobile navigation */
.tabbar{display:none!important}
#mobileFloatingShell{display:none}

@media(max-width:1080px){
  .topbar{gap:10px!important;padding-left:12px!important;padding-right:12px!important}
  .topbar-brand{flex-basis:210px!important;min-width:150px!important}
  .topnav-btn{padding:8px 9px!important}
  .period-label{min-width:190px!important}
  .emp-item{grid-template-columns:auto 1fr 1fr!important}
  .emp-item label,.emp-item .btn{justify-self:start!important}
}

@media(max-width:880px){
  :root{--topbar-h:56px}
  body{background:#f3f7fb!important}
  .desktop-view{display:none!important}
  .mobile-view{display:block!important}
  .topbar{
    position:sticky!important;
    height:calc(var(--topbar-h) + var(--safe-top))!important;
    min-height:calc(var(--topbar-h) + var(--safe-top))!important;
    padding:var(--safe-top) 10px 0!important;
    gap:8px!important;
  }
  .topbar-brand{flex:1 1 auto!important;min-width:0!important}
  .brand-logo,#brandLogoImg{width:34px!important;height:34px!important;flex-basis:34px!important}
  .brand-name{font-size:14px!important}
  .brand-sub{display:none!important}
  .topnav{display:none!important}
  .topbar-actions{gap:6px!important}
  .sync-indicator{max-width:116px!important;min-height:34px!important;padding:6px 8px!important}
  #syncLabel{overflow:hidden!important;text-overflow:ellipsis!important;white-space:nowrap!important}
  .icon-btn{width:34px!important;height:34px!important}
  main{
    max-width:none!important;
    padding:10px 10px calc(84px + var(--safe-bot))!important;
  }
  #app>.tabbar{
    display:flex!important;
    position:fixed!important;
    left:10px!important;
    right:10px!important;
    bottom:calc(8px + var(--safe-bot))!important;
    top:auto!important;
    z-index:150!important;
    width:auto!important;
    height:58px!important;
    min-height:58px!important;
    max-height:58px!important;
    margin:0!important;
    padding:5px!important;
    gap:4px!important;
    align-items:stretch!important;
    justify-content:space-between!important;
    overflow:hidden!important;
    border:1px solid var(--line)!important;
    border-radius:var(--radius-lg)!important;
    background:rgba(255,255,255,.96)!important;
    box-shadow:0 14px 34px rgba(16,32,51,.18)!important;
    backdrop-filter:blur(16px)!important;
    -webkit-backdrop-filter:blur(16px)!important;
  }
  #app>.tabbar .tabbar-btn{
    flex:1 1 0!important;
    min-width:0!important;
    height:auto!important;
    padding:5px 2px!important;
    display:flex!important;
    flex-direction:column!important;
    align-items:center!important;
    justify-content:center!important;
    gap:2px!important;
    border:1px solid transparent!important;
    border-radius:var(--radius)!important;
    background:transparent!important;
    color:var(--text-muted)!important;
    font-size:9.5px!important;
    line-height:1.05!important;
    font-weight:800!important;
    white-space:nowrap!important;
  }
  #app>.tabbar .tabbar-btn svg{
    width:19px!important;
    height:19px!important;
    margin:0!important;
    display:block!important;
  }
  #app>.tabbar .tabbar-btn.active{
    background:var(--ink)!important;
    border-color:var(--ink)!important;
    color:#fff!important;
    box-shadow:none!important;
  }
  #mobileFloatingShell{
    left:0!important;
    right:0!important;
    top:0!important;
    z-index:145!important;
    pointer-events:none!important;
  }
  #mobileFloatingShell .mf-inner{
    pointer-events:auto!important;
    padding:8px 10px 10px!important;
    background:linear-gradient(180deg,rgba(243,247,251,.98) 0%,rgba(243,247,251,.92) 80%,rgba(243,247,251,0) 100%)!important;
  }
  #mobileFloatingShell .tabbar{display:none!important}
  #mobileFloatingShell .mob-sticky-head{
    display:block!important;
    position:static!important;
    margin:0!important;
    padding:0!important;
    background:transparent!important;
  }
  #mobileFloatingShell .mob-day-header,#mobileFloatingShell .mob-day-total{display:none!important}
  .mobile-view .mob-sticky-head{
    position:relative!important;
    top:auto!important;
    left:auto!important;
    right:auto!important;
    margin:0 0 10px!important;
    padding:0!important;
    background:transparent!important;
  }
  #planningMobile,#pointageMobile,#mensuelMobile,#congesMobile{padding-top:0!important}
  .mob-week-nav{position:relative!important}
  .mob-card-strong-header,.mob-emp-header{gap:9px!important}
  .mob-plage-row{display:flex!important;gap:6px!important;align-items:center!important;margin-bottom:7px!important}
  .stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important}
  #tab-employes>div:first-child{display:grid!important;grid-template-columns:1fr!important;align-items:stretch!important}
  .search-box{width:100%!important;min-width:0!important}
  .emp-item{
    grid-template-columns:1fr!important;
    align-items:stretch!important;
  }
  .emp-item input[type="text"],.emp-item input[type="number"]{max-width:none!important;width:100%!important}
  #tab-reglages>.card.card-body{grid-template-columns:1fr!important}
  #settings-identite,#settings-top-side,#settings-sante,#settings-restore,#settings-data,#settings-log,#settings-about{
    grid-column:1/-1!important;
    grid-row:auto!important;
    min-height:auto!important;
    max-height:none!important;
  }
  #settings-top-side .settings-top-row{grid-template-columns:1fr!important}
  #settings-log{display:block!important}
  #settings-log .template-list,#settings-restore .template-list{max-height:none!important}
  .modal{max-width:calc(100vw - 24px)!important;padding:16px!important}
  #toast{
    left:10px!important;
    right:10px!important;
    bottom:calc(76px + var(--safe-bot))!important;
    max-width:none!important;
  }
}

@media(max-width:420px){
  #app>.tabbar .tabbar-btn{font-size:8.5px!important}
  #app>.tabbar .tabbar-btn svg{width:18px!important;height:18px!important}
  .sync-indicator{max-width:96px!important}
  .stats-grid{grid-template-columns:1fr!important}
}

@media(print){
  body{background:#fff!important}
  .topbar,.tabbar,.toolbar,.chips-bar,.alerts-panel,.motif-bar,.add-plage-btn,#toast,#mobileFloatingShell{display:none!important}
  .desktop-view{display:block!important}
  .mobile-view{display:none!important}
  main{padding:0!important;max-width:none!important}
  .card,.table-wrap{box-shadow:none!important;border-color:#bbb!important}
}

/* v17.2.1 - densite bureau et alignement planning avec les autres onglets */
@media(min-width:881px){
  :root{--topbar-h:56px}
  body{font-size:13px!important}
  .topbar{
    height:calc(var(--topbar-h) + var(--safe-top))!important;
    min-height:calc(var(--topbar-h) + var(--safe-top))!important;
    padding-left:14px!important;
    padding-right:14px!important;
    gap:12px!important;
  }
  .topbar-brand{flex-basis:230px!important;min-width:170px!important}
  .brand-logo,#brandLogoImg{width:34px!important;height:34px!important;flex-basis:34px!important}
  .brand-name{font-size:14px!important}
  .brand-sub{font-size:10.5px!important}
  .topnav{gap:3px!important}
  .topnav-btn{
    min-height:32px!important;
    padding:6px 10px!important;
    font-size:12.5px!important;
  }
  .icon-btn,.sync-indicator{height:32px!important;min-height:32px!important}
  .icon-btn{width:32px!important}
  .sync-indicator{padding:5px 9px!important;font-size:11.5px!important}
  main{padding:12px 16px 34px!important;max-width:1840px!important}

  .desktop-view>.toolbar,.toolbar{
    top:calc(var(--topbar-h) + var(--safe-top) + 6px)!important;
    min-height:38px!important;
    padding:6px!important;
    gap:5px!important;
    margin-bottom:8px!important;
    border-radius:var(--radius)!important;
  }
  .toolbar-group{gap:4px!important}
  .toolbar-sep{height:20px!important;margin:0 2px!important}
  .period-label{
    min-width:200px!important;
    max-width:390px!important;
    font-size:15px!important;
    line-height:1.1!important;
  }
  .period-num{
    min-height:26px!important;
    padding:3px 8px!important;
    font-size:10.8px!important;
  }
  .nav-arrow{
    width:28px!important;
    height:28px!important;
    min-width:28px!important;
  }
  .btn,.btn-sm,.btn-xs,.btn-today,.mob-action-btn{
    min-height:28px!important;
    padding:4px 8px!important;
    font-size:11.5px!important;
  }

  #empFilterBar.chips-bar,.chips-bar{
    gap:6px!important;
    margin-bottom:7px!important;
    padding-bottom:6px!important;
  }
  .filter-label,.chips-label{font-size:11.5px!important}
  .chip,.emp-chip,.smart-filter-chip{
    min-height:26px!important;
    padding:5px 9px!important;
    font-size:11.5px!important;
  }
  .pointage-select-label,
  .pointage-select,
  .pointage-toolbar-filter-sep{
    display:none!important;
  }
  #pointageEmpFilterBar{
    margin-top:-2px!important;
  }
  #pointageEmpFilterBar .chip-alert-dot{
    margin-left:2px!important;
  }

  .desktop-view .card .table-wrap{border-radius:var(--radius)!important}
  .data-table{font-size:12.3px!important}
  .data-table th,.data-table td{
    padding:7px 7px!important;
    line-height:1.25!important;
  }
  .data-table thead th,.desktop-view .data-table thead th{
    min-height:36px!important;
    padding:7px 6px!important;
    font-size:10.5px!important;
    letter-spacing:.05em!important;
  }
  .data-table thead th small{font-size:9.8px!important}
  .data-table th:first-child,.data-table tbody td:first-child{
    min-width:132px!important;
    max-width:190px!important;
  }
  .data-table tbody td:not(:first-child),
  #planningTable.data-table tbody td:not(:first-child),
  #pointageTable.data-table tbody td:not(:first-child){
    min-width:126px!important;
  }
  #mensuelTable.data-table tbody td:not(:first-child),
  #congesSoldeTable.data-table tbody td:not(:first-child){
    min-width:104px!important;
  }

  #planningTable.data-table{font-size:12.15px!important}
  #planningTable .shift-cell{
    background:#fff!important;
  }
  #planningTable .shift-cell.cell-repos{background:#f7fbfe!important}
  #planningTable .shift-cell.cell-conges{background:#f8fcfa!important}
  #planningTable .shift-cell.cell-maladie{background:#fffaf0!important}
  #planningTable .shift-cell.cell-formation{background:#faf8ff!important}
  #planningTable .shift-cell.cell-motif{background:#fff!important}
  #planningTable .plages-cell{
    min-height:70px!important;
    padding-bottom:13px!important;
  }
  #planningTable .plage-edit{
    gap:2px!important;
    margin:1px 0 3px!important;
  }
  #planningTable .plage-row{
    gap:3px!important;
    margin:1px 0!important;
  }
  #planningTable .plage-input,
  #pointageTable .pointage-input{
    width:54px!important;
    min-height:25px!important;
    padding:3px 5px!important;
    font-size:11.8px!important;
    font-weight:660!important;
  }
  #planningTable .plage-sep,#pointageTable .plage-sep{font-size:11px!important}
  #planningTable .plage-remove,#pointageTable .plage-remove{
    padding:1px 4px!important;
    font-size:10.5px!important;
  }
  #planningTable .add-plage-btn,
  #pointageTable .add-plage-btn{
    min-height:22px!important;
    padding:2px 7px!important;
    font-size:10.5px!important;
    line-height:1!important;
  }
  #planningTable .motif-bar{margin-top:3px!important}
  #planningTable .motif-trigger{
    min-height:22px!important;
    max-width:112px!important;
    padding:3px 7px!important;
    font-size:10.5px!important;
    overflow:hidden!important;
    text-overflow:ellipsis!important;
    white-space:nowrap!important;
  }
  #planningTable .motif-libre{
    min-height:28px!important;
    padding:4px 7px!important;
    font-size:11.6px!important;
  }
  #planningTable .planning-meta{gap:4px!important;margin-top:1px!important}
  #planningTable .plage-total,#pointageTable .plage-total{
    font-size:11.2px!important;
    font-weight:700!important;
  }
  #planningTable .planning-live-issue{
    bottom:1px!important;
    font-size:9.7px!important;
  }
  #planningTable .emp-avatar,#pointageTable .emp-avatar{
    width:28px!important;
    height:28px!important;
    font-size:10px!important;
  }
  #planningTable .emp-name,#pointageTable .emp-name{font-size:12.5px!important}
  #planningTable .emp-role,#planningTable .emp-meta,#pointageTable .emp-role,#pointageTable .emp-meta{
    font-size:10.5px!important;
  }

  #pointageTable .status-select{
    min-height:26px!important;
    max-width:120px!important;
    padding:3px 7px!important;
    font-size:11.5px!important;
  }

  .desktop-weekday-sticky-clone th{
    padding:7px 6px!important;
    font-size:10.5px!important;
  }
  .desktop-weekday-sticky-clone th small{font-size:9.8px!important}
}

/* v17.2.1 - reglage sauvegardes plus compact */
@media(min-width:881px){
  #tab-reglages>.card.card-body{gap:10px!important}
  #tab-reglages .settings-section{
    padding:13px!important;
    border-radius:var(--radius)!important;
  }
  #tab-reglages .settings-section h3{
    margin-bottom:9px!important;
    font-size:14px!important;
  }
  #settings-sync p,
  #settings-restore > p,
  #settings-data p{
    margin-top:0!important;
    margin-bottom:7px!important;
    font-size:11.5px!important;
    line-height:1.35!important;
  }
  #settings-sync .btn,
  #settings-sante .btn,
  #settings-restore .btn,
  #settings-data .btn,
  #settings-log .btn{
    min-height:26px!important;
    padding:4px 8px!important;
    font-size:11px!important;
  }
  #settings-sante,
  #settings-restore{
    min-height:0!important;
    max-height:370px!important;
  }
  #settings-restore .template-list{
    flex:0 1 auto!important;
    max-height:250px!important;
    gap:6px!important;
    padding-right:4px!important;
  }
  #settings-restore .template-item{
    min-height:44px!important;
    padding:7px 9px!important;
    gap:8px!important;
    border-radius:var(--radius)!important;
  }
  #settings-restore .template-item strong{
    font-size:12.6px!important;
    line-height:1.15!important;
  }
  #settings-restore .template-item div[style*="font-size:11.5px"]{
    font-size:10.8px!important;
    line-height:1.2!important;
  }
  #settings-restore .template-item > div:last-child{
    gap:5px!important;
  }
  .template-list{gap:6px!important}
  .template-item{
    padding:8px 9px!important;
    border-radius:var(--radius)!important;
  }
  .diag-card{
    min-height:50px!important;
    padding:8px 9px!important;
  }
  .diag-card span{font-size:10.5px!important}
  .diag-card strong{font-size:12px!important}
}

/* v17.2.4 — Login recentré et harmonisé */
.login-screen{
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  min-height:100dvh!important;
  width:100%!important;
  padding:calc(24px + var(--safe-top)) 20px calc(24px + var(--safe-bot))!important;
  box-sizing:border-box!important;
  overflow:auto!important;
}
.login-card{
  width:min(100%,390px)!important;
  max-width:390px!important;
  margin:auto!important;
  text-align:center!important;
  display:flex!important;
  flex-direction:column!important;
  align-items:center!important;
}
.login-logo,.login-logo-placeholder{
  margin:0 auto 22px!important;
}
.login-title,.login-subtitle,.login-error,.login-hint{
  text-align:center!important;
}
.login-input,.login-btn{
  align-self:stretch!important;
}
.login-btn{
  background:#161719!important;
  border-color:#161719!important;
  color:#fff!important;
}
.login-btn:hover:not(:disabled){
  background:#000!important;
}
.panic-btn{
  align-self:center!important;
}
@media(max-width:520px){
  .login-card{
    max-width:360px!important;
    padding:24px!important;
    border-radius:22px!important;
  }
}

/* Planning et Decompte : contenu des cellules centre et plus respirant */
@media(min-width:881px){
  #planningTable .shift-cell{
    text-align:center!important;
    vertical-align:middle!important;
  }
  #planningTable .plages-cell{
    width:100%!important;
    min-height:98px!important;
    display:flex!important;
    flex-direction:column!important;
    align-items:center!important;
    justify-content:center!important;
    gap:6px!important;
    padding-bottom:0!important;
    margin:0 auto!important;
  }
  #planningTable .plage-edit{
    width:100%!important;
    margin:0!important;
  }
  #planningTable .plage-row,
  #pointageTable .pointage-plage-row{
    position:relative!important;
    width:100%!important;
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    gap:6px!important;
    margin:0!important;
    padding-inline:20px!important;
    box-sizing:border-box!important;
  }
  #planningTable .plage-row .plage-input,
  #pointageTable .pointage-plage-row .pointage-input{
    flex:0 0 auto!important;
  }
  #planningTable .plage-input,
  #pointageTable .pointage-input{
    background:#f8fbff!important;
    border-color:#a9bdd6!important;
    color:#173b70!important;
    font-size:12.4px!important;
    font-weight:850!important;
  }
  #planningTable .plage-input:placeholder-shown,
  #pointageTable .pointage-input:placeholder-shown{
    background:#fff!important;
    border-color:#cbd5e1!important;
    color:#94a3b8!important;
    font-weight:760!important;
  }
  #planningTable .plage-input.plage-invalid{
    background:var(--error-bg)!important;
    border-color:var(--error)!important;
    color:var(--error)!important;
  }
  #planningTable .plage-row .plage-sep,
  #pointageTable .pointage-plage-row .plage-sep{
    min-width:8px!important;
    text-align:center!important;
  }
  #planningTable .plage-row .plage-remove,
  #pointageTable .pointage-plage-row .plage-remove{
    position:absolute!important;
    right:0!important;
    top:50%!important;
    transform:translateY(-50%)!important;
    margin:0!important;
  }
  #planningTable .field-hint{
    position:absolute!important;
    right:20px!important;
    top:50%!important;
    transform:translateY(-50%)!important;
    margin:0!important;
  }
  #planningTable .planning-add-row,
  #planningTable .planning-meta,
  #planningTable .motif-bar{
    width:100%!important;
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    text-align:center!important;
    margin-top:0!important;
  }
  #planningTable .planning-meta{
    gap:6px!important;
    flex-wrap:wrap!important;
  }
  #planningTable .planning-day-total{
    color:var(--success)!important;
    font-size:12.6px!important;
    font-weight:850!important;
    line-height:1.2!important;
  }
  #planningTable .planning-day-total.planning-day-total-error{
    color:var(--error)!important;
  }
  #planningTable .planning-add-row .add-plage-btn{
    min-height:24px!important;
    padding:3px 9px!important;
    font-size:11.2px!important;
    font-weight:850!important;
    line-height:1!important;
  }
  #planningTable .motif-trigger{
    align-self:center!important;
  }
  #pointageTable td.pointage-day-cell{
    text-align:center!important;
    vertical-align:middle!important;
    padding:13px 10px!important;
  }
  #pointageTable .pointage-day-content{
    min-height:98px!important;
    width:100%!important;
    display:flex!important;
    flex-direction:column!important;
    align-items:center!important;
    justify-content:center!important;
    gap:6px!important;
    margin:0 auto!important;
  }
  #pointageTable .pointage-day-content .status-select{
    align-self:center!important;
    min-width:116px!important;
    max-width:142px!important;
    width:auto!important;
    text-align:center!important;
    text-align-last:center!important;
  }
  #pointageTable .pointage-reel-label{
    width:100%!important;
    margin:0!important;
    text-align:center!important;
    font-size:12px!important;
    line-height:1.2!important;
    font-weight:750!important;
  }
  #pointageTable .pointage-reel-success{color:var(--success)!important}
  #pointageTable .pointage-reel-warn{color:var(--warn)!important}
  #pointageTable .pointage-reel-formation{color:var(--formation,var(--violet))!important}
  #pointageTable .pointage-reel-error{color:var(--error)!important}
  #pointageTable .pointage-reel-violet{color:var(--violet)!important}
  #pointageTable .pointage-extra-icon{
    color:var(--violet)!important;
    font-size:11px!important;
    font-weight:850!important;
    line-height:1!important;
  }
  #pointageTable .pointage-extra-input{
    border-color:var(--violet)!important;
    font-weight:740!important;
  }
  #pointageTable .pointage-add-plage{
    align-self:center!important;
    margin:0!important;
  }
}

/* Mode nuit */
.night-toggle{
  min-height:36px!important;
  display:inline-flex!important;
  align-items:center!important;
  gap:8px!important;
  padding:5px 10px!important;
  border:1px solid var(--line)!important;
  border-radius:var(--radius)!important;
  background:#fff!important;
  color:var(--text-muted)!important;
  font-family:inherit!important;
  font-size:12px!important;
  font-weight:800!important;
  cursor:pointer!important;
  white-space:nowrap!important;
  box-shadow:none!important;
}
.night-toggle:hover{border-color:var(--accent)!important;color:var(--accent)!important;background:var(--accent-soft)!important}
.night-toggle-track{
  width:34px!important;
  height:18px!important;
  padding:2px!important;
  display:inline-flex!important;
  align-items:center!important;
  border-radius:999px!important;
  background:#dbe5f0!important;
  border:1px solid #bfd0e1!important;
  transition:background .18s ease,border-color .18s ease!important;
}
.night-toggle-knob{
  width:12px!important;
  height:12px!important;
  border-radius:50%!important;
  background:#fff!important;
  box-shadow:0 1px 3px rgba(16,32,51,.22)!important;
  transform:translateX(0)!important;
  transition:transform .18s ease,background .18s ease!important;
}
.night-toggle.active .night-toggle-track{
  background:#315d94!important;
  border-color:#5e8cc3!important;
}
.night-toggle.active .night-toggle-knob{
  transform:translateX(16px)!important;
  background:#dbeafe!important;
}

html.night-mode,
body.night-mode{
  color-scheme:dark;
  --bg:#111820;
  --surface:#17212c;
  --surface-raised:#1c2835;
  --surface-muted:#202e3d;
  --line:#2f4052;
  --line-strong:#435971;
  --border:#2f4052;
  --border-strong:#435971;
  --text:#edf4fb;
  --text-muted:#c5d2df;
  --text-soft:#8fa2b7;
  --accent:#7db3ff;
  --accent-strong:#a9ccff;
  --accent-soft:#1f3650;
  --accent-text:#07111f;
  --ink:#e6f0fb;
  --ink-soft:#c9d8e8;
  --success:#6ee7a6;
  --success-bg:#153526;
  --warn:#f5c56b;
  --warn-bg:#3a2b12;
  --error:#ff8f99;
  --error-bg:#3a1c22;
  --info:#7dd3fc;
  --info-bg:#123143;
  --violet:#c4b5fd;
  --violet-bg:#2b2445;
  --shadow-sm:0 1px 2px rgba(0,0,0,.28);
  --shadow:0 10px 28px rgba(0,0,0,.34);
  --shadow-lg:0 22px 70px rgba(0,0,0,.52);
  background:#111820!important;
}
body.night-mode{
  background:linear-gradient(180deg,#16202c 0%,#111820 260px,#111820 100%)!important;
  color:var(--text)!important;
}
body.night-mode .login-screen,
body.night-mode .topbar,
body.night-mode .tabbar,
body.night-mode .toolbar,
body.night-mode .card,
body.night-mode .settings-section,
body.night-mode .employees-list,
body.night-mode .stats-grid .stat-card,
body.night-mode .dashboard-card,
body.night-mode .home-panel{
  background:rgba(23,33,44,.96)!important;
  border-color:var(--line)!important;
  color:var(--text)!important;
  box-shadow:var(--shadow)!important;
}
body.night-mode .topbar{
  backdrop-filter:blur(18px)!important;
}
body.night-mode .brand-name,
body.night-mode .period-label,
body.night-mode .section-title,
body.night-mode .settings-section h3,
body.night-mode .emp-name,
body.night-mode .mob-card-emp-name,
body.night-mode .home-title h1,
body.night-mode .dashboard-card h2{
  color:var(--text)!important;
}
body.night-mode .brand-sub,
body.night-mode .period-num,
body.night-mode .emp-role,
body.night-mode .emp-meta,
body.night-mode .mob-card-emp-status,
body.night-mode small,
body.night-mode .login-subtitle,
body.night-mode .login-hint{
  color:var(--text-soft)!important;
}
body.night-mode .topnav{
  background:transparent!important;
}
body.night-mode .topnav-btn{
  color:var(--text-muted)!important;
}
body.night-mode .topnav-btn:hover{
  background:var(--surface-muted)!important;
  border-color:var(--line-strong)!important;
  color:var(--text)!important;
}
body.night-mode .topnav-btn.active{
  background:#dbeafe!important;
  border-color:#dbeafe!important;
  color:#0b1220!important;
}
body.night-mode .night-toggle,
body.night-mode .sync-indicator,
body.night-mode .icon-btn,
body.night-mode .btn,
body.night-mode .btn-sm,
body.night-mode .btn-xs,
body.night-mode .btn-today,
body.night-mode .nav-arrow,
body.night-mode .chip,
body.night-mode .emp-chip,
body.night-mode .smart-filter-chip,
body.night-mode .quick-btn{
  background:#1a2633!important;
  border-color:var(--line)!important;
  color:var(--text-muted)!important;
}
body.night-mode .night-toggle:hover,
body.night-mode .sync-indicator:hover,
body.night-mode .btn:hover,
body.night-mode .btn-sm:hover,
body.night-mode .btn-today:hover,
body.night-mode .nav-arrow:hover,
body.night-mode .emp-chip:hover{
  background:var(--accent-soft)!important;
  border-color:var(--accent)!important;
  color:#dcecff!important;
}
body.night-mode .emp-chip.active,
body.night-mode .chip.active,
body.night-mode .btn.active,
body.night-mode .btn-primary,
body.night-mode .btn-warn.active{
  background:#dbeafe!important;
  border-color:#dbeafe!important;
  color:#0b1220!important;
}
body.night-mode .sync-dot{background:var(--success)!important}
body.night-mode .night-toggle-track{
  background:#26384b!important;
  border-color:#3f5570!important;
}
body.night-mode .night-toggle.active{
  color:#dbeafe!important;
}
body.night-mode .night-toggle.active .night-toggle-track{
  background:#6ea8fe!important;
  border-color:#9cc7ff!important;
}
body.night-mode .night-toggle.active .night-toggle-knob{
  background:#07111f!important;
}
body.night-mode .alerts-panel{
  background:linear-gradient(180deg,#351d22,#231a22)!important;
  border-color:#7f3038!important;
  color:#ffd5da!important;
}
body.night-mode .alerts-panel h3,
body.night-mode .alerts-panel .alert-jump,
body.night-mode .alerts-panel a{
  color:#ffb4bd!important;
}
body.night-mode .alerts-panel li{
  color:#ffd5da!important;
}
body.night-mode .table-wrap,
body.night-mode .data-table{
  background:var(--surface)!important;
  border-color:var(--line)!important;
}
body.night-mode .data-table th,
body.night-mode .data-table td{
  border-color:var(--line)!important;
}
body.night-mode .data-table thead th,
body.night-mode .desktop-view .data-table thead th,
body.night-mode .desktop-weekday-sticky-clone,
body.night-mode .desktop-weekday-sticky-clone table,
body.night-mode .desktop-weekday-sticky-clone th{
  background:#202b38!important;
  color:var(--text-muted)!important;
  border-color:var(--line)!important;
}
body.night-mode .data-table thead th small,
body.night-mode .desktop-weekday-sticky-clone th small{
  color:var(--text-soft)!important;
}
body.night-mode .data-table tbody td,
body.night-mode #planningTable .shift-cell{
  background:#17212c!important;
  color:var(--text)!important;
}
body.night-mode .data-table tbody tr:nth-child(even) td{
  background:#1b2633!important;
}
body.night-mode .data-table tbody tr:hover td{
  background:#213246!important;
}
body.night-mode .data-table th:first-child,
body.night-mode .data-table tbody td:first-child{
  background:#182330!important;
  box-shadow:1px 0 0 var(--line)!important;
}
body.night-mode .data-table tbody tr:nth-child(even) td:first-child{
  background:#1c2835!important;
}
body.night-mode .data-table .totals-row td,
body.night-mode .data-table tr[style*="background:var(--surface-alt)"] td{
  background:#233449!important;
}
body.night-mode .comment-row td,
body.night-mode .data-table .comment-row td{
  background:#221f2a!important;
}
body.night-mode .cell-repos,
body.night-mode .data-table .cell-repos,
body.night-mode #planningTable .shift-cell.cell-repos{
  background:#123143!important;
}
body.night-mode .cell-conges,
body.night-mode .data-table .cell-conges,
body.night-mode #planningTable .shift-cell.cell-conges{
  background:#153526!important;
}
body.night-mode .cell-maladie,
body.night-mode .data-table .cell-maladie,
body.night-mode #planningTable .shift-cell.cell-maladie{
  background:#3a2b12!important;
}
body.night-mode .cell-formation,
body.night-mode .data-table .cell-formation,
body.night-mode #planningTable .shift-cell.cell-formation{
  background:#2b2445!important;
}
body.night-mode .cell-motif,
body.night-mode .data-table .cell-motif,
body.night-mode #planningTable .shift-cell.cell-motif{
  background:#3a1c22!important;
}
body.night-mode .cell-conflict{
  box-shadow:inset 0 0 0 2px var(--error)!important;
}
body.night-mode input,
body.night-mode select,
body.night-mode textarea,
body.night-mode .form-input,
body.night-mode .search-box,
body.night-mode .comment-input,
body.night-mode .plage-input,
body.night-mode .pointage-input,
body.night-mode .mob-input,
body.night-mode .status-select{
  background:#101923!important;
  border-color:#506680!important;
  color:#eef6ff!important;
}
body.night-mode input::placeholder,
body.night-mode textarea::placeholder{
  color:#788da3!important;
  opacity:1!important;
}
body.night-mode #planningTable .plage-input,
body.night-mode #pointageTable .pointage-input{
  background:#142236!important;
  border-color:#6a86aa!important;
  color:#cfe4ff!important;
}
body.night-mode #planningTable .plage-input:placeholder-shown,
body.night-mode #pointageTable .pointage-input:placeholder-shown{
  background:#111b25!important;
  border-color:#43576e!important;
  color:#8fa2b7!important;
}
body.night-mode .plage-input.plage-invalid,
body.night-mode #planningTable .plage-input.plage-invalid{
  background:#3a1c22!important;
  border-color:var(--error)!important;
  color:#ffd7dc!important;
}
body.night-mode .plage-sep,
body.night-mode .mob-sep{
  color:#9db0c5!important;
}
body.night-mode .plage-remove,
body.night-mode .mob-rm{
  color:#ff9da6!important;
}
body.night-mode .add-plage-btn,
body.night-mode .mob-add,
body.night-mode .motif-trigger{
  background:#172331!important;
  border-color:#526a86!important;
  color:#c6d6e7!important;
}
body.night-mode .add-plage-btn:hover,
body.night-mode .motif-trigger:hover,
body.night-mode .mob-add:hover{
  background:#203752!important;
  border-color:var(--accent)!important;
  color:#e3f0ff!important;
}
body.night-mode .status-select.status-present,
body.night-mode .status-select.status-entreprise{
  background:#183b2a!important;
  color:#98f3bd!important;
  border-color:#3b8a61!important;
}
body.night-mode .status-select.status-repos{
  background:#123143!important;
  color:#9ee6ff!important;
  border-color:#397a9a!important;
}
body.night-mode .status-select.status-absent,
body.night-mode .status-select.status-autre{
  background:#3a1c22!important;
  color:#ffb4bd!important;
  border-color:#8f4750!important;
}
body.night-mode .status-select.status-cp{
  background:#153526!important;
  color:#98f3bd!important;
  border-color:#3b8a61!important;
}
body.night-mode .status-select.status-maladie{
  background:#3a2b12!important;
  color:#ffe0a3!important;
  border-color:#9b7432!important;
}
body.night-mode .status-select.status-formation{
  background:#2b2445!important;
  color:#d8ccff!important;
  border-color:#7565a8!important;
}
body.night-mode .motif-dropdown{
  background:#17212c!important;
  border-color:var(--line-strong)!important;
  box-shadow:var(--shadow-lg)!important;
}
body.night-mode .motif-option{
  color:var(--text)!important;
}
body.night-mode .motif-option:hover{
  background:#243447!important;
}
body.night-mode .motif-option.opt-active,
body.night-mode .motif-option.active{
  background:#dbeafe!important;
  color:#0b1220!important;
}
body.night-mode .planning-day-total,
body.night-mode #pointageTable .pointage-reel-success,
body.night-mode .diff-pos,
body.night-mode .delta-ok{
  color:var(--success)!important;
}
body.night-mode .planning-day-total.planning-day-total-error,
body.night-mode .diff-neg,
body.night-mode .delta-neg,
body.night-mode #pointageTable .pointage-reel-error{
  color:var(--error)!important;
}
body.night-mode #pointageTable .pointage-reel-warn,
body.night-mode .diff-warn,
body.night-mode .delta-warn{
  color:var(--warn)!important;
}
body.night-mode .emp-avatar{
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.12)!important;
}
body.night-mode .mob-card,
body.night-mode .mob-emp-card,
body.night-mode .mob-day-header,
body.night-mode .mob-week-nav,
body.night-mode .mob-day-chip,
body.night-mode .modal-content,
body.night-mode .template-item,
body.night-mode .todo-item,
body.night-mode .home-row,
body.night-mode .home-kpi{
  background:#17212c!important;
  border-color:var(--line)!important;
  color:var(--text)!important;
}
body.night-mode .mob-day-chip.active,
body.night-mode .mob-action-btn{
  background:#dbeafe!important;
  color:#0b1220!important;
  border-color:#dbeafe!important;
}
body.night-mode .home-footer-card{
  background:#dbeafe!important;
  color:#0b1220!important;
  border-color:#dbeafe!important;
}
