:root{
  --ink:#17120D; --ink-2:#211a12; --paper:#F7F3EC; --card:#FFFFFF;
  --gold:#C2A35E; --gold-hi:#E8D29A; --gold-deep:#977B43;
  --line:#E4DCCD; --muted:#6B6052; --ok:#166534; --no:#9B2C2C;
  --shadow:0 10px 40px rgba(23,18,13,.10);
}
*{box-sizing:border-box}
body{margin:0;background:var(--paper);color:var(--ink);
  font-family:"Iowan Old Style",Georgia,"Times New Roman",serif;line-height:1.55}
h2{font-size:1.15rem;letter-spacing:.01em;margin:0 0 .4rem}
input,select,textarea,button{font-family:inherit;font-size:1rem}
.muted{color:var(--muted);font-size:.92rem}

/* ── Marque ── */
.brand{display:flex;align-items:center;gap:.7rem}
.crest{font-size:1.7rem;color:var(--gold)}
.crest-img{height:38px;width:auto;display:block}
.login-card .crest-img{height:60px}
.brand-name{font-weight:700;letter-spacing:.18em;font-size:.95rem}
.brand-sub{color:var(--muted);font-size:.8rem;letter-spacing:.04em}

/* ── Login ── */
.login-wrap{min-height:100vh;display:grid;place-items:center;
  background:radial-gradient(1200px 600px at 50% -10%,#241b12 0%,var(--ink) 60%)}
.login-card{background:var(--card);width:min(92vw,400px);padding:2.2rem;
  border-radius:14px;box-shadow:var(--shadow);border-top:3px solid var(--gold)}
.login-card .brand{justify-content:center;margin-bottom:1.4rem}
.login-card form{display:grid;gap:1rem;margin-top:.4rem}
.foot{text-align:center;color:var(--muted);font-size:.78rem;margin:1.3rem 0 0}

label{display:grid;gap:.35rem;font-size:.85rem;color:var(--muted);letter-spacing:.02em}
input,select,textarea{width:100%;padding:.7rem .8rem;border:1px solid var(--line);
  border-radius:9px;background:#fff;color:var(--ink)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(194,163,94,.18)}
textarea{resize:vertical}

button{cursor:pointer;border:none;border-radius:9px;padding:.7rem 1.1rem;font-weight:600}
.btn-or{background:linear-gradient(180deg,var(--gold-hi),var(--gold));color:#2a2008;
  letter-spacing:.03em;box-shadow:0 4px 14px rgba(151,123,67,.35)}
.btn-or:hover{filter:brightness(1.04)}
.btn-ok{background:var(--ok);color:#fff}
.btn-no{background:#fff;color:var(--no);border:1px solid var(--no)}

.alert{background:#fbeaea;color:var(--no);border:1px solid #efc7c7;
  padding:.7rem .9rem;border-radius:9px;font-size:.88rem;margin:.4rem 0 0}

/* ── App ── */
.topbar{display:flex;justify-content:space-between;align-items:center;
  padding:1rem 1.6rem;background:var(--ink);color:#fff}
.topbar .brand-sub{color:var(--gold-hi)}
.link-out{color:#cdbfa6;text-decoration:none;font-size:.85rem;letter-spacing:.03em}
.link-out:hover{color:#fff}

.grid{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem;
  max-width:1180px;margin:1.6rem auto;padding:0 1.4rem;align-items:start}
@media(max-width:880px){.grid{grid-template-columns:1fr}}
.panel{background:var(--card);border:1px solid var(--line);border-radius:14px;
  padding:1.5rem;box-shadow:var(--shadow)}
.panel form{display:grid;gap:1rem;margin-top:.8rem}
.row{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
@media(max-width:520px){.row{grid-template-columns:1fr}}

.count{display:inline-block;min-width:1.5rem;text-align:center;background:var(--gold);
  color:#2a2008;border-radius:999px;font-size:.8rem;padding:.05rem .5rem;margin-left:.3rem}

.resultat{margin-top:1rem}
.ok{color:var(--ok);font-weight:600}
.warn{color:var(--gold-deep);font-weight:600}

/* ── Cartes de validation ── */
.carte{border:1px solid var(--line);border-radius:12px;padding:1.1rem;margin-top:1rem;
  background:#fffdf9}
.carte-tete{display:flex;justify-content:space-between;align-items:center;gap:.6rem}
.tag{background:#efe6d5;color:var(--gold-deep);border-radius:6px;padding:.1rem .55rem;
  font-size:.74rem;letter-spacing:.04em;text-transform:uppercase}
.doc{white-space:pre-wrap;background:#fff;border:1px solid var(--line);border-radius:9px;
  padding:.9rem 1rem;margin:.7rem 0;max-height:340px;overflow:auto;font-size:.95rem}
.meta{font-size:.85rem;color:var(--muted);margin:.3rem 0}
.vigilance{margin:.3rem 0 .6rem 1.1rem;padding:0;color:var(--muted);font-size:.85rem}
.hint{color:var(--muted);font-size:.74rem;font-weight:400}
.export{display:flex;gap:.5rem;margin:.2rem 0 .4rem}
.btn-dl{display:inline-flex;align-items:center;gap:.3rem;text-decoration:none;
  border:1px solid var(--gold);color:var(--gold-deep);background:#fff;
  border-radius:8px;padding:.35rem .7rem;font-size:.82rem;letter-spacing:.02em}
.btn-dl:hover{background:#fffdf6}
.decision{display:grid;gap:.6rem;margin-top:.6rem}
.decision .actions{display:flex;gap:.6rem}

.pied{max-width:1180px;margin:1rem auto 2.4rem;padding:0 1.6rem;
  color:var(--muted);font-size:.78rem;text-align:center}
