:root{
  --blue:#0070E0; --blue-d:#0058b3; --blue-l:#e8f1fd;
  --ink:#141a24; --ink2:#3a4452; --muted:#6b7280; --faint:#9aa1ac;
  --line:#e9ecf1; --bg:#f5f7fa; --card:#fff;
  --red:#e24b4a; --red-bg:#fdeceb; --amber:#b87308; --amber-bg:#fcf2dd;
  --green:#1a9d6a; --green-bg:#e6f5ee; --grey:#7a828e; --grey-bg:#eef0f3;
  --shadow:0 1px 2px rgba(16,24,40,.04), 0 6px 20px rgba(16,24,40,.06);
  --shadow-sm:0 1px 2px rgba(16,24,40,.06);
  --radius:14px;
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font-family:"Manrope",system-ui,-apple-system,sans-serif;color:var(--ink);
  background:var(--bg);line-height:1.55;-webkit-font-smoothing:antialiased}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}
h1{font-size:23px;font-weight:700;margin:0 0 .3rem;letter-spacing:-.01em}
h2{font-size:16px;font-weight:700;margin:1.9rem 0 .8rem;letter-spacing:-.01em}
.muted{color:var(--muted)} .sm{font-size:12px}

/* ---------- logo placeholder ---------- */
.logo-ph{display:inline-flex;align-items:center;justify-content:center;border:1.5px dashed #c7cdd6;
  border-radius:10px;color:var(--faint);font-weight:600;letter-spacing:.02em;background:#fff}
.logo-ph.lg{width:160px;height:66px;font-size:15px}
.logo-ph.sm{height:34px;padding:0 12px;font-size:12px}
.logo-img.lg{max-height:66px} .logo-img.sm{max-height:34px;vertical-align:middle}
.logo-ph.xl{width:220px;height:96px;font-size:17px} .logo-img.xl{max-height:96px}
.logo-ph.side{width:150px;height:54px;font-size:13px;margin:0 auto} .logo-img.side{max-height:50px}

/* ---------- AUTH ---------- */
body.auth{display:flex;flex-direction:column;min-height:100vh}
.authwrap{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1rem;width:100%}
.auth-brand{text-align:center;margin-bottom:1.7rem}
.auth-brand .product{margin-top:1rem;font-weight:700;font-size:20px;letter-spacing:.14em}
.product .p1{color:var(--ink)} .product .p2{color:var(--blue)}
.auth-brand .rule{width:46px;height:3px;background:var(--blue);border-radius:3px;margin:.75rem auto}
.auth-brand .subtitle{color:var(--muted);font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase}
.auth-card{width:100%;max-width:420px}
.card{background:var(--card);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:1.9rem}
.card-title{font-size:19px;font-weight:700;margin:0 0 1.3rem}
.field{margin-bottom:1.1rem}
.field label{display:block;font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);margin-bottom:.4rem}
input{width:100%;font:inherit;padding:.75rem .9rem;border:1px solid var(--line);border-radius:10px;background:#f6f7f9;color:var(--ink)}
input::placeholder{color:#aab0ba}
input:focus{outline:none;border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px rgba(0,112,224,.15)}
.btn{background:var(--blue);color:#fff;border:0;border-radius:10px;padding:.8rem 1.1rem;font:inherit;font-weight:600;
  cursor:pointer;box-shadow:0 8px 18px rgba(0,112,224,.22);transition:.15s}
.btn:hover{background:var(--blue-d);box-shadow:0 10px 22px rgba(0,112,224,.28)}
.btn-block{width:100%}
.forgot{display:block;text-align:center;margin-top:1.1rem;color:var(--muted);font-size:14px}
.auth-footer{margin-top:1.3rem;color:var(--faint);font-size:13px;text-align:center}
.alert{background:var(--red-bg);color:var(--red);padding:.65rem .85rem;border-radius:10px;font-size:14px;margin-bottom:1rem;border:1px solid #f6d2d1}
.authbar,.appfoot{text-align:center;color:var(--faint);font-size:12.5px;padding:1.4rem;letter-spacing:.02em}
.authbar strong,.appfoot strong{color:var(--muted)}
.authbar .b,.appfoot .b{color:var(--blue);font-weight:600}
.authbar a.b,.appfoot a.b{text-decoration:none}
.authbar a.b:hover,.appfoot a.b:hover{text-decoration:underline}

/* ---------- APP SHELL (sidebar repliable) ---------- */
body.app{min-height:100vh}
.shell{display:flex;min-height:100vh}
.sidebar{width:248px;flex:none;background:#fff;border-right:1px solid var(--line);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto;transition:width .15s}
.side-brand{padding:1.1rem 1rem .9rem;border-bottom:1px solid var(--line);text-align:center}
.side-brand a{display:block}
.side-nav{padding:.8rem .6rem;display:flex;flex-direction:column;gap:2px}
.side-nav a{display:flex;align-items:center;gap:11px;padding:.62rem .7rem;border-radius:9px;color:var(--ink2);font-weight:600;font-size:14.5px;white-space:nowrap}
.side-nav a:hover{background:var(--bg);text-decoration:none}
.side-nav a.active{background:var(--blue-l);color:var(--blue)}
.side-nav svg{flex:none;width:20px;height:20px}
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{position:sticky;top:0;z-index:9;display:flex;align-items:center;gap:1rem;background:#fff;border-bottom:1px solid var(--line);box-shadow:var(--shadow-sm);padding:.55rem 1.2rem}
.burger{border:1px solid var(--line);background:#fff;border-radius:8px;width:34px;height:34px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink2);flex:none}
.burger:hover{background:var(--bg)}
.tb-brand{font-weight:700;font-size:16px;letter-spacing:.08em}
.tb-brand .p1{color:var(--ink)} .tb-brand .p2{color:var(--blue)}
.tb-right{margin-left:auto;display:flex;align-items:center;gap:1rem}
.who{display:flex;flex-direction:column;line-height:1.2;text-align:right}
.u-name{font-weight:600;font-size:14px}
.u-role{color:var(--muted);font-size:12px}
.btn-ghost{border:1px solid var(--line);border-radius:9px;padding:.45rem .8rem;color:var(--ink2);font-size:14px;font-weight:600}
.btn-ghost:hover{background:var(--bg);text-decoration:none}
.wrap{flex:1;max-width:1040px;width:100%;margin:1.6rem auto;padding:0 1.4rem}
body.nav-collapsed .sidebar{width:64px}
body.nav-collapsed .side-nav a span{display:none}
body.nav-collapsed .side-nav a{justify-content:center;padding:.62rem}
body.nav-collapsed .side-brand .logo-ph,body.nav-collapsed .side-brand .logo-img{display:none}
body.nav-collapsed .side-brand::after{content:"PP";font-weight:700;color:var(--blue);letter-spacing:.05em}
@media(max-width:820px){.who .u-role{display:none}.tb-brand{display:none}}

/* ---------- KPIs ---------- */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:1.2rem 0 .5rem}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);
  padding:1.1rem 1.2rem;position:relative;overflow:hidden}
.kpi .n{font-size:30px;font-weight:700;letter-spacing:-.02em}
.kpi .l{color:var(--muted);font-size:13px;font-weight:500;margin-top:.1rem}
.kpi.red::before,.kpi.amber::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px}
.kpi.red::before{background:var(--red)} .kpi.amber::before{background:var(--amber)}
.kpi.red .n{color:var(--red)} .kpi.amber .n{color:var(--amber)}

/* ---------- tableaux ---------- */
.tablewrap{overflow-x:auto;border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.tbl{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.tbl th,.tbl td{text-align:left;padding:.75rem .95rem;border-bottom:1px solid var(--line);font-size:14px;vertical-align:middle}
.tbl th{background:#fafbfc;color:var(--muted);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.04em}
.tbl tbody tr:hover{background:#fafbfe}
.tbl tr:last-child td{border-bottom:0}
.tbl form{margin:0}

/* ---------- badges / cartes ---------- */
.badge{display:inline-block;padding:.22rem .6rem;border-radius:20px;font-size:12px;font-weight:600}
.st-red{background:var(--red-bg);color:var(--red)} .st-amber{background:var(--amber-bg);color:var(--amber)}
.st-green{background:var(--green-bg);color:var(--green)} .st-grey{background:var(--grey-bg);color:var(--grey)}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:14px}
.card.blink{display:block;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-sm);padding:1.1rem 1.2rem;color:var(--ink);transition:.15s}
.card.blink:hover{text-decoration:none;border-color:#cfe0f7;box-shadow:var(--shadow);transform:translateY(-1px)}
.bname{font-weight:700;font-size:16px}
.meta{margin-top:.6rem;font-size:13px;color:var(--muted)}
.btn-sm{background:#fff;border:1px solid var(--blue);color:var(--blue);border-radius:8px;padding:.4rem .7rem;
  font:inherit;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap}
.btn-sm:hover{background:var(--blue);color:#fff}
.back{font-size:14px;color:var(--muted);font-weight:600}

/* ---------- entêtes de page + formulaires ---------- */
.page-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin:0 0 .4rem}
.page-head.sub{margin:1.9rem 0 .8rem}
.row-actions{display:flex;gap:.4rem;justify-content:flex-end;align-items:center}
select{width:100%;font:inherit;padding:.72rem .9rem;border:1px solid var(--line);border-radius:10px;background:#f6f7f9;color:var(--ink)}
select:focus{outline:none;border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px rgba(0,112,224,.15)}
.form{max-width:600px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:1.5rem 1.6rem}
.form .field{margin-bottom:1.05rem}
.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}
.actions{display:flex;gap:.6rem;align-items:center;margin-top:1.3rem}
.flash{padding:.7rem .9rem;border-radius:10px;font-size:14px;margin:0 0 1rem;font-weight:500}
.flash.ok{background:var(--green-bg);color:var(--green)}
.flash.err{background:var(--red-bg);color:var(--red)}

/* ---------- technicien : scan, signature, QR ---------- */
.scan{max-width:560px;margin:0 auto}
.scan .card{margin-bottom:14px}
.eq-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:.8rem}
.eq-type{font-size:17px;font-weight:700}
.kv{width:100%;border-collapse:collapse}
.kv td{padding:.45rem 0;border-bottom:1px solid var(--line);font-size:14px;vertical-align:top}
.kv td:first-child{color:var(--muted);width:42%}
.kv tr:last-child td{border-bottom:0}
textarea{width:100%;font:inherit;padding:.7rem .9rem;border:1px solid var(--line);border-radius:10px;background:#f6f7f9;color:var(--ink);resize:vertical}
textarea:focus{outline:none;border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px rgba(0,112,224,.15)}
.sigpad{width:100%;height:170px;border:1px dashed #c7cdd6;border-radius:10px;background:#fff;touch-action:none}
.sig-actions{margin:.45rem 0 0}
.sig-thumb{height:38px;border:1px solid var(--line);border-radius:6px;background:#fff;vertical-align:middle}
.itv-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:.6rem 0;border-bottom:1px solid var(--line)}
.itv-row:last-child{border-bottom:0}
.qrgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:14px;margin-top:1rem}
.qrcard{border:1px solid var(--line);border-radius:12px;padding:14px;text-align:center;background:#fff;break-inside:avoid}
.qrcard .qr{display:flex;justify-content:center;margin-bottom:8px}
.qrlabel{font-size:14px}
.qrloc{font-size:12px;color:var(--muted);margin-top:2px}
@media print{
  .topbar,.appfoot,.noprint{display:none!important}
  body{background:#fff}
  .wrap{margin:0;max-width:none}
  .qrgrid{grid-template-columns:repeat(3,1fr)}
  .qrcard{border-color:#ccc}
}

@media(max-width:680px){.kpis{grid-template-columns:repeat(2,1fr)} .tb-nav{display:none} .who .u-role{display:none}}
