/* ===========================================================================
   Awoui · LeGuideInfo — moteur de cours
   Rendu Markdown + QCM côté client (sans build). S'appuie sur les tokens
   d'awoui.css (couleurs, polices, --wrap…). Tag LeGuideInfo subtil.
   =========================================================================== */
body{--lgi:#F4C77A; --lgi-soft:rgba(244,199,122,.13); --lgi-line:rgba(244,199,122,.4)}

.cours{max-width:var(--wrap);margin:0 auto;padding:40px 28px 0;
  display:grid;grid-template-columns:266px 1fr;gap:48px;align-items:start;min-height:62vh}

/* ---- colonne sommaire ---- */
.cours-nav{position:sticky;top:96px;align-self:start}
.lgi-tag{display:inline-flex;align-items:center;gap:7px;font-family:var(--fm);font-size:11px;
  letter-spacing:.05em;text-transform:uppercase;color:var(--lgi);
  background:var(--lgi-soft);border:1px solid var(--lgi-line);border-radius:999px;padding:4px 11px}
.cours-brand h2{font-size:19px;margin:13px 0 0;line-height:1.2}
.cours-sub{color:var(--muted);font-size:13.5px;margin-top:6px}
#coursNav{display:flex;flex-direction:column;gap:1px;margin-top:18px;border-left:1px solid var(--line)}
#coursNav a{display:flex;gap:10px;align-items:flex-start;padding:9px 14px;color:var(--muted);font-size:14px;
  border-left:2px solid transparent;margin-left:-1px;transition:color .15s,border-color .15s}
#coursNav a:hover{color:var(--text)}
#coursNav a.active{color:var(--emerald);border-left-color:var(--emerald)}
#coursNav a.qcm.active{color:var(--lgi);border-left-color:var(--lgi)}
#coursNav a .mn{font-family:var(--fm);font-size:11px;color:var(--faint);flex:0 0 auto;padding-top:2px}
#coursNav a .mt{flex:1 1 auto}
.mbadge{flex:0 0 auto;align-self:center;font-family:var(--fm);font-size:9.5px;letter-spacing:.03em;
  padding:2px 6px;border-radius:999px}
.mbadge.tp{color:var(--cyan);background:rgba(87,200,230,.12);border:1px solid rgba(87,200,230,.3)}
.mbadge.qcm{color:var(--lgi);background:var(--lgi-soft);border:1px solid var(--lgi-line)}
.cours-lab{margin-top:20px;width:100%;justify-content:center;font-size:14px}

/* ---- contenu rendu ---- */
.cours-content{min-width:0;padding-bottom:64px;scroll-margin-top:90px}
.cours-loading{color:var(--faint);font-family:var(--fm);font-size:14px}
.cours-content h1{font-family:var(--fd);font-weight:500;font-size:clamp(28px,4vw,40px);letter-spacing:-.02em;margin:0 0 10px}
.cours-content h2{font-family:var(--fd);font-weight:500;font-size:clamp(21px,2.6vw,27px);letter-spacing:-.01em;
  margin:42px 0 14px;padding-top:18px;border-top:1px solid var(--line)}
.cours-content h3{font-family:var(--fd);font-weight:500;font-size:18px;margin:28px 0 10px;color:var(--text)}
.cours-content h4{font-family:var(--fm);font-size:14px;margin:22px 0 8px;color:var(--text)}
.cours-content p{color:var(--muted);margin:0 0 14px;line-height:1.75}
.cours-content strong{color:var(--text);font-weight:600}
.cours-content em{color:var(--text)}
.cours-content a{color:var(--cyan);text-decoration:underline;text-underline-offset:3px}
.cours-content a:hover{color:var(--text)}
.cours-content ul,.cours-content ol{color:var(--muted);margin:0 0 16px;padding-left:24px;line-height:1.75}
.cours-content li{margin:6px 0}
.cours-content img{display:block;margin:18px 0;border:1px solid var(--line);border-radius:var(--r)}
.cours-content hr{border:0;border-top:1px solid var(--line);margin:34px 0}

/* code */
.cours-content code{font-family:var(--fm);font-size:.88em;color:var(--cyan);
  background:rgba(87,200,230,.10);border:1px solid rgba(87,200,230,.2);border-radius:5px;padding:1px 6px}
.cours-content pre.code{background:var(--ink-2);border:1px solid var(--line);border-radius:var(--r);
  padding:16px 18px;overflow:auto;margin:0 0 18px}
.cours-content pre.code code{color:#cfd6e6;background:none;border:0;padding:0;font-size:13.5px;line-height:1.6;white-space:pre}

/* tables */
.cours-content table{width:100%;border-collapse:collapse;margin:0 0 18px;font-size:14.5px}
.cours-content th,.cours-content td{text-align:left;padding:10px 14px;border:1px solid var(--line);vertical-align:top}
.cours-content th{background:var(--panel);color:var(--text);font-family:var(--fm);font-size:12.5px;font-weight:500}
.cours-content td{color:var(--muted)}

/* encarts (admonitions) */
.adm{border:1px solid var(--line);border-left-width:3px;border-radius:8px;padding:14px 16px;margin:0 0 18px;background:rgba(255,255,255,.02)}
.adm-title{font-family:var(--fm);font-size:11.5px;text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}
.adm p{margin:0;color:var(--muted);font-size:14.5px;line-height:1.6}
.adm.note{border-left-color:var(--cyan)} .adm.note .adm-title{color:var(--cyan)}
.adm.tip{border-left-color:var(--emerald)} .adm.tip .adm-title{color:var(--emerald)}
.adm.warn{border-left-color:var(--lgi)} .adm.warn .adm-title{color:var(--lgi)}
.cours-content blockquote{border-left:3px solid var(--line-2);padding-left:16px;margin:0 0 18px;color:var(--muted);font-style:italic}

/* ---- QCM ---- */
.quiz-q{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:20px 22px;margin:0 0 16px}
.quiz-q .qnum{font-family:var(--fm);font-size:12px;color:var(--faint)}
.quiz-q .qtext{font-family:var(--fd);font-weight:500;font-size:16.5px;margin:6px 0 14px}
.quiz-choice{display:flex;gap:11px;align-items:flex-start;padding:11px 14px;border:1px solid var(--line);
  border-radius:10px;margin-bottom:8px;cursor:pointer;transition:border-color .15s,background .15s}
.quiz-choice:hover{border-color:var(--line-2)}
.quiz-choice input{margin-top:3px;accent-color:var(--emerald);flex:0 0 auto}
.quiz-choice span{color:var(--text);font-size:14.5px}
.quiz-choice.correct{border-color:rgba(63,224,162,.55);background:rgba(63,224,162,.09)}
.quiz-choice.wrong{border-color:rgba(255,110,110,.5);background:rgba(255,110,110,.08)}
.quiz-explain{margin-top:11px;font-size:14px;color:var(--muted);line-height:1.6;border-top:1px solid var(--line);padding-top:11px;display:none}
.quiz-explain.show{display:block}
.quiz-actions{display:flex;align-items:center;gap:18px;margin-top:10px}
.quiz-score{font-family:var(--fm);font-size:15px;color:var(--text)}

/* responsive */
@media (max-width:860px){
  .cours{grid-template-columns:1fr;gap:26px;padding-top:28px}
  .cours-nav{position:static}
  #coursNav{flex-direction:row;flex-wrap:wrap;border-left:0;gap:6px}
  #coursNav a{border-left:0;border-bottom:2px solid transparent;margin-left:0;padding:8px 10px}
  #coursNav a.active{border-left:0;border-bottom-color:var(--emerald)}
  #coursNav a.qcm.active{border-bottom-color:var(--lgi)}
  .cours-lab{width:auto}
}

/* ---- pager bas de module (précédent / suivant) ---- */
.cours-pager{display:flex;justify-content:space-between;gap:14px;margin-top:50px;padding-top:24px;border-top:1px solid var(--line)}
.pager-link{display:flex;flex-direction:column;gap:3px;max-width:49%;padding:14px 18px;border:1px solid var(--line);
  border-radius:var(--r);background:var(--panel);color:var(--text);transition:border-color .2s,transform .2s,background .2s}
.pager-link:hover{border-color:rgba(63,224,162,.4);transform:translateY(-2px);background:var(--panel-2)}
.pager-link.next{margin-left:auto;text-align:right;align-items:flex-end}
.pager-dir{font-family:var(--fm);font-size:12px;color:var(--emerald)}
.pager-ttl{font-family:var(--fd);font-size:15px;line-height:1.25}

/* ---- lien retour catalogue (sidebar) ---- */
.cours-back{display:inline-flex;align-items:center;gap:7px;margin-top:20px;font-family:var(--fm);
  font-size:12.5px;color:var(--faint);transition:color .2s}
.cours-back:hover{color:var(--text)}

/* ===========================================================================
   Catalogue des formations (/formations)
   =========================================================================== */
#catalog{padding-bottom:24px}
.cat{margin-top:48px}
.cat-head h2{font-family:var(--fd);font-weight:500;font-size:clamp(20px,2.6vw,26px);letter-spacing:-.01em}
.cat-head p{color:var(--muted);font-size:15px;margin-top:6px;max-width:62ch}
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:22px}
.course-card{display:flex;flex-direction:column;background:var(--panel);border:1px solid var(--line);
  border-radius:var(--r-lg);padding:22px 22px 20px;color:inherit;
  transition:border-color .25s,transform .25s,background .25s}
a.course-card:hover{border-color:rgba(63,224,162,.4);transform:translateY(-4px);background:var(--panel-2)}
.course-card.soon{opacity:.72}
.course-top{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:14px}
.course-level{font-family:var(--fm);font-size:11.5px;color:var(--faint)}
.course-badge{font-family:var(--fm);font-size:10.5px;padding:3px 9px;border-radius:999px;letter-spacing:.03em;white-space:nowrap}
.course-badge.ok{color:var(--emerald);background:rgba(63,224,162,.1);border:1px solid rgba(63,224,162,.25)}
.course-badge.soon{color:var(--lgi);background:var(--lgi-soft);border:1px solid var(--lgi-line)}
.course-card h3{font-family:var(--fd);font-weight:500;font-size:17px;margin-bottom:7px;letter-spacing:-.01em}
.course-card p{color:var(--muted);font-size:14px;line-height:1.5;flex:1 0 auto}
.course-go{margin-top:16px;font-family:var(--fm);font-size:13px;color:var(--cyan);display:inline-flex;align-items:center;gap:8px;transition:gap .25s,color .25s}
.course-go svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:transform .25s}
.course-go.muted{color:var(--faint)}
a.course-card:hover .course-go{color:var(--emerald);gap:10px}
a.course-card:hover .course-go svg{transform:translateX(4px)}
@media(max-width:860px){.cat-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.cat-grid{grid-template-columns:1fr}.pager-link{max-width:none}}
