:root { --primary: #2c3e50; --accent: #e67e22; --light: #f8f9fa; --border: #dee2e6; --success: #27ae60; --info: #3498db; --bissel: #9b59b6; }
        body { font-family: 'Segoe UI', sans-serif; background: #eef2f3; padding: 20px; }
       
        
        /* Sélecteur Visuel */
        .selector-header { 
            background: var(--primary); color: white; padding: 25px; border-radius: 8px; 
            margin-bottom: 25px; display: flex; align-items: center; justify-content: space-between;
        }
        .selector-header select { padding: 12px; font-size: 1.0rem; border-radius: 5px; width: 400px; border: 2px solid var(--accent); cursor: pointer; }
        
        .preview-banner {
            display: flex; background: #fff; border: 1px solid var(--border); border-radius: 8px;
            margin-bottom: 20px; overflow: hidden; align-items: center; height: 180px;
        }
        .preview-img { width: 400px; height: 100%; object-fit: contain; background: #eee; padding: 10px; border-right: 2px solid var(--accent); }
        .preview-text { padding: 20px; flex: 1; }
        .preview-text h3 { margin-top: 0; color: var(--primary); }

        /* Formulaire */
        .config-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 30px; }
        .unit-card { background: var(--light); border: 1px solid var(--border); border-radius: 8px; padding: 15px; margin-bottom: 20px; }
        .field { display: flex; flex-direction: column; margin-bottom: 8px; }
        label { font-size: 0.8rem; font-weight: bold; color: #444; }
        input { padding: 8px; border: 1px solid #ccc; border-radius: 4px; transition: border 0.3s; }
        input:focus { border-color: var(--accent); outline: none; }
        .axle-row { display: grid; grid-template-columns: repeat(auto-fill, minmax(90px, 1fr)); gap: 8px; padding: 10px; background: #fff; border: 1px solid #ddd; border-radius: 4px; }
        
        .btn-calcul { background: var(--success); color: white; border: none; padding: 20px; font-size: 1.2rem; cursor: pointer; width: 100%; border-radius: 8px; margin-top: 10px; font-weight: bold; }
        .btn-calcul:hover { background: #219150; }

        /* Tableau */
        table { width: 100%; border-collapse: collapse; margin-top: 30px; }
        th, td { background:white; border: 1px solid #ddd; padding: 12px; text-align: center; }
        th { background: var(--primary); color: white; }
        .liaison-row { background-color: #fff3e0; font-weight: bold; }
        .bissel-row { background-color: #f3e5f5; font-weight: bold; }
/* Container principal isolé */
#section-legale-simulateur {
    margin-top: 60px;
    background-color: #2c3e50;
    color: #ecf0f1;
    padding: 40px 30px;
    font-size: 0.85rem;
    line-height: 1.6;
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    border-radius: 4px;
}

.grille-legale-interne {
    max-width: 1200px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 40px;
}

#section-legale-simulateur h4 {
    color: #3498db !important;
    margin-top: 0;
    margin-bottom: 20px;
    font-size: 0.95rem;
    font-weight: bold;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border-bottom: 1px solid #3e4f5f;
    padding-bottom: 10px;
}

#section-legale-simulateur p {
    margin-bottom: 15px;
    color: #ecf0f1;
    text-align: justify;
}

#section-legale-simulateur strong {
    color: #ffffff;
}

/* Mise en évidence spécifique pour l'exclusion de responsabilité */
#section-legale-simulateur .colonne-legale:first-child strong:last-of-type {
    color: #e74c3c;
}

.copyright-simulateur {
    text-align: center;
    margin-top: 40px;
    padding-top: 20px;
    border-top: 1px solid #3e4f5f;
    opacity: 0.6;
    font-size: 0.8rem;
}

															  
@media print {
    /* 1. On cache tout par défaut */
    body * { 
        visibility: hidden; 
        margin: 0; 
        padding: 0; 
    }

    /* 2. On rend visible uniquement les zones nécessaires (Ajout de #section-legale-simulateur) */
    #result-area, #result-area *, 
    #synthese-convoi, #synthese-convoi *,
    #section-legale-simulateur, #section-legale-simulateur * { 
        visibility: visible; 
    }
    
    /* 3. On repositionne proprement pour éviter les pages blanches */
    #result-area { 
        position: absolute; 
        left: 0; 
        top: 0; 
        width: 100%; 
        display: block !important;
    }

    #synthese-convoi { 
        position: relative; 
        margin-top: 20px; 
        page-break-inside: avoid; 
    }

    /* 4. On place le bloc légal après la synthèse */
    #section-legale-simulateur { 
        position: relative;
        visibility: visible !important;
        background-color: transparent !important;
        color: black !important;
        border: 1px solid #000 !important;
        margin-top: 30px !important;
        padding: 15px !important;
        page-break-inside: avoid; /* Évite de couper le bloc sur deux pages */
        display: block !important;
    }

    #section-legale-simulateur h4 { 
        color: black !important; 
        border-bottom: 1px dotted black !important; 
        font-size: 10pt;
    }

    #section-legale-simulateur p { 
        font-size: 9pt; 
        color: black !important; 
    }

    /* 5. Nettoyage final */
    .btn-print, .no-print, .btn-contact-simu { 
        display: none !important; 
    }

    /* Forcer l'affichage des couleurs */
    th { background-color: #eee !important; -webkit-print-color-adjust: exact; }
    .bissel-row { background-color: #f5f5f5 !important; -webkit-print-color-adjust: exact; }
}


/* --- CORRECTIFS UNIQUEMENT POUR MOBILE & TABLETTE --- */
@media (max-width: 767px) {
    
    /* On réduit les marges latérales excessives sur mobile */
    .main-content {
        padding: 15px 10px !important;
    }

    /* Le header (titre + select) passe en empilé */
    .selector-header {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        gap: 15px;
    }

    #type_ensemble {
        width: 100%;
        max-width: none;
    }

    /* La bannière preview : image au-dessus du texte */
    .preview-banner {
        flex-direction: column;
        text-align: center;
        padding: 10px;
    }

    .preview-img {
        max-width: 80%;
        margin-bottom: 10px;
    }

    /* Gestion du tableau : scroll horizontal pour éviter l'écrasement */
    #result-area {
        width: 100%;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    #table_results {
        min-width: 600px; /* Force le scroll pour garder les colonnes lisibles */
        font-size: 13px;
    }

    /* Les colonnes de la clause légale passent de 3 à 1 seule */
    .grille-legale-interne {
        display: block !important;
    }

    .colonne-legale {
        margin-bottom: 20px;
        width: 100%;
    }

    /* Bouton d'impression en pleine largeur */
    .btn-print {
        width: 100%;
        justify-content: center;
    }

    /* Ajustement des formulaires de saisie s'ils débordent */
    #form_container input, 
    #form_container select {
        font-size: 16px; /* Évite le zoom automatique sur iPhone */
    }
}
@media (max-width: 767px) {

    /* 1. Recalage du titre/sélecteur trop haut */
    .selector-header {
        margin-top: 15px !important; /* Ajoute de l'air sous le header du site */
        padding: 15px !important;
        box-sizing: border-box;
    }

    /* 2. Empêcher le débordement horizontal de la synthèse et des résultats */
    #result-area, 
    #synthese-convoi, 
    #form_container,
    .main-content {
        width: 100% !important;
        max-width: 100vw !important; /* Force la largeur à la vue du téléphone */
        overflow-x: hidden; /* Empêche le scroll horizontal sur le corps de page */
        box-sizing: border-box;
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    /* 3. La synthèse technique (Config-grid) */
    /* On passe les grilles de synthèse en une seule colonne pour qu'elles ne dépassent pas */
    .config-grid, 
    #synthese_content {
        display: block !important; /* On casse la grille */
        width: 100% !important;
    }

    .config-grid > div {
        width: 100% !important;
        margin-bottom: 15px;
        box-sizing: border-box;
    }

    /* 4. Le tableau de calcul reste scrollable MAIS dans son propre bloc */
    #result-area {
        overflow-x: auto !important; /* Seul le tableau peut glisser, pas la page */
        border: 1px solid #eee;
        border-radius: 4px;
    }

    /* 5. Ajustement des textes de synthèse pour éviter les coupures */
    #synthese_content p, 
    #synthese_content h3 {
        word-wrap: break-word;
        white-space: normal;
    }
}
@media (max-width: 767px) {

    /* On force la bannière à adapter sa hauteur au contenu */
    div#preview_banner.preview-banner {
        height: auto !important;
        min-height: min-content !important;
        max-height: none !important;
        overflow: visible !important; /* Permet au texte de sortir si besoin */
        display: flex !important;
        flex-direction: column !important; /* Image en haut, texte en bas */
        padding: 15px !important;
    }

    /* On corrige le bloc de texte pour qu'il revienne à la ligne */
    div#preview_banner.preview-banner div.preview-text {
        width: 100% !important;
        height: auto !important;
        overflow: visible !important;
        white-space: normal !important; /* Force le retour à la ligne */
        text-overflow: clip !important; /* Supprime les "..." de troncature */
    }

    /* On s'assure que le titre et la description ne sont pas bridés */
    div#preview_banner.preview-banner div.preview-text h3,
    div#preview_banner.preview-banner div.preview-text p {
        margin: 5px 0 !important;
        white-space: normal !important;
        overflow: visible !important;
        line-height: 1.4 !important; /* Améliore la lisibilité sur mobile */
    }
}