/* ===================================
   FORMATION PROGRAMME PAGE STYLES
   Format inspiré de BangCast avec style Eliosor
   =================================== */

/* Container étroit pour focus contenu */
.container-narrow {
    max-width: 900px;
    margin: 0 auto;
    padding: 0 var(--spacing-lg);
}

/* Hero Section */
.formation-hero {
    background: var(--color-dark);
    color: var(--color-white);
    padding: calc(80px + var(--spacing-3xl)) 0 var(--spacing-2xl);
    text-align: center;
}

.formation-hero-title {
    font-size: clamp(2rem, 5vw, 3rem);
    font-weight: 700;
    margin-bottom: var(--spacing-md);
}

.formation-hero-subtitle {
    font-size: 1.25rem;
    color: var(--color-light-gray);
    margin-bottom: var(--spacing-2xl);
}

.formation-hero-stats {
    display: flex;
    justify-content: center;
    gap: var(--spacing-xl);
    flex-wrap: wrap;
    margin-bottom: var(--spacing-2xl);
    padding: var(--spacing-xl) 0;
    border-top: 1px solid rgba(255,255,255,0.1);
    border-bottom: 1px solid rgba(255,255,255,0.1);
}

.hero-stat-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
}

.stat-icon {
    width: 50px;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-white);
    color: var(--color-dark);
    font-size: 1.5rem;
}

.stat-text {
    text-align: left;
}

.stat-text strong {
    display: block;
    font-size: 1.125rem;
    margin-bottom: 0.25rem;
}

.stat-text span {
    font-size: 0.875rem;
    color: var(--color-light-gray);
}

.formation-hero-cta {
    display: flex;
    gap: var(--spacing-md);
    justify-content: center;
    flex-wrap: wrap;
}

/* Sections alternées */
.formation-section {
    padding: var(--spacing-3xl) 0;
    background: var(--color-white);
}

.formation-section-alt {
    padding: var(--spacing-3xl) 0;
    background: var(--color-lightest);
}

.section-title-simple {
    font-size: 2rem;
    font-weight: 700;
    text-align: center;
    margin-bottom: var(--spacing-lg);
    color: var(--color-dark);
}

.section-intro {
    font-size: 1.0625rem;
    line-height: 1.7;
    text-align: center;
    color: var(--color-gray);
    margin-bottom: var(--spacing-2xl);
    max-width: 700px;
    margin-left: auto;
    margin-right: auto;
}

/* Objectifs List */
.objectifs-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
}

.objectif-item {
    display: flex;
    gap: var(--spacing-md);
    padding: var(--spacing-lg);
    background: var(--color-lightest);
    border-left: 3px solid var(--color-dark);
}

.objectif-icon {
    flex-shrink: 0;
    width: 30px;
    height: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #28a745;
    font-size: 1.5rem;
}

.objectif-content strong {
    display: block;
    font-size: 1.0625rem;
    color: var(--color-dark);
    margin-bottom: var(--spacing-xs);
}

.objectif-content p {
    font-size: 0.9375rem;
    color: var(--color-gray);
    margin: 0;
}

/* Metiers Grid */
.metiers-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-xl);
    margin-bottom: var(--spacing-2xl);
}

.metier-card {
    padding: var(--spacing-xl);
    background: var(--color-white);
    border: 2px solid var(--color-dark);
    text-decoration: none;
    color: inherit;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.metier-card:hover {
    transform: translateY(-5px);
    box-shadow: 8px 8px 0 var(--color-dark);
}

.metier-card-icon {
    width: 50px;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-dark);
    color: var(--color-white);
    font-size: 1.5rem;
}

.metier-card h3 {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--color-dark);
    margin: 0;
}

.metier-examples {
    font-size: 0.875rem;
    color: var(--color-gray);
    line-height: 1.6;
    margin: 0;
    flex-grow: 1;
}

.metier-link {
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--color-dark);
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
}

.metier-link i {
    transition: transform 0.3s ease;
}

.metier-card:hover .metier-link i {
    transform: translateX(5px);
}

.metiers-cta {
    text-align: center;
    padding: var(--spacing-lg);
    background: var(--color-white);
    border: 2px solid var(--color-dark);
}

.metiers-cta p {
    margin: 0;
    font-size: 0.9375rem;
    color: var(--color-gray);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
}

.metiers-cta i {
    color: var(--color-dark);
    font-size: 1.125rem;
}

/* Info Grid */
.info-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-xl);
}

.info-card {
    padding: var(--spacing-xl);
    background: var(--color-white);
    border: 2px solid var(--color-dark);
    text-align: center;
}

.info-card-icon {
    width: 60px;
    height: 60px;
    margin: 0 auto var(--spacing-md);
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-dark);
    color: var(--color-white);
    font-size: 1.75rem;
}

.info-card h3 {
    font-size: 1.25rem;
    font-weight: 700;
    margin-bottom: var(--spacing-sm);
    color: var(--color-dark);
}

.info-card p {
    font-size: 1rem;
    margin-bottom: 0.5rem;
    color: var(--color-dark);
}

.info-detail {
    font-size: 0.875rem !important;
    color: var(--color-gray) !important;
}

/* Méthodes List */
.methodes-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.methode-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-lg);
    background: var(--color-lightest);
    border-left: 3px solid var(--color-dark);
    font-size: 1rem;
    color: var(--color-dark);
}

.methode-item i {
    font-size: 1.5rem;
    color: var(--color-dark);
    flex-shrink: 0;
}

/* Evaluation Timeline */
.evaluation-timeline {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-lg);
    flex-wrap: wrap;
    margin-top: var(--spacing-xl);
}

.eval-step {
    flex: 1;
    min-width: 200px;
    text-align: center;
    padding: var(--spacing-lg);
    background: var(--color-white);
    border: 2px solid var(--color-dark);
}

.eval-badge {
    display: inline-block;
    padding: var(--spacing-xs) var(--spacing-md);
    background: var(--color-dark);
    color: var(--color-white);
    font-weight: 700;
    margin-bottom: var(--spacing-sm);
    font-size: 0.875rem;
    text-transform: uppercase;
}

.eval-step p {
    font-size: 0.9375rem;
    color: var(--color-gray);
    margin: 0;
}

.eval-arrow {
    font-size: 1.5rem;
    color: var(--color-dark);
}

/* Results Grid */
.results-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-xl);
    max-width: 600px;
    margin: 0 auto;
}

.result-card {
    padding: var(--spacing-2xl);
    background: var(--color-white);
    border: 3px solid var(--color-dark);
    text-align: center;
}

.result-number {
    font-size: 3rem;
    font-weight: 700;
    color: var(--color-dark);
    margin-bottom: var(--spacing-sm);
}

.result-label {
    font-size: 1rem;
    color: var(--color-gray);
}

/* Accessibility Box */
.accessibility-box {
    display: flex;
    gap: var(--spacing-xl);
    padding: var(--spacing-2xl);
    background: var(--color-white);
    border: 2px solid var(--color-dark);
    align-items: flex-start;
}

.accessibility-icon {
    flex-shrink: 0;
    width: 70px;
    height: 70px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-dark);
    color: var(--color-white);
    font-size: 2rem;
}

.accessibility-content h3 {
    font-size: 1.375rem;
    font-weight: 700;
    margin-bottom: var(--spacing-md);
    color: var(--color-dark);
}

.accessibility-content p {
    font-size: 0.9375rem;
    line-height: 1.7;
    color: var(--color-gray);
    margin-bottom: var(--spacing-sm);
}

.accessibility-content a {
    color: var(--color-dark);
    font-weight: 600;
    text-decoration: underline;
}

/* Tarif Box */
.tarif-box {
    padding: var(--spacing-2xl);
    background: var(--color-lightest);
    border: 3px solid var(--color-dark);
    text-align: center;
}

.tarif-main {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--color-dark);
    margin-bottom: var(--spacing-md);
}

.tarif-opco {
    font-size: 1rem;
    color: var(--color-gray);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
    margin: 0;
}

.tarif-opco i {
    color: var(--color-dark);
}

/* FAQ List */
.faq-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
}

.faq-item {
    padding: var(--spacing-xl);
    background: var(--color-white);
    border: 2px solid var(--color-dark);
}

.faq-question {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--color-dark);
    margin-bottom: var(--spacing-md);
}

.faq-answer {
    font-size: 0.9375rem;
    line-height: 1.7;
    color: var(--color-gray);
    margin: 0;
}

/* CTA Final */
.formation-cta-final {
    background: var(--color-dark);
    color: var(--color-white);
    padding: var(--spacing-3xl) 0;
}

.cta-final-box {
    text-align: center;
}

.cta-final-box h2 {
    font-size: 2.5rem;
    font-weight: 700;
    margin-bottom: var(--spacing-md);
}

.cta-final-box p {
    font-size: 1.125rem;
    color: var(--color-light-gray);
    margin-bottom: var(--spacing-2xl);
}

.cta-final-buttons {
    display: flex;
    gap: var(--spacing-md);
    justify-content: center;
    flex-wrap: wrap;
}

/* Footer info */
.formation-section-footer {
    background: var(--color-lightest);
    padding: var(--spacing-xl) 0;
}

.footer-info {
    text-align: center;
    font-size: 0.875rem;
    color: var(--color-gray);
}

.footer-info p {
    margin-bottom: var(--spacing-xs);
}

.footer-info a {
    color: var(--color-dark);
    font-weight: 600;
    text-decoration: underline;
}

.footer-note {
    margin-top: var(--spacing-md);
    font-style: italic;
    font-size: 0.8125rem;
}

/* Responsive */
@media (max-width: 768px) {
    .formation-hero-stats {
        flex-direction: column;
        gap: var(--spacing-md);
    }
    
    .hero-stat-item {
        width: 100%;
        justify-content: flex-start;
        align-items: flex-start;
    }
    
    .stat-icon {
        flex-shrink: 0;
    }
    
    .stat-text {
        padding-top: 3px;
    }
    
    .metiers-grid {
        grid-template-columns: 1fr;
        gap: var(--spacing-lg);
    }
    
    .info-grid {
        grid-template-columns: 1fr;
        gap: var(--spacing-lg);
    }
    
    .results-grid {
        grid-template-columns: 1fr;
        gap: var(--spacing-lg);
    }
    
    .evaluation-timeline {
        flex-direction: column;
    }
    
    .eval-arrow {
        transform: rotate(90deg);
    }
    
    .accessibility-box {
        flex-direction: column;
        gap: var(--spacing-md);
    }
    
    .accessibility-icon {
        width: 60px;
        height: 60px;
        font-size: 1.75rem;
        margin: 0 auto;
    }
    
    .formation-hero-cta,
    .cta-final-buttons {
        flex-direction: column;
        width: 100%;
    }
    
    .formation-hero-cta .btn,
    .cta-final-buttons .btn {
        width: 100%;
    }
}

@media (max-width: 480px) {
    .objectif-item {
        flex-direction: column;
        text-align: center;
    }
    
    .objectif-icon {
        margin: 0 auto;
    }
}
