/* ============================================================
   CRIR Stages — CSS v1.1
   Couleurs charte : #DF4818 (orange) | #505659 (gris foncé)
   ============================================================ */

:root {
    --crir-orange:  #DF4818;
    --crir-gris:    #505659;
    --crir-light:   #f7f7f7;
    --crir-border:  #e0e0e0;
    --crir-blanc:   #ffffff;
    --crir-radius:  6px;
    --crir-shadow:  0 2px 10px rgba(0,0,0,.08);
}

/* ============================================================
   CONTENEUR
   ============================================================ */
.crir-container {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 20px 60px;
}

/* ============================================================
   BREADCRUMB
   ============================================================ */
.crir-breadcrumb {
    font-size: 0.85rem;
    color: var(--crir-gris);
    margin: 20px 0 16px;
    opacity: .75;
}
.crir-breadcrumb a { color: var(--crir-orange); text-decoration: none; }
.crir-breadcrumb a:hover { text-decoration: underline; }

/* ============================================================
   EN-TÊTE FICHE
   ============================================================ */
.crir-stage-header { margin-bottom: 28px; }

.crir-stage-badges {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-bottom: 10px;
}
.crir-stage-badges span {
    display: inline-block;
    padding: 3px 12px;
    border-radius: 20px;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: .3px;
}
.crir-badge-code   { background: var(--crir-orange); color: #fff; }
.crir-badge-cpf    { background: #27ae60; color: #fff; }
.crir-badge-niveau { background: var(--crir-light); color: var(--crir-gris); border: 1px solid var(--crir-border); }

.crir-stage-header h1 {
    font-size: 1.9rem;
    font-weight: 700;
    color: var(--crir-orange);
    margin: 6px 0 8px;
    line-height: 1.25;
}

.crir-soustitre {
    font-size: 1.05rem;
    color: var(--crir-gris);
    font-style: italic;
    margin: 0 0 18px;
}

/* Bandeau infos rapides */
.crir-infos-rapides {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    align-items: center;
    background: var(--crir-light);
    border-left: 4px solid var(--crir-orange);
    padding: 16px 20px;
    border-radius: 0 var(--crir-radius) var(--crir-radius) 0;
    margin-bottom: 8px;
}
.crir-info-item { display: flex; align-items: center; gap: 10px; }
.crir-info-icon { font-size: 1.3rem; }
.crir-info-label { display: block; font-size: 0.72rem; color: var(--crir-gris); text-transform: uppercase; letter-spacing: .5px; opacity: .8; }
.crir-info-valeur { display: block; font-weight: 700; font-size: 0.95rem; color: var(--crir-gris); }

.crir-btn-pdf {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: var(--crir-orange);
    color: #fff !important;
    padding: 9px 18px;
    border-radius: var(--crir-radius);
    text-decoration: none !important;
    font-size: 0.88rem;
    font-weight: 700;
    transition: background .2s, transform .15s;
}
.crir-btn-pdf:hover { background: #c03c10; transform: translateY(-1px); }

/* ============================================================
   LAYOUT 2 COLONNES
   ============================================================ */
.crir-layout {
    display: grid;
    grid-template-columns: 1fr 300px;
    gap: 32px;
    align-items: start;
}
@media (max-width: 860px) {
    .crir-layout { grid-template-columns: 1fr; }
    .crir-sidebar { order: -1; }
    .crir-stage-header h1 { font-size: 1.4rem; }
}

/* ============================================================
   SECTIONS
   ============================================================ */
.crir-section {
    margin-bottom: 28px;
    padding-bottom: 24px;
    border-bottom: 1px solid var(--crir-border);
}
.crir-section:last-child { border-bottom: none; }

.crir-section h2 {
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--crir-orange);
    margin-bottom: 14px;
    padding-bottom: 6px;
    border-bottom: 2px solid var(--crir-orange);
    display: inline-block;
}

.crir-datemodif {
    font-size: 0.78rem;
    font-weight: 400;
    color: var(--crir-gris);
    opacity: .7;
}

.crir-texte { color: var(--crir-gris); line-height: 1.75; }
.crir-texte ul, .crir-texte ol { padding-left: 20px; }
.crir-texte li { margin-bottom: 5px; }
.crir-texte a { color: var(--crir-orange); }

/* Programme accordéon */
.crir-programme { display: flex; flex-direction: column; gap: 8px; }

.crir-module {
    border: 1px solid var(--crir-border);
    border-radius: var(--crir-radius);
    overflow: hidden;
}
.crir-module summary {
    padding: 11px 16px;
    cursor: pointer;
    font-weight: 700;
    font-size: 0.92rem;
    color: var(--crir-gris);
    background: var(--crir-light);
    list-style: none;
    position: relative;
    padding-right: 36px;
    transition: background .15s;
}
.crir-module summary::-webkit-details-marker { display: none; }
.crir-module summary::after {
    content: '▼';
    position: absolute; right: 14px; top: 50%; transform: translateY(-50%);
    font-size: 0.65rem; color: var(--crir-orange); transition: transform .2s;
}
.crir-module[open] summary::after { transform: translateY(-50%) rotate(180deg); }
.crir-module summary:hover { background: #efefef; }
.crir-module[open] summary { color: var(--crir-orange); border-bottom: 1px solid var(--crir-border); }

.crir-module-contenu {
    padding: 12px 16px;
    font-size: 0.9rem;
    line-height: 1.65;
    color: var(--crir-gris);
}

/* Section CPF */
.crir-section-cpf {
    background: #fff8f5;
    border: 1px solid #f5c6b0;
    border-radius: var(--crir-radius);
    padding: 20px;
}

/* Note */
.crir-note {
    background: #fff8e6;
    border-left: 4px solid #f0ad4e;
    padding: 12px 16px;
    border-radius: 0 var(--crir-radius) var(--crir-radius) 0;
    font-size: 0.9rem;
    color: var(--crir-gris);
    margin-top: 8px;
}

/* ============================================================
   SIDEBAR
   ============================================================ */
.crir-sidebar { position: sticky; top: 20px; }

.crir-sidebar-bloc {
    background: var(--crir-blanc);
    border: 1px solid var(--crir-border);
    border-radius: var(--crir-radius);
    padding: 18px;
    margin-bottom: 16px;
    box-shadow: var(--crir-shadow);
}
.crir-sidebar-bloc h3 {
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--crir-orange);
    margin: 0 0 12px;
    padding-bottom: 8px;
    border-bottom: 1px solid var(--crir-border);
}
.crir-sidebar-bloc p, .crir-sidebar-bloc li {
    font-size: 0.88rem;
    color: var(--crir-gris);
    line-height: 1.6;
    margin: 0;
}

/* Sessions */
.crir-bloc-sessions { border-top: 3px solid var(--crir-orange); }
.crir-sessions-liste {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.crir-sessions-liste li {
    background: var(--crir-light);
    padding: 7px 12px;
    border-radius: 4px;
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--crir-gris);
    border-left: 3px solid var(--crir-orange);
}
.crir-sessions-vide { color: var(--crir-gris); opacity: .7; font-style: italic; }

/* Conditions pédagogiques */
.crir-conditions {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 5px;
}
.crir-conditions li::before {
    content: '✓ ';
    color: var(--crir-orange);
    font-weight: 700;
}

/* ============================================================
   FORMULAIRE
   ============================================================ */
.crir-section-formulaire {
    background: var(--crir-light);
    border-radius: var(--crir-radius);
    padding: 32px;
    margin-top: 16px;
    border-top: 3px solid var(--crir-orange);
}
.crir-section-formulaire h2 {
    border-bottom: none;
    display: block;
    font-size: 1.4rem;
    margin-bottom: 6px;
}
.crir-section-formulaire > p {
    color: var(--crir-gris);
    margin-bottom: 24px;
    opacity: .8;
}

.crir-formulaire { display: flex; flex-direction: column; gap: 16px; }

.crir-form-row { display: flex; flex-direction: column; gap: 16px; }
.crir-form-row-2 { flex-direction: row; }
@media (max-width: 600px) { .crir-form-row-2 { flex-direction: column; } }

.crir-form-group { display: flex; flex-direction: column; gap: 5px; flex: 1; }

.crir-form-group label {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--crir-gris);
}
.crir-form-group label .required { color: var(--crir-orange); }

.crir-formulaire input[type="text"],
.crir-formulaire input[type="email"],
.crir-formulaire input[type="tel"],
.crir-formulaire select,
.crir-formulaire textarea {
    width: 100%;
    padding: 10px 14px;
    border: 1px solid var(--crir-border);
    border-radius: var(--crir-radius);
    font-size: 0.92rem;
    color: var(--crir-gris);
    background: var(--crir-blanc);
    transition: border-color .2s, box-shadow .2s;
    box-sizing: border-box;
    font-family: inherit;
}
.crir-formulaire input:focus,
.crir-formulaire select:focus,
.crir-formulaire textarea:focus {
    outline: none;
    border-color: var(--crir-orange);
    box-shadow: 0 0 0 3px rgba(223,72,24,.15);
}

.crir-radios { display: flex; gap: 20px; }
.crir-radio-label {
    display: flex; align-items: center; gap: 7px;
    font-size: 0.92rem; color: var(--crir-gris); cursor: pointer;
    font-weight: 400 !important;
}
.crir-radio-label input { accent-color: var(--crir-orange); width: 16px; height: 16px; }

.crir-form-rgpd { }
.crir-checkbox-label {
    display: flex; align-items: flex-start; gap: 8px;
    font-size: 0.83rem; color: var(--crir-gris); cursor: pointer;
    font-weight: 400 !important; line-height: 1.5;
}
.crir-checkbox-label input { accent-color: var(--crir-orange); margin-top: 2px; flex-shrink: 0; }
.crir-checkbox-label a { color: var(--crir-orange); }

.crir-btn-submit {
    align-self: flex-start;
    background: var(--crir-orange);
    color: #fff;
    border: none;
    padding: 12px 28px;
    border-radius: var(--crir-radius);
    font-size: 1rem;
    font-weight: 700;
    cursor: pointer;
    transition: background .2s, transform .15s;
    font-family: inherit;
}
.crir-btn-submit:hover { background: #c03c10; transform: translateY(-1px); }

.crir-form-success {
    background: #d4edda; color: #155724;
    border: 1px solid #c3e6cb; border-radius: var(--crir-radius);
    padding: 14px 18px; font-weight: 600; margin-bottom: 16px;
}
.crir-form-error {
    background: #f8d7da; color: #721c24;
    border: 1px solid #f5c6cb; border-radius: var(--crir-radius);
    padding: 14px 18px; font-weight: 600; margin-bottom: 16px;
}

/* ============================================================
   LISTE DES STAGES (ARCHIVE)
   ============================================================ */
.crir-archive-stages .crir-container { padding-top: 30px; }

.crir-archive-header { text-align: center; margin-bottom: 28px; }
.crir-archive-header h1 { font-size: 2rem; color: var(--crir-orange); margin-bottom: 10px; }
.crir-archive-header p  { color: var(--crir-gris); }

.crir-filtres {
    display: flex; flex-wrap: wrap; gap: 8px;
    justify-content: center; margin-bottom: 36px;
}
.crir-filtre-btn {
    padding: 7px 16px;
    border: 2px solid var(--crir-border);
    border-radius: 20px;
    text-decoration: none;
    color: var(--crir-gris);
    font-size: 0.85rem;
    font-weight: 600;
    transition: all .2s;
}
.crir-filtre-btn:hover, .crir-filtre-btn.actif {
    border-color: var(--crir-orange);
    background: var(--crir-orange);
    color: #fff;
}

.crir-cat-section { margin-bottom: 40px; }
.crir-cat-titre {
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--crir-orange);
    border-bottom: 3px solid var(--crir-orange);
    padding-bottom: 8px;
    margin-bottom: 20px;
}

.crir-grille {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 18px;
}

.crir-card {
    border: 1px solid var(--crir-border);
    border-radius: 20px 0 20px 0;
    padding: 20px;
    background: #F9ECE5;
    display: flex;
    flex-direction: column;
    box-shadow: var(--crir-shadow);
    transition: box-shadow .2s, transform .2s;
}
.crir-card:hover { box-shadow: 0 6px 20px rgba(0,0,0,.12); transform: translateY(-2px); }

.crir-card-top { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; }
.crir-card-code { display: none; }
.crir-card-cpf  { background: #4a90d9; color: #fff; padding: 2px 10px; border-radius: 12px; font-size: 0.82rem; font-weight: 700; }

.crir-card h3 { font-size: 1.08rem; font-weight: 700; margin: 0 0 5px; line-height: 1.3; }
.crir-card h3 a { color: var(--crir-gris); text-decoration: none; }
.crir-card h3 a:hover { color: var(--crir-orange); }
.crir-card-soustitre { font-size: 0.9rem; color: var(--crir-gris); opacity: .75; margin: 0 0 8px; font-style: italic; }
.crir-card-desc { display: none; }

.crir-card-infos {
    display: flex; flex-wrap: wrap; gap: 6px;
    font-size: 1rem; font-weight: 600; color: var(--crir-gris);
    padding-top: 10px; margin-bottom: 12px;
    border-top: 1px solid var(--crir-border);
}

.crir-card-lien {
    display: block; text-align: center;
    background: var(--crir-light);
    border: 1px solid var(--crir-orange);
    color: var(--crir-orange) !important;
    padding: 8px; border-radius: var(--crir-radius);
    text-decoration: none !important;
    font-weight: 700; font-size: 0.97rem;
    transition: all .2s;
}
.crir-card-lien:hover { background: var(--crir-orange); color: #fff !important; }

/* Séparateur entre familles de logiciels */
.crir-famille-sep-wrapper {
    display: flex;
    align-items: center;
    gap: 14px;
    margin: 20px 0 20px;
}

.crir-famille-label {
    font-size: 0.95rem;
    font-weight: 700;
    color: #aaa;
    letter-spacing: .5px;
    text-transform: uppercase;
    white-space: nowrap;
    flex-shrink: 0;
}

.crir-famille-sep {
    border: none;
    border-top: 2px dashed var(--crir-border);
    flex-grow: 1;
    margin: 0;
}

/* ============================================================
   SHORTCODE
   ============================================================ */
.crir-shortcode-stages { margin: 16px 0; }
.crir-sc-cat { margin-bottom: 20px; }
.crir-sc-cat h3 { font-size: 1.05rem; color: var(--crir-orange); border-bottom: 2px solid var(--crir-orange); padding-bottom: 5px; margin-bottom: 8px; }
.crir-sc-cat ul { list-style: none; padding: 0; }
.crir-sc-cat li { padding: 6px 0; border-bottom: 1px solid var(--crir-border); display: flex; align-items: center; gap: 10px; }
.crir-sc-cat li a { color: var(--crir-gris); text-decoration: none; font-weight: 500; flex: 1; }
.crir-sc-cat li a:hover { color: var(--crir-orange); }
.crir-sc-cat li span { font-size: 0.8rem; color: var(--crir-gris); opacity: .7; }
.crir-sc-cpf { background: #27ae60; color: #fff; padding: 1px 7px; border-radius: 10px; font-size: 0.72rem; font-weight: 700; opacity: 1 !important; }
