*{box-sizing:border-box}
:root{--red:#b91c1c;--dark:#0f172a;--border:#e2e8f0;--green:#16a34a;--blue:#2563eb;--orange:#d97706}
body{margin:0;font-family:Arial,Helvetica,sans-serif;background:linear-gradient(180deg,#f1f5f9,#e5e7eb);color:#0f172a}
.app{max-width:1180px;margin:18px auto;background:#fff;border-radius:28px;overflow:hidden;box-shadow:0 18px 50px rgba(15,23,42,.16)}
.login{max-width:430px}
.header{background:radial-gradient(circle at top,#ef4444,#b91c1c 60%,#7f1d1d);color:#fff;padding:30px 22px;text-align:center}
.badge{width:64px;height:64px;margin:0 auto 12px;background:#fff;color:#b91c1c;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:32px;box-shadow:0 8px 20px rgba(0,0,0,.15)}
.header h1{margin:0;font-size:30px;letter-spacing:-.5px}.header p{margin:7px 0 0;font-size:14px;opacity:.92}
.content{padding:22px}h2{margin:18px 0 12px;font-size:22px;letter-spacing:-.4px}
.row{display:flex;gap:12px;align-items:end;flex-wrap:wrap}.field{flex:1;min-width:180px}
label{display:block;font-size:13px;font-weight:800;margin:10px 0 6px}
input,select{width:100%;padding:13px 14px;border:1px solid #cbd5e1;border-radius:14px;font-size:15px;background:#fff;outline:none}
input:focus{border-color:#991b1b;box-shadow:0 0 0 3px rgba(185,28,28,.12)}
button{cursor:pointer}.btn{border:0;border-radius:14px;padding:13px 16px;background:var(--red);color:#fff;font-weight:900;font-size:15px;text-decoration:none;display:inline-block;box-shadow:0 6px 14px rgba(185,28,28,.18)}
.btn.dark{background:#0f172a;box-shadow:none}.btn.gray{background:#64748b;box-shadow:none}.btn.green{background:#16a34a;box-shadow:none}.btn.small{padding:8px 11px;font-size:12px;border-radius:10px}
.topbar{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:18px}.nav{display:flex;gap:9px;flex-wrap:wrap}.nav a{background:#0f172a;color:#fff;padding:10px 14px;border-radius:999px;text-decoration:none;font-weight:900;font-size:13px}
.alert{background:#fee2e2;color:#991b1b;padding:12px;border-radius:14px;margin-bottom:12px}.success{background:#dcfce7;color:#166534;padding:12px;border-radius:14px;margin-bottom:12px}
.note{font-size:13px;color:#64748b;line-height:1.4}
.card{background:#f8fafc;border:1px solid var(--border);border-radius:22px;padding:18px;margin:16px 0;box-shadow:0 6px 18px rgba(15,23,42,.04)}
.monthbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin:12px 0}.monthbar input{max-width:190px}
.calendar{display:grid;grid-template-columns:repeat(7,1fr);gap:10px}.dow{text-align:center;font-size:12px;color:#64748b;font-weight:900;padding:6px;text-transform:uppercase}
.day{min-height:130px;border:1px solid var(--border);border-radius:20px;background:#fff;padding:10px;position:relative;box-shadow:0 4px 12px rgba(15,23,42,.04)}
.day.empty{background:#f8fafc;color:#94a3b8}.num{font-weight:950;font-size:15px;margin-bottom:8px}.admin-day{min-height:142px}
.checks label{display:flex;align-items:center;gap:6px;margin:5px 0;font-size:12px;font-weight:900}.checks input{width:auto;transform:scale(1.1)}
.type-pill{display:inline-block;border-radius:999px;padding:5px 9px;margin:2px;font-size:11px;font-weight:950}.garde{background:#dcfce7;color:#166534}.astreinte{background:#dbeafe;color:#1d4ed8}.GIFF{background:#fef3c7;color:#92400e}
.user-day{transition:.15s}.type-btn{width:100%;border:0;border-radius:15px;margin:4px 0;padding:10px 9px;font-size:12px;font-weight:950;text-align:left;background:#e5e7eb;color:#334155;transition:.12s}.type-btn:hover{transform:translateY(-1px)}
.type-btn.on{background:var(--green);color:white}.type-btn.on.astreinte-btn{background:var(--blue)}.type-btn.on.GIFF-btn{background:var(--orange)}
.slotbox{display:none;background:#eff6ff;border:1px solid #bfdbfe;border-radius:15px;padding:9px;margin-top:6px}.slotbox.open{display:block}
.slotline{display:flex;align-items:center;justify-content:space-between;font-size:12px;font-weight:900;margin:7px 0}.slotline input{width:auto;transform:scale(1.15)}
.hint{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0 16px}.hint span{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:999px;padding:8px 11px;font-size:12px;font-weight:900;color:#334155}
.tablewrap{overflow:auto}table{width:100%;border-collapse:collapse;background:white}th,td{border:1px solid #e5e7eb;padding:10px;font-size:13px;text-align:left}th{background:#f1f5f9}
@media(max-width:720px){.app{margin:0;min-height:100vh;border-radius:0}.content{padding:14px}.header{padding:24px 16px}.header h1{font-size:24px}.badge{width:56px;height:56px}.calendar{gap:6px}.day{min-height:102px;padding:7px;border-radius:15px}.admin-day{min-height:118px}.num{font-size:13px}.type-btn{font-size:11px;padding:8px 6px}.slotline{font-size:10px}.dow{font-size:10px;padding:3px}.row{display:block}.field{min-width:0}.btn{width:100%;text-align:center;margin-top:6px}.nav a{font-size:12px;padding:9px 11px}}
.btn.danger{background:#dc2626;box-shadow:none}
.tablewrap input,.tablewrap select{min-width:120px;padding:9px;border-radius:10px}
@media(max-width:720px){
  .tablewrap table,.tablewrap tbody,.tablewrap tr,.tablewrap td,.tablewrap th{display:block;width:100%}
  .tablewrap th{display:none}
  .tablewrap td{border:none;border-bottom:1px solid #e5e7eb}
}

/* V3.3 mobile lisible */
.calendar-wrap{width:100%;overflow-x:auto;padding-bottom:8px}
.user-calendar,.admin-calendar{min-width:820px}
.user-calendar .day{min-height:112px}
.user-calendar .type-btn{white-space:nowrap;text-align:center}
.admin-savebar{position:sticky;top:0;z-index:3;background:rgba(248,250,252,.95);padding:10px 0;margin-bottom:10px;border-bottom:1px solid #e2e8f0}
.admin-savebar.bottom{position:static;border-bottom:0;border-top:1px solid #e2e8f0;margin-top:10px}
.admin-savebar .btn{width:100%}
.modal{display:none;position:fixed;inset:0;background:rgba(15,23,42,.55);z-index:99;align-items:center;justify-content:center;padding:18px}
.modal.open{display:flex}
.modal-card{width:100%;max-width:360px;background:#fff;border-radius:24px;padding:22px;box-shadow:0 20px 60px rgba(0,0,0,.28);position:relative}
.modal-card h2{margin-top:0}
.modal-close{position:absolute;right:14px;top:10px;border:0;background:#e5e7eb;border-radius:50%;width:34px;height:34px;font-size:24px;font-weight:900}
.slotline.big{font-size:18px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;padding:14px 16px;margin:10px 0}
.slotline.big input{transform:scale(1.6)}
@media(max-width:720px){
  .user-calendar,.admin-calendar{min-width:760px}
  .calendar-wrap{margin-left:-2px}
  .day{min-height:104px}
  .admin-day{min-height:120px}
  .type-btn{font-size:12px;padding:9px 7px}
}

/* V3.4 - vue utilisateur verticale */
.user-list{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
}
.user-card{
  background:#fff;
  border:1px solid #e2e8f0;
  border-radius:22px;
  padding:15px;
  box-shadow:0 6px 18px rgba(15,23,42,.05);
}
.user-card.empty{
  opacity:.62;
  background:#f8fafc;
}
.user-card-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:12px;
}
.user-date{
  font-size:18px;
  font-weight:950;
  color:#0f172a;
}
.user-sub{
  font-size:12px;
  color:#64748b;
  font-weight:800;
  margin-top:3px;
}
.no-need{
  background:#f1f5f9;
  color:#64748b;
  border-radius:14px;
  padding:13px;
  font-weight:900;
  text-align:center;
}
.big-choice{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  width:100%;
  border-radius:16px;
  padding:14px 15px;
  margin:9px 0;
  background:#e5e7eb;
  color:#334155;
  font-size:16px;
  font-weight:950;
  cursor:pointer;
  transition:.15s;
}
.big-choice input{
  display:none;
}
.big-choice strong{
  font-size:20px;
}
.big-choice.checked.green{
  background:#16a34a;
  color:white;
}
.big-choice.checked.blue{
  background:#2563eb;
  color:white;
}
.big-choice.checked.orange{
  background:#d97706;
  color:white;
}
.slots-list{
  display:none;
  background:#eff6ff;
  border:1px solid #bfdbfe;
  border-radius:18px;
  padding:10px 13px;
  margin:8px 0 12px;
}
.slots-list.open{
  display:block;
}
.slot-choice{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:12px 0;
  font-size:16px;
  font-weight:900;
  color:#0f172a;
}
.slot-choice input{
  width:26px;
  height:26px;
}
.savebar-user{
  background:rgba(255,255,255,.96);
  padding:10px 0;
  z-index:4;
}
.savebar-user.top{
  position:sticky;
  top:0;
  border-bottom:1px solid #e2e8f0;
  margin-bottom:14px;
}
.savebar-user.bottom{
  position:sticky;
  bottom:0;
  border-top:1px solid #e2e8f0;
  margin-top:14px;
}
.savebar-user .btn{
  width:100%;
}
@media(max-width:900px){
  .user-list{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media(max-width:720px){
  .user-list{
    grid-template-columns:1fr;
    gap:12px;
  }
  .user-card{
    border-radius:20px;
    padding:14px;
  }
  .user-date{
    font-size:19px;
  }
  .big-choice{
    font-size:16px;
    padding:15px;
  }
  .monthbar input{
    max-width:none;
  }
}

/* V3.5 - page utilisateurs séparée */
.users-list{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
}
.user-edit-card{
  background:#fff;
  border:1px solid #e2e8f0;
  border-radius:22px;
  padding:16px;
  box-shadow:0 6px 18px rgba(15,23,42,.05);
}
.user-edit-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  margin-bottom:12px;
  font-size:18px;
}
.role-badge{
  border-radius:999px;
  padding:7px 10px;
  font-size:12px;
  font-weight:900;
}
.admin-role{
  background:#fee2e2;
  color:#991b1b;
}
.user-role{
  background:#dcfce7;
  color:#166534;
}
.btn.danger{
  background:#dc2626;
  box-shadow:none;
  margin-top:8px;
}
.btn:disabled{
  opacity:.45;
  cursor:not-allowed;
}
@media(min-width:1000px){
  .users-list{
    grid-template-columns:1fr 1fr;
  }
}

/* V3.6 - utilisateurs popup + mois ouvert */
.open-month-card{
  border-left:6px solid #2563eb;
}
.open-month-display{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  background:#eff6ff;
  border:1px solid #bfdbfe;
  border-radius:18px;
  padding:14px;
  margin:10px 0;
}
.open-month-display strong{
  font-size:24px;
}
.open-check{
  display:flex;
  align-items:center;
  gap:10px;
  background:#eff6ff;
  border:1px solid #bfdbfe;
  border-radius:18px;
  padding:14px;
  margin:12px 0;
  font-size:15px;
  font-weight:900;
}
.open-check input{
  width:24px;
  height:24px;
}
.open-user-month{
  background:#eff6ff;
  border:1px solid #bfdbfe;
  border-radius:18px;
  padding:14px;
  margin-bottom:14px;
}
.open-user-month strong{
  font-size:20px;
}
.admin-user-month{
  margin-bottom:0;
}
.simple-users-list{
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
}
.simple-user-row{
  width:100%;
  border:1px solid #e2e8f0;
  background:#fff;
  border-radius:18px;
  padding:15px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  text-align:left;
  box-shadow:0 5px 15px rgba(15,23,42,.04);
}
.simple-user-row strong{
  display:block;
  font-size:17px;
  color:#0f172a;
}
.simple-user-row small{
  display:block;
  margin-top:4px;
  color:#64748b;
  font-weight:800;
}
.simple-user-row em{
  font-style:normal;
  border-radius:999px;
  padding:7px 10px;
  font-size:12px;
  font-weight:950;
  white-space:nowrap;
}
.user-modal-card{
  max-width:430px;
}
@media(min-width:850px){
  .simple-users-list{
    grid-template-columns:1fr 1fr;
  }
}
@media(max-width:720px){
  .simple-user-row{
    align-items:flex-start;
    flex-direction:column;
  }
}

/* V3.7 - historique + récapitulatif */
.history-monthbar{
  background:#f8fafc;
  border:1px solid #e2e8f0;
  border-radius:18px;
  padding:12px;
}
.history-monthbar label{
  width:100%;
  margin-top:0;
}
.history-monthbar select{
  flex:1;
  min-width:220px;
}
.recap-box{
  background:#f0fdf4;
  border:1px solid #bbf7d0;
  border-radius:20px;
  padding:15px;
  margin:14px 0;
}
.recap-box h2{
  margin-top:0;
}
.recap-line{
  background:#fff;
  border:1px solid #dcfce7;
  border-radius:14px;
  padding:11px;
  margin:8px 0;
}
.recap-line strong{
  display:block;
  color:#166534;
  margin-bottom:4px;
}
.recap-line span{
  color:#0f172a;
  font-weight:800;
}
.readonly-choice{
  cursor:default;
}
.readonly-choice input{
  pointer-events:none;
}
.floating-btn{
  position:fixed;
  bottom:20px;
  right:20px;
  width:60px;
  height:60px;
  background:#b00000;
  color:white;
  font-size:26px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  box-shadow:0 8px 20px rgba(0,0,0,0.3);
  z-index:999;
}
@media(max-width:720px){
  .history-monthbar select{
    min-width:0;
    width:100%;
  }
}

/* Correction visuelle mois ouvert */
.current-open-month{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  background:#eff6ff;
  border:1px solid #bfdbfe;
  border-radius:18px;
  padding:14px;
  margin-bottom:14px;
}

.current-open-month span{
  font-size:18px;
  font-weight:900;
  color:#0f172a;
}

.current-open-month strong{
  font-size:26px;
  font-weight:950;
  color:#b91c1c;
}

.open-month-line{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}

.open-month-line label{
  margin:0;
  font-size:16px;
  font-weight:900;
  color:#0f172a;
}

.open-month-line input[type="month"]{
  max-width:210px;
}

.open-month-line .btn{
  white-space:nowrap;
}

@media(max-width:720px){
  .current-open-month{
    display:block;
  }

  .current-open-month span{
    display:block;
    margin-bottom:8px;
  }

  .open-month-line{
    display:block;
  }

  .open-month-line label{
    display:block;
    margin-bottom:8px;
  }

  .open-month-line input[type="month"],
  .open-month-line .btn{
    width:100%;
    max-width:none;
  }
}

/* Popup validation configuration mois */
.month-shown{
  background:#fff7ed;
  border:1px solid #fed7aa;
  color:#7c2d12;
  border-radius:16px;
  padding:12px 14px;
  margin:12px 0;
  font-size:18px;
  font-weight:900;
}

.month-shown strong{
  color:#b91c1c;
}

.confirm-modal{
  display:none;
  position:fixed;
  inset:0;
  background:rgba(15,23,42,.62);
  z-index:9999;
  align-items:center;
  justify-content:center;
  padding:18px;
}

.confirm-modal.open{
  display:flex;
}

.confirm-modal-card{
  width:100%;
  max-width:560px;
  max-height:86vh;
  background:#fff;
  border-radius:24px;
  padding:22px;
  box-shadow:0 24px 70px rgba(0,0,0,.35);
  display:flex;
  flex-direction:column;
}

.confirm-modal-card h2{
  margin-top:0;
  margin-bottom:6px;
}

.confirm-month{
  background:#eff6ff;
  border:1px solid #bfdbfe;
  border-radius:16px;
  padding:12px;
  margin:12px 0;
  font-size:17px;
  font-weight:900;
}

.confirm-month strong{
  color:#b91c1c;
}

.confirm-list{
  overflow-y:auto;
  max-height:48vh;
  border:1px solid #e2e8f0;
  border-radius:18px;
  padding:10px;
  background:#f8fafc;
}

.confirm-row{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:center;
  background:white;
  border:1px solid #e2e8f0;
  border-radius:14px;
  padding:11px 12px;
  margin:7px 0;
}

.confirm-row strong{
  color:#0f172a;
  white-space:nowrap;
}

.confirm-row span{
  color:#166534;
  font-weight:900;
  text-align:right;
}

.confirm-empty{
  background:#fff;
  border:1px dashed #cbd5e1;
  border-radius:14px;
  padding:16px;
  text-align:center;
  font-weight:900;
  color:#64748b;
}

.confirm-actions{
  display:flex;
  gap:10px;
  justify-content:flex-end;
  margin-top:16px;
}

.confirm-actions .btn{
  min-width:130px;
}

@media(max-width:720px){
  .confirm-modal-card{
    max-height:90vh;
    padding:16px;
  }

  .confirm-row{
    display:block;
  }

  .confirm-row span{
    display:block;
    text-align:left;
    margin-top:4px;
  }

  .confirm-actions{
    display:block;
  }

  .confirm-actions .btn{
    width:100%;
    margin-top:8px;
  }
}

/* Bouton effacer configuration mois */
.clear-month-form{
  margin:12px 0 16px;
}

.btn.danger{
  background:#dc2626;
  box-shadow:none;
}

.danger-text{
  background:#fee2e2;
  border:1px solid #fecaca;
  color:#991b1b;
  border-radius:16px;
  padding:12px;
  font-weight:900;
  line-height:1.35;
}

.small-modal{
  max-width:460px;
}

/* Alerte comptes utilisateurs en attente */
.pending-users-link{
  background:#f59e0b !important;
  color:#111827 !important;
  position:relative;
}

.pending-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:22px;
  height:22px;
  margin-left:6px;
  padding:0 6px;
  border-radius:999px;
  background:#dc2626;
  color:white;
  font-size:12px;
  font-weight:950;
}

.pending-alert-modal{
  display:none;
  position:fixed;
  inset:0;
  background:rgba(15,23,42,.58);
  z-index:99999;
  align-items:center;
  justify-content:center;
  padding:18px;
}

.pending-alert-modal.open{
  display:flex;
}

.pending-alert-card{
  width:100%;
  max-width:420px;
  background:#fff;
  border-radius:24px;
  padding:22px;
  box-shadow:0 24px 70px rgba(0,0,0,.35);
  border-top:8px solid #f59e0b;
}

.pending-alert-card h2{
  margin-top:0;
  color:#92400e;
}

.pending-alert-card p{
  font-size:16px;
  font-weight:800;
  line-height:1.4;
}

.pending-alert-actions{
  display:flex;
  gap:10px;
  margin-top:18px;
}

.pending-alert-actions .btn{
  flex:1;
  text-align:center;
}

@media(max-width:720px){
  .pending-alert-actions{
    display:block;
  }

  .pending-alert-actions .btn{
    width:100%;
    margin-top:8px;
  }
}

/* V3.9 - dernier jour d'envoi */
.deadline-label{
  display:block;
  font-weight:900;
  margin:12px 0 6px;
}

.deadline-input{
  width:100%;
  padding:13px 14px;
  border:1px solid #cbd5e1;
  border-radius:14px;
  font-size:16px;
  background:#fff;
}

.deadline-info{
  margin-top:10px;
  padding:10px 12px;
  border-radius:14px;
  background:#fff7ed;
  border:1px solid #fed7aa;
  color:#9a3412;
  font-weight:900;
}

.deadline-info strong{
  color:#b91c1c;
}


/* Mini calendrier propre pour dernier jour d'envoi */
.deadline-calendar-box{
  margin-top:16px;
  background:#f8fafc;
  border:1px solid #e2e8f0;
  border-radius:20px;
  padding:14px;
}

.deadline-calendar-title{
  text-align:center;
  font-size:18px;
  font-weight:950;
  color:#0f172a;
  margin-bottom:12px;
}

.deadline-calendar-grid{
  display:grid;
  grid-template-columns:repeat(7, 1fr);
  gap:7px;
}

.deadline-calendar-days{
  margin-bottom:8px;
}

.deadline-calendar-days div{
  text-align:center;
  font-size:12px;
  font-weight:950;
  color:#64748b;
  text-transform:uppercase;
}

.deadline-calendar-empty{
  min-height:38px;
}

.deadline-calendar-day{
  height:38px;
  border:1px solid #cbd5e1;
  background:white;
  border-radius:12px;
  font-weight:900;
  color:#0f172a;
  cursor:pointer;
  box-shadow:0 2px 6px rgba(15,23,42,.05);
}

.deadline-calendar-day:hover{
  background:#eff6ff;
  border-color:#60a5fa;
}

.deadline-calendar-day.selected{
  background:#16a34a;
  border-color:#16a34a;
  color:white;
  box-shadow:0 5px 14px rgba(22,163,74,.28);
}

.deadline-input{
  display:none;
}

@media(max-width:720px){
  .deadline-calendar-box{
    padding:10px;
  }

  .deadline-calendar-grid{
    gap:5px;
  }

  .deadline-calendar-day{
    height:34px;
    border-radius:10px;
    font-size:13px;
  }

  .deadline-calendar-empty{
    min-height:34px;
  }
}

.home-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:16px;
}
.home-tile{
  display:block;
  text-decoration:none;
  color:white;
  border-radius:18px;
  padding:22px 18px;
  min-height:125px;
  box-shadow:0 10px 25px rgba(15,23,42,.18);
  border:none;
}

.home-tile strong{
  display:block;
  font-size:20px;
  margin-top:10px;
  color:white;
}

.home-tile span{
  display:block;
  margin-top:8px;
  font-weight:900;
  color:white;
}

.home-icon{
  font-size:30px;
}

.home-tile.blue{
  background:#2563eb;
}

.home-tile.green{
  background:#16a34a;
}

.home-tile.orange{
  background:#d97706;
}

.home-tile.dark{
  background:#1e293b;
}

.home-tile.red{
  background:#7f1d1d;
}

.center-nav{
  justify-content:center;
}