:root {
  --bleu: #4361ee;
  --bleu-fonce: #2b2d42;
  --vert: #2ec27e;
  --rouge: #e5484d;
  --or: #f9c74f;
  --violet: #7048e8;
  --fond: #eef2ff;
  --carte: #ffffff;
  --rayon: 22px;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  font-family: "Trebuchet MS", "Segoe UI", system-ui, sans-serif;
  background: linear-gradient(160deg, #eef2ff, #e0f7fa);
  color: var(--bleu-fonce);
  min-height: 100vh;
  -webkit-tap-highlight-color: transparent;
}

/* ---------- icônes (technique du masque : colorables en CSS) ---------- */
.ico {
  display: inline-block;
  width: 1.1em;
  height: 1.1em;
  vertical-align: -0.18em;
  background-color: currentColor;
  -webkit-mask: var(--src) center / contain no-repeat;
          mask: var(--src) center / contain no-repeat;
}
.ico.or { color: var(--or); }
.ico.vert { color: var(--vert); }
.ico.rouge { color: var(--rouge); }

/* ---------- gestion des écrans ---------- */
.vue { display: none; max-width: 760px; margin: 0 auto; padding: 18px; }
.vue.active { display: block; animation: apparait .25s ease; }
@keyframes apparait { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; } }

/* ---------- menu ---------- */
.entete { text-align: center; margin: 18px 0 26px; }
.entete h1 { font-size: 2.1rem; margin: 0; color: var(--bleu); }
.sous-titre { color: #5a6; font-size: 1.1rem; margin: 6px 0 0; }

.theme-titre {
  font-size: 1.15rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--violet);
  margin: 22px 6px 12px;
}
.grille { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 14px; }

.carte-comp {
  background: var(--carte);
  border: none;
  border-radius: var(--rayon);
  padding: 18px;
  text-align: left;
  cursor: pointer;
  box-shadow: 0 4px 14px rgba(67, 97, 238, .12);
  transition: transform .12s, box-shadow .12s;
  display: flex;
  align-items: center;
  gap: 14px;
  font: inherit;
}
.carte-comp:hover { transform: translateY(-3px); box-shadow: 0 8px 22px rgba(67, 97, 238, .22); }
.carte-comp:active { transform: scale(.98); }
.carte-comp .rond {
  flex: 0 0 auto;
  width: 54px; height: 54px;
  border-radius: 50%;
  background: var(--bleu);
  color: #fff;
  display: grid; place-items: center;
  font-size: 1.6rem;
}
.carte-comp .infos { flex: 1; }
.carte-comp .nom { display: block; font-weight: bold; font-size: 1.08rem; }
.carte-comp .reussite { display: block; font-size: .9rem; color: #789; margin-top: 4px; }

/* ---------- jeu ---------- */
.barre-jeu {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 16px;
}
.btn-icone {
  border: none; background: #fff; border-radius: 50%;
  width: 48px; height: 48px; font-size: 1.3rem; cursor: pointer;
  box-shadow: 0 3px 8px rgba(0,0,0,.1); color: var(--bleu-fonce);
}
.progression-jeu { font-size: 1.1rem; font-weight: bold; color: var(--violet); }
.score-jeu { font-size: 1.25rem; font-weight: bold; }

#titre-jeu { text-align: center; color: var(--bleu); margin: 4px 0; }
.consigne { text-align: center; color: #678; margin: 0 0 14px; }

.carte-exercice {
  background: var(--carte);
  border-radius: var(--rayon);
  padding: 30px 22px;
  box-shadow: 0 6px 20px rgba(67, 97, 238, .14);
  text-align: center;
}
.enonce { font-size: 2.6rem; font-weight: bold; margin-bottom: 22px; letter-spacing: 1px; }

/* saisie nombre */
.saisie-nombre {
  font-size: 2rem; width: 160px; text-align: center;
  padding: 10px; border: 3px solid var(--bleu); border-radius: 16px;
  outline: none;
}
.saisie-nombre:focus { border-color: var(--violet); }

/* QCM */
.grille-qcm { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 6px; }
.btn-qcm {
  font-size: 1.8rem; padding: 18px; border: 3px solid var(--bleu);
  background: #fff; border-radius: 16px; cursor: pointer; color: var(--bleu-fonce);
  transition: transform .1s;
}
.btn-qcm:hover { background: var(--fond); }
.btn-qcm:active { transform: scale(.96); }
.btn-qcm.bon { background: var(--vert); color: #fff; border-color: var(--vert); }
.btn-qcm.mauvais { background: var(--rouge); color: #fff; border-color: var(--rouge); }

.btn-valider {
  display: block; margin: 18px auto 0;
  font-size: 1.3rem; padding: 12px 34px;
  background: var(--bleu); color: #fff; border: none;
  border-radius: 30px; cursor: pointer; font-weight: bold;
}
.btn-valider:active { transform: scale(.97); }

/* ligne graduée */
.ligne-svg {
  width: 100%; height: auto; max-width: 600px; margin: 10px auto 0;
  display: block; cursor: pointer; user-select: none;
}
.ligne-svg:hover { filter: drop-shadow(0 0 1px var(--bleu)); }

.feedback { font-size: 1.5rem; font-weight: bold; min-height: 38px; margin-top: 16px; }
.feedback.bon { color: var(--vert); }
.feedback.mauvais { color: var(--rouge); }

.btn-aide {
  display: block; margin: 18px auto 0; background: none; border: 2px dashed var(--or);
  color: #b8860b; padding: 8px 18px; border-radius: 20px; cursor: pointer; font-size: 1rem;
}
.texte-aide { text-align: center; color: #b8860b; min-height: 22px; }

/* ---------- résultats ---------- */
#vue-resultat { text-align: center; padding-top: 50px; }
#medaille-resultat { font-size: 6rem; line-height: 1; }
#titre-resultat { font-size: 2rem; color: var(--bleu); }
.detail-resultat { font-size: 1.3rem; color: #567; }
.boutons-fin { display: flex; gap: 14px; justify-content: center; margin-top: 26px; }
.btn-principal, .btn-secondaire {
  font-size: 1.2rem; padding: 14px 26px; border-radius: 30px; cursor: pointer; border: none; font-weight: bold;
}
.btn-principal { background: var(--violet); color: #fff; }
.btn-secondaire { background: #fff; color: var(--bleu-fonce); box-shadow: 0 3px 8px rgba(0,0,0,.1); }

/* petite pluie d'étoiles à la bonne réponse */
.etoile-pop {
  position: fixed; pointer-events: none; font-size: 2rem;
  animation: monte 1s ease-out forwards;
}
@keyframes monte {
  to { transform: translateY(-120px) rotate(40deg); opacity: 0; }
}
