:root{
  --navy:#101126; --magenta:#E8368F; --blue:#5170FF;
  --ink:#1a1a2e; --muted:#6b6f80; --line:#e7e8ef; --bg:#f6f7fb; --card:#fff;
  --radius:14px; --shadow:0 2px 10px rgba(16,17,38,.06);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Helvetica Neue',Arial,sans-serif;color:var(--ink);
  background:var(--bg);line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
.wrap{max-width:920px;margin:0 auto;padding:0 18px}

/* Header */
.topbar{background:var(--navy);color:#fff;padding:14px 0;position:sticky;top:0;z-index:20}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;letter-spacing:.3px}
.brand .dot{width:11px;height:11px;border-radius:50%;
  background:linear-gradient(135deg,var(--magenta),var(--blue))}
.topbar a.logout{color:#b9bdd0;font-size:13px;white-space:nowrap}
.topbar a.logout:hover{color:#fff}
.topsearch{flex:1;max-width:420px;margin:0 18px}
.topsearch input{width:100%;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.18);
  color:#fff;border-radius:9px;padding:8px 13px;font-size:14px;font-family:inherit}
.topsearch input::placeholder{color:#aeb3cc}
.topsearch input:focus{outline:none;border-color:var(--blue);background:rgba(255,255,255,.16)}
.bigsearch{margin:6px 0 18px}
.bigsearch input{width:100%;border:2px solid var(--line);border-radius:13px;
  padding:15px 18px;font-size:17px;font-family:inherit;box-shadow:var(--shadow)}
.bigsearch input:focus{outline:none;border-color:var(--blue)}
@media(max-width:640px){.topsearch{margin:0 8px}.brand span:last-child{display:none}}

/* Breadcrumb */
.crumb{padding:16px 0 4px;color:var(--muted);font-size:13px}
.crumb a:hover{color:var(--blue)}
.crumb .sep{margin:0 7px;opacity:.5}

h1.page{font-size:22px;color:var(--navy);margin:6px 0 2px}
.sub{color:var(--muted);font-size:14px;margin-bottom:18px}

/* Grille catégories */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));
  gap:14px;margin:14px 0 30px}
.cat{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px 18px 16px;box-shadow:var(--shadow);display:block;
  transition:transform .08s ease,box-shadow .12s ease,border-color .12s}
.cat:hover{transform:translateY(-2px);box-shadow:0 8px 22px rgba(16,17,38,.10);
  border-color:var(--blue)}
.cat .code{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.6px;
  color:#fff;background:var(--navy);padding:3px 8px;border-radius:6px}
.cat h3{font-size:16px;color:var(--navy);margin:11px 0 6px}
.cat .count{color:var(--magenta);font-weight:700;font-size:13px}

/* Liste thématiques */
.list{margin:10px 0 34px}
.row{background:var(--card);border:1px solid var(--line);border-radius:12px;
  padding:14px 16px;margin-bottom:10px;box-shadow:var(--shadow);
  display:flex;align-items:center;gap:14px;transition:border-color .12s,transform .08s}
.row:hover{border-color:var(--blue);transform:translateX(2px)}
.row .ref{font-size:11px;font-weight:700;color:var(--muted);min-width:64px}
.row .meta{flex:1;min-width:0;overflow:hidden}
.row .meta strong{color:var(--navy);font-size:15px;display:block;overflow-wrap:anywhere}
.row .meta .accroche{display:block;color:var(--muted);font-size:13px;margin-top:2px;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.row .go{color:var(--blue);font-weight:700;font-size:20px}

/* Écran final */
.argu{background:linear-gradient(135deg,var(--navy),#23264f);
  color:#fff;border-radius:var(--radius);padding:20px 22px;margin:8px 0 18px;
  box-shadow:0 8px 26px rgba(16,17,38,.18)}
.argu .head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.argu .head h2{font-size:14px;text-transform:uppercase;letter-spacing:.7px;
  color:var(--magenta)}
.argu .head .src{font-size:11px;color:#8a8fb0}
.argu ul{list-style:none}
.argu li{position:relative;padding:11px 12px 11px 14px;margin-bottom:9px;
  background:rgba(255,255,255,.06);border-left:3px solid var(--magenta);
  border-radius:8px;font-size:16.5px;cursor:pointer;transition:background .12s}
.argu li:hover{background:rgba(255,255,255,.12)}
.argu li .copied{position:absolute;right:10px;top:50%;transform:translateY(-50%);
  font-size:11px;color:var(--blue);opacity:0;transition:opacity .2s}
.argu li.ok .copied{opacity:1}
.argu-loading{display:flex;align-items:center;gap:10px;color:#b9bdd0;
  font-size:14px;padding:10px 2px}
.spin{width:15px;height:15px;border:2px solid rgba(255,255,255,.25);
  border-top-color:var(--magenta);border-radius:50%;display:inline-block;
  animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.argu .actions{display:flex;gap:10px;margin-top:6px}
.btn{display:inline-flex;align-items:center;gap:7px;font-size:14px;font-weight:600;
  border:none;border-radius:9px;padding:10px 16px;cursor:pointer}
.btn.regen{background:var(--magenta);color:#fff}
.btn.regen:hover{filter:brightness(1.07)}
.btn.regen[disabled]{opacity:.6;cursor:wait}
.btn.ghost{background:rgba(255,255,255,.12);color:#fff}

.section{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px 20px;margin-bottom:16px;box-shadow:var(--shadow)}
.section h2{font-size:13px;text-transform:uppercase;letter-spacing:.6px;
  color:var(--navy);margin-bottom:12px}
.section ul{list-style:none}
.section li{position:relative;padding-left:20px;margin-bottom:7px}
.section li::before{content:"";position:absolute;left:2px;top:9px;width:7px;height:7px;
  border-radius:50%;background:var(--blue)}
.dl{display:inline-flex;align-items:center;gap:9px;background:var(--blue);color:#fff;
  font-weight:700;font-size:15px;padding:13px 22px;border-radius:11px;
  box-shadow:0 4px 14px rgba(81,112,255,.35)}
.dl:hover{filter:brightness(1.06)}
.tag{display:inline-block;font-size:11px;font-weight:700;color:var(--blue);
  background:#eef1ff;padding:3px 9px;border-radius:6px;margin-left:8px}

/* Email à envoyer (écran fiche agent) */
.mail-body{white-space:pre-wrap;font-size:14.5px;color:var(--ink);line-height:1.55;
  background:var(--bg);border:1px solid var(--line);border-radius:10px;padding:14px 16px}
.btn-copy{margin-top:12px;display:inline-flex;align-items:center;gap:8px;background:var(--blue);
  color:#fff;border:none;border-radius:10px;padding:11px 18px;font-size:14px;font-weight:700;
  cursor:pointer;box-shadow:0 4px 14px rgba(81,112,255,.30);transition:filter .12s,background .15s}
.btn-copy:hover{filter:brightness(1.06)}
.btn-copy.done{background:#157a3c;box-shadow:none}
.btn-copy.small{padding:7px 12px;font-size:13px;box-shadow:none;margin-top:0}
.mail-subject-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:12px}
.mail-label{font-size:11px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;
  color:var(--muted)}
.mail-subject{flex:1;min-width:160px;font-size:14.5px;font-weight:600;color:var(--navy);
  background:var(--bg);border:1px solid var(--line);border-radius:8px;padding:8px 12px}

/* Login */
.login{max-width:380px;margin:9vh auto;background:var(--card);border:1px solid var(--line);
  border-radius:var(--radius);padding:30px 28px;box-shadow:var(--shadow)}
.login h1{color:var(--navy);font-size:20px;margin-bottom:4px}
.login p{color:var(--muted);font-size:13px;margin-bottom:18px}
.login input{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:10px;
  font-size:15px;margin-bottom:12px}
.login input:focus{outline:none;border-color:var(--blue)}
.login button{width:100%;background:var(--magenta);color:#fff;border:none;border-radius:10px;
  padding:12px;font-size:15px;font-weight:700;cursor:pointer}
.login .err{color:#c0245f;font-size:13px;margin-bottom:10px}
.empty{color:var(--muted);padding:30px 0;text-align:center}

/* ---- Admin ---- */
.admin-bar{display:flex;align-items:center;gap:14px;padding:14px 0 0}
.admin-bar a{color:var(--blue);font-size:13px;font-weight:600}
.badge-admin{background:var(--magenta);color:#fff;font-size:11px;font-weight:700;
  letter-spacing:.8px;padding:3px 9px;border-radius:6px}
.admin-card .count{color:var(--muted);font-weight:400;line-height:1.4;display:block;margin-top:4px}
.form-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:24px;box-shadow:var(--shadow);margin-bottom:24px;max-width:640px}
.form-card label{display:block;font-weight:600;color:var(--navy);font-size:14px;
  margin:14px 0 6px}
.form-card input[type=text],.form-card select,.form-card textarea{width:100%;
  padding:11px 13px;border:1px solid var(--line);border-radius:10px;font-size:15px;
  font-family:inherit}
.form-card input:focus,.form-card select:focus,.form-card textarea:focus{outline:none;
  border-color:var(--blue)}
.form-card .check{display:flex;align-items:center;gap:9px;font-weight:400;
  font-size:14px;margin-top:16px}
.form-card .check input{width:auto}
.form-card .check .warn{color:var(--muted);font-size:12px}
.btn-primary{margin-top:20px;background:var(--magenta);color:#fff;border:none;
  border-radius:10px;padding:13px 24px;font-size:15px;font-weight:700;cursor:pointer}
.btn-primary[disabled]{opacity:.6;cursor:wait}
.btn-ghost{display:inline-flex;align-items:center;background:#eef1ff;color:var(--blue);
  font-weight:600;font-size:14px;padding:12px 18px;border-radius:10px}
.hint{color:var(--muted);font-size:13px;margin-top:12px}
.err-box{background:#fdecf3;color:#c0245f;border:1px solid #f5c2d8;border-radius:10px;
  padding:12px 16px;margin:14px 0;font-size:14px}
.ok-box{background:#e9f9ee;color:#157a3c;border:1px solid #b8e6c6;border-radius:10px;
  padding:12px 16px;margin:16px 0;font-size:14px;font-weight:600}
.actions-row{display:flex;gap:12px;flex-wrap:wrap;margin:20px 0 40px}
.fam-tabs{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0 18px}
.tab{background:var(--card);border:1px solid var(--line);border-radius:9px;
  padding:8px 13px;font-size:13px;font-weight:700;color:var(--navy)}
.tab span{color:var(--muted);font-weight:400;margin-left:3px}
.tab.active{background:var(--navy);color:#fff;border-color:var(--navy)}
.tab.active span{color:#b9bdd0}
code{background:#eef1ff;padding:2px 6px;border-radius:5px;font-size:13px}
.draft-flag{background:#fff7e0;color:#946200;border:1px solid #f0d98a;border-radius:10px;
  padding:11px 16px;margin:14px 0;font-size:14px;font-weight:600}
.dl-duree-box{display:flex;align-items:center;gap:16px;flex-wrap:wrap;
  background:#f0f3ff;border:1px solid #d4ddff;border-radius:12px;padding:16px 18px;margin:16px 0}
.dl-duree-box span{font-size:14px;color:var(--navy)}
