/* e-LAB v0.1.0 - charte validee (POC v8) : sombre par defaut, clair derive */
:root{
  color-scheme:dark;
  --bg:#0D1117; --surface:#151B23; --surface2:#1C242E; --raise:#212B37;
  --line:#232D39; --line2:#2D3947;
  --text:#E8EEF4; --muted:#8B99A8; --faint:#5B6875;
  --accent:#2BD9C7; --accent2:#19B3A6; --accent-glow:rgba(43,217,199,.14);
  --on-accent:#06312C;
  --violet:#8B7CF6; --amber:#F5B94A; --blue:#5EA2F7; --rouge:#F26D6D;
  --r:14px; --r-sm:9px;
}
html[data-theme="light"]{
  color-scheme:light;
  --bg:#F2F5F7; --surface:#FFFFFF; --surface2:#EEF2F6; --raise:#FFFFFF;
  --line:#E3E9EE; --line2:#D2DBE2;
  --text:#16232E; --muted:#5A6B78; --faint:#94A2AE;
  --accent:#0FA79A; --accent2:#0B8A80; --accent-glow:rgba(15,167,154,.11);
  --on-accent:#FFFFFF;
  --violet:#6C5CE7; --amber:#C98A12; --blue:#2D7DD2; --rouge:#C0392B;
}
*{box-sizing:border-box;margin:0;padding:0}
[hidden]{display:none!important}
html{background:var(--bg)}
body{font-family:'Inter',-apple-system,sans-serif;background:
  radial-gradient(1200px 500px at 85% -10%,var(--accent-glow),transparent 60%),var(--bg);
  color:var(--text);min-height:100vh}
input,select,textarea,button{font:inherit;color:var(--text)}
.wordmark{font-weight:800;font-size:20px;letter-spacing:-.03em}
.wordmark span{color:var(--accent)}
.wordmark.big{font-size:30px;text-align:center}

/* ---- login ---- */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}
.login-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);
  padding:34px 30px;width:100%;max-width:380px}
.login-sub{text-align:center;color:var(--muted);font-size:13px;margin:6px 0 24px}
.login-card label{display:block;font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:.08em;color:var(--faint);margin-bottom:14px}
.login-card input{display:block;width:100%;margin-top:6px;font-size:14px;
  background:var(--surface2);border:1px solid var(--line2);border-radius:var(--r-sm);
  padding:11px 12px;outline:none}
.login-card input:focus{border-color:var(--accent)}
.login-err{color:var(--rouge);font-size:12.5px;margin-bottom:12px}
.newbtn{border:none;font-size:13px;font-weight:700;border-radius:99px;
  padding:11px 20px;cursor:pointer;color:var(--on-accent);
  background:linear-gradient(135deg,var(--accent),var(--accent2))}
.newbtn:hover{filter:brightness(1.1)}
.newbtn.wide{width:100%;margin-top:6px}
.linkbtn{display:block;width:100%;border:none;background:none;color:var(--muted);
  font-size:12.5px;margin-top:14px;cursor:pointer;text-align:center}
.linkbtn:hover{color:var(--accent)}

/* ---- shell app ---- */
.app-wrap{display:flex;min-height:100vh}
nav{width:216px;flex:none;min-height:100vh;display:flex;flex-direction:column;
  padding:22px 0;border-right:1px solid var(--line)}
nav .wordmark{padding:0 22px 24px}
nav a{display:flex;align-items:center;gap:11px;padding:9px 22px;margin:1px 10px;
  font-size:13.5px;font-weight:500;color:var(--muted);cursor:pointer;border-radius:10px;
  text-decoration:none}
nav a:hover{color:var(--text);background:var(--surface2)}
nav a.on{color:var(--text);background:var(--accent-glow)}
nav a.on .ic{color:var(--accent)}
nav a .ic{width:17px;text-align:center;font-size:14px;color:var(--faint)}
nav a .n{margin-left:auto;font-family:'JetBrains Mono',monospace;font-size:10.5px;
  background:var(--accent);color:var(--on-accent);border-radius:99px;padding:2px 8px;font-weight:700}
nav .sep{height:1px;background:var(--line);margin:14px 22px}
nav .user{margin-top:auto;padding:14px 22px;font-size:12px;color:var(--faint);line-height:1.5}
nav .user b{color:var(--muted);font-weight:600}
main{flex:1;min-width:0;padding:26px 30px;max-width:1240px}

/* ---- liste travaux ---- */
.page-head{display:flex;align-items:center;gap:14px;margin-bottom:20px;flex-wrap:wrap}
.page-head h1{font-size:21px;font-weight:700;letter-spacing:-.02em}
.page-head .spacer{flex:1}
.search{font-size:13.5px;padding:9px 16px;border:1px solid var(--line2);
  border-radius:99px;outline:none;background:var(--surface);width:250px}
.search::placeholder{color:var(--faint)}
.search:focus{border-color:var(--accent)}
.tabs{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap}
.tabs button{border:1px solid var(--line2);background:var(--surface);font-size:12.5px;
  font-weight:600;color:var(--muted);padding:7px 15px;cursor:pointer;border-radius:99px}
.tabs button:hover{color:var(--text);border-color:var(--faint)}
.tabs button.on{color:var(--on-accent);background:var(--accent);border-color:var(--accent)}
.tabs button .n{font-family:'JetBrains Mono',monospace;font-size:11px;margin-left:6px;opacity:.75}
.wlist{display:flex;flex-direction:column;gap:9px}
.wrow{display:grid;grid-template-columns:4px 96px 1.15fr 1fr 92px 64px;
  gap:14px;align-items:center;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r);padding:13px 16px 13px 0;cursor:pointer;
  transition:border-color .12s,transform .12s}
.wrow:hover{border-color:var(--accent);transform:translateY(-1px)}
.wrow .bar{align-self:stretch;border-radius:99px}
.wrow .num{font-family:'JetBrains Mono',monospace;font-size:12px;font-weight:600;color:var(--muted)}
.wrow .cl b{display:block;font-size:13.5px;font-weight:600}
.wrow .cl span,.wrow .pt span{font-size:11.5px;color:var(--muted)}
.wrow .cl .cid{font-family:'JetBrains Mono',monospace;font-size:10.5px;color:var(--faint);margin-right:5px}
.wrow .pt b{display:block;font-size:13px;font-weight:500}
.wrow .days{font-family:'JetBrains Mono',monospace;font-size:12px;font-weight:700;color:var(--accent);text-align:right}
.badge{font-size:10.5px;font-weight:700;border-radius:99px;padding:5px 11px;text-align:center}
.badge.devis{background:rgba(139,124,246,.15);color:var(--violet)}
.badge.en_cours{background:var(--accent-glow);color:var(--accent)}
.badge.fini{background:rgba(245,185,74,.14);color:var(--amber)}
.badge.releve{background:rgba(94,162,247,.14);color:var(--blue)}
.badge.facture{background:var(--surface2);color:var(--muted)}
.badge.annule{background:rgba(242,109,109,.12);color:var(--rouge)}
.placeholder{background:var(--surface);border:1px dashed var(--line2);border-radius:var(--r);
  padding:64px 20px;text-align:center;color:var(--muted);font-size:14px}

/* ---- modale nouveau travail ---- */
.modal-bg{position:fixed;inset:0;background:rgba(6,9,13,.7);z-index:100;
  display:flex;align-items:flex-start;justify-content:center;padding:8vh 14px;
  backdrop-filter:blur(3px)}
.modal{background:var(--surface);border:1px solid var(--line2);border-radius:var(--r);
  width:100%;max-width:440px;padding:22px}
.modal h3{font-size:15px;font-weight:700;margin-bottom:16px}
.modal label{display:block;font-size:10.5px;font-weight:700;text-transform:uppercase;
  letter-spacing:.08em;color:var(--faint);margin-bottom:12px}
.modal input,.modal select{display:block;width:100%;margin-top:5px;font-size:13.5px;
  background:var(--surface2);border:1px solid var(--line2);border-radius:var(--r-sm);
  padding:9px 11px;outline:none}
.modal input:focus,.modal select:focus{border-color:var(--accent)}
.modal .row{display:flex;gap:10px;justify-content:flex-end;margin-top:8px}
.btn{border:1px solid var(--line2);background:var(--surface2);font-size:12.5px;
  font-weight:600;border-radius:var(--r-sm);padding:8px 15px;cursor:pointer}
.btn:hover{border-color:var(--accent);color:var(--accent)}

@media (max-width:880px){
  nav{width:58px}
  nav .wordmark{padding:0 0 22px;text-align:center;font-size:15px}
  nav a{padding:10px 0;justify-content:center;margin:1px 8px}
  nav a .txt,nav a .n,nav .user{display:none}
  main{padding:16px 12px}
  .wrow{grid-template-columns:4px 1fr 92px;grid-template-areas:"bar cl badge" "bar pt days"}
  .wrow .bar{grid-area:bar}.wrow .cl{grid-area:cl}.wrow .pt{grid-area:pt}
  .wrow .num{display:none}
  .wrow .badge{grid-area:badge}.wrow .days{grid-area:days}
}

/* ===== v0.3.0 : editeur bon de travail ===== */
.back{border:none;background:none;font-size:13px;font-weight:600;color:var(--accent);cursor:pointer;padding:4px 0;margin-bottom:10px}
.back:hover{text-decoration:underline}
.topbar{display:flex;align-items:center;gap:12px;margin-bottom:14px;flex-wrap:wrap}
.wo-ref{font-family:'JetBrains Mono',monospace;font-size:13px;background:var(--surface2);border:1px solid var(--line2);border-radius:99px;padding:5px 14px;font-weight:600}
.wtype{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:600;color:var(--muted)}
.wtype i{width:8px;height:8px;border-radius:99px;display:inline-block;box-shadow:0 0 8px currentColor}
.status-group{display:flex;border:1px solid var(--line2);border-radius:99px;overflow:hidden;background:var(--surface)}
.status-group button{border:none;background:none;font-size:12px;font-weight:600;padding:8px 15px;cursor:pointer;color:var(--muted)}
.status-group button.on{color:var(--on-accent);background:var(--accent)}
.status-group button.on.devis{background:var(--violet);color:#fff}
.status-group button.on.fini{background:var(--amber);color:#3A2A05}
.act{border:none;font-size:12.5px;font-weight:700;border-radius:99px;padding:9px 17px;cursor:pointer;display:none}
.act.show{display:inline-block}
.act.releve{background:rgba(94,162,247,.16);color:var(--blue);border:1px solid rgba(94,162,247,.4)}
.act.direct{background:linear-gradient(135deg,var(--accent),var(--accent2));color:var(--on-accent)}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:18px;margin-bottom:16px}
.card h2{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-bottom:6px}
.wo-card{display:grid;grid-template-columns:1.15fr 1fr 1fr .9fr;gap:14px;align-items:end}
.f label{display:block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--faint);margin-bottom:5px}
.f input,.f select{font-size:13.5px;width:100%;border:1px solid var(--line2);background:var(--surface2);border-radius:var(--r-sm);padding:8px 10px;outline:none}
.f input:focus,.f select:focus{border-color:var(--accent)}
.wo-card .row2{grid-column:1/-1;display:flex;gap:16px;align-items:center;flex-wrap:wrap;padding-top:4px}
.chip{display:inline-flex;align-items:center;background:var(--surface2);color:var(--accent);border:1px solid var(--line2);border-radius:99px;padding:3px 11px;font-weight:600;font-family:'JetBrains Mono',monospace;font-size:11px}
.standby{font-size:12px;color:var(--muted);margin-left:auto}
.standby b{font-family:'JetBrains Mono',monospace;color:var(--accent)}
.dtabs{display:flex;gap:6px;margin-bottom:14px}
.dtabs button{border:1px solid var(--line2);background:var(--surface);font-size:12.5px;font-weight:700;color:var(--muted);padding:8px 18px;cursor:pointer;border-radius:99px}
.dtabs button.on{color:var(--on-accent);background:var(--accent);border-color:var(--accent)}
.hint{font-size:12px;color:var(--muted);margin-bottom:10px}
.hint kbd{font-family:'JetBrains Mono',monospace;font-size:10.5px;background:var(--surface2);border:1px solid var(--line2);border-radius:5px;padding:1px 6px}
svg{display:block;width:100%;height:auto;user-select:none}
.odo{max-width:620px;margin:0 auto}
.arch-label{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:600;letter-spacing:.14em;color:var(--faint);text-align:center;text-transform:uppercase}
.tooth{cursor:pointer;outline:none}
.tooth .crown{fill:var(--surface2);stroke:var(--line2);stroke-width:1.3;transition:fill .12s,stroke .12s}
.tooth .fdi{font-family:'JetBrains Mono',monospace;font-size:9.5px;font-weight:500;fill:var(--muted);text-anchor:middle;pointer-events:none}
.tooth:hover .crown{stroke:var(--accent);fill:var(--accent-glow)}
.tooth:focus-visible .crown{stroke:var(--accent);stroke-width:2.2}
.tooth.sel .crown{fill:var(--accent);stroke:var(--accent);filter:drop-shadow(0 0 6px var(--accent-glow))}
.tooth.sel .fdi{fill:var(--on-accent);font-weight:700}
.tooth.pending .crown{fill:var(--accent-glow);stroke:var(--accent);stroke-dasharray:4 3}
.tooth .dot{fill:var(--or,#E5B558);opacity:0}
.tooth.noted .dot{opacity:1}
.midline{stroke:var(--line2);stroke-dasharray:3 5;stroke-width:1}
.panel-title{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:8px;gap:10px;flex-wrap:wrap}
.panel-title .actions{display:flex;gap:8px;align-items:center}
.count{font-family:'JetBrains Mono',monospace;font-size:11.5px;color:var(--accent);background:var(--accent-glow);border-radius:99px;padding:3px 10px;font-weight:700}
.te-head,.te-row{display:grid;grid-template-columns:18px 40px 66px minmax(120px,1fr) 36px 58px 40px 44px 66px 50px 24px 30px 24px;gap:6px;align-items:center}
.te-head{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--faint);padding:0 0 7px;border-bottom:1px solid var(--line)}
.te-row{padding:6px 0;border-bottom:1px solid var(--line);position:relative}
.te-row:last-child{border-bottom:none}
.te-row.dragging{opacity:.35}
.te-row.drop-above{box-shadow:0 -2px 0 0 var(--accent)}
.te-row.drop-below{box-shadow:0 2px 0 0 var(--accent)}
.grip{cursor:grab;color:var(--faint);font-size:13px;text-align:center;user-select:none;padding:6px 0;border-radius:6px}
.grip:hover{color:var(--accent);background:var(--accent-glow)}
.te-row input,.te-row select,.te-row .ro{font-size:12.5px;border:none;border-bottom:1.5px solid transparent;background:transparent;padding:4px 2px;outline:none;min-width:0;width:100%;color:var(--text)}
.te-row input:hover{border-bottom-color:var(--line2)}
.te-row input:focus,.te-row select:focus{border-bottom-color:var(--accent)}
.te-row input::placeholder{color:var(--faint)}
.code-in{font-family:'JetBrains Mono',monospace;font-weight:700;font-size:12px;text-transform:uppercase;color:var(--accent)}
.dent-in{font-family:'JetBrains Mono',monospace;font-weight:700;font-size:12px;text-align:center}
.dent-in.filled{background:var(--accent);color:var(--on-accent);border-radius:var(--r-sm)}
.num{text-align:right;font-family:'JetBrains Mono',monospace;font-size:12px}
.ro{color:var(--muted);text-align:right;font-family:'JetBrains Mono',monospace;font-size:12px}
.ro.total{color:var(--text);font-weight:700}
.tva-btn{border:none;background:var(--surface2);cursor:pointer;font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:700;color:var(--muted);border-radius:99px;padding:4px 0;width:100%;text-align:center}
.tva-btn.t2{background:rgba(139,124,246,.16);color:var(--violet)}
.tech-sel{font-family:'JetBrains Mono',monospace;font-size:11.5px;text-align:center;appearance:none;-webkit-appearance:none;cursor:pointer;color:var(--muted);background:transparent}
.tech-sel.set{color:var(--accent);font-weight:700}
.done-btn{border:1.5px solid var(--line2);background:none;cursor:pointer;border-radius:6px;width:20px;height:20px;font-size:12px;color:transparent;justify-self:center;padding:0}
.done-btn:hover{border-color:var(--accent)}
.done-btn.on{background:var(--accent);border-color:var(--accent);color:var(--on-accent)}
.tdel{border:none;background:none;cursor:pointer;color:var(--faint);font-size:15px;padding:5px;border-radius:var(--r-sm);justify-self:center}
.tdel:hover{color:var(--rouge);background:rgba(242,109,109,.12)}
.lot-btn{background:none;cursor:pointer;justify-self:center;font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:700;color:var(--faint);border:1px dashed var(--line2);border-radius:99px;padding:4px 5px}
.lot-btn:hover{border-color:var(--or,#E5B558);color:var(--or,#E5B558)}
.lot-btn.has{background:rgba(229,181,88,.13);border:1px solid var(--or,#E5B558);color:var(--or,#E5B558)}
.te-row.entry{background:linear-gradient(90deg,var(--accent-glow) 0,transparent 60%);border-left:3px solid var(--accent);border-radius:var(--r-sm);padding-left:5px;margin-left:-8px;border-bottom:none;margin-top:6px}
.te-row.entry .ro{color:var(--faint)}
.lotpop{position:absolute;right:0;top:100%;z-index:40;background:var(--raise);border:1px solid var(--line2);border-radius:var(--r-sm);box-shadow:0 12px 34px rgba(0,0,0,.5);width:320px;max-width:94vw;padding:12px}
.lotpop h4{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:8px}
.lotpop label{display:flex;gap:9px;align-items:baseline;font-size:12.5px;padding:6px 4px;border-radius:6px;cursor:pointer}
.lotpop label:hover{background:var(--surface2)}
.lotpop .lc{font-family:'JetBrains Mono',monospace;font-weight:700;color:var(--or,#E5B558);min-width:92px}
.lotpop .exp{margin-left:auto;font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--faint)}
.lotpop input{accent-color:var(--accent)}
.totals{display:flex;justify-content:flex-end;gap:22px;margin-top:14px;padding-top:12px;border-top:1px solid var(--line);flex-wrap:wrap;align-items:end}
.tot{text-align:right}
.tot .l{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--faint)}
.tot .v{font-family:'JetBrains Mono',monospace;font-size:14px;font-weight:700;margin-top:3px}
.tot.grand .v{color:var(--accent);font-size:17px}
.tot input{font-family:'JetBrains Mono',monospace;font-size:13.5px;font-weight:700;width:54px;text-align:right;border:none;border-bottom:1.5px solid var(--line2);background:transparent;outline:none;padding:2px;color:var(--text)}
.tot input:focus{border-bottom-color:var(--accent)}
.summary{background:linear-gradient(160deg,var(--surface2),var(--surface));border:1px solid var(--line2);border-radius:var(--r);padding:18px;margin-bottom:16px}
.summary h2{color:var(--muted);font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:9px}
.sline{display:flex;gap:12px;font-size:13px;line-height:1.6;padding:3px 0}
.sline .k{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--accent);font-weight:700;flex:none;width:42px;padding-top:2px}
.sline .v{flex:1}
.sline .v em{color:var(--faint);font-style:normal}
.sline .v b{color:var(--text)}
.sline .v .lot{color:var(--or,#E5B558);font-family:'JetBrains Mono',monospace;font-size:11.5px}
.ac{position:absolute;top:100%;left:64px;z-index:30;background:var(--raise);border:1px solid var(--line2);border-radius:var(--r-sm);box-shadow:0 12px 34px rgba(0,0,0,.5);max-height:240px;overflow-y:auto;min-width:360px;max-width:92%}
.ac div{padding:8px 12px;font-size:12.5px;cursor:pointer;display:flex;gap:10px;align-items:baseline}
.ac div:hover,.ac div.hl{background:var(--surface2)}
.ac .c{font-family:'JetBrains Mono',monospace;font-weight:700;color:var(--accent);min-width:62px}
.ac .p{margin-left:auto;font-family:'JetBrains Mono',monospace;font-size:11.5px;color:var(--muted);white-space:nowrap}
.ac .macro-tag,.macro-tag{font-size:9px;font-weight:800;background:rgba(139,124,246,.18);color:var(--violet);border-radius:4px;padding:2px 6px;letter-spacing:.06em}
.det .grp{border-bottom:1px solid var(--line);padding:11px 0}
.det .grp:last-child{border-bottom:none;padding-bottom:0}
.det h3{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);margin-bottom:9px}
.det{max-width:640px}
.det .fr{display:grid;grid-template-columns:90px 1fr;gap:6px 10px;align-items:center;font-size:12.5px;margin-bottom:7px}
.det .fr label{color:var(--muted);font-size:11.5px;font-weight:500}
.det .fr input,.det .fr select{font-size:12.5px;width:100%;border:1px solid var(--line2);border-radius:7px;background:var(--surface2);padding:6px 8px;outline:none}
.det .fr input:focus,.det .fr select:focus{border-color:var(--accent)}
.det textarea{width:100%;resize:vertical;min-height:48px;border:1px solid var(--line2);border-radius:var(--r-sm);padding:8px;background:var(--surface2);outline:none;font-size:12.5px;color:var(--text)}
.det textarea:focus{border-color:var(--accent)}
.det .toggles{display:grid;grid-template-columns:1fr 1fr;gap:7px 12px}
.det .tog{display:flex;align-items:center;gap:8px;font-size:12px;cursor:pointer}
.det .tog input{accent-color:var(--accent)}
.det .flags{display:flex;gap:8px;flex-wrap:wrap}
.flag{border:1px solid var(--line2);background:none;font-size:11.5px;font-weight:700;border-radius:99px;padding:6px 13px;cursor:pointer;color:var(--muted)}
.flag.on.rappel{background:rgba(242,109,109,.13);border-color:var(--rouge);color:var(--rouge)}
.flag.on.plainte{background:rgba(229,181,88,.13);border-color:var(--or,#E5B558);color:var(--or,#E5B558)}
:root{--or:#E5B558}
html[data-theme="light"]{--or:#B4842E}
@media (max-width:880px){
  .wo-card{grid-template-columns:1fr 1fr}
  .te-head{display:none}
  .te-head,.te-row{grid-template-columns:16px 36px 58px 1fr 28px 22px;
    grid-template-areas:"grip dent code lib lot del" "grip qte pu rem tech done" "grip tva tva total total total"}
  .a-grip{grid-area:grip}.a-dent{grid-area:dent}.a-code{grid-area:code}
  .a-lib{grid-area:lib}.a-qte{grid-area:qte}.a-pu{grid-area:pu}.a-rem{grid-area:rem}
  .a-tva{grid-area:tva}.a-total{grid-area:total}.a-tech{grid-area:tech}
  .a-done{grid-area:done}.a-lot{grid-area:lot}.a-del{grid-area:del}
  .ac{left:8px;right:8px;min-width:0;max-width:none}
  .lotpop{right:8px}
}
