:root{--bg:#0f1117;--panel:#181b24;--panel-2:#1f232f;--border:#2a2f3d;--text:#e7e9ee;--muted:#9aa0ad;--accent:#f97316;--accent-700:#c2570c;--green:#22c55e;--green-bg:#14331f;--orange:#f59e0b;--orange-bg:#3a2a0c;--red:#ef4444;--red-bg:#3a1414;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}body{background:var(--bg);color:var(--text);margin:0}.app{max-width:1280px;margin:0 auto;padding:24px}.topbar{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.topbar h1{margin:0;font-size:1.5rem}.subtitle{color:var(--muted);margin:6px 0 0;font-size:.85rem}.btn{border:1px solid var(--border);background:var(--panel-2);color:var(--text);cursor:pointer;border-radius:8px;padding:9px 16px;font-size:.9rem;transition:background .15s,border-color .15s}.btn:hover{border-color:var(--accent)}.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.btn.primary:hover{background:var(--accent-700)}.btn.ghost{background:0 0}.btn.sm{padding:6px 12px;font-size:.82rem}.btn:disabled{opacity:.6;cursor:default}.icon-btn{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 6px;font-size:.95rem}.icon-btn:hover{background:var(--panel-2);color:var(--text)}.stats{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin:24px 0;display:grid}.stat{background:var(--panel);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:4px;padding:16px;display:flex}.stat.green{border-color:var(--green)}.stat-value{font-size:1.6rem;font-weight:700}.stat-label{color:var(--muted);font-size:.82rem}.filters{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}select,input,textarea{background:var(--panel-2);border:1px solid var(--border);color:var(--text);border-radius:8px;max-width:100%;padding:8px 10px;font-family:inherit;font-size:.88rem}textarea{resize:vertical}select:focus,input:focus,textarea:focus{border-color:var(--accent);outline:none}.table-wrap{border:1px solid var(--border);background:var(--panel);border-radius:12px;overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:.86rem}thead th{text-align:left;color:var(--muted);border-bottom:1px solid var(--border);white-space:nowrap;padding:12px 10px;font-weight:600}tbody td{border-bottom:1px solid var(--border);vertical-align:middle;padding:11px 10px}tbody tr:hover:not(.detail-row),tr.open{background:var(--panel-2)}.strong{font-weight:600}.ref{color:var(--muted);font-size:.8rem;font-weight:400}.muted{color:var(--muted)}.warn{color:var(--orange)}.ok{color:var(--green)}.actions{white-space:nowrap}.pill{white-space:nowrap;border-radius:999px;padding:3px 9px;font-size:.78rem;display:inline-block}.ext-CONFIRMEE{background:var(--green-bg);color:#7ee2a0}.ext-A_VERIFIER{background:var(--orange-bg);color:#f5c97a}.ext-ABSENTE{background:var(--red-bg);color:#f59a9a}.st-A_VISITER{background:var(--green-bg);color:#7ee2a0}.st-A_ETUDIER{color:#9fc0ff;background:#1d2740}.st-A_ECARTER{color:var(--muted);background:#2a2f3d}.note{border-radius:6px;padding:2px 8px;font-weight:700}.note-high{background:var(--green-bg);color:#7ee2a0}.note-mid{background:var(--orange-bg);color:#f5c97a}.note-low{background:var(--panel-2);color:var(--muted)}.agebar{flex-direction:column;gap:4px;min-width:90px;display:flex}.agebar-track{background:var(--panel-2);border-radius:999px;height:6px;overflow:hidden}.agebar-fill{border-radius:999px;height:100%;transition:width .3s}.agebar-label{white-space:nowrap;font-size:.74rem}.age-fresh{background:var(--green);color:#7ee2a0}.age-warm{background:var(--orange);color:#f5c97a}.age-stale{background:var(--accent);color:#f7b27a}.age-old{background:var(--red);color:#f59a9a}.agebar-label.age-fresh,.agebar-label.age-warm,.agebar-label.age-stale,.agebar-label.age-old{background:0 0}.detail-row td{background:#14171f;padding:0}.detail{padding:16px 20px}.detail-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px 24px;display:grid}.field{flex-direction:column;gap:2px;display:flex}.field-label{color:var(--muted);text-transform:uppercase;letter-spacing:.03em;font-size:.74rem}.field-value{font-size:.9rem}.field-value a{color:var(--accent)}.detail-note{border-radius:8px;margin:14px 0 0;padding:10px 12px;font-size:.88rem}.ok-note{background:var(--green-bg)}.warn-note{background:var(--orange-bg)}.empty{text-align:center;color:var(--muted);flex-direction:column;align-items:center;gap:16px;padding:60px 20px;display:flex}.banner{border-radius:8px;margin-bottom:14px;padding:10px 14px}.banner.error{background:var(--red-bg);color:#f59a9a}.overlay{z-index:50;background:#0000008c;justify-content:flex-end;display:flex;position:fixed;inset:0}.drawer{background:var(--panel);border-left:1px solid var(--border);flex-direction:column;width:min(640px,100%);height:100%;display:flex}.drawer-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 22px;display:flex}.drawer-head h2{margin:0;font-size:1.15rem}.drawer-body{flex:1;padding:18px 22px;overflow-y:auto}.drawer-foot{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;padding:16px 22px;display:flex}fieldset{border:1px solid var(--border);border-radius:10px;margin:0 0 18px;padding:14px 16px 16px}legend{color:var(--accent);padding:0 6px;font-size:.82rem;font-weight:600}.grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.grid label{color:var(--muted);flex-direction:column;gap:5px;min-width:0;font-size:.82rem;display:flex}.grid input,.grid select,.grid textarea{width:100%;min-width:0}.grid label.col-2{grid-column:span 2}.grid label.check{color:var(--text);flex-direction:row;align-items:center;gap:8px;font-size:.86rem}.grid label.check input{width:auto}.viab-preview{background:var(--panel-2);color:var(--text);border-radius:8px;margin:12px 0 0;padding:10px 12px;font-size:.85rem}.form-error{color:#f59a9a;background:var(--red-bg);border-radius:8px;padding:10px 12px}@media (width<=640px){html,body{overflow-x:hidden}.app{padding:16px 14px}.topbar h1{font-size:1.2rem}.topbar>.btn.primary{width:100%}.grid{grid-template-columns:1fr}.grid label.col-2{grid-column:span 1}.overlay{justify-content:stretch}.drawer{border-left:none;width:100%}.drawer-head,.drawer-foot,.drawer-body{padding:14px 16px}fieldset{padding:12px 12px 14px}.drawer-foot .btn{flex:1}}
