/* ============================================================
   CRIR Formations — CSS v1.4
   Couleurs charte : #DF4818 (orange) | #252525 (titres) | #555555 (secondaire)
   ============================================================ */

:root {
    --crir-orange:  #DF4818;
    --crir-gris:    #3D3D3D;
    --crir-titre:   #252525;
    --crir-light:   #F0F0F0;
    --crir-border:  #c5c5c5;
    --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;
}
.crir-container-top {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 20px 0px;
}
.crir-titre-top {
    max-width: 1100px;
    margin: auto;
    padding: 0 0px 0px 20px;
	text-align: left;
}
/* ============================================================
   BREADCRUMB
   ============================================================ */
.crir-breadcrumb {
    font-size: 1.2rem;
    color: var(--crir-gris);
    margin: 15px 0 15px;
}
.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: 20px;
}
.crir-stage-badges span {
    display: inline-block;
    padding: 0px 8px 0px 8px;
    border-radius: 10px;
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: .3px;
}
/* Badge CPF masqué sur la fiche */
/* .crir-badge-cpf    { display: none; } */
.crir-badge-code   { background: var(--crir-orange); color: #fff; }
.crir-badge-niveau { background: var(--crir-light); color: var(--crir-gris); border: 1px solid var(--crir-border); }
.crir-badge-cpf	   {
    background: #DFEFFB;
    color: #025690;
	border: 1px solid #98CDF1;
    padding: 2px 7px 1px 7px;
    border-radius: 12px;
    font-size: 1rem;
    font-weight: 700;
}
.crir-stage-header h1 {
    font-size: 1.9rem;
    font-weight: 700;
    color: var(--crir-orange);
    margin: 20px 0 15px;
    line-height: 1.25;
}

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

/* Bandeau infos rapides */
.crir-infos-rapides {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    align-items: center;
    background: #F0F0F0;
    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-item img {
	width: 20px;
	margin-right: 5px;
}
.crir-info-icon { font-size: 2rem; width: 1.8em; text-align: center; }
.crir-info-label { display: block; font-size: 1rem; color: var(--crir-gris); text-transform: uppercase; letter-spacing: .5px; }
.crir-info-valeur { display: block; font-weight: 700; font-size: 1.1rem; color: var(--crir-titre); }

.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: 1.1rem;
    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: 15px;
    padding-bottom: 15px;
}
.crir-section:last-child { border-bottom: none; }

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

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

.crir-texte {
	color: var(--crir-gris);
	line-height: 1.4;
	text-align: justify;
}
.crir-texte ul, .crir-texte ol { padding-left: 20px; }
.crir-texte li {

}
.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: 1.2rem;
    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: 1.3rem;
    line-height: 1.4;
    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: 1.1rem;
    color: var(--crir-gris);
    margin-top: 8px;
}

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

.crir-sidebar-bloc {
    background: var(--crir-blanc);
    border: 1px solid var(--crir-border);
    border-radius: var(--crir-radius);
    padding: 10px;
    margin-bottom: 16px;
    box-shadow: var(--crir-shadow);
}
.crir-sidebar-bloc h3 {
    font-size: 1.2rem;
    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: 1.2rem;
    color: var(--crir-gris);
    line-height: 1.5;
    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: 1.1rem;
    font-weight: 600;
    color: var(--crir-titre);
    border-left: 3px solid var(--crir-orange);
}
.crir-sessions-vide { color: var(--crir-gris); 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;
}

.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: 0px; flex: 1; }

.crir-form-group label {
    font-size: 1.3rem;
    font-weight: 600;
    color: var(--crir-gris);
	margin-bottom: 0px;
}
.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: 5px 5px;
    border: 1px solid var(--crir-border);
    border-radius: var(--crir-radius);
    font-size: 1.4rem;
    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: 1rem; color: var(--crir-gris); cursor: pointer;
    font-weight: 400 !important;
}
.crir-radio-label input { accent-color: var(--crir-orange); width: 16px; height: 16px; }

.crir-checkbox-label {
    display: flex; align-items: flex-start; gap: 8px;
    font-size: 0.9rem; 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 FORMATIONS (ARCHIVE)
   Fond de page #F8F8F6, tuiles blanches
   ============================================================ */

/* Fond de page gris clair */
body.post-type-archive-stage,
.crir-archive-stages {
    background-color: #F8F8F6;
}

.crir-archive-stages .crir-container { padding-top: 10px; }

.crir-archive-header {
	width:100%;
	text-align: center;
	margin-top: 30px;
	margin-bottom: 28px;
	background-image: linear-gradient(90deg, #DF4818 0%, #005691 100%);
}
.vaguehaut svg {
	height: 20px;
	width: 100%;
}.vaguebas svg {
	height: 20px;
	width: 100%;
	transform: rotate(180deg);
	position:relative;
	bottom:-10px;
}
.vague-shape-fill {
	fill: #f8f8f6;
  	transform: rotateY(0deg);
  	transform-origin: center;
}
.crir-archive-header h1 { 
	font-family: "Roboto", Sans-serif;
 	font-size: 30px;
	font-weight: 500;
	color: #FFFFFF;
	margin-bottom: 0px;
	padding: 0px 0px 0px 0px;
}
.crir-archive-header p  {
	color: #FFFFFF;
	font-size: 100%;
	padding-bottom: 0px;
	margin-bottom: 0px
}
.crir-top-header {
	width:100%;
	margin-top: 0px;
	margin-bottom: 20px;
	background-image: linear-gradient(90deg, #DF4818 0%, #005691 100%);
}
.crir-top-header h1 { 
	font-family: "Roboto", Sans-serif;
 	font-size: 30px;
	font-weight: 500;
	color: #FFFFFF;
	margin-bottom: 10px;
	margin-top: 10px;
	padding: 0px 0px 0px 0px;
}
.crir-top-header p  {
	color: #FFFFFF;
	font-size: 1.5rem;
	padding-bottom: 0px;
	margin-bottom: 0px
}
.crir-filtres {
    display: flex; flex-wrap: wrap; gap: 8px;
    justify-content: center; margin-bottom: 36px;
}
.crir-filtre-btn {
    padding: 5px 5px;
    border: 1px solid var(--crir-border);
    border-radius: 15px;
    text-decoration: none;
    color: var(--crir-gris);
    font-size: 1.2rem;
    font-weight: 600;
    transition: all .2s;
    background: var(--crir-blanc);
}
.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.5rem;
    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;
}

/* Tuile : fond blanc, contour orange au survol */
.crir-card {
    border: 1px solid var(--crir-border);
    border-radius: 12px;
    padding: 5px 15px 10px 15px;
    background: var(--crir-blanc);
    display: flex;
    flex-direction: column;
    box-shadow: var(--crir-shadow);
    transition: border-color .2s, box-shadow .2s, transform .2s;
    cursor: pointer;
    text-decoration: none;
}
.crir-card:hover {
    border-color: #DF4818;
    box-shadow: 0 6px 20px rgba(223,72,24,.13);
    transform: translateY(-2px);
	background-color: #F4E5E1;
}

.crir-card-top {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    margin-bottom: 4px;
    min-height: 22px;
}
.crir-card-code { display: none; }

/* Badge CPF discret sur le catalogue */
.crir-card-cpf {
    background: #DFEFFB;
    color: #025690;
	border: 1px solid #98CDF1;
    padding: 2px 7px 1px 7px;
    border-radius: 12px;
    font-size: 0.82rem;
    font-weight: 700;
}

.crir-card h3 {
    font-size: 1.4rem;
    font-weight: 600;
    margin: 0 0 6px;
    line-height: 1.3;
    color: #013254;
}
/* Le lien est sur la tuile entière, pas sur le h3 */
.crir-card h3 a {
    color: #014370;
    text-decoration: none;
    pointer-events: none;
}

.crir-card-soustitre {
    font-size: 1.2rem;
    color: #3d3d3d;
    margin: 0 0 10px;
    line-height: 1.4;
}
.crir-card-desc { display: none; }

.crir-card-infos {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    padding-top: 5px;
    margin-top: auto;
    border-top: 1px solid var(--crir-border);
	justify-content: space-between;
}

/* Durée */
.crir-card-duree {
    display: flex;
    align-items: center;
    /* gap: 2px; */
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--crir-titre);
}
.crir-card-duree .crir-ic {
    height: 1.5em !important;
    width: 1.5em !important;
    font-size: 1.3em;
    color: var(--crir-orange);
    line-height: 1;
    display: inline-flex;
    align-items: center;
}

/* Prix HT visible et coloré, TTC en gris */
.crir-card-prix {
    display: flex;
    align-items: center;
    /* gap: 2px; */
	font-size: 1.1rem;
}
.crir-card-prix img {
	width:15px;
	margin-right: 5px;
}
.crir-card-prix .crir-ic {
    height: 1.5em !important;
    width: 1.5em !important;
    font-size: 1.3em;
    color: var(--crir-orange);
    line-height: 1;
    display: inline-flex;
    align-items: center;
}
.crir-prix-ht {
    font-size: 1.1rem;
    color: #888;
	font-weight: 600;
}
.crir-prix-ttc {
    font-size: 1.1rem;
    color: var(--crir-orange);
    font-weight: 600;
}

/* 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: 1rem;
    font-weight: 700;
    color: #555555;
    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.9rem; color: var(--crir-gris); }
.crir-sc-cpf { background: #27ae60; color: #fff; padding: 1px 7px; border-radius: 10px; font-size: 0.8rem; font-weight: 700; }
