:root{
  --ink:#14110E; --paper:#FFFFFF; --blue:#1E4E8C; --red:#B11226;
  --graphite:#6B6660; --rule:#E4E1DA; --wash:#FAF9F6;
  --grotesk:"Helvetica Neue",Arial,"Liberation Sans",sans-serif;
  --tech:"Bahnschrift","Arial Narrow",ui-monospace,"DejaVu Sans Mono",monospace;
  --serif:Georgia,"Times New Roman",serif;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;height:100%}
body{background:var(--paper);color:var(--ink);font-family:var(--serif);
  display:flex;flex-direction:column;min-height:100vh;max-width:560px;margin:0 auto;
  box-shadow:0 0 0 1px var(--rule)}

/* ---------- en-tête registre + logo ---------- */
.ledger-head{padding:12px 16px 11px;border-bottom:2px solid var(--ink);position:sticky;top:0;background:var(--paper);z-index:5}
.ledger-top{display:flex;justify-content:space-between;align-items:center;gap:12px}
#logo{height:30px;cursor:pointer}
.ref{font-family:var(--tech);font-size:12px;color:var(--blue);letter-spacing:.05em;text-align:right}
.ledger-line{display:flex;gap:12px;align-items:baseline;margin-top:9px;
  font-family:var(--tech);font-size:13px;letter-spacing:.03em;flex-wrap:wrap}
.ledger-line .date{font-weight:700;text-transform:capitalize}
.ledger-line .meta{color:var(--graphite)}
#hStatus{margin-left:auto;font-family:var(--tech);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  border:1.5px solid var(--ink);padding:2px 8px}
#hStatus.open{color:var(--blue);border-color:var(--blue)}

.scroll{flex:1;overflow-y:auto;padding-bottom:90px}
.eyebrow{font-family:var(--tech);text-transform:uppercase;letter-spacing:.2em;font-size:10.5px;color:var(--blue);padding:16px 16px 8px}
.rowline{display:flex;gap:10px;padding:12px 16px 0}
.ghost{font-family:var(--grotesk);font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:11px;
  border:1.5px solid var(--ink);background:var(--paper);color:var(--ink);padding:9px 13px;cursor:pointer}
.ghost:active{background:var(--ink);color:var(--paper)}

/* ---------- synthèse ---------- */
.tally{display:flex;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.tally>div{flex:1;padding:12px 14px;border-right:1px solid var(--rule)}
.tally>div:last-child{border-right:0}
.tally .n{font-family:var(--tech);font-weight:700;font-size:24px;line-height:1}
.tally .n .frac{font-size:14px;color:var(--graphite)}
.tally .n.alert{color:var(--red)}
.tally .l{font-family:var(--grotesk);text-transform:uppercase;letter-spacing:.1em;font-size:9.5px;color:var(--graphite);margin-top:5px}

/* ---------- journal : gouttière réglée ---------- */
.journal .entry{display:grid;grid-template-columns:64px 1fr;border-bottom:1px solid var(--rule)}
.gutter{border-right:1px solid var(--rule);padding:12px 0 12px 14px;position:relative}
.gutter::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:var(--fc,var(--graphite))}
.gutter .t{font-family:var(--tech);font-weight:700;font-size:14px}
.gutter .fam{font-family:var(--tech);text-transform:uppercase;font-size:8.5px;letter-spacing:.1em;color:var(--graphite);margin-top:3px}
.body{padding:11px 14px 12px}
.body .cat{font-family:var(--grotesk);font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:11px;color:var(--fc,var(--ink))}
.body .desc{font-size:15px;line-height:1.42;margin:5px 0 0}
.locs{display:flex;flex-wrap:wrap;gap:5px;margin-top:8px}
.loc{font-family:var(--tech);font-size:11px;border:1px solid var(--rule);padding:1px 7px}
.badges{display:flex;flex-wrap:wrap;gap:6px;margin-top:9px}
.badge{font-family:var(--tech);font-size:10px;text-transform:uppercase;letter-spacing:.08em;padding:2px 7px;border:1px solid var(--ink)}
.badge.fuda{border-color:var(--blue);color:var(--blue)}
.badge.demain{border-color:#C77400;color:#C77400}
.badge.hot{background:var(--red);border-color:var(--red);color:#fff}

/* ---------- effectifs ---------- */
.crew{border-bottom:1px solid var(--rule);padding:13px 16px}
.crew-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.crew .co{font-family:var(--grotesk);font-weight:700;letter-spacing:.04em;font-size:14px}
.crew .lot{font-family:var(--tech);font-size:11px;color:var(--graphite);text-transform:uppercase;letter-spacing:.05em;margin-top:2px}
.crew .chief{display:inline-block;font-family:var(--tech);font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;margin-top:5px}
.crew .chief.on{color:#2E7D4F}
.crew .chief.off{color:var(--red)}
.crew-right{display:flex;align-items:center;gap:10px;flex-shrink:0}
.crew .cnt{font-family:var(--tech);font-size:14px}
.crew .cnt b{font-size:17px}
.pres{font-family:var(--tech);text-transform:uppercase;letter-spacing:.08em;font-size:10px;border:1.5px solid var(--rule);
  background:var(--paper);color:var(--graphite);padding:7px 10px;cursor:pointer}
.pres.on{border-color:var(--ink);color:var(--ink)}
.postes{margin-top:12px;border-top:1px solid var(--rule);padding-top:10px}
.poste{display:flex;align-items:center;gap:10px;padding:6px 0;flex-wrap:wrap}
.poste .pn{font-family:var(--tech);font-size:13px;min-width:120px;flex:1}
.poste .pn.chefn{color:var(--blue);font-weight:700}
.poste .ps{display:flex;align-items:center;gap:6px}
.poste .psl{font-family:var(--tech);font-size:9px;text-transform:uppercase;letter-spacing:.08em;color:var(--graphite)}
.poste .rm{border:0;background:none;color:var(--graphite);font-size:15px;cursor:pointer;padding:4px}
.stepper{display:flex;align-items:center}
.stepper button{width:30px;height:30px;border:1.5px solid var(--ink);background:var(--paper);font-size:16px;line-height:1;cursor:pointer;color:var(--ink)}
.stepper button:active{background:var(--ink);color:var(--paper)}
.stepper .val{min-width:30px;text-align:center;font-family:var(--tech);font-weight:700;font-size:15px}
.addposte{margin-top:8px}
.addposte select,.hint{font-family:var(--tech);font-size:12px}
.hint{color:var(--graphite);padding:4px 0}
.addposte select{border:1.5px solid var(--rule);padding:8px;background:var(--paper);color:var(--ink);width:100%}
.crew-foot{display:flex;justify-content:space-between;align-items:baseline;padding:16px;border-top:2px solid var(--ink);font-family:var(--tech)}
.crew-foot .lab{text-transform:uppercase;letter-spacing:.14em;font-size:11px;color:var(--graphite)}
.crew-foot .big{font-weight:700;font-size:22px}
.crew-foot .big b{color:var(--blue)}

/* ---------- photos ---------- */
.pgrid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--rule);border-top:1px solid var(--rule);margin-top:8px}
.ph{background:var(--wash);aspect-ratio:4/3;position:relative;display:flex;flex-direction:column;justify-content:flex-end;padding:8px;overflow:hidden}
.ph img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.ph .tab{position:absolute;top:0;left:0;width:5px;height:100%;z-index:2}
.ph .frame{position:absolute;inset:0;background:repeating-linear-gradient(135deg,#efece6 0 10px,#f6f4f0 10px 20px)}
.ph .cap,.ph .when{position:relative;z-index:3;font-family:var(--tech)}
.ph .cap{font-size:11px;background:var(--paper);display:inline-block;padding:1px 5px;align-self:flex-start}
.ph .when{font-size:10px;color:var(--graphite);background:var(--paper);display:inline-block;padding:0 5px;margin-top:2px;align-self:flex-start}

/* ---------- navigation ---------- */
.tabbar{position:fixed;left:50%;transform:translateX(-50%);bottom:0;width:100%;max-width:560px;height:64px;background:var(--paper);
  border-top:2px solid var(--ink);display:flex}
.tabbar button{flex:1;border:0;background:none;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  font-family:var(--grotesk);cursor:pointer;color:var(--graphite)}
.tabbar button .ic{font-family:var(--tech);font-weight:700;font-size:16px;line-height:1}
.tabbar button .tx{text-transform:uppercase;letter-spacing:.1em;font-size:9px}
.tabbar button.on{color:var(--ink)}
.tabbar button.on .ic{color:var(--blue)}
.fab{position:fixed;left:50%;margin-left:198px;bottom:78px;width:58px;height:58px;border-radius:50%;background:var(--ink);color:var(--paper);
  border:0;font-size:30px;cursor:pointer;box-shadow:0 6px 18px rgba(0,0,0,.3);z-index:20}
@media(max-width:480px){.fab{margin-left:0;right:18px;left:auto;transform:none}}

/* ---------- feuilles ---------- */
.sheet-wrap{position:fixed;inset:0;z-index:40;display:none}
.sheet-wrap.show{display:block}
.scrim{position:absolute;inset:0;background:rgba(20,17,14,.45)}
.sheet{position:absolute;left:50%;transform:translateX(-50%) translateY(100%);bottom:0;width:100%;max-width:560px;background:var(--paper);
  border-top:2px solid var(--ink);max-height:92%;overflow-y:auto;animation:up .26s forwards}
@media(prefers-reduced-motion:reduce){.sheet{animation:none;transform:translateX(-50%)}}
.sheet h2{font-family:var(--grotesk);font-weight:800;text-transform:uppercase;letter-spacing:.1em;font-size:13px;margin:0;
  padding:16px 16px 4px;display:flex;justify-content:space-between;align-items:center}
.sheet h2 .x{font-family:var(--tech);color:var(--graphite);cursor:pointer;font-size:20px}
.field{padding:12px 16px;border-top:1px solid var(--rule)}
.field>.lab{font-family:var(--tech);text-transform:uppercase;letter-spacing:.12em;font-size:10px;color:var(--graphite);display:block;margin-bottom:8px}
.field.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.chips{display:flex;flex-wrap:wrap;gap:7px}
.chip{font-family:var(--grotesk);font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:11px;border:1.5px solid var(--rule);
  padding:7px 11px;cursor:pointer;color:var(--graphite);background:var(--paper);display:flex;align-items:center;gap:7px}
.chip .dot{width:9px;height:9px;display:inline-block}
.chip[aria-pressed="true"]{border-color:var(--ink);color:var(--ink)}
.imp{display:flex;gap:7px}
.imp .chip{flex:1;justify-content:center}
.imp .chip[data-v="haute"][aria-pressed="true"]{border-color:var(--red);color:var(--red)}
input,textarea,select{width:100%;font-family:var(--serif);font-size:15px;border:1.5px solid var(--rule);padding:10px;background:var(--paper);color:var(--ink)}
.field.grid3 input,.field.grid3 select{font-family:var(--tech)}
input:focus,textarea:focus,select:focus,.chip:focus-visible,button:focus-visible{outline:2px solid var(--blue);outline-offset:2px}
.toggles{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.toggle{font-family:var(--tech);text-transform:uppercase;letter-spacing:.06em;font-size:11px;border:1.5px solid var(--rule);
  padding:11px;cursor:pointer;color:var(--graphite);background:var(--paper);text-align:left}
.toggle[aria-pressed="true"]{border-color:var(--ink);color:var(--ink)}
.toggle[data-k="createFudaSubject"][aria-pressed="true"]{border-color:var(--blue);color:var(--blue)}
.save{margin:14px 16px 24px;width:calc(100% - 32px);background:var(--ink);color:var(--paper);border:0;
  font-family:var(--grotesk);font-weight:800;text-transform:uppercase;letter-spacing:.1em;font-size:13px;padding:16px;cursor:pointer}

.empty{padding:36px 24px;text-align:center;color:var(--graphite)}
.empty .big{font-family:var(--serif);font-size:17px;color:var(--ink)}
.empty .sm{font-family:var(--tech);font-size:12px;text-transform:uppercase;letter-spacing:.1em;margin-top:8px}
.toast{position:fixed;left:50%;bottom:92px;transform:translateX(-50%) translateY(20px);background:var(--ink);color:var(--paper);
  font-family:var(--tech);font-size:12px;letter-spacing:.04em;padding:10px 16px;opacity:0;transition:.25s;z-index:60;pointer-events:none}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
@keyframes up{to{transform:translateX(-50%) translateY(0)}}
