/* =======================
   🌗 STYLES GÉNÉRAUX
======================= */
/* Utilisation de "body" au lieu de ":root" car Tailwind est appliqué au body */
body {
  font-family: 'Inter', sans-serif;
  /* Couleurs claires cohérentes avec le fond Tailwind (bg-gray-50) */
  background: linear-gradient(135deg, #f0f9ff, #f3f4f6);
  background-size: 400% 400%;
  animation: gradientMove 15s ease infinite;
  color: #1f2937; /* Couleur de texte sombre standard */
  transition: background 0.5s ease, color 0.4s ease;
  min-height: 100vh;
}

@keyframes gradientMove {
  0% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

/* =======================
   🌙 MODE SOMBRE (Harmonisation des couleurs)
======================= */
body.dark-mode {
  /* Couleurs plus profondes pour le mode sombre */
  background: linear-gradient(135deg, #0f172a, #1a2333, #111827);
  color: #e2e8f0; /* Texte clair */
}

/* Règle générale pour garantir que les textes internes restent clairs */
body.dark-mode h1,
body.dark-mode h2,
body.dark-mode h3,
body.dark-mode p,
body.dark-mode label,
body.dark-mode span {
  color: #e5e7eb !important; /* Texte par défaut clair */
}

body.dark-mode .quiz-card {
  background-color: rgba(30, 41, 59, 0.9); /* Arrière-plan de la carte */
  border-color: #334155;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5);
}

body.dark-mode input,
body.dark-mode select,
body.dark-mode textarea {
  /* Assure que le selecteur de langue et les champs de formulaire sont sombres */
  background-color: #1e293b !important;
  border-color: #475569 !important;
  color: #f1f5f9 !important;
}

body.dark-mode .quiz-section {
  /* Sections internes (bleu-100/70) */
  background-color: rgba(51, 65, 85, 0.6) !important;
  border-color: #475569 !important;
}

body.dark-mode .choice-button {
  /* Boutons de sélection 'Marchandises / Services' */
  background-color: rgba(30, 41, 59, 0.8) !important;
  color: #f8fafc !important;
  border-color: #334155 !important;
}

body.dark-mode .choice-button:hover {
  background-color: rgba(51, 65, 85, 0.8) !important;
}

/* Correction des couleurs d'icônes/texte spécifiques si nécessaire */
body.dark-mode .text-gray-500,
body.dark-mode .text-gray-600 {
  color: #a1a1aa !important; /* Texte secondaire légèrement plus clair */
}


body.dark-mode .bg-blue-100\/70 {
  /* Remplacement spécifique pour les backgrounds de section */
  background-color: rgba(30, 58, 138, 0.3) !important;
}

body.dark-mode .bg-gray-200\/70 {
  /* Remplacement spécifique pour la section des résultats */
  background-color: rgba(51, 65, 85, 0.4) !important;
}

body.dark-mode footer {
  background-color: #0f172a !important;
  color: #cbd5e1 !important;
  border-color: #1e293b !important;
}

/* =======================
   🔘 BOUTON DARK MODE
======================= */
#dark-mode-toggle {
  cursor: pointer;
  font-size: 1.3rem;
  transition: all 0.3s ease;
}

body.dark-mode #dark-mode-toggle {
  background-color: rgba(255, 255, 255, 0.15);
  color: #facc15; /* Jaune pour le soleil/lune en dark mode */
  border-color: #475569;
}

/* =======================
   🧩 STRUCTURE DU QUIZ
======================= */
.quiz-card {
  background: rgba(255, 255, 255, 0.85);
  backdrop-filter: blur(8px);
  border: 1px solid #e5e7eb;
  transition: all 0.4s ease;
}

/* Transitions pour les sections du quiz (déplacements) */
.quiz-section {
    display: none;
    opacity: 0;
    transform: translateY(20px) scale(0.98);
    transition: opacity 0.6s ease, transform 0.6s ease;
}
.quiz-section.active {
    display: block;
    opacity: 1;
    transform: translateY(0) scale(1);
}

.choice-button {
  transition: all 0.3s ease;
  cursor: pointer;
}

.choice-button:hover {
  transform: translateY(-3px);
}

/* =======================
   ✅ OPTIONS DE RÉPONSE (Nouveau style)
======================= */
.response-label {
    /* Style pour le clic */
    transition: all 0.25s ease;
    user-select: none;
    line-height: 1.2;
}

.response-label input[type="radio"]:checked + span {
    font-weight: bold;
    color: #1D4ED8; /* Utilise la couleur du thème (afcfta-blue) */
}

.response-label:hover {
    /* Ajout d'une ombre au survol pour un effet de carte tactile */
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.08);
}

/* Styles pour le mode sombre */
body.dark-mode .response-label {
    background-color: rgba(30, 41, 59, 0.8) !important;
    border-color: #334155 !important;
}

body.dark-mode .response-label input[type="radio"]:checked + span {
    color: #60a5fa; /* Bleu clair pour le mode sombre */
}


/* =======================
   📊 BARRES DE PROGRESSION
======================= */
.progress-bar {
  height: 0.6rem;
  border-radius: 9999px;
  /* Couleurs plus claires pour correspondre à afcfta-blue */
  background: linear-gradient(90deg, #1D4ED8, #3B82F6);
  transition: width 0.5s ease;
}

body.dark-mode .progress-bar {
  background: linear-gradient(90deg, #2563eb, #60a5fa);
}

/* =======================
   ✅ BOUTONS
======================= */
button {
  transition: all 0.3s ease;
}

/* Suppression de l'effet de scale pour les boutons au profit du style hover de Tailwind */
/* button:hover {
  transform: scale(1.03);
} */

/* =======================
   📱 RESPONSIVE
======================= */
@media (max-width: 640px) {
  #main-title {
    font-size: 1.6rem;
  }

  .choice-button {
    padding: 1rem;
  }
}

/* =======================
   🌍 SÉLECTEUR DE LANGUE (Optimisé pour le mode sombre)
======================= */
.language-container {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  font-family: 'Inter', sans-serif;
  margin-bottom: 1.5rem;
}

#language-label {
  font-size: 0.95rem;
  font-weight: 600;
  color: #374151;
}

body.dark-mode #language-label {
  color: #e5e7eb !important; /* Correction avec !important */
}

.language-select-wrapper {
  position: relative;
  display: inline-block;
}

#language-select {
  appearance: none;
  padding: 0.55rem 2.2rem 0.55rem 1rem;
  border: 1px solid #d1d5db;
  border-radius: 8px;
  background-color: #ffffff;
  color: #1f2937;
  font-size: 0.95rem;
  font-weight: 500;
  transition: all 0.25s ease;
  cursor: pointer;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.06);
}

.language-select-wrapper::after {
  content: '▾';
  position: absolute;
  right: 0.8rem;
  top: 50%;
  transform: translateY(-50%);
  font-size: 0.85rem;
  color: #6b7280;
  pointer-events: none;
}

#language-select:hover {
  border-color: #93c5fd;
  box-shadow: 0 2px 6px rgba(59, 130, 246, 0.15);
}

#language-select:focus {
  outline: none;
  border-color: #3b82f6;
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.25);
}

body.dark-mode #language-select {
  background-color: #1e293b !important;
  border-color: #334155 !important;
  color: #e2e8f0 !important;
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.05); /* Ombre légère pour le dark mode */
}

body.dark-mode #language-select:hover {
  border-color: #60a5fa !important;
}

body.dark-mode .language-select-wrapper::after {
  color: #94a3b8;
}

/* =======================
   📊 SECTION RÉSULTATS
======================= */
#results-section {
    background-color: rgba(229, 231, 235, 0.7);
    border: 1px solid #d1d5db;
}

/* --- Carte de Recommandation --- */
#recommendation-card {
  /* Assure l'application des couleurs personnalisées du thème */
  transition: background-color 0.4s ease, transform 0.3s ease;
}

/* Les classes bg-green-500, bg-yellow-500, bg-red-500 sont appliquées en JS
   Elles sont déjà gérées par Tailwind (donc par le navigateur) */

#recommendation-card:hover {
    transform: translateY(-3px);
}
/* Pas de dark-mode spécifique ici, on laisse les couleurs du diagnostic s'appliquer */


/* =======================
   ✨ ANIMATION SCORES
======================= */

/* 1. Animation du score final (Pulse) */
@keyframes pulse-once {
    0% { transform: scale(1); color: #1d4ed8; }
    50% { transform: scale(1.15); color: #10b981; }
    100% { transform: scale(1); }
}

#final-score.animate-pulse-once,
.animate-pulse-once {
    animation: pulse-once 1s ease-out;
}

/* 2. Animation des scores détaillés par section (Fade-in séquentiel) */
.section-score-item {
    opacity: 0;
    /* Démarrer légèrement en dessous */
    transform: translateY(10px);
    transition: opacity 0.5s ease-out, transform 0.5s ease-out;
}

.section-score-item.show {
    opacity: 1;
    transform: translateY(0);
}

body.dark-mode #sectional-scores-container > div {
    /* Cible les divs générées dans sectional-scores-container */
    border-color: #374151;
}

/* =======================
   👣 PIED DE PAGE
======================= */
footer a {
  transition: color 0.3s ease, transform 0.3s ease; /* Ajout du transform */
}

footer a:hover {
  transform: scale(1.1);
  color: #2563eb; /* Couleur bleue pour l'icône au survol */
}

body.dark-mode footer a:hover {
  color: #60a5fa;
}
/* =======================
   📊 SECTION RÉSULTATS (Amélioration de l'affichage)
======================= */
#results-section {
    background-color: rgba(229, 231, 235, 0.7); /* gris clair transparent */
    border: 1px solid #d1d5db;
    /* Nouveaux styles */
    border-radius: 1.5rem; /* Coins plus arrondis */
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.1); /* Ombre plus moderne */
    padding: 2.5rem; /* Plus d'espace intérieur */
}

/* --- AFFICHAGE DU SCORE GLOBAL --- */
#score-display {
    margin-bottom: 2rem;
    padding: 1.5rem;
    border-radius: 0.75rem;
    background-color: #ffffff; /* Fond blanc pour faire ressortir */
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.08); /* Ombre légère pour effet de flottement */
    border: 2px solid #1D4ED8; /* Bordure accentuée (AfCFTA Blue) */
    transition: all 0.4s ease;
}

body.dark-mode #score-display {
    background-color: #1f2937; /* Fond sombre */
    border-color: #3b82f6;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.4);
}

#final-score {
    font-size: 5rem; /* Augmente la taille pour l'impact */
    font-weight: 900;
    line-height: 1;
}

/* --- DÉTAIL DES SCORES PAR SECTION --- */
#detail-title {
    margin-top: 2rem;
    padding-bottom: 0.5rem;
    border-color: #a1a1aa; 
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

#sectional-scores-container {
    /* Utilisation de grid pour un espacement uniforme et moderne */
    display: grid;
    gap: 1.5rem; 
    padding-top: 0.5rem;
}

/* Style des cartes de score individuelles */
.section-score-item {
    opacity: 0;
    transform: translateY(10px); 
    transition: opacity 0.5s ease-out, transform 0.5s ease-out;
    padding: 1rem;
    border-radius: 0.75rem;
    background-color: #ffffff;
    border: 1px solid #e5e7eb;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
}

.section-score-item.show {
    opacity: 1;
    transform: translateY(0);
}

body.dark-mode .section-score-item {
    background-color: #1e293b;
    border-color: #374151;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

/* --- Carte de Recommandation --- */
#recommendation-card {
    padding: 1.5rem; /* Augmente le padding */
    border-radius: 1rem; /* Assure un arrondi cohérent */
    background: linear-gradient(135deg, #1D4ED8, #2563eb);
    color: white;
    transition: background-color 0.4s ease, transform 0.3s ease;
}
#recommendation-card:hover {
    transform: translateY(-3px);
}
body.dark-mode #recommendation-card {
  background: linear-gradient(135deg, #1e40af, #3b82f6);
}

#recommendation-title {
    font-weight: 800; /* Plus gras */
    text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.2);
}

#action-list {
    /* Styles pour rendre la liste des actions plus lisible */
    list-style: disc;
    list-style-position: inside;
    padding-left: 1rem;
    margin-top: 1rem;
}

#action-list > li {
    padding-left: 0.5rem;
    margin-bottom: 0.5rem;
    border-left: 3px solid rgba(255, 255, 255, 0.5); /* Barre latérale blanche pour accentuation */
}
/* =======================
   ✨ ANIMATION SCORES (Nouveau)
======================= */

/* 2. Animation des scores détaillés par section (Fade-in séquentiel) */
.section-score-item {
    opacity: 0;
    /* Démarrer légèrement en dessous */
    transform: translateY(10px); 
    transition: opacity 0.5s ease-out, transform 0.5s ease-out;
}

/* Appliquer l'animation lorsque la section parente est active */
#results-section.active .section-score-item {
    opacity: 1;
    transform: translateY(0);
}
/* =======================
   ✨ EFFETS ET ANIMATIONS DE LA PAGE DE RÉSULTATS
======================= */

/* 1. Animation d'impulsion pour le score final */
/* Ceci crée un effet visuel fort lorsque le score s'affiche */
@keyframes pulse-once-final-score {
    0% { transform: scale(1); opacity: 0.8; }
    50% { transform: scale(1.1); opacity: 1; }
    100% { transform: scale(1); opacity: 1; }
}

/* Applique l'animation au score */
.animate-pulse-once {
    animation: pulse-once-final-score 1.2s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards; 
}

/* 2. Animation des scores détaillés par section (Fade-in séquentiel) */
/* Les éléments apparaissent un par un avec un léger glissement vertical */
.section-score-item {
    opacity: 0;
    transform: translateY(20px); /* L'élément commence 20px plus bas */
    transition: opacity 0.5s ease-out, transform 0.5s ease-out;
}

/* Déclenche l'animation lorsque la section de résultats est active */
#results-section.active .section-score-item {
    opacity: 1;
    transform: translateY(0);
}

/* =======================
   🎨 STYLES DES CARTES DE RECOMMANDATION (Amélioré)
======================= */

/* Style général pour la carte de recommandation */
#recommendation-card {
    border-radius: 1rem; /* Assure des coins bien arrondis */
    color: white;
    transition: all 0.3s ease; /* Pour l'effet de survol */
    min-height: 200px; /* Assure une taille minimale pour l'esthétique */
    display: flex;
    flex-direction: column;
}

/* Effet de survol sur toutes les cartes pour l'engagement */
#recommendation-card:hover {
    transform: translateY(-3px); /* Soulève légèrement la carte */
    box-shadow: 0 15px 30px rgba(0, 0, 0, 0.25);
}

/* --- Style pour la Maîtrise EXCELLENTE (Vert) --- */
#recommendation-card.bg-green-500 {
    /* Gradient allant du vert clair au vert foncé */
    background: linear-gradient(145deg, #34d399, #10b981); 
    box-shadow: 0 8px 15px rgba(16, 185, 129, 0.5); /* Ombre basée sur la couleur verte */
}
body.dark-mode #recommendation-card.bg-green-500 {
    background: linear-gradient(145deg, #059669, #047857); /* Gradient plus sombre */
}


/* --- Style pour la Maîtrise INTERMÉDIAIRE (Jaune/Orange) --- */
#recommendation-card.bg-yellow-500 {
    /* Gradient allant du jaune à l'orange */
    background: linear-gradient(145deg, #fcd34d, #f59e0b); 
    box-shadow: 0 8px 15px rgba(245, 158, 11, 0.5); /* Ombre basée sur la couleur jaune */
    color: #374151; /* Texte sombre pour un meilleur contraste sur le jaune */
}
body.dark-mode #recommendation-card.bg-yellow-500 {
    background: linear-gradient(145deg, #d97706, #b45309); /* Gradient plus sombre */
    color: white; /* Texte blanc en mode sombre */
}


/* --- Style pour la Maîtrise FAIBLE (Rouge) --- */
#recommendation-card.bg-red-500 {
    /* Gradient allant du rouge au rouge foncé */
    background: linear-gradient(145deg, #f87171, #ef4444); 
    box-shadow: 0 8px 15px rgba(239, 68, 68, 0.5); /* Ombre basée sur la couleur rouge */
}
body.dark-mode #recommendation-card.bg-red-500 {
    background: linear-gradient(145deg, #b91c1c, #991b1b); /* Gradient plus sombre */
}

/* Amélioration de la liste d'actions dans la carte */
#recommendation-card #action-list {
    border-top: 1px solid rgba(255, 255, 255, 0.3); /* Séparateur */
    padding-top: 1.5rem;
    margin-top: 1.5rem;
}
#recommendation-card #action-list div {
    display: flex;
    align-items: flex-start;
    margin-bottom: 0.6rem;
}
#recommendation-card #action-list i {
    flex-shrink: 0; 
    margin-top: 0.3em;
    opacity: 0.8;
}



/* =======================
   📱 RESPONSIVE - OPTIMISATION MOBILE
   (Appliqué aux écrans de 639px de large ou moins)
======================= */
@media (max-width: 639px) {
    
    /* 1. Diminution de la Taille du Score */
    /* La classe Tailwind 'text-7xl' est écrasée sur mobile */
    #final-score {
        font-size: 3.5rem !important; /* Correspond à 'text-5xl' ou 'text-6xl' - plus petit et lisible */
        /* font-size: 3rem !important; pour text-5xl */
    }

    /* 2. Ajustement des Marges et Espacements */
    /* Réduction de l'espace global dans les cartes pour gagner de la place */
    #recommendation-card,
    .section-score-item {
        padding: 1rem !important; /* Réduit le padding intérieur de 1.5rem à 1rem */
    }
    
    /* 3. Ajustement de l'En-tête des Résultats */
    /* L'en-tête était un 'flex justify-between', on le passe en mode bloc pour empiler les éléments */
    #results-section .bg-afcfta-blue.flex {
        flex-direction: column;
        align-items: flex-start;
    }
    #results-section .bg-afcfta-blue .text-right {
        margin-top: 0.5rem;
    }
    
    /* 4. Amélioration de la Lisibilité du Texte dans la Recommandation */
    #recommendation-title {
        font-size: 1.5rem !important; /* Taille de titre plus gérable */
    }
    #recommendation-text {
        font-size: 0.875rem; /* Taille de texte standard (text-sm) */
        line-height: 1.4;
    }
}
/* =======================
   🌙 FIX MODE SOMBRE - PAGE DE CONFIDENTIALITÉ
   Ces règles sont nécessaires car la page ne charge pas Script1.js
======================= */

/* Cible le conteneur principal de la page de confidentialité */
body.dark-mode #app {
    /* Utilisation d'un gris sombre qui correspond à votre thème */
    background-color: #1f2937 !important; 
    color: #e5e7eb; /* Couleur de texte clair par défaut */
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.5), 0 10px 10px -5px rgba(0, 0, 0, 0.2);
}

/* Force la couleur du texte et des éléments de liste à s'inverser */
body.dark-mode #app h1,
body.dark-mode #app h2,
body.dark-mode #app h3,
body.dark-mode #app p,
body.dark-mode #app strong,
body.dark-mode #app ul,
body.dark-mode #app li {
    color: #e5e7eb !important; /* Texte clair */
}

/* Styles spécifiques pour les liens et les séparateurs */
body.dark-mode #app a {
    color: var(--afcfta-green) !important; 
}
body.dark-mode #app .text-afcfta-blue {
    color: #38bdf8 !important; /* Bleu clair pour les titres principaux */
}
body.dark-mode #app .text-gray-600,
body.dark-mode #app .text-gray-500 {
     color: #9ca3af !important; /* Gris moyen pour les textes secondaires */
}

/* Ligne de séparation dans le pied de page */
body.dark-mode #app .border-t {
    border-color: #374151 !important; 
}
.privacy-links {
  margin-top: 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.btn-privacy {
  background: #1e3a8a;
  color: #fff;
  padding: 10px 15px;
  border-radius: 8px;
  text-align: center;
  text-decoration: none;
  font-weight: 600;
  transition: 0.2s;
}

.btn-privacy:hover {
  background: #0f1e4d;
}
