/* Gestion de seuil – Obélix Menhirs – CERPEG */

:root {
  --blue:#1a4a6e; --blue2:#2c6fa8; --blue3:#eef4fb;
  --brown:#7d4e24; --gold:#c9a227; --gold2:#fff8e1;
  --green:#27864e; --glight:#d4f0e0; --gborder:#28a745;
  --red:#c0392b; --rlight:#fde8e6;
  --bg:#f4f1ec; --white:#fff;
  --border:#ccc; --pre:#eef3f8; --text:#2d2d2d; --muted:#666;
}
*{margin:0;padding:0;box-sizing:border-box;}
body{font-family:'Segoe UI',Arial,sans-serif;background:var(--bg);color:var(--text);font-size:14px;display:flex;flex-direction:column;min-height:100vh;}

/* ─── HEADER ─── */
.site-header{
  background:linear-gradient(135deg,#122f47,var(--blue));
  color:#fff;padding:14px 24px;display:flex;align-items:center;gap:14px;
  box-shadow:0 2px 8px rgba(0,0,0,.25);
  print-color-adjust:exact;-webkit-print-color-adjust:exact;
}
.hdr-icon{font-size:32px;line-height:1;}
.hdr-text h1{font-size:19px;font-weight:700;letter-spacing:.4px;}
.hdr-text p{font-size:12px;opacity:.8;margin-top:2px;}

/* ─── NAV ─── */
.nav-bar{
  background:var(--white);border-bottom:2px solid var(--blue);
  padding:0 20px;display:flex;align-items:center;gap:2px;
  position:sticky;top:0;z-index:200;
  box-shadow:0 2px 6px rgba(0,0,0,.07);
}
.nav-btn{
  padding:10px 14px;background:none;border:none;border-bottom:3px solid transparent;
  cursor:pointer;font-size:13px;font-weight:500;color:var(--muted);
  transition:all .2s;display:flex;align-items:center;gap:5px;white-space:nowrap;
}
.nav-btn:hover{color:var(--blue);}
.nav-btn.active{color:var(--blue);border-bottom-color:var(--blue);}
.sdot{
  width:9px;height:9px;border-radius:50%;background:var(--border);
  display:inline-block;flex-shrink:0;transition:background .3s;
}

/* ─── MAIN ─── */
.main{padding:22px;max-width:1400px;margin:0 auto;flex:1;}
.section{display:none;}
.section.active > *{max-width:1100px;margin-left:auto;margin-right:auto;}
.section.active{display:block;}

/* ─── CARDS OVERVIEW ─── */
.cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:16px;}
@media(max-width:680px){.cards-grid{grid-template-columns:1fr;}}
.card{
  background:var(--white);border-radius:10px;padding:22px;
  box-shadow:0 2px 10px rgba(0,0,0,.07);border-top:4px solid var(--blue);
  display:flex;flex-direction:column;gap:10px;
  transition:transform .2s,box-shadow .2s;
}
.card:hover{transform:translateY(-3px);box-shadow:0 5px 18px rgba(0,0,0,.12);}
.card-num{font-size:11px;font-weight:700;color:var(--blue);text-transform:uppercase;letter-spacing:1px;}
.card h3{font-size:15px;color:var(--text);line-height:1.35;}
.card p{font-size:12px;color:var(--muted);line-height:1.55;flex-grow:1;}
.card-sbadge{font-size:12px;color:var(--muted);background:var(--bg);padding:4px 8px;border-radius:20px;text-align:center;border:1px solid var(--border);}

/* ─── INTRO BOX ─── */
.intro-box{
  background:var(--white);border-radius:10px;padding:18px 22px;margin-bottom:22px;
  box-shadow:0 1px 8px rgba(0,0,0,.07);border-left:5px solid var(--gold);
}
.intro-box h2{color:var(--brown);margin-bottom:8px;font-size:17px;}
.intro-box p{font-size:13px;line-height:1.6;color:var(--text);margin-bottom:5px;}

/* ─── SECTION HEADER ─── */
.sec-hdr{
  background:var(--white);border-radius:8px;padding:12px 20px;margin-bottom:0;
  border-left:4px solid var(--blue);box-shadow:0 1px 4px rgba(0,0,0,.06);
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
}
.sec-hdr-text{flex:1;min-width:0;}
.sec-hdr h2{font-size:17px;color:var(--blue);}
.sec-hdr p{font-size:12px;color:var(--muted);margin-top:3px;}
.sec-hdr-docs{display:flex;align-items:center;gap:6px;flex-shrink:0;flex-wrap:wrap;}

/* ─── DOC REF ─── */
.doc-ref{
  background:var(--gold2);border:1px solid #f0c060;border-radius:6px;
  padding:9px 13px;margin-bottom:15px;font-size:12px;color:#7d5a00;
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;
}
.doc-ref strong{color:#5a3f00;white-space:nowrap;}

/* ─── QUESTION BLOCKS ─── */
.q-block{
  background:var(--white);border-radius:8px;padding:16px 20px;margin-bottom:13px;
  box-shadow:0 1px 4px rgba(0,0,0,.06);
}
.q-label{
  font-weight:600;color:var(--blue);margin-bottom:9px;font-size:14px;
  display:flex;align-items:flex-start;gap:8px;flex-wrap:wrap;
}
.q-num{
  background:var(--blue);color:#fff;border-radius:50%;
  width:22px;height:22px;min-width:22px;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;flex-shrink:0;margin-top:1px;
}
.field-row{display:flex;align-items:center;gap:8px;margin-top:7px;flex-wrap:wrap;}
.flabel{font-size:12px;color:var(--muted);white-space:nowrap;}

/* ─── INPUTS ─── */
input[type=text],input[type=number],textarea,select{
  border:1.5px solid var(--border);border-radius:5px;padding:6px 9px;
  font-size:13px;font-family:inherit;background:#fff;
  transition:border-color .2s,background .3s;outline:none;color:var(--text);
}
input[type=text]:focus,input[type=number]:focus,textarea:focus{
  border-color:var(--blue);box-shadow:0 0 0 2px rgba(26,74,110,.12);
}
input.correct,textarea.correct{background:var(--glight)!important;border-color:var(--gborder)!important;}
input.incorrect,textarea.incorrect{background:var(--rlight)!important;border-color:#e74c3c!important;}
input.prefill{background:var(--pre);color:var(--muted);cursor:not-allowed;}
textarea{resize:vertical;}

/* ─── RADIO ─── */
.radio-grp{display:flex;gap:20px;margin-top:6px;flex-wrap:wrap;}
.radio-grp label{display:flex;align-items:center;gap:6px;font-size:13px;cursor:pointer;}
.radio-grp input[type=radio]{width:15px;height:15px;cursor:pointer;accent-color:var(--blue);}

/* ─── FORMULA BOX ─── */
.fml-box{
  background:var(--pre);border:1px solid #b8d0e8;border-radius:7px;
  padding:11px 14px;margin:8px 0;font-family:'Courier New',monospace;font-size:13px;
  color:var(--blue);font-weight:600;letter-spacing:.3px;
}

/* ─── TABLES ─── */
.param-tbl{width:100%;border-collapse:collapse;background:var(--white);border-radius:8px;overflow:hidden;box-shadow:0 1px 4px rgba(0,0,0,.06);margin-bottom:18px;}
.param-tbl th{background:var(--blue);color:#fff;padding:9px 13px;text-align:left;font-size:13px;font-weight:600;}
.param-tbl td{border:1px solid var(--border);padding:9px 13px;vertical-align:middle;}
.param-tbl tr:nth-child(even) td{background:#f9f9f9;}
.param-tbl td input[type=text],.param-tbl td input[type=number]{width:100%;}

/* ─── STOCK TABLE ─── */
.stock-wrap{overflow-x:auto;margin-bottom:6px;}
.stk{border-collapse:collapse;font-size:12px;min-width:860px;width:100%;}
.stk th,.stk td{border:1px solid #999;padding:5px 7px;text-align:center;vertical-align:middle;}
.stk th{background:var(--blue);color:#fff;font-size:11px;font-weight:600;white-space:nowrap;}
.stk .thsub{background:#2c6fa8;font-size:10px;}
.stk .thparam{background:#3d7a56;font-size:11px;}
.stk .prefill{background:var(--pre);color:var(--muted);}
.stk input{width:72px;padding:4px 5px;font-size:12px;text-align:center;}
.sinput{width:64px!important;padding:3px 5px!important;font-size:12px!important;text-align:center!important;}
.stk .pcell{background:#fdf8ef;text-align:left;padding:5px 7px;vertical-align:top;}
.stk .pcell label{font-size:11px;display:flex;align-items:center;gap:4px;margin-bottom:4px;white-space:nowrap;}
.stk .pcell input{width:68px;padding:3px 5px;font-size:11px;}
.stk .calcrow td{background:#fdf3d8;font-size:11px;font-style:italic;text-align:left;padding:6px 10px;color:#7d5000;}

/* ─── TOOLTIP SYSTEM ─── */
#tip{
  position:fixed;background:#1a2c3d;color:#fff;font-size:12px;padding:8px 12px;
  border-radius:7px;max-width:270px;line-height:1.5;z-index:9000;
  pointer-events:none;opacity:0;transition:opacity .15s;box-shadow:0 4px 14px rgba(0,0,0,.3);
}
.hint{
  display:inline-flex;align-items:center;justify-content:center;
  width:17px;height:17px;border-radius:50%;background:var(--gold);
  color:#fff;font-size:10px;font-weight:700;cursor:help;flex-shrink:0;
  margin-left:4px;vertical-align:middle;
}

/* ─── ACTIONS BAR ─── */
.act-bar{
  background:var(--white);border-top:2px solid var(--border);
  padding:12px 22px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  position:sticky;bottom:0;z-index:150;box-shadow:0 -2px 8px rgba(0,0,0,.07);
}
.sbadge{
  font-size:12px;font-weight:600;padding:4px 13px;border-radius:20px;border:1px solid;
  display:none;
}
.sbadge.vis{display:inline-block;}

/* ─── BUTTONS ─── */
.btn{
  border:none;padding:9px 18px;border-radius:6px;cursor:pointer;
  font-size:13px;font-weight:600;display:inline-flex;align-items:center;gap:6px;
  transition:all .2s;
}
.btn-blue{background:var(--blue);color:#fff;}
.btn-blue:hover{background:var(--blue2);}
.btn-out{background:#fff;color:var(--blue);border:2px solid var(--blue);}
.btn-out:hover{background:var(--blue);color:#fff;}
.sp{flex:1;}

/* ─── SCORE MODAL ─── */
#modal{
  display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);
  z-index:9000;align-items:center;justify-content:center;
}
#modal.vis{display:flex;}
.modal-box{
  background:#fff;border-radius:12px;padding:28px;max-width:480px;width:92%;
  box-shadow:0 8px 32px rgba(0,0,0,.3);max-height:90vh;overflow-y:auto;
}
.modal-box h3{color:var(--blue);font-size:18px;margin-bottom:14px;}
.sc-row{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:8px;margin-bottom:8px;}
.sc-pct{font-size:22px;font-weight:800;min-width:52px;text-align:right;}
.sc-info div:first-child{font-weight:600;font-size:13px;}
.sc-info div:last-child{font-size:12px;color:#555;}
.sc-total{
  margin-top:14px;padding:14px 18px;border-radius:8px;background:#f0f4f8;
  border:2px solid;display:flex;align-items:center;gap:16px;
}
.sc-total .big{font-size:30px;font-weight:800;}

/* ─── SECTION LABELS ─── */
.block-label{font-size:14px;font-weight:600;color:var(--blue);margin:18px 0 10px;}



/* ─── DOCS NAV GROUP ─── */
.docs-nav-group{display:flex;align-items:center;gap:6px;margin-left:10px;}
.docs-nav-label{font-size:12px;font-weight:700;color:var(--muted);display:flex;align-items:center;gap:5px;white-space:nowrap;padding-right:4px;border-right:1px solid var(--border);}
.docs-nav-label svg{flex-shrink:0;}
.doc-link-btn{
  display:flex;align-items:center;gap:4px;
  padding:5px 10px;border-radius:5px;border:1.5px solid var(--gold);
  background:#fff;color:var(--brown);font-size:12px;font-weight:700;
  cursor:pointer;transition:all .2s;white-space:nowrap;
}
.doc-link-btn:hover{background:var(--gold);color:#fff;}
.doc-link-btn svg{flex-shrink:0;}


/* ─── MCQ ─── */
.mcq-options{display:flex;flex-direction:column;gap:7px;margin-top:10px;}
.mcq-opt{display:flex;align-items:center;gap:10px;padding:8px 14px;border-radius:7px;border:1.5px solid var(--border);cursor:pointer;font-size:13px;background:#fff;transition:border-color .15s,background .15s;user-select:none;}
.mcq-opt:hover{border-color:var(--blue2);background:var(--blue3,#eef4fb);}
.mcq-opt input[type=checkbox]{width:16px;height:16px;accent-color:var(--blue);flex-shrink:0;cursor:pointer;}
.mcq-opt .ol{font-weight:700;color:var(--blue);min-width:18px;flex-shrink:0;}
.mcq-opt.opt-ok{background:var(--glight)!important;border-color:var(--gborder)!important;}
.mcq-opt.opt-bad{background:var(--rlight)!important;border-color:#e74c3c!important;}
.mcq-opt.opt-miss{background:#fff3cd!important;border-color:#ffc107!important;}
.mcq-note{font-size:11px;color:var(--muted);margin-top:6px;font-style:italic;}


/* ─── QUIZ STEP ─── */
.quiz-progress{
  display:flex;align-items:center;gap:14px;
  background:var(--white);border-radius:8px;padding:12px 18px;margin-bottom:16px;
  box-shadow:0 1px 4px rgba(0,0,0,.06);
}
.q-counter-txt{font-size:13px;font-weight:700;color:var(--blue);white-space:nowrap;min-width:110px;}
.q-pbar-wrap{flex:1;height:7px;background:var(--border);border-radius:99px;overflow:hidden;}
.q-pbar-fill{height:100%;background:var(--blue);border-radius:99px;transition:width .35s ease;}
.quiz-nav-btns{
  display:flex;align-items:center;gap:10px;
  background:var(--white);border-radius:8px;padding:12px 18px;margin-top:14px;
  box-shadow:0 1px 4px rgba(0,0,0,.06);
}
.q-block{display:none;}
.q-block.q-active{display:block;}


/* ─── CARDS COLORS & WIDTH ─── */
.cards-grid{max-width:860px;}
.card-step1{border-top-color:#d4531a!important;}        /* orange – étape 1 */
.card-step2{border-top-color:#27864e!important;}        /* vert   – étape 2 */
.card-step3{border-top-color:#2c6fa8!important;}        /* bleu   – étape 3 */
.card-step1 .card-num{color:#b03a0a;}
.card-step2 .card-num{color:#27864e;}
.card-step3 .card-num{color:#2c6fa8;}


/* ─── COULEURS PAR ÉTAPE ─── */
/* -- Étape 1 : orange #d4531a -- */
#section-a1 .sec-hdr{border-left-color:#d4531a;}
#section-a1 .sec-hdr h2{color:#d4531a;}
#section-a1 .q-num{background:#d4531a;}
#section-a1 .q-label{color:#d4531a;}
#section-a1 .q-pbar-fill{background:#d4531a;}
#section-a1 .q-counter-txt{color:#d4531a;}
#section-a1 .sld-btn{background:#d4531a;}
#section-a1 .sld-btn:hover{background:#b03a0a;}
#section-a1 .doc-ref{background:#fdf0ea;border-color:#f0a080;}
#section-a1 .block-label{color:#d4531a;}
#section-a1 .fml-box{border-color:#f0a080;color:#b03a0a;}

/* -- Étape 2 : vert #27864e -- */
#section-a2 .sec-hdr{border-left-color:#27864e;}
#section-a2 .sec-hdr h2{color:#27864e;}
#section-a2 .param-tbl th{background:#27864e;}
#section-a2 .doc-ref{background:#eaf5ee;border-color:#80c89a;}
#section-a2 .block-label{color:#27864e;}

/* -- Étape 3 : bleu #2c6fa8 -- */
#section-a3 .sec-hdr{border-left-color:#2c6fa8;}
#section-a3 .sec-hdr h2{color:#2c6fa8;}
#section-a3 .doc-ref{background:#eef4fb;border-color:#90b8dc;}
#section-a3 .block-label{color:#2c6fa8;}


/* ─── IDENTITY & TIMER ─── */
.identity-fields{display:flex;gap:6px;align-items:center;}
.id-inp{border:1.5px solid var(--border);border-radius:5px;padding:5px 9px;
  font-size:12px;font-family:inherit;background:#fff;color:var(--text);
  width:110px;transition:border-color .2s;outline:none;}
.id-inp:focus{border-color:var(--blue);box-shadow:0 0 0 2px rgba(26,74,110,.1);}
.timer-badge{display:flex;align-items:center;gap:5px;font-size:12px;font-weight:600;
  color:var(--muted);padding:5px 10px;background:var(--bg);
  border-radius:5px;border:1px solid var(--border);white-space:nowrap;}
@media(max-width:600px){.identity-fields{display:none;}.timer-badge{display:none;}}
@media print{.identity-fields,.timer-badge{display:none!important;}}


/* ─── MODAL IDENTITY FORM ─── */
.modal-identity-form{background:#f0f4f8;border-radius:8px;padding:12px 14px;margin-bottom:12px;display:flex;flex-direction:column;gap:8px;}
.modal-id-row{display:flex;align-items:center;gap:10px;}
.modal-id-label{font-size:12px;font-weight:600;color:var(--muted);min-width:48px;}
.modal-time-row{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:6px;margin-bottom:12px;}
.modal-time-row strong{color:var(--text);}


/* ─── QUIZ : avertissement réponse manquante ─── */
.q-warn{
  font-size:12px;font-weight:600;color:#c0392b;
  background:#fde8e6;border:1px solid #e74c3c;border-radius:6px;
  padding:7px 12px;margin-top:10px;display:none;
}
.q-no-answer{
  border:2px solid #e74c3c!important;
  box-shadow:0 0 0 3px rgba(231,76,60,.12)!important;
}


/* ─── CUSTOM DIALOGS ─── */
#dlg-overlay{
  display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);
  z-index:10000;align-items:center;justify-content:center;
  animation:dlgFadeIn .18s ease;
}
#dlg-overlay.vis{display:flex;}
@keyframes dlgFadeIn{from{opacity:0}to{opacity:1}}
.dlg-box{
  background:#fff;border-radius:14px;padding:26px 28px;
  max-width:400px;width:92%;
  box-shadow:0 12px 48px rgba(0,0,0,.22);
  animation:dlgSlideIn .18s ease;
}
@keyframes dlgSlideIn{from{transform:translateY(-14px);opacity:0}to{transform:none;opacity:1}}
.dlg-icon{font-size:28px;margin-bottom:10px;line-height:1;}
.dlg-icon svg{display:block;margin:0 auto;}
.dlg-title{font-size:16px;font-weight:700;color:var(--text);margin-bottom:6px;text-align:center;}
.dlg-msg{font-size:13px;color:var(--muted);text-align:center;line-height:1.6;margin-bottom:20px;}
.dlg-btns{display:flex;gap:10px;justify-content:center;}
.dlg-btn{
  padding:9px 22px;border:none;border-radius:7px;font-size:13px;font-weight:600;
  cursor:pointer;transition:all .15s;min-width:90px;
}
.dlg-btn-primary{background:var(--blue);color:#fff;}
.dlg-btn-primary:hover{background:var(--blue2);}
.dlg-btn-primary.danger{background:#e53935;}
.dlg-btn-primary.danger:hover{background:#c62828;}
.dlg-btn-secondary{background:#f0f2f5;color:var(--text);}
.dlg-btn-secondary:hover{background:#e0e3e8;}


/* ─── CHARADE ─── */
.charade-box{
  background:linear-gradient(135deg,#fdf8ef,#fff8e1);
  border:1.5px solid #e8c060;border-radius:10px;
  padding:14px 18px;margin:10px 0 14px;
}
.charade-line{
  font-size:13px;line-height:1.7;color:var(--text);padding:4px 0;
  border-bottom:1px dashed #e8d890;
}
.charade-line:last-child{border-bottom:none;}
.charade-tout{font-style:italic;color:var(--blue);font-weight:600;border-bottom:none;margin-top:4px;}
.charade-part{
  display:inline-block;min-width:80px;font-weight:700;
  color:#a07800;margin-right:6px;font-size:12px;
}
.charade-select-label{font-size:12px;color:var(--muted);margin-bottom:8px;font-style:italic;}

/* ─── DRAG & DROP ─── */
.drag-area{background:var(--bg);border-radius:10px;padding:14px 16px;margin-top:10px;}
.drag-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px;}
.drag-chip{
  padding:8px 16px;background:var(--blue);color:#fff;
  border-radius:20px;font-size:13px;font-weight:600;cursor:grab;
  user-select:none;transition:transform .15s,box-shadow .15s,opacity .2s;
  box-shadow:0 2px 6px rgba(26,74,110,.25);
}
.drag-chip:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(26,74,110,.35);}
.drag-chip:active{cursor:grabbing;transform:scale(.96);}
.drag-chip.dragging{opacity:.35;}
.drag-chip.placed{opacity:.4;pointer-events:none;background:#999;}
.drag-drop-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.drag-drop-label{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;}
.drag-zone{
  min-width:160px;min-height:42px;border:2.5px dashed var(--border);
  border-radius:9px;display:flex;align-items:center;justify-content:center;
  background:#fff;transition:border-color .2s,background .2s;position:relative;
  padding:6px 12px;
}
.drag-zone.over{border-color:var(--blue);background:var(--blue3);}
.drag-zone.correct{border-color:var(--gborder);background:var(--glight);}
.drag-zone.incorrect{border-color:#e74c3c;background:var(--rlight);}
.drag-zone-hint{font-size:12px;color:var(--muted);font-style:italic;pointer-events:none;}
.drag-zone-chip{
  padding:7px 14px;background:var(--blue);color:#fff;
  border-radius:20px;font-size:13px;font-weight:600;
}
.drag-reset-btn{
  background:none;border:1px solid var(--border);border-radius:5px;
  padding:5px 9px;cursor:pointer;color:var(--muted);font-size:15px;
  transition:background .15s;
}
.drag-reset-btn:hover{background:#e0e3e8;}
@media(max-width:600px){.drag-chips{gap:6px;}.drag-chip{font-size:12px;padding:7px 12px;}}


/* ─── DRAG3 (phrase à trous) ─── */
.drag3-sentence{
  display:flex;align-items:center;flex-wrap:wrap;gap:6px;
  background:#fff;border-radius:8px;padding:12px 16px;border:1.5px solid var(--border);
  margin-top:6px;
}
.drag3-text{font-size:13px;font-weight:500;color:var(--text);}
.drag3-zone{min-width:110px;min-height:36px;padding:4px 10px;}

.drag2z-targets{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-top:8px;}
.drag2z-item{display:flex;align-items:center;gap:8px;}
.drag2z-item .drag-drop-label{font-size:12px;font-weight:600;color:var(--muted);white-space:nowrap;}

/* ─── PRINT ─── */
@media print{
  /* Masquer éléments non imprimables */
  .nav-bar,.act-bar,.intro-box img,.docs-nav-group,
  .doc-ref,.quiz-nav-btns,.quiz-progress,
  .hint,.site-footer,#modal,#tip{display:none!important;}

  /* Forcer affichage de toutes les sections + récap */
  body{background:#fff!important;font-size:10pt;color:#000;margin:0;padding:0;}
  .main{padding:6mm;max-width:100%!important;}
  .section{display:block!important;}
  #section-overview{display:none!important;}
  #print-recap{display:block!important;}

  /* Tout sur une seule page */
  html,body{height:auto!important;}
  .site-header{background:#fff!important;color:#000!important;
    border-bottom:2px solid #000;padding:4mm 6mm;box-shadow:none;}
  .hdr-text h1{font-size:13pt;color:#000;}
  .hdr-text p{font-size:9pt;color:#444;}

  /* Supprimer les couleurs et ombres */
  .q-block,.card,.param-tbl,.sec-hdr,.intro-box{
    box-shadow:none!important;border:1px solid #ccc!important;
    background:#fff!important;border-radius:0!important;}
  .sec-hdr{border-left:3px solid #000!important;margin-bottom:4mm!important;}
  .sec-hdr h2{color:#000!important;font-size:11pt;}
  .q-label,.q-num{color:#000!important;background:#e0e0e0!important;}
  .mcq-opt{border:1px solid #ccc!important;padding:3px 6px!important;font-size:9pt;}
  .mcq-opt.opt-ok{background:#e8f5e9!important;border-color:#388e3c!important;}
  .mcq-opt.opt-bad{background:#ffebee!important;border-color:#e53935!important;}
  .mcq-opt.opt-miss{background:#fff8e1!important;border-color:#f9a825!important;}
  .param-tbl th{background:#e0e0e0!important;color:#000!important;}
  .stk th{background:#e0e0e0!important;color:#000!important;}
  .fml-box{background:#f5f5f5!important;border-color:#999!important;color:#000!important;}
  input[type=text],textarea,.sinput{
    border:1px solid #999!important;border-radius:0!important;
    background:#fff!important;font-size:9pt;}
  input.correct,.sinput.correct{background:#e8f5e9!important;}
  input.incorrect,.sinput.incorrect{background:#ffebee!important;}
  .prefill{background:#f5f5f5!important;}

  /* Sections sur une page — pas de sauts */
  .section{page-break-inside:avoid;}
  .stock-wrap{overflow:visible!important;}
  .stk{font-size:8pt;}
  .stk input,.sinput{width:52px!important;font-size:8pt!important;}

  /* Récapitulatif en bas */
  #print-recap{border-top:2pt solid #000;margin-top:6mm;padding-top:4mm;}
  .print-score-row{display:flex;gap:10mm;font-size:10pt;margin-bottom:3mm;}
  .print-score-row span{font-weight:700;}
  .print-score-total{font-size:13pt;font-weight:800;border-top:1px solid #ccc;
    padding-top:3mm;margin-top:3mm;}
}

/* ─── RESPONSIVE ─── */
@media(max-width:900px){
  .main{padding:14px;}
  .cards-grid{grid-template-columns:1fr 1fr;}
  .docs-nav-group{flex-shrink:0;}
  .nav-btn{padding:8px 10px;font-size:12px;}
}
@media(max-width:600px){
  .site-header{padding:10px 14px;}
  .hdr-text h1{font-size:15px;}
  .hdr-text p{display:none;}
  .cards-grid{grid-template-columns:1fr;}
  .nav-bar{overflow-x:auto;padding:0 8px;gap:0;}
  .nav-btn{padding:8px 9px;font-size:11px;gap:3px;}
  .sdot{display:none;}
  .main{padding:10px;}
  .intro-box{flex-direction:column!important;}
  .intro-box img{width:100%!important;max-width:260px;margin:0 auto;}
  .q-block{padding:12px 14px;}
  .mcq-opt{padding:7px 10px;font-size:12px;}
  .fml-box{font-size:12px;}
  .act-bar{padding:10px 12px;gap:8px;}
  .btn{padding:8px 12px;font-size:12px;}
  .stock-wrap{font-size:11px;}
  .stk input,.sinput{width:52px!important;}
  .param-tbl td input[type=text]{min-width:0;}
  .modal-box{padding:18px;}
  .doc-ref{font-size:11px;}
  .sec-hdr h2{font-size:15px;}
}
@media(max-width:420px){
  .hdr-text h1{font-size:13px;}
  .nav-btn{font-size:10px;padding:7px 7px;}
}


/* ─── FOOTER ─── */
.site-footer{
  background:linear-gradient(135deg,#122f47,var(--blue));
  color:rgba(255,255,255,.75);text-align:center;
  padding:10px 20px;font-size:12px;letter-spacing:.5px;
  display:flex;align-items:center;justify-content:center;gap:14px;
  margin-top:auto;
}
.site-footer a{color:rgba(255,255,255,.85);text-decoration:none;}
.site-footer a:hover{color:#fff;}
.site-footer .sep{opacity:.35;}
@media print{
  .site-footer{display:none!important;}
}
