:root{--navy:#1F3864;--blue:#2E5496;--vert:#1c7a3d;--rouge:#9C0006;--gris:#f4f5f7}
*{box-sizing:border-box}body{margin:0;font:15px/1.45 "Segoe UI",system-ui,sans-serif;background:var(--gris);color:#1c2733}
nav{background:var(--navy);color:#fff;padding:8px 16px;display:flex;gap:14px;align-items:center;flex-wrap:wrap}
nav a{color:#dbe6ff;text-decoration:none}nav a:hover{color:#fff}nav .droite{margin-left:auto;color:#b9c8e8}
nav .droite a{color:#fff}
main{max-width:1240px;margin:22px auto;padding:0 16px}
h1{color:var(--navy);font-size:1.5em}h2{color:var(--blue);font-size:1.1em;margin:.8em 0 .4em}
table{border-collapse:collapse;width:100%;background:#fff;margin:.5em 0}
th,td{border:1px solid #d7dce4;padding:5px 8px;text-align:left;vertical-align:top}
th{background:var(--blue);color:#fff;font-weight:600;font-size:.92em}
tr:nth-child(even) td{background:#fafbfd}
.carte{background:#fff;border:1px solid #d7dce4;border-radius:8px;padding:12px 16px;margin:10px 0}
.carte.alerte{border-color:#e3b100;background:#fff9e6}
.colonnes{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:900px){.colonnes{grid-template-columns:1fr}}
label{display:block;margin:6px 0;font-size:.95em}
input,select{padding:5px 7px;border:1px solid #b8c0cc;border-radius:5px;font:inherit;max-width:100%}
button,.btn{background:var(--blue);color:#fff;border:0;border-radius:6px;padding:6px 14px;cursor:pointer;
font:inherit;text-decoration:none;display:inline-block;margin:2px}
button:hover,.btn:hover{background:var(--navy)}
button.secondaire,.btn.secondaire{background:#e6eaf1;color:var(--navy)}
button.coche{background:none;padding:0;font-size:1.1em}
.enligne{display:inline-block}
.badge{background:var(--rouge);color:#fff;border-radius:9px;padding:1px 7px;font-size:.8em}
.erreur{color:var(--rouge);font-weight:600}.info{color:var(--blue)}.ok{color:var(--vert)}
.petit{font-size:.84em;color:#5b6675}
.rouge{color:var(--rouge);font-weight:600}.vert{color:var(--vert);font-weight:600}
.annule td{opacity:.5;text-decoration:line-through}
.trou{border-left:4px solid var(--rouge)}
.proposition{background:#eef5ee;border-radius:6px;padding:6px 10px}
.grille td{min-width:90px;font-size:.85em}
.grille td.trou{background:#ffe3e3}.grille td.ok2{background:#eaf6ec}.grille td.vide{background:#f6f7f9}
.oph{display:block;font-weight:700;color:var(--navy)}
.ortho{display:block;color:#2e6b39}
.aide{display:block;color:#8a5a00;font-style:italic}
body.connexion{display:flex;min-height:100vh;align-items:center;justif