/* Planning CIS v2 */
:root{--brand:#c0392b;--bg:#f2f4f6;--text:#2c3e50;--muted:#555;--card:#fff;--shadow:0 2px 6px rgba(0,0,0,.10);--border:#e6e6e6}
/* Phosphor Icons styling */
.ph{display:inline-block;vertical-align:middle;flex-shrink:0}
*{box-sizing:border-box}
body{font-family:Arial,sans-serif;background:var(--bg);margin:0;padding-bottom:86px;color:var(--text)}
body.has-pwa-banner{padding-bottom:150px}
.header{background:var(--brand);color:#fff;display:flex;justify-content:space-between;align-items:center;padding:14px 16px;position:sticky;top:0;z-index:20}
.header .left{font-weight:bold}.header .right{opacity:.95;display:flex;align-items:center;gap:8px}

.container{padding:18px;max-width:980px;margin:0 auto}
.card{background:var(--card);padding:18px;border-radius:10px;box-shadow:var(--shadow);margin-bottom:14px}
.card h3{margin:0 0 12px;font-size:17px;font-weight:600;display:flex;align-items:center;gap:10px;justify-content:flex-start}
.card.statut-actuel-card h3,.card.equipe-garde-card h3,.card.manoeuvre-card h3,.card.visite-medicale-card h3,.card.acces-rapides-card h3,.card.amicale-card h3{justify-content:center!important}
.big{font-size:22px;font-weight:bold}
.small{color:var(--muted);font-size:14px;line-height:1.5}
.kv{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
.pill{padding:6px 10px;border-radius:999px;background:#f3f3f3;font-size:13px;color:#333;display:inline-block}
.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;border-radius:10px;background:var(--brand);color:#fff;text-decoration:none;font-weight:bold;transition:background .2s}
.btn:hover{background:#a93226}
.btn.secondary{background:#34495e}
.btn.secondary:hover{background:#2c3e50}
.btn.light{background:#f7f7f7;color:#222;border:1px solid var(--border);font-weight:600}

/* Planning list */
.ligne{display:flex;margin-bottom:8px}
.mois{writing-mode:vertical-rl;font-weight:bold;background:#e0e0e0;padding:8px 6px;min-width:34px;text-align:center}
.bloc{flex:1;background:#fff;padding:10px;box-shadow:var(--shadow)}
.titre{text-align:center;font-weight:bold}
.periode{text-align:center;font-size:14px;color:var(--muted)}
.manoeuvre{margin-top:6px;padding:6px 8px;background:#ffeaa7;color:#2d3436;font-size:13px;font-weight:bold;border-radius:6px;text-align:center;line-height:1.3}
.semaine{writing-mode:vertical-rl;font-weight:bold;background:#f0f0f0;padding:8px 6px;min-width:38px;text-align:center}
.e1{border-left:6px solid #2980b9}.e2{border-left:6px solid #27ae60}.e3{border-left:6px solid #8e44ad}.e4{border-left:6px solid #16a085}
.sep-mois{margin:25px 0 10px;text-align:center;font-weight:bold;color:var(--text);border-top:2px solid #ccc;padding-top:8px}

/* Bottom nav */
.nav-bottom{position:fixed;bottom:0;width:100%;background:#fff;border-top:2px solid var(--brand);display:flex;justify-content:space-around;padding:10px 0;z-index:30}
.nav-bottom a{text-decoration:none;color:var(--text);text-align:center;min-width:70px;display:flex;flex-direction:column;align-items:center;gap:4px}
.nav-bottom a .ph{font-size:22px}
.nav-bottom a span{font-size:13px;display:block;line-height:1}
.nav-bottom .active{color:var(--brand);font-weight:bold}

/* Menu pleine page */
.sheet-backdrop{
  position:fixed;
  top:0;
  left:0;
  right:0;
  bottom:0;
  background:rgba(0,0,0,.5);
  display:none;
  z-index:100;
}

.sheet-backdrop.open{
  display:block;
}

.sheet{
  position:fixed;
  top:0;
  left:0;
  right:0;
  bottom:0;
  background:#fff;
  z-index:101;
  transition:transform .3s ease;
  transform:translateX(100%);
  padding:0;
  overflow-y:auto;
  box-shadow:-5px 0 20px rgba(0,0,0,.2);
  display:flex;
  flex-direction:column;
}

.sheet.open{
  transform:translateX(0);
}

.sheet .menu-content .userbox{background:#f7f7f7;border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:20px}
.sheet .userbox-content{text-align:center}
.sheet .userbox .grade{font-weight:800;font-size:14px}
.sheet .userbox .name{font-weight:800;font-size:18px;margin-top:4px}
.sheet .userbox .equipe-info{margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}
.sheet .userbox .equipe-info strong{display:block;color:var(--text);font-size:14px;margin-bottom:6px}
.sheet .userbox .chef-equipe{color:#555;font-size:12px;margin-top:4px}
.sheet .userbox .meta{color:#555;font-size:13px;margin-top:12px;line-height:1.5}
.sheet .menu-content .menu-links{margin-top:0}
.sheet .menu-links a{display:flex;align-items:center;justify-content:space-between;padding:16px;border-radius:12px;text-decoration:none;color:var(--text);border:1px solid var(--border);margin-bottom:12px;background:#fff;transition:background .2s;font-size:14px}
.sheet .menu-links a:hover{background:#f5f5f5}
.sheet .menu-links a:active{background:#eee}
.sheet .menu-links a > div:first-child{display:flex;align-items:center;gap:10px;flex:1}
.sheet .menu-links small{color:#666;display:block;margin-top:4px;font-size:12px}
.sheet .menu-header{background:#fff;border-bottom:1px solid var(--border);padding:12px 16px;position:sticky;top:0;z-index:10}
.sheet .menu-back-btn{display:flex;align-items:center;gap:8px;padding:8px 12px;border:none;background:transparent;cursor:pointer;color:var(--text);border-radius:8px;font-size:15px;font-weight:500;transition:background .2s}
.sheet .menu-back-btn:hover{background:#f0f0f0}
.sheet .menu-back-btn .ph{font-size:20px}
.sheet .menu-content{padding:20px;flex:1;overflow-y:auto}

/* Forms */
.form{background:#fff;border:1px solid var(--border);border-radius:12px;padding:14px;box-shadow:var(--shadow)}

/* PWA Install Banner */
.pwa-install-banner{
  position:fixed;
  bottom:70px;
  left:0;
  right:0;
  background:var(--brand);
  color:#fff;
  z-index:25;
  box-shadow:0 -2px 10px rgba(0,0,0,.2);
  padding:14px 16px;
  animation:slideUp .3s ease;
}
@keyframes slideUp{
  from{transform:translateY(100%);opacity:0}
  to{transform:translateY(0);opacity:1}
}
.pwa-install-content{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  max-width:980px;
  margin:0 auto;
}
.pwa-install-text{
  flex:1;
  display:flex;
  flex-direction:column;
  gap:4px;
}
.pwa-install-text strong{
  font-size:15px;
  font-weight:bold;
}
.pwa-install-text span{
  font-size:13px;
  opacity:.9;
}
.pwa-install-buttons{
  display:flex;
  align-items:center;
  gap:8px;
}
.pwa-install-btn{
  padding:8px 16px;
  background:#fff;
  color:var(--brand);
  border:none;
  border-radius:8px;
  font-weight:bold;
  font-size:14px;
  cursor:pointer;
  transition:background .2s;
}
.pwa-install-btn:hover{
  background:#f0f0f0;
}
.pwa-install-btn:active{
  background:#e0e0e0;
}
.pwa-install-close{
  width:32px;
  height:32px;
  background:transparent;
  color:#fff;
  border:none;
  font-size:24px;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  transition:background .2s;
}
.pwa-install-close:hover{
  background:rgba(255,255,255,.2);
}
@media (max-width:480px){
  .pwa-install-content{
    flex-direction:column;
    align-items:stretch;
  }
  .pwa-install-buttons{
    justify-content:space-between;
  }
  .pwa-install-btn{
    flex:1;
  }
}
.input{width:100%;padding:12px;border-radius:10px;border:1px solid var(--border);margin:8px 0 12px;font-size:15px;box-sizing:border-box}
.input:focus{outline:none;border-color:var(--brand)}
select.input{background:#fff;cursor:pointer}
.label{font-size:13px;color:#555;font-weight:700;display:block;margin-top:8px}
.label:first-child{margin-top:0}
.err{background:#ffe3e3;border:1px solid #ffb6b6;padding:10px;border-radius:10px;color:#7a1212;margin-bottom:12px}

/* Modal */
.modal-backdrop{position:fixed!important;top:0!important;left:0!important;right:0!important;bottom:0!important;background:rgba(0,0,0,.5);display:none!important;visibility:hidden!important;opacity:0!important;z-index:9999!important;align-items:center;justify-content:center;padding:20px;box-sizing:border-box;transition:opacity .3s ease}
.modal-backdrop.open{display:flex!important;visibility:visible!important;opacity:1!important}
.modal{background:#fff;border-radius:12px;box-shadow:0 4px 20px rgba(0,0,0,.3);max-width:500px;width:calc(100% - 40px);max-height:90vh;overflow-y:auto;position:relative;animation:modalFadeIn .3s ease;margin:0}
@keyframes modalFadeIn{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
.modal-header{display:flex;justify-content:space-between;align-items:center;padding:18px;border-bottom:1px solid var(--border)}
.modal-header h3{margin:0;font-size:18px;font-weight:600;display:flex;align-items:center;gap:10px}
.modal-close{background:transparent;border:none;font-size:24px;cursor:pointer;color:var(--muted);padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:background .2s}
.modal-close:hover{background:#f0f0f0}
.modal-body{padding:18px}
.modal-footer{padding:12px 18px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px}

/* ============================= */
/*  BANDEAU MANŒUVRE             */
/* ============================= */
.manoeuvre-header{
  background:#ffffff;
  border-bottom:3px solid var(--brand);
  padding:16px 0 14px;
  text-align:center !important;
  width:100%;
  display:block;
}

.manoeuvre-title{
  font-size:24px;
  font-weight:900 !important;
  letter-spacing:1px;
  text-transform:uppercase;
  color:var(--text);
  text-align:center !important;
  display:block;
  width:100%;
}

.manoeuvre-subtitle{
  margin-top:4px;
  font-size:15px;
  font-weight:600;
  color:var(--muted);
  text-align:center;
}

/* ============================= */
/*  BOARD PRINCIPAL              */
/* ============================= */
.planning-board{
  display:grid !important;
  grid-template-columns:1.1fr 1fr 1fr 0.85fr 0.85fr !important;
  grid-template-rows:1fr !important;
  gap:8px;
  padding:8px;
  height:calc(100vh - 140px - 66px); /* header (60px) + titre (~60px) + menu du bas (66px) */
  overflow:hidden;
  margin-bottom:0; /* Pas d'espace avant le menu */
  max-height:calc(100vh - 140px - 66px); /* Force la hauteur maximale */
  position:relative; /* Pour éviter les débordements */
  width:100% !important;
  max-width:100% !important;
  box-sizing:border-box;
  margin:0;
  border-radius:8px;
  background:#e9ecef; /* Fond uni sans séparateurs verticaux */
}

/* Colonnes */
.board-col{
  display:flex !important;
  flex-direction:column !important;
  height:100% !important;
  min-width:0;
  background:transparent;
}

/* Personnel - pleine hauteur */
.planning-board > .board-col.personnel{
  grid-column:1 !important;
  grid-row:1 !important;
}

/* SSUAP - pleine hauteur */
.planning-board > .board-col:nth-child(2){
  grid-column:2 !important;
  grid-row:1 !important;
}

/* INCENDIE - pleine hauteur */
.planning-board > .board-col:nth-child(3){
  grid-column:3 !important;
  grid-row:1 !important;
}

/* DIVERS / ALIMENTATION */
.planning-board > .board-col:nth-child(4){
  grid-column:4 !important;
  grid-row:1 !important;
}

/* ABSENTS / INDISPO */
.planning-board > .board-col:nth-child(5){
  grid-column:5 !important;
  grid-row:1 !important;
}

.board-col.split{
  gap:8px;
}

.board-col.split .board-card{
  flex:1;
  min-height:0;
}

/* Cartes */
.board-card{
  display:flex;
  flex-direction:column;
  height:100%;
  padding:8px;
  border-radius:8px;
  box-shadow:0 2px 6px rgba(0,0,0,.12);
  min-height:0; /* Permet au flex de fonctionner correctement */
}

.board-card h3{
  font-size:13px;
  font-weight:800 !important;
  text-align:center !important;
  text-transform:uppercase;
  letter-spacing:.8px;
  margin:0 0 8px;
  padding:6px 0;
  border-radius:6px;
  background:#f4f6f8;
  border:1px solid var(--border);
  display:block;
  width:100%;
}

/* Couleurs spécifiques par mission */
.board-card.suap h3{
  border-color:#27ae60;
  color:#27ae60;
}

.board-card.incendie h3{
  border-color:var(--brand);
  color:var(--brand);
}

.board-card.divers h3{
  border-color:#e67e22;
  color:#e67e22;
}

.board-card.alimentation h3{
  border-color:#f39c12;
  color:#f39c12;
}

.board-card.absent h3{
  border-color:#c0392b;
  color:#c0392b;
}

.board-card.indispo h3{
  border-color:#7f8c8d;
  color:#7f8c8d;
}

/* Labels des véhicules */
.vehicle-label{
  font-size:10px;
  color:var(--muted);
  text-align:center;
  margin-bottom:4px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.5px;
}

.vehicle-labels{
  display:block;
  text-align:center;
  margin-bottom:4px;
}

.vehicle-labels .vehicle-label{
  margin-bottom:2px;
  display:block;
}

/* Corps scrollable */
.board-body{
  flex:1 1 0; /* Force le flex à prendre toute la hauteur disponible */
  overflow-y:auto; /* Scroll si le contenu dépasse */
  overflow-x:hidden;
  background:#f8f9fa;
  border-radius:4px;
  padding:6px;
  position:relative;
  min-height:32px; /* Hauteur minimale réduite pour les zones vides */
}

/* Blocs véhicules */
.vehicle-block{
  border:1px dashed var(--border);
  border-radius:6px;
  margin-bottom:8px;
  padding:6px;
  background:#fff;
  display:flex;
  flex-direction:column;
  min-height:0;
}

/* VSAV : le bloc doit prendre toute la hauteur disponible */
.board-card.suap .vehicle-block{
  flex:1;
  margin-bottom:8px; /* Espace entre VSAV et VLU/SacPS */
}

.board-card.suap .vehicle-block:last-child{
  margin-bottom:0; /* Pas d'espace après le dernier bloc */
}

.vehicle-title{
  font-size:11px;
  font-weight:800;
  text-align:center;
  margin-bottom:6px;
  letter-spacing:.6px;
  color:var(--text);
}

.vehicle-dropzone{
  min-height:32px; /* Hauteur minimale réduite pour toutes les zones vides */
  overflow-y:auto; /* Scroll si le contenu dépasse */
  border:2px dashed #ccc;
  border-radius:6px;
  position:relative;
  background:#fafafa;
  padding:4px;
}

.vehicle-dropzone:empty::after{
  content:"+";
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%);
  font-size:28px;
  font-weight:700;
  color:#bbb;
  pointer-events:none;
}

.vehicle-dropzone.drag-over{
  background:#e8f5e9;
  border:2px dashed #27ae60;
  border-color:#27ae60;
}

/* VSAV, VLU/SacPS, FPT : scroll si contenu dépasse */
.vehicle-dropzone[data-vehicle="vsav"],
.vehicle-dropzone[data-vehicle="vlu-sacps"],
.vehicle-dropzone[data-vehicle="fpt"]{
  flex:1;
  min-height:80px;
  max-height:100%; /* Limite la hauteur pour activer le scroll */
  overflow-y:auto; /* Scroll si le contenu dépasse */
}

/* PERSONNEL – mini cards */
.person-line{
  background:#fff;
  border:2px solid var(--brand);
  border-radius:6px;
  padding:6px 8px;
  margin-bottom:6px;
  font-size:11px;
  font-weight:600;
  white-space:nowrap;
  box-shadow:0 2px 4px rgba(0,0,0,.1);
  cursor:grab;
  user-select:none;
  transition:all .2s;
  position:relative;
  display:block;
  min-height:32px;
}

.person-grade{
  display:inline-block;
  min-width:55px;
  color:#555;
  font-weight:700;
  font-size:11px;
}

.person-name{
  font-weight:700;
  color:#2c3e50;
  font-size:11px;
}

.person-line.dragging{
  opacity:0.6;
  transform:scale(0.98);
  border-color:#27ae60;
  box-shadow:0 4px 8px rgba(39,174,96,.3);
}

.person-line:hover{
  box-shadow:0 3px 6px rgba(0,0,0,.15);
  border-color:var(--brand);
  transform:translateY(-1px);
}

.person-line:active{
  cursor:grabbing;
}

/* ============================= */
/*  COULEURS MISSIONS            */
/* ============================= */
.board-card.suap{border-left:4px solid #27ae60}
.board-card.incendie{border-left:4px solid var(--brand)}
.board-card.divers{border-left:4px solid #e67e22}
.board-card.alimentation{border-left:4px solid #f39c12}
.board-card.absent{border-left:4px solid var(--brand);background:#fff5f5}
.board-card.indispo{border-left:4px solid #7f8c8d}

/* Zone de drop active */
.board-body.drag-over,
.vehicle-dropzone.drag-over{
  background:#e8f5e9;
  border:2px dashed #27ae60;
}


/* Wrapper pour rôle + personne */
.dd-role-wrapper{
  margin-bottom:4px;
}

/* Rôle centré dans la colonne (en dehors de l'étiquette) */
.dd-role-wrapper .dd-person-role,
.board-body .dd-person-role{
  font-size:11px;
  color:var(--brand);
  font-weight:700;
  text-align:center;
  margin-bottom:3px;
  width:100%;
  display:block;
  text-transform:uppercase;
  letter-spacing:0.5px;
}


/* Bouton de suppression dans les zones de drop */
.dd-remove-btn{
  position:absolute;
  top:2px;
  right:2px;
  background:#e74c3c;
  color:#fff;
  border:none;
  border-radius:50%;
  width:20px;
  height:20px;
  cursor:pointer;
  font-size:14px;
  line-height:1;
  padding:0;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:background .2s;
}

.dd-remove-btn:hover{
  background:#c0392b;
}


/* Modal de sélection de rôle */
.role-select-modal{
  position:fixed !important;
  top:0 !important;
  left:0 !important;
  width:100vw !important;
  height:100vh !important;
  z-index:9999 !important;
  display:none !important; /* Cachée par défaut */
  align-items:center !important;
  justify-content:center !important;
  pointer-events:auto !important;
  margin:0 !important;
  padding:0 !important;
}

.role-select-modal.show{
  display:flex !important; /* Affichée uniquement avec la classe .show */
}

.role-select-backdrop{
  position:absolute !important;
  top:0 !important;
  left:0 !important;
  right:0 !important;
  bottom:0 !important;
  background:rgba(0,0,0,.5) !important;
  z-index:1 !important;
}

.role-select-content{
  position:relative !important;
  background:#fff !important;
  border-radius:12px;
  padding:24px;
  box-shadow:0 8px 32px rgba(0,0,0,.4);
  min-width:320px;
  max-width:90vw;
  z-index:2 !important;
  margin:0 !important;
  transform:translate(0, 0) !important;
  border:2px solid var(--brand);
}

.role-select-content h4{
  margin:0 0 16px 0;
  font-size:18px;
  font-weight:700;
  text-align:center;
  color:var(--text);
}

.role-select-dropdown{
  width:100%;
  padding:10px;
  border:1px solid var(--border);
  border-radius:8px;
  font-size:14px;
  margin-bottom:12px;
  background:#fff;
  cursor:pointer;
}

.role-select-dropdown:focus{
  outline:none;
  border-color:var(--brand);
}

.role-select-buttons{
  display:flex;
  gap:8px;
  justify-content:flex-end;
}

.role-select-buttons .btn{
  padding:8px 16px;
  font-size:13px;
}

/* Responsive sécurité (si besoin plus tard) */
@media (max-width:1100px){
  .planning-board{
    grid-template-columns:1fr !important;
    height:auto;
  }
}

/* ============================= */
/*  IMPRESSION A4 PAYSAGE        */
/* ============================= */
@media print {
  @page {
    size: A4 landscape;
    margin: 10mm;
  }
  
  /* Masquer les éléments non nécessaires à l'impression */
  body .container,
  .nav-bottom,
  .sheet,
  .manoeuvre-header {
    display: none !important;
  }
  
  /* Masquer la colonne Agent disponible */
  .board-col.personnel {
    display: none !important;
  }
  
  /* Ajuster le planning-board pour l'impression */
  .planning-board {
    display: grid !important;
    grid-template-columns: 1fr 1fr 0.85fr 0.85fr !important; /* 4 colonnes au lieu de 5 */
    grid-template-rows: auto !important;
    height: auto !important;
    max-height: none !important;
    page-break-inside: avoid;
    margin: 0 !important;
    padding: 5mm !important;
    gap: 3mm !important;
  }
  
  /* Ajuster les cartes pour l'impression */
  .board-card {
    page-break-inside: avoid;
    break-inside: avoid;
    box-shadow: none !important;
    border: 1px solid #000 !important;
  }
  
  /* Ajuster les zones de drop pour afficher tout le contenu */
  .vehicle-dropzone,
  .board-body {
    overflow: visible !important;
    max-height: none !important;
    height: auto !important;
    min-height: auto !important;
  }
  
  /* Ajuster les blocs véhicules */
  .vehicle-block {
    page-break-inside: avoid;
    break-inside: avoid;
    margin-bottom: 3mm !important;
  }
  
  /* Ajuster les person-line pour l'impression */
  .person-line {
    page-break-inside: avoid;
    break-inside: avoid;
    font-size: 9px !important;
    padding: 3px 5px !important;
    margin-bottom: 2px !important;
  }
  
  .person-grade,
  .person-name {
    font-size: 9px !important;
  }
  
  /* Ajuster les titres */
  .board-card h3 {
    font-size: 11px !important;
    padding: 3px 0 !important;
    margin-bottom: 3px !important;
  }
  
  .vehicle-title {
    font-size: 9px !important;
    margin-bottom: 2px !important;
  }
  
  /* Masquer les boutons de suppression */
  .dd-remove-btn {
    display: none !important;
  }
  
  /* Ajuster les rôles */
  .dd-person-role {
    font-size: 8px !important;
  }
  
  /* Forcer l'affichage de tout le contenu */
  .board-col.split {
    display: flex !important;
    flex-direction: column !important;
    gap: 3mm !important;
  }
  
  .board-col.split .board-card {
    flex: 1 1 auto !important;
  }
}
