/* ═══════════════════════════════════════════════
   OSA — Feuille de styles principale
   ════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════
   DESIGN SYSTEM — OSA v3
   Palette : Slate profond + Bleu saphir + Or doux
═══════════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}

:root{
  /* Neutrals — bleu-ardoise neutre */
  --s950:#0f1923;--s900:#1a2635;--s800:#243447;--s700:#3a4d61;
  --s600:#56697c;--s500:#7d8f9e;--s400:#a5b4bf;--s300:#c8d4db;
  --s200:#dfe7ed;--s100:#edf2f5;--s50:#f4f7f9;

  /* Accent — #336699 et sa rampe */
  --a700:#1a3a5c;--a600:#264f7a;--a500:#336699;--a400:#4a7fad;
  --a300:#7aaac8;--a100:#cce0f0;--a50:#e8f3fa;

  /* Accent secondaire — bleu-ciel clair pour highlights doux */
  --t500:#2980b9;--t400:#5ba3d0;--t100:#d6eaf8;--t50:#eaf5fb;

  /* Sémantiques */
  --ok:#1e8449;--ok-l:#eafaf1;--ok-b:#a9dfbf;
  --err:#c0392b;--err-l:#fdedec;--err-b:#f5b7b1;
  --warn:#b7770d;--warn-l:#fef9e7;--warn-b:#f9e79f;

  /* Typo */
  --font:'DM Sans',system-ui,sans-serif;
  --mono:'DM Mono',monospace;

  /* Layout */
  --r:10px;--rlg:16px;--rxl:20px;
}

body{
  font-family:var(--font);font-size:14px;line-height:1.65;
  color:var(--s900);
  background:linear-gradient(160deg, #dceef8 0%, #f4f7f9 50%, #e8f3fa 100%);
  background-attachment:fixed;
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
}

/* ── Layout ──────────────────────────────────── */
.wrap   {max-width:1140px;margin:0 auto;padding:36px 28px}
.wrap-sm{max-width:660px; margin:0 auto;padding:36px 28px}

/* ── Page header ─────────────────────────────── */
.ph{display:flex;align-items:flex-start;gap:16px;margin-bottom:32px}
.ph-txt{flex:1}
.ph-title{font-size:24px;font-weight:700;letter-spacing:-.04em;line-height:1.15;color:var(--s950)}
.ph-sub{font-size:13px;color:var(--s500);margin-top:5px}

/* ── Carte ───────────────────────────────────── */
.card{
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.9);
  border-radius:var(--rxl);
  overflow:hidden;
  box-shadow:0 1px 3px rgba(51,102,153,.06),0 8px 24px rgba(51,102,153,.05);
}
.card+.card{margin-top:16px}

.card-h{
  padding:14px 22px;
  background:linear-gradient(135deg, var(--a50) 0%, #f0f8ff 100%);
  border-bottom:1px solid var(--a100);
  display:flex;align-items:center;justify-content:space-between;gap:10px;
}
.card-h-title{
  font-size:10.5px;font-weight:700;
  text-transform:uppercase;letter-spacing:.1em;
  color:var(--a600);
}
.card-b{padding:22px}

/* ── Table ───────────────────────────────────── */
.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl th{
  text-align:left;padding:10px 16px;
  font-size:10px;font-weight:700;
  text-transform:uppercase;letter-spacing:.1em;
  color:var(--a500);border-bottom:1px solid var(--a100);
  background:linear-gradient(135deg, var(--a50) 0%, #f0f8ff 100%);
  white-space:nowrap;
}
.tbl td{padding:14px 16px;vertical-align:middle;border-bottom:1px solid var(--s100)}
.tbl tbody tr:last-child td{border-bottom:none}
.tbl tbody tr{transition:background .1s}
.tbl tbody tr:hover{background:var(--a50)}

/* ── Formulaires ─────────────────────────────── */
.fg{margin-bottom:18px}
.fg label,.fg-label{
  display:block;font-size:11px;font-weight:700;
  color:var(--a600);text-transform:uppercase;
  letter-spacing:.08em;margin-bottom:6px;
}
.inp{
  width:100%;padding:10px 14px;
  border:1.5px solid var(--s200);
  border-radius:var(--r);
  font-size:14px;font-family:var(--font);
  color:var(--s900);background:#fff;
  outline:none;appearance:none;-webkit-appearance:none;
  transition:border-color .15s,box-shadow .15s;
}
.inp::placeholder{color:var(--s400)}
.inp:focus{border-color:var(--a500);box-shadow:0 0 0 3px rgba(51,102,153,.15)}
textarea.inp{resize:vertical;min-height:80px;line-height:1.6}
select.inp{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' fill='none' stroke='%23336699' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;
  padding-right:36px;cursor:pointer;
}
.inp-row{display:flex;gap:12px;align-items:flex-end}
.inp-row>.fg{flex:1;margin-bottom:0}
.help{font-size:12px;color:var(--s500);margin-top:5px;line-height:1.5}
.hint{
  background:var(--warn-l);border:1px solid var(--warn-b);
  border-radius:var(--r);padding:10px 14px;
  font-size:12px;color:var(--warn);margin-top:8px;line-height:1.5;
}

/* ── Échelle ─────────────────────────────────── */
.scale{display:flex;gap:10px;flex-wrap:wrap;padding:4px 0}
.scale-item{cursor:pointer}
.scale-item input{display:none}
.scale-item span{
  width:46px;height:46px;
  display:flex;align-items:center;justify-content:center;
  border-radius:var(--r);border:1.5px solid var(--s200);
  font-size:16px;font-weight:500;font-family:var(--mono);
  color:var(--s700);background:#fff;
  transition:all .14s;
}
.scale-item:hover span{border-color:var(--a500);background:var(--a50);color:var(--a500)}
.scale-item input:checked+span{
  background:var(--a500);
  color:#fff;border-color:var(--a500);
  box-shadow:0 2px 10px rgba(51,102,153,.35);
}

/* ── Checklist ───────────────────────────────── */
.checklist{display:flex;flex-direction:column;gap:8px}
.check-item{
  display:flex;align-items:center;gap:12px;
  padding:11px 15px;border-radius:var(--r);
  border:1.5px solid var(--s200);
  cursor:pointer;transition:all .13s;
  font-size:14px;color:var(--s800);background:#fff;
}
.check-item:hover{border-color:var(--a400);background:var(--a50)}
.check-item:has(input:checked){border-color:var(--a500);background:var(--a50)}
.check-item input{accent-color:var(--a500);width:16px;height:16px;flex-shrink:0}

/* ── Boutons ─────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:7px;
  padding:9px 18px;border-radius:var(--r);
  border:1.5px solid transparent;
  font-size:13px;font-weight:500;font-family:var(--font);
  cursor:pointer;text-decoration:none;
  transition:all .14s;white-space:nowrap;line-height:1.3;
  letter-spacing:-.01em;
}
.btn:active{transform:translateY(1px)}

.btn-p{
  background:linear-gradient(135deg,var(--a500),var(--a600));
  color:#fff;border-color:var(--a500);
  box-shadow:0 1px 3px rgba(51,102,153,.3),0 4px 12px rgba(51,102,153,.2);
}
.btn-p:hover{background:linear-gradient(135deg,var(--a600),var(--a700));border-color:var(--a600)}

.btn-s{
  background:rgba(255,255,255,.9);color:var(--s700);
  border-color:var(--s200);
  box-shadow:0 1px 2px rgba(0,0,0,.05);
}
.btn-s:hover{background:var(--a50);border-color:var(--a300);color:var(--a600)}

.btn-d{background:var(--err-l);color:var(--err);border-color:var(--err-b)}
.btn-d:hover{background:#fee2e2}
.btn-g{background:var(--ok-l);color:var(--ok);border-color:var(--ok-b)}
.btn-g:hover{background:#d1fae5}
/* Bouton teal */
.btn-t{background:var(--a100);color:var(--a400);border-color:var(--a300)}
.btn-t:hover{background:#99f6e4}

.btn-sm{padding:5px 12px;font-size:12px;border-radius:8px}
.btn-xs{padding:3px 8px;font-size:11px;border-radius:6px}

form{display:inline}
.brow{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.mb{margin-bottom:16px}

/* ── Badges ──────────────────────────────────── */
.badge{
  display:inline-flex;align-items:center;
  padding:3px 10px;border-radius:99px;
  font-size:11px;font-weight:600;border:1px solid transparent;
  letter-spacing:.02em;
}
.ba{background:var(--ok-l);color:var(--ok);border-color:var(--ok-b)}
.bi{background:var(--s100);color:var(--s600);border-color:var(--s200)}
.bt{background:var(--a50);color:var(--a500);border-color:var(--a100)}
.bw{background:var(--warn-l);color:var(--warn);border-color:var(--warn-b)}
.br{background:var(--err-l);color:var(--err);border-color:var(--err-b)}
/* Badge teal pour archives */
.barchive{background:#fef3c7;color:#92400e;border-color:#fcd34d}

/* ── Flash ───────────────────────────────────── */
.flash{
  display:flex;align-items:center;gap:10px;
  padding:12px 18px;border-radius:var(--r);
  margin-bottom:18px;font-size:13px;font-weight:500;
  border:1px solid transparent;
  animation:flashIn .2s ease;
}
@keyframes flashIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
.flash-ic{
  width:20px;height:20px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:12px;flex-shrink:0;font-weight:700;
}
.flash-ok{background:var(--ok-l);color:var(--ok);border-color:var(--ok-b)}
.flash-ok .flash-ic{background:var(--ok);color:#fff}
.flash-err{background:var(--err-l);color:var(--err);border-color:var(--err-b)}
.flash-err .flash-ic{background:var(--err);color:#fff}
.flash-info{background:var(--a50);color:var(--a600);border-color:var(--a100)}
.flash-info .flash-ic{background:var(--a500);color:#fff}

/* ── Éditeur questions ───────────────────────── */
.qcard{
  background:#fff;border:1.5px solid var(--s200);
  border-radius:var(--rlg);margin-bottom:8px;
  overflow:hidden;transition:border-color .14s,box-shadow .14s;
}
.qcard:hover{border-color:var(--s300);box-shadow:0 2px 12px rgba(0,0,0,.06)}
.qcard.off{opacity:.5}

.qhdr{
  display:flex;align-items:center;gap:10px;
  padding:12px 18px;cursor:pointer;user-select:none;
  transition:background .1s;
}
.qhdr:hover{background:var(--s50)}
.qnum{
  font-family:var(--mono);font-size:10px;font-weight:500;
  color:var(--s400);background:var(--s100);
  border:1px solid var(--s200);border-radius:5px;
  padding:2px 6px;min-width:24px;text-align:center;flex-shrink:0;
}
.qtitle{flex:1;font-size:13px;font-weight:500;color:var(--s900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.qchev{font-size:10px;color:var(--s400);transition:transform .18s;flex-shrink:0}
.qchev.open{transform:rotate(180deg)}

.qbody{padding:18px;border-top:1px solid var(--s100);display:none}
.qbody.open{display:block;animation:qbIn .15s ease}
@keyframes qbIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}

.opts{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:8px;margin-top:12px}
.opt{
  display:flex;align-items:center;gap:9px;
  padding:8px 12px;border-radius:var(--r);
  border:1.5px solid var(--s200);
  font-size:12px;font-weight:500;color:var(--s700);
  cursor:pointer;transition:all .12s;background:#fff;
}
.opt:hover{border-color:var(--a400);background:var(--a50);color:var(--a600)}
.opt:has(input:checked){border-color:var(--a500);background:var(--a50);color:var(--a600)}
.opt input{accent-color:var(--a500)}

/* ── Progression ─────────────────────────────── */
.prog-wrap{margin-bottom:24px}
.prog-top{display:flex;justify-content:space-between;font-size:12px;color:var(--s400);margin-bottom:8px;font-family:var(--mono)}
.prog-track{height:5px;background:var(--s200);border-radius:99px;overflow:hidden}
.prog-fill{height:100%;background:var(--a500);border-radius:99px;transition:width .35s ease}

/* ── Stats ───────────────────────────────────── */
.scard{
  background:rgba(255,255,255,.85);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.9);
  border-radius:var(--rxl);margin-bottom:16px;overflow:hidden;
  box-shadow:0 1px 3px rgba(51,102,153,.06),0 8px 24px rgba(51,102,153,.04);
}
.scard-h{
  padding:14px 22px;
  background:linear-gradient(135deg, var(--a50) 0%, #eaf5fb 100%);
  border-bottom:1px solid var(--a100);
  display:flex;align-items:flex-start;gap:12px;
}
.snum{
  font-family:var(--mono);font-size:10px;color:var(--a500);
  background:var(--a50);border:1px solid var(--a100);
  border-radius:5px;padding:2px 7px;margin-top:2px;flex-shrink:0;
}
.stitle{font-size:14px;font-weight:500;flex:1;line-height:1.45;color:var(--s900)}
.scard-b{padding:22px;display:grid;grid-template-columns:1fr auto;gap:28px;align-items:start}
@media(max-width:700px){.scard-b{grid-template-columns:1fr}}

.bar-row{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.bar-lbl{min-width:100px;max-width:180px;font-size:13px;color:var(--s700);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:0}
.bar-track{flex:1;height:22px;background:var(--s100);border-radius:6px;overflow:hidden}
.bar-fill{height:100%;background:linear-gradient(90deg,var(--a500),var(--a400));border-radius:6px;transition:width .7s cubic-bezier(.4,0,.2,1);min-width:3px}
.bar-ct{font-size:12px;color:var(--s500);min-width:80px;text-align:right;white-space:nowrap;font-family:var(--mono)}
.trep{padding:10px 14px;background:var(--a50);border-radius:var(--r);font-size:13px;line-height:1.6;margin-bottom:8px;border-left:3px solid var(--a300);color:var(--s700)}
.moy{display:inline-flex;align-items:center;gap:8px;padding:7px 16px;background:var(--a50);color:var(--a600);border:1px solid var(--a100);border-radius:99px;font-size:16px;font-weight:600;margin-bottom:14px;font-family:var(--mono)}
.chart-box{width:200px;height:200px;flex-shrink:0}

/* ── Utils ───────────────────────────────────── */
.mt1{margin-top:8px}.mt2{margin-top:16px}.mt3{margin-top:24px}
.mb1{margin-bottom:8px}.mb2{margin-bottom:16px}
.muted{color:var(--s500)}.small{font-size:12px}.xs{font-size:11px}
.mono{font-family:var(--mono)}
.fbetween{display:flex;align-items:center;justify-content:space-between;gap:12px}
.frow{display:flex;align-items:center;gap:8px}
.center{text-align:center}
.req{color:var(--err);margin-left:2px}
.sep{height:1px;background:linear-gradient(90deg,transparent,var(--a200,var(--a100)),transparent);margin:28px 0}

/* ── Header ──────────────────────────────────── */
.hdr{
  background:linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(232,243,250,.96) 100%);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(51,102,153,.12);
  box-shadow:0 1px 0 rgba(51,102,153,.06),0 4px 20px rgba(51,102,153,.08);
  position:sticky;top:0;z-index:200;
}

.hdr-top{
  display:flex;align-items:center;
  padding:0 32px;height:72px;gap:0;
}

.hdr-logo{
  display:flex;align-items:center;gap:14px;
  text-decoration:none;flex-shrink:0;
  margin-right:32px;padding-right:32px;
  border-right:1px solid var(--a100);
}
.hdr-logo img{height:44px;width:auto;object-fit:contain;display:block;}
.hdr-logo-txt{display:flex;flex-direction:column;line-height:1.2;}
.hdr-logo-name{
  font-size:18px;font-weight:700;
  background:var(--a500);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  letter-spacing:-.03em;font-family:var(--mono);
}
.hdr-logo-name b{-webkit-text-fill-color:unset;color:var(--a400)}
.hdr-logo-sub{font-size:10px;font-weight:500;color:var(--a400);text-transform:uppercase;letter-spacing:.1em;margin-top:1px;}

.hdr-nav{display:flex;align-items:center;gap:2px;flex:1}
.hdr-lnk{
  display:flex;align-items:center;gap:7px;
  padding:7px 14px;border-radius:var(--r);
  font-size:13px;font-weight:500;color:var(--s600);
  text-decoration:none;transition:all .13s;white-space:nowrap;
}
.hdr-lnk svg{width:15px;height:15px;flex-shrink:0;opacity:.6}
.hdr-lnk:hover{background:var(--a50);color:var(--a600)}
.hdr-lnk:hover svg{opacity:1}
.hdr-lnk.on{background:var(--a50);color:var(--a600);font-weight:600}
.hdr-lnk.on svg{opacity:1}

.hdr-sp{flex:1}

.hdr-bar{
  background:linear-gradient(90deg, var(--a700) 0%, var(--a500) 60%, var(--a400) 100%);
  padding:0 32px;height:36px;
  display:flex;align-items:center;gap:16px;
}
.hdr-bar-item{
  display:flex;align-items:center;gap:6px;
  font-size:11px;color:rgba(255,255,255,.6);
  font-family:var(--mono);
}
.hdr-bar-item b{color:rgba(255,255,255,.9);font-weight:600}
.hdr-bar-dot{width:4px;height:4px;border-radius:50%;background:rgba(255,255,255,.3);flex-shrink:0}
.hdr-bar-sp{flex:1}
.hdr-bar-lnk{
  display:flex;align-items:center;gap:5px;
  font-size:11px;font-weight:500;
  color:rgba(255,255,255,.4);
  text-decoration:none;padding:3px 10px;border-radius:5px;
  transition:background .12s,color .12s;font-family:var(--mono);
}
.hdr-bar-lnk:hover{background:rgba(255,255,255,.08);color:rgba(255,255,255,.8)}
.hdr-bar-lnk.hi{color:rgba(255,255,255,.7)}

/* ── Étoiles ──────────────────────────────────── */
.stars-wrap{display:inline-flex;gap:4px;align-items:center}
.star-btn{background:none;border:none;padding:2px;cursor:pointer;line-height:0;border-radius:4px;transition:transform .1s}
.star-btn:hover{transform:scale(1.15)}
.star-btn svg{width:38px;height:38px;display:block;fill:none;stroke:#d1d5db;stroke-width:1.5;stroke-linejoin:round;transition:fill .12s,stroke .12s}
.star-btn.star-on svg{fill:#f59e0b;stroke:#f59e0b}

/* ── Période ──────────────────────────────────── */
.periode-wrap{display:flex;gap:16px;flex-wrap:wrap}
.periode-wrap>div{flex:1;min-width:160px}

/* ── Classement drag ─────────────────────────── */
.rank-list{display:flex;flex-direction:column;gap:8px;margin-bottom:8px}
.rank-item{display:flex;align-items:center;gap:10px;padding:10px 14px;background:#fff;border:1.5px solid var(--s200);border-radius:var(--r);cursor:grab;user-select:none;transition:border-color .12s,box-shadow .12s}
.rank-item:hover{border-color:var(--a400);box-shadow:0 2px 8px rgba(45,91,227,.1)}
.rank-item.dragging{opacity:.5;box-shadow:0 4px 16px rgba(0,0,0,.15)}
.rank-handle{color:var(--s400);font-size:14px;flex-shrink:0}

/* ── Matrice ─────────────────────────────────── */
.matrice-wrap{overflow-x:auto}
.matrice-table{border-collapse:collapse;width:100%;font-size:13px}
.matrice-table th{padding:10px 14px;background:var(--s50);border:1px solid var(--s200);font-weight:600;text-align:center;white-space:nowrap}
.matrice-table th:first-child{text-align:left;min-width:140px}
.matrice-lig{padding:10px 14px;border:1px solid var(--s200);font-weight:500;color:var(--s800)}
.matrice-cell{padding:10px 14px;border:1px solid var(--s200);text-align:center}
.matrice-radio{accent-color:var(--a500);width:18px;height:18px;cursor:pointer}
.matrice-table tr:hover td{background:#fafafa}

/* ── Section / titre ─────────────────────────── */
.section-titre{font-size:16px;font-weight:700;color:var(--s900);padding:6px 0 4px;border-bottom:2px solid var(--a100);margin-bottom:4px;letter-spacing:-.02em}

/* ── Guide ───────────────────────────────────── */
.guide-panel{background:var(--a50);border:1px solid var(--a100);border-radius:var(--rxl);padding:20px 22px;margin-bottom:20px}
.guide-panel h3{font-size:13px;font-weight:700;color:var(--a700);text-transform:uppercase;letter-spacing:.07em;margin-bottom:14px}
.guide-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px}
.guide-item{background:#fff;border:1px solid var(--a100);border-radius:var(--r);padding:10px 12px}
.guide-item-type{font-size:11px;font-weight:700;color:var(--a600);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}
.guide-item-desc{font-size:12px;color:var(--s600);line-height:1.5}

/* ── QR code ─────────────────────────────────── */
.qr-wrap{text-align:center;padding:16px}
.qr-wrap img{max-width:180px;border-radius:var(--r);border:4px solid #fff;box-shadow:0 2px 8px rgba(0,0,0,.1)}
.qr-url{font-size:11px;color:var(--s400);margin-top:8px;font-family:var(--mono);word-break:break-all}

@media print{.noprint{display:none!important}.scard{break-inside:avoid}.hdr,.hdr-user{display:none}}

/* ── Planification ───────────────────────────────── */
.plan-wrap{transition:box-shadow .14s}
.plan-wrap:hover{box-shadow:0 2px 16px rgba(51,102,153,.1)}

/* ── Header utilisateur ──────────────────────── */
.hdr-user{
  background:#fff;
  border-bottom:1px solid var(--s200);
  box-shadow:0 1px 0 var(--s100),0 2px 12px rgba(0,0,0,.04);
  display:flex;align-items:center;
  padding:0 32px;height:72px;gap:16px;
}
.hdr-user-sp{flex:1}
.hdr-user-tag{
  font-size:12px;font-weight:500;color:var(--s400);
  font-family:var(--mono);letter-spacing:.04em;
  padding:5px 14px;border-radius:99px;
  background:var(--s50);border:1px solid var(--s200);
}

/* ── Styles additionnels html_head ── */
/* Organisation dans le header répondant */
.hdr-org-block{display:flex;align-items:center;gap:10px}
.hdr-org-logo{height:40px;max-width:120px;object-fit:contain;border-radius:6px}
.hdr-org-nom{font-size:13px;font-weight:600;color:var(--s700);max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ── Animations cookie banner ── */
@keyframes slideUpBanner{from{transform:translateY(100%)}to{transform:translateY(0)}}
