/* ============================================================
   ANIMA — Module Infirmerie (B2 + B3 + B4)
   ------------------------------------------------------------
   Poste sanitaire AS. Réutilise tokens + primitives .glass /
   .seg / .tag / .empty-state / .sf-btn de styles.css. AUCUNE
   valeur hex en dur : tout passe par les custom properties.
   Non lié dans index.html → branché en B5 (avec cache-buster).
   ============================================================ */

.inf-module{display:flex; flex-direction:column; gap:var(--sp-4); padding:18px 0 56px}

/* ---------- Nav interne par onglets (réutilise .seg) ---------- */
.inf-nav{align-self:flex-start; max-width:100%; flex-wrap:wrap}
.inf-nav button{position:relative}
.inf-tab-count{
  min-width:18px; height:18px; padding:0 5px; border-radius:9px; display:inline-grid; place-items:center;
  font-size:.62rem; line-height:1; background:var(--accent-bg); color:var(--accent);
  border:1px solid var(--accent-glow);
}
.inf-nav button.on .inf-tab-count{background:rgba(255,248,238,.18); color:var(--bg-0); border-color:transparent}

/* ---------- En-têtes de bloc ---------- */
.inf-block-head{display:flex; align-items:center; gap:10px; margin:0 0 14px}
.inf-block-ico{color:var(--accent); display:grid; place-items:center}
.inf-block-ico svg{width:18px; height:18px}
.inf-block-title{font-size:1rem; font-weight:600; color:var(--text); letter-spacing:.01em}

/* ---------- Pastille de niveau (monochrome, chiffre) ---------- */
.inf-niv{
  width:28px; height:28px; border-radius:8px; flex:none; display:grid; place-items:center;
  border:1px solid var(--line-2); background:rgba(15,12,10,.4);
}
.inf-niv-num{font-size:.86rem; font-weight:700; line-height:1}
.inf-niv--0{color:var(--text-3); border-color:var(--line)}
.inf-niv--1{color:var(--accent); border-color:var(--accent-glow); background:var(--accent-bg)}
.inf-niv--2{color:var(--warn); border-color:var(--warn-line); background:var(--warn-bg)}
.inf-niv--3{color:var(--crit); border-color:var(--crit-line); background:var(--crit-bg)}

.inf-badge-ico{display:inline-grid; place-items:center}
.inf-badge-ico svg{width:13px; height:13px}

/* ---------- Liste des fiches ---------- */
.inf-list-wrap,.inf-today-wrap,.inf-docs-wrap,.inf-baignade-wrap{display:flex; flex-direction:column}
.inf-list{list-style:none; display:flex; flex-direction:column; gap:8px}
.inf-row{border-radius:var(--r-md); border:1px solid var(--line); background:linear-gradient(160deg, var(--glass-from), var(--glass-to))}
.inf-row--n3{border-color:var(--crit-line)}
.inf-row--n2{border-color:var(--warn-line)}
.inf-row-btn{
  width:100%; display:flex; align-items:center; gap:13px; padding:12px 15px; cursor:pointer;
  background:none; border:0; color:inherit; text-align:left; border-radius:var(--r-md);
  transition:background var(--dur-fast) var(--ease-out);
}
.inf-row-btn:hover,.inf-row-btn:focus-visible{background:var(--glass-soft-from); outline:none}
.inf-row-main{flex:1; min-width:0; display:flex; flex-direction:column; gap:6px}
.inf-row-name{font-size:.92rem; font-weight:600; color:var(--text)}
.inf-row-badges{display:flex; align-items:center; gap:7px; flex-wrap:wrap}
.inf-row-sub{font-size:.7rem; color:var(--text-3)}
.inf-row-chev{color:var(--text-3); display:grid; place-items:center; flex:none}
.inf-row-chev svg{width:18px; height:18px}
.inf-badge-photo,.inf-badge-revue{gap:5px}

/* ---------- Détail fiche ---------- */
.inf-detail-head{display:flex; align-items:center; gap:16px; flex-wrap:wrap; margin-bottom:4px}
.inf-detail-title{display:flex; align-items:center; gap:11px; flex-wrap:wrap}
.inf-detail-title h2{font-size:1.25rem; font-weight:700; letter-spacing:-.01em; color:var(--text)}
.inf-detail-grid{display:grid; gap:var(--sp-3); grid-template-columns:repeat(2, minmax(0, 1fr))}
.inf-panel{border-radius:var(--r-lg); overflow:hidden}
.inf-panel > .inf-block-head{padding:13px 16px 0; margin-bottom:10px}
.inf-panel-body{padding:0 16px 16px; display:flex; flex-direction:column; gap:10px}
.inf-panel--crit{border-color:var(--crit-line)}
.inf-panel--crit .inf-block-ico{color:var(--crit)}
.inf-panel--health{border-color:var(--warn-line)}
.inf-panel--health .inf-block-ico{color:var(--warn)}

/* champ étiqueté + valeur (vide = explicite, jamais blanc muet) */
.inf-field{display:flex; flex-direction:column; gap:2px}
.inf-field-lbl{font-family:var(--font-sans); font-size:.64rem; color:var(--text-3); letter-spacing:.07em; text-transform:uppercase}
.inf-field-val{font-size:.86rem; color:var(--text); line-height:1.45; white-space:pre-wrap; word-break:break-word}
.inf-field-val--empty{color:var(--text-3); font-style:italic}
.inf-att-text{font-size:.92rem; color:var(--text); line-height:1.5; white-space:pre-wrap}

/* réglage soignant */
.inf-adjust{display:flex; align-items:center; gap:12px; flex-wrap:wrap}
.inf-adjust-lbl{font-size:.8rem; color:var(--text-2); font-weight:500}
.inf-adjust-seg button{min-width:40px; justify-content:center; font-family:var(--font-mono); padding:8px 0}
.inf-adjust-auto{font-size:.7rem; color:var(--text-3)}
.inf-revue{display:flex; align-items:center; gap:9px; font-size:.86rem; color:var(--text-2); cursor:pointer; margin-top:2px}
.inf-revue-cb,.inf-doc-check input,.inf-today-cb{
  width:18px; height:18px; flex:none; accent-color:var(--accent); cursor:pointer;
}

/* contacts */
.inf-contact{border:1px solid var(--line); border-radius:var(--r-sm); padding:11px 13px; display:flex; flex-direction:column; gap:8px}
.inf-contact + .inf-contact{margin-top:8px}
.inf-contact-idx{font-size:.66rem; color:var(--accent)}

/* suivi : pièces, rappels, notes */
.inf-doc-line,.inf-rappel-line{display:flex; align-items:center; gap:9px; font-size:.84rem; color:var(--text-2)}
.inf-doc-line.is-done .inf-doc-label{color:var(--text-3); text-decoration:line-through}
.inf-doc-req{background:var(--surface-2); color:var(--text-3); border-color:var(--line)}
.inf-doc-label,.inf-rappel-lbl{flex:1; min-width:0}
.inf-rappel-h,.inf-maj{font-size:.72rem; color:var(--text-3)}
.inf-notes{font-size:.84rem; color:var(--text); line-height:1.5; white-space:pre-wrap}
.inf-maj{margin-top:4px}

/* baignade — éditeur réutilisé */
.inf-baignade-edit{display:flex; flex-direction:column; gap:11px}
.inf-aisance-seg{display:flex; flex-wrap:wrap; gap:7px}
.inf-aisance-opt{
  font-family:var(--font-sans); font-size:.76rem; font-weight:500; color:var(--text-2);
  border:1px solid var(--line); background:rgba(15,12,10,.35); border-radius:var(--r-xs);
  padding:7px 12px; cursor:pointer; transition:.16s;
}
.inf-aisance-opt:hover{border-color:var(--line-2); color:var(--text)}
.inf-aisance-opt.on{color:var(--bg-0); background:var(--accent); border-color:transparent; font-weight:600}
.inf-aisance-opt.inf-aisance--2.on{background:var(--warn)}
.inf-aisance-opt.inf-aisance--3.on{background:var(--crit)}
.inf-note-field{display:flex; flex-direction:column; gap:6px}
.inf-note-input{
  font-family:var(--font-sans); font-size:.84rem; color:var(--text); background:rgba(15,12,10,.4);
  border:1px solid var(--line); border-radius:var(--r-sm); padding:9px 11px; resize:vertical; min-height:44px;
}
.inf-note-input:focus{outline:none; border-color:var(--line-2)}

/* ---------- Aujourd'hui ---------- */
.inf-today-list{list-style:none; display:flex; flex-direction:column; gap:8px; margin-top:14px}
.inf-today-item{border:1px solid var(--line); border-radius:var(--r-md); background:linear-gradient(160deg, var(--glass-from), var(--glass-to))}
.inf-today-item.is-done{opacity:.55}
.inf-today-item.is-done .inf-today-geste{text-decoration:line-through; color:var(--text-3)}
.inf-today-check{display:flex; align-items:center; gap:13px; padding:12px 15px; cursor:pointer}
.inf-today-body{display:flex; flex-direction:column; gap:4px; min-width:0}
.inf-today-geste{font-size:.9rem; font-weight:600; color:var(--text)}
.inf-today-sub{display:flex; align-items:center; gap:9px; flex-wrap:wrap}
.inf-today-jeune{font-size:.78rem; color:var(--text-2)}
.inf-today-h{font-size:.74rem; color:var(--accent)}

/* ---------- Documents ---------- */
.inf-docgroup{border-radius:var(--r-lg); overflow:hidden; margin-top:10px}
.inf-docgroup-head{display:flex; align-items:center; gap:11px; padding:12px 15px; border-bottom:1px solid var(--line)}
.inf-docgroup-name{font-size:.9rem; font-weight:600; color:var(--text)}
.inf-docgroup-count{margin-left:auto; font-size:.72rem; color:var(--warn)}
.inf-docgroup-list{list-style:none; display:flex; flex-direction:column; gap:2px; padding:8px 15px 12px}
.inf-doc-todo .inf-doc-check{display:flex; align-items:center; gap:11px; padding:7px 0; cursor:pointer; font-size:.86rem; color:var(--text-2)}

/* ---------- Baignade (tableau) ---------- */
.inf-baignade-table{display:flex; flex-direction:column; gap:8px; margin-top:14px}
.inf-bg-row{
  display:flex; align-items:flex-start; gap:16px; flex-wrap:wrap; padding:13px 15px;
  border:1px solid var(--line); border-radius:var(--r-md); background:linear-gradient(160deg, var(--glass-from), var(--glass-to));
}
.inf-bg-row--risk{border-color:var(--crit-line); background:var(--crit-bg)}
.inf-bg-name{display:flex; align-items:center; gap:10px; flex-wrap:wrap; min-width:200px; flex:1; font-size:.9rem; font-weight:600; color:var(--text)}
.inf-bg-ctrl{flex:2; min-width:240px}
.inf-bg-flag{gap:5px}

/* ---------- Messages (erreur, hors-ligne) ---------- */
.inf-msg{display:flex; gap:13px; align-items:flex-start; padding:16px; border-radius:var(--r-lg)}
.inf-msg--crit{border-color:var(--crit-line)}
.inf-msg-ico{color:var(--crit); flex:none; display:grid; place-items:center}
.inf-msg-ico svg{width:22px; height:22px}
.inf-msg-title{display:block; font-size:.88rem; font-weight:600; color:var(--text); margin-bottom:4px}
.inf-msg-body{font-size:.82rem; color:var(--text-2); line-height:1.45}
.inf-empty-btn{margin-top:12px}
.inf-empty-btn .ico{width:15px; height:15px}

/* ---------- B1 — rapport d'import (cohérence ; non stylé jusqu'ici) ---------- */
.inf-import .upload-zone{margin-top:6px}
.inf-stats{list-style:none; display:grid; grid-template-columns:repeat(auto-fit, minmax(150px, 1fr)); gap:10px; margin:16px 0}
.inf-stat{display:flex; align-items:baseline; gap:9px; padding:12px 14px; border:1px solid var(--line); border-radius:var(--r-md); background:rgba(15,12,10,.3)}
.inf-stat-val{font-size:1.3rem; font-weight:700; color:var(--text)}
.inf-stat-lab{font-size:.72rem; color:var(--text-3)}
.inf-stat--ok .inf-stat-val{color:var(--ok)}
.inf-stat--warn .inf-stat-val{color:var(--warn)}
.inf-vides{margin-top:14px}
.inf-vides-list{list-style:none; display:flex; flex-direction:column; gap:5px; font-size:.82rem; color:var(--text-2); margin-top:8px}
.inf-vides-list li{padding-left:14px; position:relative}
.inf-vides-list li::before{content:''; position:absolute; left:0; top:8px; width:5px; height:5px; border-radius:50%; background:var(--warn)}

/* ---------- Responsive (cible portable Ulefone) ---------- */
@media (max-width:760px){
  .inf-detail-grid{grid-template-columns:1fr}
  .inf-nav{width:100%}
  .inf-nav button{flex:1; justify-content:center}
  .inf-nav .inf-tab-lbl{display:none}
  .inf-bg-row{flex-direction:column; gap:10px}
  .inf-bg-ctrl{width:100%}
}
