
/* ============================================================
   === CALENDRIER FORMATIONS (P6-BIS) ===
   ============================================================ */

/* Hero calendrier */
.calendrier-hero { background: linear-gradient(135deg, #1a2a4a 0%, #26231E 100%); }
.calendrier-hero-stats { display:flex; gap:16px; flex-wrap:wrap; margin-top:28px; }
.hero-stat-badge {
    display:flex; align-items:center; gap:8px;
    background:rgba(255,255,255,0.12);
    border:1px solid rgba(255,255,255,0.2);
    color:#fff; padding:10px 18px; border-radius:24px;
    font-family:'Lato',sans-serif; font-size:14px;
}
.hero-stat-badge strong { font-size:18px; font-family:'Barlow Condensed',sans-serif; font-weight:700; }

/* Barre filtres sticky */
.calendrier-filtres {
    position:sticky; top:80px; z-index:90;
    background:#fff; box-shadow:0 2px 8px rgba(0,0,0,.1);
    padding:18px 0; border-bottom:1px solid #eee;
}
.filtres-pills { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:14px; }
.filtre-pill {
    padding:7px 18px; border-radius:20px;
    background:#F0F0F0; color:#4A4A4A;
    cursor:pointer; border:none;
    font-family:'Barlow Condensed',sans-serif; font-weight:700;
    font-size:13px; letter-spacing:.5px; text-transform:uppercase;
    transition:all .2s ease;
}
.filtre-pill:hover { background:#e0e0e0; }
.filtre-pill.active { background:#C0392B; color:#fff; }

.filtres-selects { display:flex; gap:12px; flex-wrap:wrap; align-items:center; }
.filtre-select {
    padding:9px 14px; border:1px solid #E0E0E0; border-radius:2px;
    font-family:'Lato',sans-serif; font-size:14px;
    min-width:160px; background:#fff; color:#26231E;
    cursor:pointer; transition:border-color .2s;
}
.filtre-select:focus { outline:none; border-color:#C0392B; }

.recherche-calendrier { position:relative; flex:1; min-width:220px; }
.recherche-calendrier input {
    width:100%; padding:9px 14px 9px 42px;
    border:1px solid #E0E0E0; border-radius:2px;
    font-family:'Lato',sans-serif; font-size:14px;
    transition:border-color .2s;
}
.recherche-calendrier input:focus { outline:none; border-color:#C0392B; }
.recherche-calendrier .loupe {
    position:absolute; left:13px; top:50%; transform:translateY(-50%);
    color:#aaa; pointer-events:none;
}

.btn-reset-filtres {
    background:none; border:none; color:#C0392B;
    cursor:pointer; font-family:'Lato',sans-serif; font-size:13px;
    padding:6px 0; text-decoration:underline; margin-top:8px;
}

/* En-tete section sessions */
.calendrier-entete {
    display:flex; justify-content:space-between; align-items:flex-start;
    margin-bottom:20px; flex-wrap:wrap; gap:12px;
}
.compteur-sessions { font-family:'Lato',sans-serif; color:#4A4A4A; font-size:14px; margin:0; }
.compteur-sessions span { font-weight:700; color:#C0392B; }

/* Toggle vue */
.vue-toggle { display:flex; border:1px solid #E0E0E0; border-radius:2px; overflow:hidden; }
.vue-btn {
    display:flex; align-items:center; gap:6px;
    padding:8px 14px; border:none; background:#fff;
    cursor:pointer; font-family:'Lato',sans-serif; font-size:13px;
    color:#4A4A4A; transition:all .2s;
}
.vue-btn:hover { background:#f5f5f5; }
.vue-btn.active { background:#C0392B; color:#fff; }

/* Bouton print */
.print-bar { margin-bottom:16px; }
.btn-print {
    display:inline-flex; align-items:center; gap:8px;
    background:none; border:1px solid #E0E0E0; border-radius:2px;
    padding:7px 14px; cursor:pointer; font-family:'Lato',sans-serif;
    font-size:13px; color:#4A4A4A; transition:all .2s;
}
.btn-print:hover { border-color:#C0392B; color:#C0392B; }

/* Tableau */
.calendrier-table { width:100%; border-collapse:collapse; background:#fff; box-shadow:0 2px 8px rgba(0,0,0,.08); border-radius:2px; overflow:hidden; }
.calendrier-table th {
    background:#26231E; color:#fff;
    font-family:'Barlow Condensed',sans-serif; font-weight:700;
    font-size:13px; letter-spacing:.5px; text-transform:uppercase;
    padding:13px 14px; text-align:left; white-space:nowrap;
}
.calendrier-table td { padding:12px 14px; border-bottom:1px solid #F5F5F5; vertical-align:middle; font-size:14px; }
.calendrier-table tbody tr:hover td { background:#FAFAFA; }

/* Separateur mois */
.mois-separator td {
    background:#1a2a4a; color:#fff;
    font-family:'Barlow Condensed',sans-serif; font-weight:700;
    font-size:13px; letter-spacing:1px; text-transform:uppercase;
    padding:9px 14px;
}

/* Badges */
.badge-categorie {
    display:inline-block; padding:3px 9px; border-radius:3px;
    font-size:11px; font-family:'Barlow Condensed',sans-serif; font-weight:700;
    color:#fff; white-space:nowrap; letter-spacing:.3px;
}
.badge-statut {
    display:inline-block; padding:3px 9px; border-radius:3px;
    font-size:11px; font-family:'Lato',sans-serif; font-weight:700; white-space:nowrap;
}
.badge-ouvert     { background:#e8f5e9; color:#27AE60; }
.badge-complet-row { background:#fce4e4; color:#C0392B; }
.badge-certif     { display:inline-block; background:#e8f5e9; color:#27AE60; font-size:11px; padding:2px 7px; border-radius:10px; margin-left:6px; }

/* Badges places */
.badge-places      { display:inline-block; font-size:13px; font-weight:700; }
.badge-places-ok   { color:#27AE60; }
.badge-places-urgent { color:#E67E22; }
.badge-complet     { background:#fce4e4; color:#C0392B; padding:3px 8px; border-radius:3px; font-size:11px; }

/* Ville cell */
.ville-cell { display:flex; align-items:center; gap:4px; }
.ville-lieu { display:block; font-size:12px; color:#aaa; margin-top:2px; }

/* Lien formation */
.formation-link { color:#26231E; font-weight:700; text-decoration:none; font-family:'Barlow Condensed',sans-serif; font-size:15px; }
.formation-link:hover { color:#C0392B; }

/* Bouton sm */
.btn-sm { padding:6px 14px !important; font-size:13px !important; }
.btn-attente {
    padding:6px 12px; background:none; border:1px solid #ddd;
    border-radius:2px; color:#4A4A4A; font-size:13px;
    cursor:pointer; transition:all .2s;
}
.btn-attente:hover { border-color:#aaa; }

/* Message aucune session */
.no-sessions { text-align:center; padding:60px 20px; }
.no-sessions .icon-empty { width:72px; height:72px; color:#ddd; margin:0 auto 20px; display:block; }
.no-sessions h3 { font-family:'Barlow Condensed',sans-serif; font-size:24px; margin-bottom:10px; }
.no-sessions p { color:#888; }

/* Vue cards sessions */
.sessions-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.session-card {
    background:#fff; border-radius:4px; border-top:4px solid #ccc;
    box-shadow:0 2px 10px rgba(0,0,0,.07); overflow:hidden;
    display:flex; flex-direction:column; transition:transform .2s, box-shadow .2s;
}
.session-card:hover { transform:translateY(-3px); box-shadow:0 6px 20px rgba(0,0,0,.12); }
.session-card-header { display:flex; justify-content:space-between; align-items:center; padding:14px 16px 0; gap:8px; flex-wrap:wrap; }
.session-card-body { padding:14px 16px; flex:1; }
.session-card-titre { font-family:'Barlow Condensed',sans-serif; font-size:17px; font-weight:700; margin-bottom:8px; }
.session-card-titre a { color:#26231E; text-decoration:none; }
.session-card-titre a:hover { color:#C0392B; }
.session-card-infos { list-style:none; margin:12px 0 0; padding:0; display:flex; flex-direction:column; gap:6px; }
.session-card-infos li { display:flex; align-items:center; gap:8px; font-size:14px; color:#4A4A4A; }
.session-card-footer { display:flex; justify-content:space-between; align-items:center; padding:14px 16px; border-top:1px solid #F0F0F0; gap:10px; flex-wrap:wrap; }
.session-prix { font-family:'Barlow Condensed',sans-serif; font-size:16px; font-weight:700; color:#C0392B; }

/* Barre places */
.places-bar-wrap { margin-top:14px; }
.places-bar { width:100%; height:6px; background:#E0E0E0; border-radius:3px; overflow:hidden; }
.places-bar-fill { height:100%; border-radius:3px; transition:width .4s; }
.places-bar-label { font-size:12px; font-weight:700; margin-top:4px; }

/* Section intra */
.section-intra {
    background:#1a2a4a; padding:64px 0;
    color:#fff;
}
.intra-grid { display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:start; }
.intra-icon { width:64px; height:64px; background:rgba(255,255,255,.1); border-radius:50%; display:flex; align-items:center; justify-content:center; margin-bottom:20px; }
.intra-titre { font-family:'Barlow Condensed',sans-serif; font-size:32px; font-weight:700; margin-bottom:16px; }
.intra-texte { font-size:16px; opacity:.85; line-height:1.7; margin-bottom:20px; }
.intra-avantages { list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:10px; }
.intra-avantages li { display:flex; align-items:center; gap:10px; font-size:15px; }
.intra-avantages .check { color:#C0392B; font-weight:700; font-size:16px; }
.intra-form-card { background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.15); border-radius:4px; padding:28px; }
.intra-form-titre { font-family:'Barlow Condensed',sans-serif; font-size:22px; font-weight:700; color:#C0392B; margin-bottom:20px; }
.intra-form-simple .form-group { margin-bottom:14px; }
.intra-form-simple label { display:block; font-size:13px; font-weight:700; margin-bottom:4px; color:rgba(255,255,255,.8); }
.intra-form-simple input,
.intra-form-simple textarea { width:100%; padding:9px 12px; border:1px solid rgba(255,255,255,.2); border-radius:2px; background:rgba(255,255,255,.1); color:#fff; font-family:'Lato',sans-serif; font-size:14px; }

/* Modal liste attente */
#modal-attente-overlay { position:fixed; inset:0; background:rgba(0,0,0,.6); z-index:1000; display:flex; align-items:center; justify-content:center; padding:20px; }
.modal-attente { background:#fff; border-radius:4px; padding:32px; max-width:500px; width:100%; position:relative; }
.modal-close { position:absolute; top:12px; right:16px; background:none; border:none; font-size:20px; cursor:pointer; color:#666; }
.modal-close:hover { color:#C0392B; }

/* Print */
.dpm-print-header { display:none; }
@media print {
    .site-header, .top-bar, .site-footer,
    .calendrier-filtres, .vue-toggle,
    .btn-inscrire, .btn-attente, .btn-primary, .btn-secondary,
    .section-intra, .breadcrumb, .print-bar { display:none !important; }

    .dpm-print-header { display:block !important; text-align:center; margin-bottom:20px; padding-bottom:16px; border-bottom:2px solid #C0392B; }
    .dpm-print-header h2 { font-family:'Barlow Condensed',sans-serif; font-size:24px; }
    .dpm-print-header p { color:#888; font-size:13px; }

    .calendrier-table th { background:#C0392B !important; -webkit-print-color-adjust:exact; print-color-adjust:exact; }
    .mois-separator td  { background:#1a2a4a !important; -webkit-print-color-adjust:exact; print-color-adjust:exact; }

    @page { size:A4 landscape; margin:15mm; }
}

/* Responsive */
@media (max-width:1024px) {
    .sessions-grid { grid-template-columns:repeat(2,1fr); }
    .intra-grid { grid-template-columns:1fr; }
}
@media (max-width:768px) {
    .calendrier-filtres { position:static; }
    .filtres-selects { flex-direction:column; }
    .filtre-select, .recherche-calendrier { width:100%; min-width:auto; }
    .sessions-grid { grid-template-columns:1fr; }
    .calendrier-hero-stats { flex-direction:column; gap:10px; }
    .calendrier-entete { flex-direction:column; }

    .calendrier-table thead { display:none; }
    .calendrier-table tr.session-row {
        display:block; margin-bottom:16px;
        box-shadow:0 2px 8px rgba(0,0,0,.08);
        border-radius:4px; overflow:hidden;
    }
    .calendrier-table td {
        display:flex; justify-content:space-between; align-items:center;
        padding:10px 14px; border-bottom:1px solid #F0F0F0; font-size:14px;
    }
    .calendrier-table td::before {
        content:attr(data-label);
        font-weight:700; color:#26231E;
        margin-right:12px; flex-shrink:0; font-size:12px;
        text-transform:uppercase; letter-spacing:.3px;
    }
    .mois-separator td { display:block; }
    .mois-separator td::before { display:none; }
}

/* Badge "Nouveau" menu */
.menu-badge {
    background:#C0392B; color:#fff;
    font-size:10px; padding:2px 6px;
    border-radius:10px; margin-left:6px;
    vertical-align:middle; font-family:'Lato',sans-serif;
    font-weight:700; letter-spacing:.3px;
}
