:root{
  --bg:#f4f5f7; --surface:#ffffff; --line:#e2e4e9; --line-strong:#cfd2d9;
  --text:#1f2430; --muted:#6b7280; --primary:#4f46b5; --primary-d:#3c3489;
  --info-bg:#eef0fb; --danger:#c0392b; --ok:#1d9e75;
  --radius:8px; --radius-lg:12px;
}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  background:var(--bg);color:var(--text);font-size:15px;line-height:1.5}
a{color:var(--primary);text-decoration:none}
h1{font-size:22px;font-weight:600;margin:0 0 4px}
.muted{color:var(--muted);font-size:13px}

/* --- Barre supérieure --- */
.topbar{display:flex;align-items:center;gap:18px;background:var(--surface);
  border-bottom:1px solid var(--line);padding:10px 22px}
.brand{display:flex;align-items:center;gap:9px}
.brand-mark{display:inline-flex;align-items:center;justify-content:center;
  width:32px;height:32px;border-radius:var(--radius);background:var(--info-bg);
  color:var(--primary-d);font-weight:700;font-size:12px}
.brand-name{font-weight:600}
.topnav{display:flex;gap:14px;margin-left:10px}
.topnav a{color:var(--text);font-size:14px;padding:6px 4px}
.topnav a:hover{color:var(--primary)}
.userbox{margin-left:auto;display:flex;align-items:center;gap:10px;font-size:13px}
.user-name{font-weight:500}
.user-role{color:var(--muted)}
.logout{color:var(--danger)}

.content{max-width:920px;margin:26px auto;padding:0 22px}
.page-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px}
.footer{max-width:920px;margin:30px auto;padding:0 22px;color:var(--muted);font-size:12px}

/* --- Boutons --- */
.btn{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line-strong);
  background:var(--surface);color:var(--text);border-radius:var(--radius);
  padding:8px 14px;font-size:14px;cursor:pointer}
.btn:hover{background:var(--bg)}
.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-d)}
.btn-block{width:100%;justify-content:center;margin-top:8px}

/* --- Tuiles tableau de bord --- */
.tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;margin-top:18px}
.tile{display:flex;flex-direction:column;gap:6px;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--radius-lg);padding:16px 18px}
.tile-title{font-weight:600}
.tile-desc{color:var(--muted);font-size:13px}
a.tile:hover{border-color:var(--primary);box-shadow:0 0 0 2px var(--info-bg)}
.tile-soon{opacity:.6}

/* --- Connexion --- */
.login-body{display:flex;min-height:100vh;align-items:center;justify-content:center;background:var(--bg)}
.login-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:30px 28px;width:340px;text-align:center}
.login-brand{margin-bottom:12px}
.login-card h1{font-size:20px}
.login-sub{color:var(--muted);font-size:13px;margin:2px 0 18px}
.login-card label{display:block;text-align:left;font-size:13px;color:var(--muted);margin-bottom:12px}
.login-card input{width:100%;margin-top:5px}

/* --- Champs --- */
input{height:38px;border:1px solid var(--line-strong);border-radius:var(--radius);
  padding:0 10px;font-size:14px;background:#fff;color:var(--text)}
input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px var(--info-bg)}

/* --- Alertes --- */
.alert{border-radius:var(--radius);padding:9px 12px;font-size:13px;margin-bottom:12px}
.alert-error{background:#fcebeb;color:var(--danger)}

/* --- Éditeur de référentiel --- */
.ref-tree{margin:18px 0 10px}
.ref-pole,.ref-bloc,.ref-mat{display:flex;align-items:center;gap:8px;padding:7px 10px;
  border-top:1px solid var(--line)}
.ref-pole{background:var(--info-bg);border-radius:var(--radius);border-top:none;margin-top:10px}
.ref-bloc{padding-left:24px;font-weight:500}
.ref-mat{padding-left:44px;color:#374151}
.ref-name{flex:1;height:32px}
.ref-coef{width:64px;height:32px;text-align:center}
.ref-code{width:78px;height:32px}
.coef-label{font-size:11px;color:var(--muted)}
.icon-btn{border:none;background:transparent;color:var(--muted);cursor:pointer;
  font-size:14px;width:28px;height:28px;border-radius:var(--radius)}
.icon-btn.del:hover{color:var(--danger);background:#fcebeb}
.btn-add{border:1px dashed var(--line-strong);background:transparent;color:var(--muted);
  border-radius:var(--radius);padding:5px 10px;font-size:12px;cursor:pointer;margin:6px 0}
.btn-add:hover{color:var(--primary);border-color:var(--primary)}
.btn-add-mat{margin-left:44px}
.btn-add-bloc{margin-left:24px}

/* ============ Brique 2 : tableaux, formulaires, badges ============ */
.section-title{font-size:17px;font-weight:600;margin:26px 0 10px;padding-top:18px;border-top:1px solid var(--line)}
.section-title-sm{font-size:14px;font-weight:600;margin:18px 0 8px;color:var(--muted)}

.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:18px}

.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-grid label{display:flex;flex-direction:column;gap:5px;font-size:13px;color:var(--muted)}
.form-grid input,.form-grid select{height:38px}
.form-grid .col-2{grid-column:1 / -1}
@media(max-width:620px){.form-grid{grid-template-columns:1fr}}

select{height:38px;border:1px solid var(--line-strong);border-radius:var(--radius);padding:0 8px;font-size:14px;background:#fff;color:var(--text)}
select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px var(--info-bg)}

.inline-form{display:flex;flex-wrap:wrap;align-items:center;gap:10px}
.inline-form input{height:36px}

table.grid{width:100%;border-collapse:collapse;font-size:14px;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:10px}
table.grid th{text-align:left;font-size:12px;font-weight:600;color:var(--muted);
  background:var(--bg);padding:9px 12px;border-bottom:1px solid var(--line)}
table.grid td{padding:9px 12px;border-top:1px solid var(--line)}
table.grid tr:first-child td{border-top:none}
.row-actions{display:flex;gap:12px;align-items:center;white-space:nowrap}

.badge{display:inline-block;font-size:11px;padding:2px 8px;border-radius:20px}
.badge.ok{background:#e4f6ee;color:var(--ok)}
.badge.warn{background:#fdf2e0;color:#b46a00}
.badge.muted{background:#eef0f3;color:var(--muted)}

.link{border:none;background:none;color:var(--primary);cursor:pointer;font-size:14px;padding:0}
.link:hover{text-decoration:underline}
.link-danger{border:none;background:none;color:var(--danger);cursor:pointer;font-size:14px;padding:0}
.link-danger:hover{text-decoration:underline}
.alert-ok{background:#e4f6ee;color:var(--ok)}

/* ============ Brique 3 : barre de contexte (formation/promotion) ============ */
.context-bar{display:flex;flex-wrap:wrap;gap:18px;align-items:center;background:var(--surface);
  border-bottom:1px solid var(--line);padding:8px 22px}
.context-bar label{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--muted)}
.context-bar select{height:32px;font-size:13px}
.form-grid label span{display:flex;align-items:center;gap:8px;color:var(--text);font-size:14px}
.form-grid input[type=checkbox]{height:auto;width:auto}

/* ============ Brique 4 : calendrier d'alternance ============ */
.cal-weeks{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:8px;margin-bottom:6px}
.cal-week{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:7px 10px;
  border:1px solid var(--line);border-radius:var(--radius);background:var(--surface)}
.cal-week select{height:30px;font-size:12px}
.cal-dates{font-size:12px;color:var(--muted)}
.cal-cfa{border-left:4px solid var(--ok)}
.cal-entreprise{border-left:4px solid #b46a00}
.cal-ferie{border-left:4px solid var(--muted);opacity:.7}

/* ============ Brique 4 : grille de planning ============ */
.planning-nav{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}
.planning-week{font-weight:600;display:flex;align-items:center;gap:8px}
table.planning{width:100%;border-collapse:collapse;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;table-layout:fixed}
table.planning th{background:var(--bg);font-size:12px;padding:8px;border:1px solid var(--line);text-align:center}
table.planning th.demi{width:90px;text-align:left}
table.planning td.slot{border:1px solid var(--line);vertical-align:top;padding:6px;height:88px;position:relative}
.seance{background:var(--info-bg);border-radius:6px;padding:5px 7px;margin-bottom:5px;cursor:pointer;font-size:12px;
  display:flex;flex-direction:column;gap:2px}
.seance:hover{outline:1px solid var(--primary)}
.seance-mat{font-weight:600;color:var(--primary-d)}
.seance-h,.seance-salle{color:var(--muted);font-size:11px}
.slot-add{position:absolute;bottom:5px;right:5px;width:22px;height:22px;border-radius:6px;
  border:1px dashed var(--line-strong);background:transparent;color:var(--muted);cursor:pointer;line-height:1}
.slot-add:hover{color:var(--primary);border-color:var(--primary)}
@media(max-width:700px){table.planning{font-size:11px}table.planning td.slot{height:auto}}

/* ============ Brique 5 : émargement QR ============ */
.emarge-layout{display:flex;gap:22px;flex-wrap:wrap;align-items:flex-start}
.emarge-qr{flex:0 0 220px}
.emarge-list{flex:1;min-width:300px}
.qr-box{width:200px;height:200px;background:#fff;border:1px solid var(--line-strong);border-radius:var(--radius);
  display:flex;align-items:center;justify-content:center;padding:8px;margin:0 auto}
.qr-box svg{width:100%;height:100%}
.qr-box.closed{color:var(--muted);text-align:center;font-weight:600}
.emarge-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px}
.badge.no{background:#fcebeb;color:var(--danger)}
.cell-actions{display:flex;gap:4px}
.mini-btn{width:26px;height:26px;border:1px solid var(--line-strong);background:var(--surface);border-radius:6px;
  cursor:pointer;font-size:12px;font-weight:600;color:var(--muted)}
.mini-btn:hover{border-color:var(--primary);color:var(--primary)}

/* Page de scan (apprenti) */
.scan-body{display:flex;min-height:100vh;align-items:center;justify-content:center;background:var(--bg);padding:20px}
.scan-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:30px 26px;max-width:360px;width:100%;text-align:center}
.scan-card h1{font-size:20px;margin:10px 0 6px}
.scan-card p{color:var(--muted);font-size:14px;margin:0}
.scan-icon{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:34px;margin:0 auto;color:#fff}
.scan-ok .scan-icon{background:var(--ok)}
.scan-expired .scan-icon{background:#b46a00}
.scan-error .scan-icon{background:var(--danger)}

/* Feuille de pointage imprimable */
.print-body{background:var(--bg);margin:0;padding:20px}
.print-toolbar{display:flex;gap:10px;justify-content:flex-end;max-width:800px;margin:0 auto 14px}
.sheet{background:#fff;max-width:800px;margin:0 auto;padding:28px 32px;border:1px solid var(--line);border-radius:8px}
.sheet-head{display:flex;justify-content:space-between;align-items:flex-start;border-bottom:2px solid #222;padding-bottom:10px;margin-bottom:12px}
.sheet-title{font-size:20px;font-weight:700}
.sheet-sub{color:#444;font-size:13px;margin-top:2px}
.sheet-date{font-size:14px}
.sheet-context{display:flex;flex-direction:column;gap:3px;font-size:13px;margin-bottom:14px;color:#333}
.sheet-table{width:100%;border-collapse:collapse;font-size:14px}
.sheet-table th,.sheet-table td{border:1px solid #999;padding:7px 10px;text-align:left}
.sheet-table th{background:#f0f0f4}
.sheet-foot{display:flex;justify-content:space-between;align-items:flex-end;margin-top:24px;font-size:12px;color:#444}
.sign-box{border:1px solid #999;border-radius:6px;width:230px;height:80px;padding:6px;font-size:12px}
@media print{
  .print-toolbar{display:none}
  .print-body{padding:0;background:#fff}
  .sheet{border:none;max-width:100%;padding:0}
}

/* ============ Brique 6A : notes & relevé ============ */
.note-in{width:90px;height:34px;text-align:center}
table.releve th.rot{height:120px;width:34px;padding:0;vertical-align:bottom}
table.releve th.rot span{display:inline-block;writing-mode:vertical-rl;transform:rotate(180deg);white-space:nowrap;padding:6px 2px;font-weight:600}
table.releve .mat-cell{text-align:left;min-width:180px;font-weight:500}
table.releve td{text-align:center}
table.releve .grp{font-weight:700;background:var(--info-bg)}
table.releve .note-low{color:var(--danger);font-weight:700}

/* ============ Brique 6B : compétences ============ */
.comp-block{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);margin-bottom:10px;padding:0 12px}
.comp-block > summary{cursor:pointer;padding:12px 4px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.comp-block > summary::-webkit-details-marker{display:none}
.comp-code{font-weight:700;color:var(--primary-d);min-width:46px}
.comp-lib{flex:1;min-width:200px}
.comp-stat{margin-left:auto}
.comp-count{font-size:12px}
.comp-form{padding:0 4px 14px}
table.comp-grid{width:100%;margin-top:6px}
table.comp-grid .ind-lib{text-align:left;font-size:13px}
table.comp-grid th:nth-child(3),table.comp-grid th:nth-child(4),table.comp-grid th:nth-child(5),
table.comp-grid td:nth-child(3),table.comp-grid td:nth-child(4),table.comp-grid td:nth-child(5){text-align:center;width:48px}

/* ============ Brique 6C : NIP ============ */
table.nip-grid .ind-lib{text-align:left;font-size:13px}
table.nip-grid td:nth-child(2){text-align:center;width:120px}
.nip-pole td{background:var(--info-bg);font-weight:600}
.nip-score{height:34px}

/* ============ Brique 7 : bulletin ============ */
.no-print{}
.appr-edit{max-width:800px;margin:14px auto 40px}
.bulletin-table td:nth-child(2),.bulletin-table td:nth-child(3),.bulletin-table td:nth-child(4),
.bulletin-table th:nth-child(2),.bulletin-table th:nth-child(3),.bulletin-table th:nth-child(4){text-align:center;width:80px}
.bulletin-table .b-pole td{background:#e9ebf7;font-weight:700}
.bulletin-table .b-bloc td{background:#f4f5fb;font-weight:600}
.bulletin-table .b-mat td:first-child{padding-left:22px}
.bulletin-table .b-gen td{background:#222;color:#fff;font-weight:700}
.bulletin-table .b-low{color:#c0392b;font-weight:700}
.bulletin-cols{display:flex;gap:14px;margin-top:14px;flex-wrap:wrap}
.b-box{flex:1;min-width:240px;border:1px solid #999;border-radius:6px;padding:10px 12px}
.b-box-title{font-weight:700;font-size:13px;margin-bottom:6px;border-bottom:1px solid #ccc;padding-bottom:4px}
table.mini{width:100%;border-collapse:collapse;font-size:13px}
table.mini td{padding:3px 4px}
table.mini td:last-child{text-align:right;font-weight:600;white-space:nowrap}
table.mini .mini-strong td{border-top:1px solid #ccc;font-weight:700}
.comp-mini td{vertical-align:top;border-bottom:1px solid #eee}
.comp-mini .cm-code{font-weight:700;width:46px}
.comp-mini .cm-lib{font-size:12px}
.comp-mini .cm-st{text-align:right;width:54px}
.b-appr{min-height:48px;font-size:13px}
@media print{
  .b-box{break-inside:avoid}
  .bulletin-table .b-gen td{background:#222 !important;color:#fff !important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .bulletin-table .b-pole td,.bulletin-table .b-bloc td{-webkit-print-color-adjust:exact;print-color-adjust:exact}
}

/* ============ Brique 7b : NIP dans la moyenne ============ */
.b-tag{display:inline-block;font-size:10px;font-weight:700;background:var(--primary,#4a55d6);color:#fff;border-radius:4px;padding:1px 5px;vertical-align:middle}
.ref-src{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--muted,#666);margin:0 6px}
.ref-src select{height:30px}

/* ============ Brique 7c : bulletin une page + classement ============ */
.bul-head{display:flex;justify-content:space-between;gap:16px;border-bottom:2px solid #222;padding-bottom:8px;margin-bottom:10px}
.bul-title{font-size:20px;font-weight:800}
.bul-sub{font-size:12px;color:#444}
.bul-head-r{text-align:right;font-size:12px}
.bul-appr-name{font-size:15px;font-weight:700}
.bul-line{font-size:12px;color:#333}
.b-rang{float:right;font-weight:700;background:#fff;color:#222;border-radius:4px;padding:0 8px;margin-left:8px}
.comp-2col td.cm-lib{font-size:11px}
.comp-2col td{padding:2px 4px}
.comp-2col td:nth-child(3){border-right:1px solid #ddd;padding-right:10px}

@media print{
  @page{ size:A4 portrait; margin:10mm; }
  html,body{background:#fff}
  .print-toolbar,.appr-edit,.no-print{display:none !important}
  .sheet.onepage{box-shadow:none;margin:0;padding:0;max-width:none;width:100%}
  /* compactage pour tenir sur une page */
  .sheet.onepage{font-size:11px}
  .sheet.onepage .bul-title{font-size:17px}
  .sheet.onepage .bulletin-table td,.sheet.onepage .bulletin-table th{padding:2px 6px;font-size:11px}
  .sheet.onepage .b-box{padding:6px 8px}
  .sheet.onepage .b-box-title{font-size:11px;margin-bottom:3px}
  .sheet.onepage table.mini td{padding:1px 4px;font-size:11px}
  .sheet.onepage .bulletin-cols{gap:10px;margin-top:8px}
  .sheet.onepage .b-appr{min-height:34px;font-size:11px}
  .sheet.onepage .sheet-foot{margin-top:8px;font-size:10px}
  .b-box,.bulletin-cols,.bulletin-table tr{break-inside:avoid}
  .badge{-webkit-print-color-adjust:exact;print-color-adjust:exact}
}

/* ============ Brique 8 : gestion des absences ============ */
table.abs-grid td,table.abs-grid th{font-size:13px}
table.abs-grid tr.abs-nj td{background:#fdecec}
.abs-del-row td{background:transparent !important}
.abs-low{color:#c0392b;font-weight:700}
.hidden-form{display:none}
