/* Moteur de jeu Défi — styles isolés pour ne pas perturber le jeu classique. */

.defi-game-app {
  max-width: 920px;
}

.defi-game-start,
.defi-result-panel,
.defi-game-panel {
  max-width: 860px;
  margin-left: auto;
  margin-right: auto;
}

.defi-game-start h2,
.defi-result-panel h2 {
  margin: 0;
  color: #2b160c;
  font-size: clamp(2rem, 5vw, 3rem);
  line-height: 1.04;
}

.defi-start-intro,
.defi-start-note {
  color: #4b3222;
  font-weight: 700;
  line-height: 1.4;
}

.defi-start-summary {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin: 18px 0;
}

.defi-start-summary span {
  display: grid;
  gap: 4px;
  padding: 12px 10px;
  border: 1.5px solid rgba(124, 63, 25, .22);
  border-radius: 16px;
  background: rgba(255, 250, 235, .72);
  color: #4a2d1a;
  font-weight: 800;
  text-align: center;
}

.defi-start-summary strong {
  font-size: 1.18rem;
  color: #2f6f1f;
}

.defi-player-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 16px;
}

.defi-player-grid label {
  display: grid;
  gap: 6px;
  color: #3a2418;
  font-weight: 900;
}

.defi-player-grid input {
  min-height: 48px;
  padding: 10px 13px;
  border: 2px solid rgba(124, 63, 25, .25);
  border-radius: 14px;
  background: #fffaf0;
  color: #2b160c;
  font: inherit;
  font-weight: 750;
}

.defi-warning-line {
  padding: 10px 12px;
  border: 1.5px solid rgba(207, 109, 19, .45);
  border-radius: 14px;
  background: rgba(255, 239, 210, .82);
  color: #7d3f08;
  font-weight: 800;
}

.defi-start-actions,
.defi-result-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  margin-top: 18px;
}

.defi-primary-button,
.defi-secondary-button,
.defi-action-button {
  min-height: 48px;
  border: 0;
  border-radius: 999px;
  padding: 12px 20px;
  font: inherit;
  font-weight: 950;
  cursor: pointer;
  transition: transform .14s ease, box-shadow .14s ease, opacity .14s ease;
}

.defi-primary-button {
  color: #fffaf0;
  background: linear-gradient(180deg, #72aa35, #4f8426);
  box-shadow: 0 5px 0 rgba(43, 92, 20, .95), 0 12px 24px rgba(35, 80, 18, .22);
}

.defi-secondary-button,
.defi-action-button {
  color: #4a2d1a;
  background: #fff9e9;
  border: 2px solid rgba(124, 63, 25, .24);
  box-shadow: 0 4px 0 rgba(124, 63, 25, .18);
}

.defi-primary-button:hover,
.defi-secondary-button:hover,
.defi-action-button:hover {
  transform: translateY(-1px);
}

.defi-primary-button:disabled,
.defi-secondary-button:disabled,
.defi-action-button:disabled {
  cursor: not-allowed;
  opacity: .55;
  transform: none;
}

.defi-action-button span {
  color: #bd2d18;
}

.defi-game-stats {
  display: grid;
  grid-template-columns: 1.05fr 1fr 1fr .82fr 1fr;
  gap: 10px;
  margin: 10px auto 14px;
}

.defi-stat {
  position: relative;
  overflow: hidden;
  min-height: 72px;
  display: grid;
  align-content: center;
  gap: 4px;
  padding: 10px 12px;
  border: 2px solid rgba(124, 63, 25, .22);
  border-radius: 16px;
  background: rgba(255, 250, 235, .92);
  color: #2b160c;
  box-shadow: 0 4px 0 rgba(124, 63, 25, .12);
}

.defi-stat span {
  color: #5f3b23;
  font-size: .78rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.defi-stat strong {
  font-size: clamp(1.05rem, 2.5vw, 1.5rem);
  line-height: 1;
}

.defi-stat-progress {
  border-color: rgba(87, 145, 45, .55);
}

.defi-stat-progress i {
  --progress: 0%;
  display: block;
  width: 100%;
  height: 7px;
  margin-top: 4px;
  border-radius: 999px;
  background: linear-gradient(90deg, #73aa35 var(--progress), rgba(115, 170, 53, .18) var(--progress));
}

.heart-full {
  color: #cf2d25;
  letter-spacing: .06em;
}

.heart-empty {
  color: #9d8675;
  letter-spacing: .06em;
}

.defi-question-card {
  padding: 16px;
  border: 3px solid rgba(124, 63, 25, .28);
  border-radius: 24px;
  background: rgba(255, 249, 229, .94);
  box-shadow: 0 6px 0 rgba(0,0,0,.14), 0 18px 42px rgba(72, 42, 20, .14);
}

.defi-question-label {
  margin: 0 0 12px;
  color: #2b160c;
  font-size: clamp(1.25rem, 3.5vw, 1.8rem);
  font-weight: 950;
  text-align: center;
}

.defi-photo-frame {
  position: relative;
  overflow: hidden;
  aspect-ratio: 4 / 3;
  border-radius: 20px;
  border: 2px solid rgba(124, 63, 25, .22);
  background: #e7c989;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.4);
}

.defi-photo-frame img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.defi-photo-fallback {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  color: #5c3517;
  font-size: 1.2rem;
  font-weight: 900;
}

.defi-photo-credit {
  position: absolute;
  right: 10px;
  bottom: 10px;
  max-width: calc(100% - 20px);
  padding: 5px 8px;
  border-radius: 999px;
  background: rgba(43, 22, 12, .68);
  color: #fffaf0;
  font-size: .78rem;
  font-weight: 800;
}

.defi-hint-box,
.defi-feedback {
  margin-top: 12px;
  padding: 12px 14px;
  border-radius: 16px;
  font-weight: 800;
  line-height: 1.35;
}

.defi-hint-box {
  border: 1.5px solid rgba(207, 125, 24, .42);
  background: rgba(255, 239, 204, .92);
  color: #683806;
}

.defi-feedback {
  border: 1.5px solid rgba(124, 63, 25, .22);
  background: rgba(255, 255, 255, .72);
  color: #3a2418;
}

.defi-feedback a {
  color: #2f6f1f;
  font-weight: 950;
}

.defi-feedback.is-good {
  border-color: rgba(75, 132, 38, .48);
  background: rgba(225, 244, 205, .9);
}

.defi-feedback.is-bad {
  border-color: rgba(188, 58, 32, .48);
  background: rgba(255, 226, 219, .9);
}

.defi-feedback.is-neutral {
  border-color: rgba(207, 125, 24, .42);
  background: rgba(255, 239, 204, .9);
}

.defi-answer-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 14px;
}

.defi-answer-button {
  min-height: 72px;
  padding: 13px 14px;
  border: 2px solid rgba(124, 63, 25, .25);
  border-radius: 18px;
  background: rgba(255, 253, 244, .95);
  color: #2b160c;
  box-shadow: 0 4px 0 rgba(124, 63, 25, .13);
  font: inherit;
  font-size: clamp(1.02rem, 3vw, 1.28rem);
  font-weight: 950;
  text-align: left;
  cursor: pointer;
}

.defi-answer-button.is-selected {
  border-color: #5e9c2c;
  background: #e7f4cc;
  box-shadow: 0 4px 0 rgba(75, 132, 38, .42);
}

.defi-answer-button.is-correct {
  border-color: #4f8426;
  background: #dbf0bc;
}

.defi-answer-button.is-wrong {
  border-color: #bd3a22;
  background: #ffdcd3;
}

.defi-action-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(160px, 1.2fr) minmax(0, 1fr);
  align-items: center;
  gap: 12px;
  margin-top: 16px;
}

.defi-result-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin: 16px 0;
}

.defi-result-summary div {
  display: grid;
  gap: 5px;
  padding: 12px;
  border: 1.5px solid rgba(124, 63, 25, .22);
  border-radius: 16px;
  background: rgba(255, 250, 235, .72);
}

.defi-result-summary span {
  color: #5f3b23;
  font-size: .78rem;
  font-weight: 900;
  text-transform: uppercase;
}

.defi-result-summary strong {
  color: #2b160c;
  font-size: 1.25rem;
}

.defi-review-block {
  margin-top: 14px;
  padding: 14px;
  border-radius: 18px;
  background: rgba(232, 244, 214, .85);
  color: #2d4f1d;
  font-weight: 800;
}

.defi-review-block h3,
.defi-online-scores h3 {
  margin-top: 0;
}

.defi-save-message {
  white-space: pre-wrap;
  margin-top: 12px;
}

.defi-online-scores {
  margin-top: 14px;
  padding: 14px;
  border: 1.5px solid rgba(124, 63, 25, .2);
  border-radius: 18px;
  background: rgba(255, 250, 235, .72);
  color: #3a2418;
}

.defi-online-scores ol {
  margin: 0;
  padding-left: 1.4em;
  font-weight: 800;
}

.hidden {
  display: none !important;
}

@media (max-width: 760px) {
  .defi-game-start,
  .defi-result-panel,
  .defi-game-panel {
    max-width: none;
  }

  .defi-game-stats {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
  }

  .defi-stat {
    min-height: 62px;
    padding: 9px 8px;
    border-radius: 14px;
  }

  .defi-stat span {
    font-size: .68rem;
  }

  .defi-stat strong {
    font-size: 1.05rem;
  }

  .defi-start-summary,
  .defi-result-summary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .defi-player-grid,
  .defi-answer-grid {
    grid-template-columns: 1fr;
  }

  .defi-answer-button {
    min-height: 58px;
    text-align: center;
  }

  .defi-action-row {
    grid-template-columns: 1fr;
  }

  .defi-action-row .defi-primary-button {
    order: -1;
    min-height: 56px;
    font-size: 1.15rem;
  }

  .defi-photo-frame {
    aspect-ratio: 1.2 / 1;
  }
}

@media (max-width: 430px) {
  .defi-game-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .defi-question-card {
    padding: 12px;
    border-radius: 20px;
  }

  .defi-start-summary,
  .defi-result-summary {
    grid-template-columns: 1fr;
  }
}


/* Liens directs vers les fiches d'encyclopédie depuis le résultat du mode Défi. */
.defi-review-race-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: 10px;
  margin: 12px 0 14px;
}

.defi-review-race-link {
  display: grid;
  gap: 3px;
  padding: 10px 12px;
  border: 1.5px solid rgba(47, 111, 31, .36);
  border-radius: 14px;
  background: rgba(255, 250, 235, .76);
  color: #244916;
  text-decoration: none;
  font-weight: 950;
  box-shadow: 0 3px 0 rgba(47, 111, 31, .14);
}

.defi-review-race-link:hover {
  transform: translateY(-1px);
  background: rgba(232, 244, 214, .95);
}

.defi-review-race-link small {
  color: #5d7a4a;
  font-size: .78rem;
  font-weight: 850;
}

/* --------------------------------------------------------------------------
   Défi v1 — polissage interface mobile
   Objectif : rapprocher l'écran de jeu du visuel proposé, sans modifier le
   moteur PHP/JS ni le jeu classique.
   -------------------------------------------------------------------------- */

.defi-game-app {
  scroll-behavior: smooth;
}

.defi-game-panel {
  width: 100%;
}

.defi-game-stats {
  align-items: stretch;
}

.defi-game-stats .defi-stat:nth-child(2) {
  border-color: rgba(47, 111, 31, .40);
  background: linear-gradient(180deg, rgba(235, 248, 213, .96), rgba(255, 250, 235, .94));
}

.defi-game-stats .defi-stat:nth-child(4) {
  border-color: rgba(207, 125, 24, .42);
  background: linear-gradient(180deg, rgba(255, 240, 210, .96), rgba(255, 250, 235, .94));
}

.defi-game-stats .defi-stat:nth-child(5) {
  border-color: rgba(199, 48, 39, .30);
  background: linear-gradient(180deg, rgba(255, 235, 230, .96), rgba(255, 250, 235, .94));
}

.defi-question-card {
  position: relative;
}

.defi-question-card::before {
  content: "";
  position: absolute;
  inset: 8px 8px auto;
  height: 5px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(83, 139, 44, .85), rgba(220, 145, 47, .75), rgba(83, 139, 44, .2));
  opacity: .75;
  pointer-events: none;
}

.defi-photo-frame {
  background:
    radial-gradient(circle at 20% 20%, rgba(255, 255, 255, .45), transparent 28%),
    linear-gradient(180deg, #e9d09c, #c99b5d);
}

.defi-answer-button {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  -webkit-tap-highlight-color: transparent;
}

.defi-answer-button::after {
  content: "";
  width: 22px;
  height: 22px;
  margin-left: 10px;
  border: 2px solid rgba(124, 63, 25, .28);
  border-radius: 50%;
  background: rgba(255, 250, 235, .6);
  flex: 0 0 auto;
}

.defi-answer-button.is-selected::after {
  border-color: #4f8426;
  background: radial-gradient(circle, #4f8426 0 42%, transparent 45%), #f5ffe8;
}

.defi-answer-button.is-correct::after {
  content: "✓";
  display: grid;
  place-items: center;
  border-color: #4f8426;
  background: #4f8426;
  color: #fffaf0;
  font-size: .9rem;
  font-weight: 1000;
}

.defi-answer-button.is-wrong::after {
  content: "×";
  display: grid;
  place-items: center;
  border-color: #bd3a22;
  background: #bd3a22;
  color: #fffaf0;
  font-size: 1rem;
  font-weight: 1000;
}

.defi-action-row .defi-primary-button {
  letter-spacing: .01em;
}

.defi-feedback a,
.defi-review-race-link {
  touch-action: manipulation;
}

.defi-result-summary div:first-child {
  border-color: rgba(47, 111, 31, .42);
  background: linear-gradient(180deg, rgba(228, 246, 207, .96), rgba(255, 250, 235, .82));
}

@media (max-width: 760px) {
  .defi-game-app {
    padding-left: max(8px, env(safe-area-inset-left));
    padding-right: max(8px, env(safe-area-inset-right));
    padding-bottom: max(10px, env(safe-area-inset-bottom));
  }

  .defi-game-stats {
    position: sticky;
    top: 6px;
    z-index: 20;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 6px;
    margin: 4px auto 10px;
    padding: 6px;
    border: 1.5px solid rgba(124, 63, 25, .14);
    border-radius: 18px;
    background: rgba(255, 248, 229, .88);
    box-shadow: 0 8px 24px rgba(72, 42, 20, .16);
    backdrop-filter: blur(9px);
  }

  .defi-stat {
    min-height: 52px;
    padding: 7px 5px;
    border-width: 1.5px;
    border-radius: 13px;
    box-shadow: none;
  }

  .defi-stat span {
    font-size: .56rem;
    letter-spacing: .03em;
  }

  .defi-stat strong {
    font-size: .88rem;
  }

  .defi-stat-progress i {
    height: 5px;
  }

  .defi-question-label {
    margin-top: 4px;
    margin-bottom: 10px;
    font-size: clamp(1.12rem, 5.3vw, 1.45rem);
  }

  .defi-question-card {
    padding: 13px;
    border-width: 2px;
    border-radius: 22px;
  }

  .defi-photo-frame {
    aspect-ratio: 1.22 / 1;
    border-radius: 18px;
  }

  .defi-photo-credit {
    right: 7px;
    bottom: 7px;
    font-size: .68rem;
  }

  .defi-answer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 9px;
    margin-top: 12px;
  }

  .defi-answer-button {
    min-height: 64px;
    padding: 10px 9px;
    border-radius: 16px;
    font-size: clamp(.92rem, 4vw, 1.06rem);
    line-height: 1.08;
  }

  .defi-answer-button::after {
    width: 18px;
    height: 18px;
    margin-left: 6px;
    border-width: 1.5px;
  }

  .defi-action-row {
    grid-template-columns: 1fr 1.22fr 1fr;
    gap: 8px;
    margin-top: 12px;
  }

  .defi-primary-button,
  .defi-secondary-button,
  .defi-action-button {
    min-height: 50px;
    padding: 10px 10px;
    border-radius: 16px;
    font-size: .92rem;
  }

  .defi-action-row .defi-primary-button {
    order: 0;
    min-height: 54px;
    font-size: 1rem;
    border-radius: 18px;
  }

  .defi-hint-box,
  .defi-feedback {
    margin-top: 10px;
    padding: 10px 11px;
    border-radius: 14px;
    font-size: .92rem;
  }

  .defi-result-summary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .defi-review-race-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 430px) {
  .defi-game-stats {
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 4px;
    padding: 5px;
  }

  .defi-stat {
    min-height: 48px;
    padding: 6px 3px;
  }

  .defi-stat span {
    font-size: .50rem;
  }

  .defi-stat strong {
    font-size: .76rem;
  }

  .defi-answer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .defi-answer-button {
    min-height: 60px;
    padding: 9px 7px;
    font-size: .88rem;
  }

  .defi-result-summary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 360px) {
  .defi-game-stats {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .defi-answer-grid,
  .defi-result-summary,
  .defi-review-race-grid {
    grid-template-columns: 1fr;
  }

  .defi-action-row {
    grid-template-columns: 1fr;
  }

  .defi-action-row .defi-primary-button {
    order: -1;
  }
}

/* --------------------------------------------------------------------------
   Correctif mobile Défi v1.1
   - photo au ratio 3/2, sans rognage ;
   - statistiques forcées sur une seule ligne ;
   - réponses toujours en 2 colonnes sur téléphone ;
   - actions maintenues sur une seule ligne même sur petits écrans.
   -------------------------------------------------------------------------- */

.defi-photo-frame {
  aspect-ratio: 3 / 2 !important;
}

.defi-photo-frame img {
  object-fit: contain !important;
  background: #efe0bc;
}

.defi-stat strong > span {
  font-size: inherit !important;
  font-weight: inherit !important;
  text-transform: none !important;
  letter-spacing: inherit !important;
}

@media (max-width: 760px) {
  .defi-game-stats {
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
    gap: 4px !important;
    padding: 4px !important;
    margin: 3px auto 8px !important;
    border-radius: 14px !important;
  }

  .defi-stat {
    min-width: 0 !important;
    min-height: 44px !important;
    padding: 5px 2px !important;
    border-radius: 10px !important;
    gap: 2px !important;
  }

  .defi-stat > span {
    font-size: .46rem !important;
    line-height: 1 !important;
    letter-spacing: 0 !important;
  }

  .defi-stat strong {
    font-size: .70rem !important;
    line-height: 1 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: clip !important;
  }

  .defi-stat:nth-child(2) strong {
    font-size: .64rem !important;
  }

  #defiHearts {
    letter-spacing: -.08em !important;
  }

  .defi-question-card {
    padding: 10px !important;
  }

  .defi-question-card::before {
    inset: 6px 6px auto !important;
    height: 4px !important;
  }

  .defi-question-label {
    margin: 8px 0 8px !important;
    font-size: clamp(1.05rem, 5vw, 1.32rem) !important;
  }

  .defi-answer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
  }

  .defi-answer-button {
    min-height: 56px !important;
    padding: 8px 6px !important;
    font-size: clamp(.82rem, 3.8vw, .98rem) !important;
    line-height: 1.08 !important;
  }

  .defi-answer-button::after {
    width: 17px !important;
    height: 17px !important;
    margin-left: 5px !important;
    flex: 0 0 17px !important;
  }

  .defi-action-row {
    grid-template-columns: .92fr 1.08fr .92fr !important;
    gap: 6px !important;
  }

  .defi-primary-button,
  .defi-secondary-button,
  .defi-action-button {
    min-height: 46px !important;
    padding: 8px 6px !important;
    border-radius: 14px !important;
    font-size: .82rem !important;
    line-height: 1.08 !important;
  }

  .defi-action-row .defi-primary-button {
    order: 0 !important;
    min-height: 48px !important;
    font-size: .92rem !important;
  }
}

@media (max-width: 380px) {
  .defi-game-stats {
    gap: 3px !important;
    padding: 3px !important;
  }

  .defi-stat {
    min-height: 40px !important;
    padding: 4px 1px !important;
  }

  .defi-stat > span {
    font-size: .40rem !important;
  }

  .defi-stat strong {
    font-size: .62rem !important;
  }

  .defi-stat:nth-child(2) strong {
    font-size: .56rem !important;
  }

  .defi-answer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .defi-action-row {
    grid-template-columns: .86fr 1fr .86fr !important;
  }

  .defi-action-button span {
    display: block;
  }
}

/* --------------------------------------------------------------------------
   Correctif Défi v1.2 — encyclopédie en fenêtre intégrée
   Objectif : consulter une fiche sans quitter la partie en cours.
   -------------------------------------------------------------------------- */
body.defi-modal-open {
  overflow: hidden;
}

.defi-encyclo-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: grid;
  place-items: center;
  padding: 18px;
}

.defi-encyclo-modal.hidden {
  display: none !important;
}

.defi-encyclo-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(31, 18, 10, .58);
  backdrop-filter: blur(4px);
}

.defi-encyclo-modal-panel {
  position: relative;
  z-index: 1;
  width: min(980px, 100%);
  height: min(86vh, 900px);
  display: grid;
  grid-template-rows: auto 1fr auto;
  overflow: hidden;
  border: 3px solid rgba(124, 63, 25, .30);
  border-radius: 24px;
  background: #fff8e7;
  box-shadow: 0 28px 90px rgba(20, 10, 5, .42);
}

.defi-encyclo-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
  border-bottom: 1.5px solid rgba(124, 63, 25, .18);
  background: linear-gradient(180deg, rgba(255, 250, 235, .98), rgba(239, 225, 193, .92));
}

.defi-encyclo-modal-kicker {
  margin: 0 0 2px;
  color: #5d7a2a;
  font-size: .78rem;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.defi-encyclo-modal-header h2 {
  margin: 0;
  color: #2b160c;
  font-size: clamp(1.05rem, 4.5vw, 1.55rem);
  line-height: 1.1;
}

.defi-encyclo-close-button {
  width: 46px;
  height: 46px;
  flex: 0 0 46px;
  border: 0;
  border-radius: 50%;
  background: #6f3d1d;
  color: #fff8e7;
  font: inherit;
  font-size: 2rem;
  line-height: 1;
  font-weight: 900;
  cursor: pointer;
  box-shadow: 0 4px 0 rgba(67, 34, 15, .45);
}

.defi-encyclo-frame {
  width: 100%;
  height: 100%;
  border: 0;
  background: #fffaf0;
}

.defi-encyclo-modal-footer {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px 12px;
  border-top: 1.5px solid rgba(124, 63, 25, .18);
  background: rgba(255, 250, 235, .95);
}

.defi-encyclo-inline-link {
  cursor: pointer;
}

@media (max-width: 760px) {
  .defi-encyclo-modal {
    padding: 0;
    place-items: stretch;
  }

  .defi-encyclo-modal-panel {
    width: 100%;
    height: 100dvh;
    max-height: none;
    border-width: 0;
    border-radius: 0;
  }

  .defi-encyclo-modal-header {
    padding-top: max(10px, env(safe-area-inset-top));
  }

  .defi-encyclo-close-button {
    width: 44px;
    height: 44px;
    flex-basis: 44px;
  }
}


/* --------------------------------------------------------------------------
   Défi v1.3 — validation plus ludique des bonnes réponses
   Objectif : remplacer le petit encart vert par une animation courte sur la photo.
   -------------------------------------------------------------------------- */
.defi-photo-frame {
  isolation: isolate;
}

.defi-photo-frame.is-good-answer {
  border-color: rgba(79, 132, 38, .78) !important;
  box-shadow:
    0 0 0 4px rgba(115, 170, 53, .16),
    0 10px 28px rgba(47, 111, 31, .22),
    inset 0 0 0 1px rgba(255,255,255,.45) !important;
}

.defi-reward-pop {
  position: absolute;
  inset: 0;
  z-index: 4;
  display: grid;
  place-items: center;
  padding: 16px;
  background:
    radial-gradient(circle at center, rgba(255, 250, 235, .78), rgba(255, 250, 235, .24) 48%, rgba(24, 72, 17, .12));
  pointer-events: none;
  animation: defiRewardFade .95s ease both;
}

.defi-reward-pop.hidden {
  display: none !important;
}

.defi-reward-pop::before {
  content: "✨  🐄  ✨";
  position: absolute;
  top: 8%;
  left: 50%;
  transform: translateX(-50%);
  color: #fff7d5;
  font-size: clamp(1.5rem, 7vw, 3rem);
  text-shadow: 0 3px 12px rgba(43, 22, 12, .35);
  animation: defiRewardSpark .9s ease both;
}

.defi-reward-card {
  width: min(360px, 88%);
  display: grid;
  justify-items: center;
  gap: 4px;
  padding: 18px 18px 16px;
  border: 3px solid rgba(79, 132, 38, .66);
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(250, 255, 235, .97), rgba(220, 242, 192, .96));
  color: #224614;
  text-align: center;
  box-shadow: 0 12px 0 rgba(47, 111, 31, .28), 0 24px 52px rgba(37, 60, 18, .28);
  transform-origin: center;
  animation: defiRewardPop .55s cubic-bezier(.18, 1.22, .28, 1) both;
}

.defi-reward-icon {
  width: 52px;
  height: 52px;
  display: grid;
  place-items: center;
  margin-top: -42px;
  border: 4px solid #fffaf0;
  border-radius: 50%;
  background: #57942e;
  color: #fffaf0;
  font-size: 2rem;
  font-weight: 1000;
  box-shadow: 0 6px 16px rgba(47, 111, 31, .35);
}

.defi-reward-card strong {
  color: #2b160c;
  font-size: clamp(1.35rem, 6vw, 2.25rem);
  line-height: 1;
  font-weight: 1000;
}

.defi-reward-race {
  color: #2f6f1f;
  font-size: clamp(1.05rem, 4.5vw, 1.55rem);
  font-weight: 1000;
}

.defi-reward-points {
  margin-top: 4px;
  padding: 5px 13px;
  border-radius: 999px;
  background: #57942e;
  color: #fffaf0;
  font-size: clamp(1.05rem, 4.4vw, 1.45rem);
  font-weight: 1000;
  box-shadow: 0 4px 0 rgba(47, 111, 31, .35);
}

.defi-reward-card small {
  max-width: 100%;
  color: #4c6b36;
  font-size: .78rem;
  font-weight: 850;
  line-height: 1.2;
}

.defi-reward-streak {
  margin-top: 4px;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(255, 229, 189, .9);
  color: #9b4d08;
  font-size: .9rem;
  font-weight: 1000;
}

@keyframes defiRewardPop {
  0% { opacity: 0; transform: translateY(18px) scale(.82) rotate(-2deg); }
  62% { opacity: 1; transform: translateY(0) scale(1.04) rotate(1deg); }
  100% { opacity: 1; transform: translateY(0) scale(1) rotate(0); }
}

@keyframes defiRewardFade {
  0% { opacity: 0; }
  12% { opacity: 1; }
  82% { opacity: 1; }
  100% { opacity: .92; }
}

@keyframes defiRewardSpark {
  0% { opacity: 0; transform: translateX(-50%) translateY(16px) scale(.7); }
  45% { opacity: 1; transform: translateX(-50%) translateY(0) scale(1.05); }
  100% { opacity: .9; transform: translateX(-50%) translateY(-8px) scale(1); }
}

@media (max-width: 430px) {
  .defi-reward-pop {
    padding: 10px;
  }

  .defi-reward-card {
    width: min(300px, 92%);
    padding: 15px 12px 12px;
    border-radius: 20px;
  }

  .defi-reward-icon {
    width: 44px;
    height: 44px;
    margin-top: -35px;
    font-size: 1.6rem;
  }

  .defi-reward-card small {
    font-size: .66rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  .defi-reward-pop,
  .defi-reward-pop::before,
  .defi-reward-card {
    animation: none !important;
  }
}

/* --------------------------------------------------------------------------
   Défi v1.4 — rapprochement du mockup mobile
   - cartes de score centrées et plus lisibles ;
   - rythme visuel plus proche du modèle proposé ;
   - boutons réponses et actions plus équilibrés ;
   - conservation du ratio photo 3/2 sans rognage.
   -------------------------------------------------------------------------- */

.defi-game-panel {
  max-width: 760px;
}

.defi-game-stats {
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
}

.defi-stat {
  justify-items: center !important;
  align-content: center !important;
  text-align: center !important;
  gap: 6px !important;
  padding: 12px 10px !important;
  border-radius: 20px !important;
}

.defi-stat > span {
  width: 100%;
  text-align: center !important;
}

.defi-stat strong {
  width: 100%;
  display: flex !important;
  align-items: center;
  justify-content: center;
  gap: .18em;
  text-align: center !important;
  white-space: nowrap;
}

.defi-stat-progress i {
  width: min(92px, 82%) !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

#defiHearts {
  display: flex !important;
  align-items: center;
  justify-content: center;
  gap: .10em;
  letter-spacing: 0 !important;
  font-size: 1.15rem !important;
}

.defi-question-card {
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
  padding: 18px !important;
  border-radius: 26px !important;
  background:
    linear-gradient(180deg, rgba(255, 253, 241, .96), rgba(255, 246, 221, .94));
}

.defi-question-label {
  margin-top: 6px !important;
  margin-bottom: 14px !important;
  font-weight: 1000;
  letter-spacing: -.02em;
}

.defi-photo-frame {
  aspect-ratio: 3 / 2 !important;
  border-radius: 22px !important;
  border-color: rgba(214, 165, 72, .72) !important;
  background: #efe2c2 !important;
}

.defi-photo-frame img {
  object-fit: contain !important;
  background: #efe2c2 !important;
}

.defi-answer-grid {
  max-width: 760px;
  margin: 16px auto 0 !important;
  gap: 14px !important;
}

.defi-answer-button {
  min-height: 82px !important;
  padding: 14px 16px !important;
  border-radius: 20px !important;
  justify-content: center !important;
  text-align: center !important;
  line-height: 1.1 !important;
  box-shadow: 0 5px 0 rgba(124, 63, 25, .13), 0 10px 22px rgba(72, 42, 20, .08) !important;
}

.defi-answer-button.is-selected {
  transform: translateY(-1px);
  box-shadow: 0 5px 0 rgba(75, 132, 38, .45), 0 12px 26px rgba(60, 120, 35, .16) !important;
}

.defi-action-row {
  max-width: 760px;
  margin: 18px auto 0 !important;
}

.defi-action-row .defi-primary-button {
  min-height: 60px !important;
  font-size: 1.18rem !important;
  border-radius: 999px !important;
}

.defi-action-button {
  border-radius: 18px !important;
}

.defi-feedback.is-bad,
.defi-feedback.is-neutral,
.defi-hint-box {
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
}

@media (max-width: 760px) {
  .defi-game-app {
    padding-left: max(8px, env(safe-area-inset-left));
    padding-right: max(8px, env(safe-area-inset-right));
  }

  .defi-game-stats {
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
    gap: 6px !important;
    padding: 7px !important;
    margin: 4px auto 10px !important;
    border-radius: 20px !important;
  }

  .defi-stat {
    min-height: 64px !important;
    padding: 8px 4px !important;
    border-radius: 16px !important;
    gap: 4px !important;
  }

  .defi-stat > span {
    font-size: .55rem !important;
    line-height: 1 !important;
    letter-spacing: .02em !important;
  }

  .defi-stat strong {
    font-size: .92rem !important;
    line-height: 1.02 !important;
  }

  .defi-stat:nth-child(2) strong {
    font-size: .84rem !important;
  }

  #defiHearts {
    font-size: .98rem !important;
    gap: .03em;
  }

  .defi-stat-progress i {
    width: 72% !important;
    height: 6px !important;
    margin-top: 1px !important;
  }

  .defi-question-card {
    padding: 12px !important;
    border-radius: 22px !important;
  }

  .defi-question-label {
    margin-top: 10px !important;
    margin-bottom: 10px !important;
    font-size: clamp(1.05rem, 5vw, 1.36rem) !important;
  }

  .defi-photo-frame {
    border-radius: 18px !important;
  }

  .defi-answer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 9px !important;
    margin-top: 12px !important;
  }

  .defi-answer-button {
    min-height: 68px !important;
    padding: 10px 8px !important;
    border-radius: 17px !important;
    font-size: clamp(.86rem, 3.9vw, 1rem) !important;
  }

  .defi-answer-button::after {
    width: 18px !important;
    height: 18px !important;
    margin-left: 6px !important;
    flex-basis: 18px !important;
  }

  .defi-action-row {
    grid-template-columns: .92fr 1.12fr .92fr !important;
    gap: 8px !important;
    margin-top: 12px !important;
  }

  .defi-action-row .defi-primary-button {
    min-height: 54px !important;
    font-size: 1rem !important;
    border-radius: 999px !important;
  }

  .defi-action-button {
    min-height: 50px !important;
    padding: 8px 5px !important;
    font-size: .82rem !important;
    border-radius: 16px !important;
  }
}

@media (max-width: 430px) {
  .defi-game-stats {
    gap: 5px !important;
    padding: 6px !important;
  }

  .defi-stat {
    min-height: 58px !important;
    padding: 7px 3px !important;
    border-radius: 14px !important;
  }

  .defi-stat > span {
    font-size: .48rem !important;
  }

  .defi-stat strong {
    font-size: .78rem !important;
  }

  .defi-stat:nth-child(2) strong {
    font-size: .70rem !important;
  }

  #defiHearts {
    font-size: .86rem !important;
  }

  .defi-answer-button {
    min-height: 62px !important;
    font-size: clamp(.78rem, 3.7vw, .92rem) !important;
  }
}

@media (max-width: 360px) {
  .defi-game-stats {
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
    gap: 3px !important;
    padding: 4px !important;
  }

  .defi-stat {
    min-height: 50px !important;
    padding: 5px 1px !important;
  }

  .defi-stat > span {
    font-size: .38rem !important;
  }

  .defi-stat strong {
    font-size: .62rem !important;
  }

  .defi-stat:nth-child(2) strong {
    font-size: .56rem !important;
  }

  #defiHearts {
    font-size: .72rem !important;
  }

  .defi-answer-grid,
  .defi-result-summary,
  .defi-review-race-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .defi-action-row {
    grid-template-columns: .86fr 1fr .86fr !important;
  }

  .defi-action-row .defi-primary-button {
    order: 0 !important;
  }
}

/* --------------------------------------------------------------------------
   Défi v1.20.2 — écrans avant/après plus compacts sur mobile
   Objectif : réduire fortement la hauteur des écrans de démarrage et résultat
   sur les téléphones anciens ou les écrans peu hauts.
   -------------------------------------------------------------------------- */

@media (max-width: 760px), (max-height: 740px) {
  .defi-game-start.panel,
  .defi-result-panel.panel {
    width: min(100%, 560px) !important;
    margin-top: 8px !important;
    margin-bottom: 10px !important;
    padding: 14px 12px !important;
    border-radius: 18px !important;
  }

  .defi-game-start .defi-kicker,
  .defi-result-panel .defi-kicker {
    margin-bottom: 4px !important;
    font-size: .68rem !important;
    letter-spacing: .06em !important;
  }

  .defi-game-start h2,
  .defi-result-panel h2 {
    margin: 0 0 8px !important;
    font-size: clamp(1.55rem, 8vw, 2.15rem) !important;
    line-height: 1.02 !important;
  }

  .defi-start-intro {
    margin: 4px 0 10px !important;
    font-size: .94rem !important;
    line-height: 1.25 !important;
  }

  .defi-start-note {
    display: none !important;
  }

  .defi-warning-line {
    margin: 8px 0 !important;
    padding: 8px 9px !important;
    font-size: .78rem !important;
    line-height: 1.2 !important;
  }

  .defi-start-summary {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 7px !important;
    margin: 10px 0 12px !important;
  }

  .defi-start-summary span {
    min-height: 42px !important;
    padding: 7px 8px !important;
    border-radius: 13px !important;
    gap: 1px !important;
    font-size: .78rem !important;
    line-height: 1.08 !important;
  }

  .defi-start-summary strong {
    font-size: 1.02rem !important;
    line-height: 1 !important;
  }

  .defi-player-grid {
    grid-template-columns: 1fr !important;
    gap: 9px !important;
    margin-top: 8px !important;
  }

  .defi-player-grid label {
    gap: 4px !important;
    font-size: .92rem !important;
  }

  .defi-player-grid input {
    min-height: 42px !important;
    padding: 8px 10px !important;
    border-radius: 12px !important;
    font-size: .96rem !important;
  }

  .defi-start-actions {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
    gap: 8px !important;
    margin-top: 12px !important;
  }

  .defi-start-actions .defi-primary-button,
  .defi-start-actions .defi-secondary-link {
    width: 100% !important;
    min-height: 44px !important;
    padding: 9px 10px !important;
    border-radius: 14px !important;
    text-align: center !important;
    font-size: .9rem !important;
    line-height: 1.05 !important;
  }

  .defi-result-summary {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 7px !important;
    margin: 10px 0 !important;
  }

  .defi-result-summary div {
    min-height: 58px !important;
    padding: 8px 9px !important;
    border-radius: 13px !important;
    gap: 2px !important;
  }

  .defi-result-summary span {
    font-size: .66rem !important;
    letter-spacing: .04em !important;
    line-height: 1 !important;
  }

  .defi-result-summary strong {
    font-size: 1.05rem !important;
    line-height: 1.08 !important;
  }

  .defi-review-block {
    margin-top: 10px !important;
    padding: 10px !important;
    border-radius: 14px !important;
    font-size: .84rem !important;
    line-height: 1.25 !important;
  }

  .defi-review-block h3,
  .defi-online-scores h3 {
    margin: 0 0 6px !important;
    font-size: 1rem !important;
  }

  .defi-review-block p {
    margin: 4px 0 8px !important;
  }

  .defi-review-race-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 7px !important;
    margin: 8px 0 10px !important;
  }

  .defi-review-race-link {
    padding: 8px 9px !important;
    border-radius: 12px !important;
    font-size: .82rem !important;
  }

  .defi-result-actions {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
    margin-top: 12px !important;
  }

  .defi-result-actions .defi-primary-button,
  .defi-result-actions .defi-secondary-button,
  .defi-result-actions .defi-secondary-link {
    width: 100% !important;
    min-height: 42px !important;
    padding: 8px 9px !important;
    border-radius: 14px !important;
    font-size: .84rem !important;
    line-height: 1.05 !important;
    text-align: center !important;
  }

  .defi-save-message {
    margin-top: 8px !important;
    padding: 8px !important;
    font-size: .78rem !important;
    line-height: 1.2 !important;
  }

  .defi-online-scores {
    margin-top: 10px !important;
    padding: 10px !important;
    border-radius: 14px !important;
    font-size: .82rem !important;
    line-height: 1.25 !important;
  }

  .defi-online-scores ol {
    padding-left: 1.2em !important;
  }
}

@media (max-width: 390px), (max-height: 680px) {
  .defi-game-start.panel,
  .defi-result-panel.panel {
    padding: 12px 10px !important;
  }

  .defi-game-start h2,
  .defi-result-panel h2 {
    font-size: clamp(1.42rem, 7.5vw, 1.9rem) !important;
  }

  .defi-start-intro {
    font-size: .86rem !important;
  }

  .defi-start-summary span {
    min-height: 38px !important;
    padding: 6px !important;
    font-size: .70rem !important;
  }

  .defi-start-summary strong {
    font-size: .94rem !important;
  }

  .defi-player-grid input {
    min-height: 39px !important;
    font-size: .88rem !important;
  }

  .defi-start-actions,
  .defi-result-actions {
    grid-template-columns: 1fr !important;
  }

  .defi-result-summary {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 6px !important;
  }

  .defi-result-summary div {
    min-height: 52px !important;
    padding: 7px !important;
  }

  .defi-result-summary span {
    font-size: .60rem !important;
  }

  .defi-result-summary strong {
    font-size: .96rem !important;
  }

  .defi-review-race-grid {
    grid-template-columns: 1fr !important;
  }
}

/* ─────────────────────────────────────────────────────────────
   Défi v1.21.33 — feedback erreur plus ludique
   - suppression du grand bandeau rouge après erreur ;
   - malus affiché sur la photo ;
   - la bonne réponse devient un raccourci discret vers la fiche.
   ───────────────────────────────────────────────────────────── */

.defi-answer-button {
  flex-direction: row;
  gap: 6px;
}

.defi-answer-main {
  min-width: 0;
}

.defi-answer-sub {
  display: block;
  width: 100%;
  margin-top: 3px;
  color: #2f6f1f;
  font-size: .72rem;
  font-weight: 950;
  line-height: 1;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.defi-answer-button.is-encyclo-link {
  cursor: pointer;
  box-shadow: 0 4px 0 rgba(75, 132, 38, .44), 0 0 0 4px rgba(79, 132, 38, .10);
}

.defi-answer-button.is-encyclo-link:hover,
.defi-answer-button.is-encyclo-link:focus-visible {
  transform: translateY(-1px);
  outline: 3px solid rgba(79, 132, 38, .25);
  outline-offset: 2px;
}

.defi-answer-button.is-encyclo-link::after {
  align-self: center;
}

.defi-reward-pop.is-bad {
  background:
    radial-gradient(circle at center, rgba(255, 244, 238, .78), rgba(255, 230, 221, .30) 48%, rgba(189, 58, 34, .14));
}

.defi-reward-pop.is-neutral {
  background:
    radial-gradient(circle at center, rgba(255, 248, 228, .78), rgba(255, 238, 196, .30) 48%, rgba(207, 125, 24, .14));
}

.defi-reward-pop.is-bad::before {
  content: "🐄  Oups  🐄";
}

.defi-reward-pop.is-neutral::before {
  content: "🐄  À revoir  🐄";
}

.defi-reward-pop.is-bad .defi-reward-card {
  border-color: rgba(189, 58, 34, .68);
  background: linear-gradient(180deg, rgba(255, 248, 243, .97), rgba(255, 218, 209, .96));
  color: #7b2414;
  box-shadow: 0 12px 0 rgba(189, 58, 34, .24), 0 24px 52px rgba(90, 30, 18, .26);
}

.defi-reward-pop.is-neutral .defi-reward-card {
  border-color: rgba(207, 125, 24, .62);
  background: linear-gradient(180deg, rgba(255, 250, 235, .97), rgba(255, 235, 198, .96));
  color: #764008;
  box-shadow: 0 12px 0 rgba(207, 125, 24, .23), 0 24px 52px rgba(90, 55, 18, .24);
}

.defi-reward-pop.is-bad .defi-reward-icon,
.defi-reward-pop.is-bad .defi-reward-points {
  background: #bd3a22;
  box-shadow: 0 4px 0 rgba(132, 34, 18, .35);
}

.defi-reward-pop.is-neutral .defi-reward-icon,
.defi-reward-pop.is-neutral .defi-reward-points {
  background: #cf7d18;
  box-shadow: 0 4px 0 rgba(126, 72, 8, .32);
}

.defi-reward-pop.is-bad .defi-reward-race,
.defi-reward-pop.is-neutral .defi-reward-race {
  color: #2b160c;
}

@media (max-width: 700px) {
  .defi-answer-sub {
    font-size: .68rem;
  }
}

/* ─────────────────────────────────────────────────────────────
   Défi v1.21.34 — lien fiche sans déplacement du libellé
   - la bonne réponse reste cliquable vers l'encyclopédie ;
   - le lien est positionné discrètement sans pousser le nom de la race ;
   - les autres réponses restent visuellement verrouillées après correction.
   ───────────────────────────────────────────────────────────── */

.defi-answer-button.is-answer-locked {
  cursor: default !important;
}

.defi-answer-button.is-encyclo-link {
  position: relative !important;
  padding-right: 72px !important;
  padding-bottom: 18px !important;
  cursor: pointer !important;
}

.defi-answer-button.is-encyclo-link .defi-answer-main {
  display: block !important;
  width: 100% !important;
  text-align: center !important;
}

.defi-answer-button.is-encyclo-link .defi-answer-sub {
  position: absolute !important;
  right: 54px !important;
  bottom: 10px !important;
  display: inline-block !important;
  width: auto !important;
  max-width: 8.5em !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
  color: #2f6f1f !important;
  font-size: .64rem !important;
  font-weight: 950 !important;
  line-height: 1 !important;
  text-align: right !important;
  text-decoration: underline !important;
  text-overflow: ellipsis !important;
  text-underline-offset: 2px !important;
  white-space: nowrap !important;
  pointer-events: none !important;
}

@media (max-width: 700px) {
  .defi-answer-button.is-encyclo-link {
    padding-right: 58px !important;
    padding-bottom: 17px !important;
  }

  .defi-answer-button.is-encyclo-link .defi-answer-sub {
    right: 46px !important;
    bottom: 8px !important;
    max-width: 7.2em !important;
    font-size: .58rem !important;
  }
}

/* Défi v1.21.36 — message d'enregistrement discret
   Le message noir sous le résultat est supprimé en cas de succès.
   Il ne réapparaît qu'en cas d'enregistrement en cours ou d'erreur. */
.defi-save-message {
  display: none !important;
  margin-top: 8px !important;
  padding: 8px 10px !important;
  border: 1px solid rgba(117, 153, 83, .55) !important;
  border-radius: 12px !important;
  background: rgba(232, 244, 214, .85) !important;
  color: #2f6b35 !important;
  font-family: inherit !important;
  font-size: .82rem !important;
  font-weight: 850 !important;
  line-height: 1.25 !important;
  white-space: normal !important;
}

.defi-save-message.is-visible:not(.hidden) {
  display: block !important;
}

/* ─────────────────────────────────────────────────────────────
   Défi v1.21.37 — fin de partie optimisée pour téléphone
   - résumé plus compact ;
   - score/réussite prioritaires ;
   - statistiques secondaires sous forme de pastilles ;
   - races à retravailler plus hautes dans l'écran ;
   - boutons d'action plus lisibles sur mobile.
   ───────────────────────────────────────────────────────────── */

.defi-result-summary-compact {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: stretch;
}

.defi-result-summary-compact .defi-result-main-stat {
  min-height: 78px;
  border-color: rgba(92, 142, 76, .34);
  background: linear-gradient(135deg, rgba(232, 244, 214, .88), rgba(255, 250, 235, .82));
}

.defi-result-summary-compact .defi-result-mini-stats {
  grid-column: 1 / -1;
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  min-height: 0;
  padding: 0;
  border: 0;
  background: transparent;
}

.defi-result-mini-stat {
  display: inline-flex;
  align-items: baseline;
  gap: 5px;
  padding: 7px 10px;
  border: 1.5px solid rgba(124, 63, 25, .16);
  border-radius: 999px;
  background: rgba(255, 250, 235, .78);
  color: #4b3222;
  font-weight: 900;
  line-height: 1;
}

.defi-result-mini-stat em {
  color: #6a4429;
  font-size: .70rem;
  font-style: normal;
  text-transform: uppercase;
}

.defi-result-mini-stat strong {
  color: #2b160c;
  font-size: .92rem;
}

.defi-secondary-link-muted {
  opacity: .88;
}

@media (max-width: 760px), (max-height: 740px) {
  .defi-result-panel.panel {
    padding: 12px 10px !important;
  }

  .defi-result-panel .defi-kicker {
    margin-bottom: 2px !important;
  }

  .defi-result-panel h2 {
    margin-bottom: 8px !important;
    font-size: clamp(1.55rem, 7.2vw, 2.05rem) !important;
  }

  .defi-result-summary-compact {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 7px !important;
    margin: 8px 0 10px !important;
  }

  .defi-result-summary-compact .defi-result-main-stat {
    min-height: 54px !important;
    padding: 8px 10px !important;
  }

  .defi-result-summary-compact .defi-result-main-stat span {
    font-size: .64rem !important;
  }

  .defi-result-summary-compact .defi-result-main-stat strong {
    font-size: 1.08rem !important;
  }

  .defi-result-summary-compact .defi-result-mini-stats {
    gap: 5px !important;
    margin-top: 0 !important;
  }

  .defi-result-mini-stat {
    padding: 5px 7px !important;
    gap: 4px !important;
    border-radius: 999px !important;
  }

  .defi-result-mini-stat em {
    font-size: .56rem !important;
    letter-spacing: .02em !important;
  }

  .defi-result-mini-stat strong {
    font-size: .76rem !important;
  }

  .defi-review-block {
    margin-top: 8px !important;
    padding: 10px !important;
    border-radius: 15px !important;
  }

  .defi-review-block h3 {
    margin-bottom: 3px !important;
    font-size: 1.05rem !important;
  }

  .defi-review-block p {
    margin: 0 0 7px !important;
    font-size: .82rem !important;
    line-height: 1.18 !important;
  }

  .defi-review-race-grid {
    grid-template-columns: 1fr !important;
    gap: 6px !important;
    margin: 6px 0 8px !important;
  }

  .defi-review-race-link {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    align-items: center !important;
    gap: 8px !important;
    min-height: 40px !important;
    padding: 7px 10px !important;
    border-radius: 13px !important;
  }

  .defi-review-race-link span {
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
  }

  .defi-review-race-link small {
    font-size: .72rem !important;
    white-space: nowrap !important;
  }

  .defi-review-block > .defi-secondary-link {
    min-height: 40px !important;
    padding: 8px 10px !important;
    border-radius: 14px !important;
    font-size: .88rem !important;
  }

  .defi-result-actions {
    grid-template-columns: 1fr 1fr !important;
    gap: 7px !important;
    margin-top: 10px !important;
  }

  .defi-result-actions .defi-primary-button {
    grid-column: 1 / -1 !important;
    min-height: 38px !important;
  }

  .defi-result-actions .defi-secondary-button,
  .defi-result-actions .defi-secondary-link {
    min-height: 40px !important;
    padding: 8px 8px !important;
    border-radius: 14px !important;
    font-size: .82rem !important;
  }
}

@media (max-width: 390px), (max-height: 680px) {
  .defi-result-panel h2 {
    font-size: clamp(1.35rem, 6.8vw, 1.72rem) !important;
  }

  .defi-result-summary-compact .defi-result-main-stat {
    min-height: 48px !important;
    padding: 7px !important;
  }

  .defi-result-mini-stat {
    padding: 4px 6px !important;
  }

  .defi-result-actions {
    grid-template-columns: 1fr !important;
  }
}



/* Défi v1.21.38 — fin de partie : statut discret en haut, suppression du classement bas */
.defi-result-status {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  max-width: 100%;
  margin: 2px 0 8px;
  padding: 6px 10px;
  border: 1.5px solid rgba(79, 132, 38, .30);
  border-radius: 999px;
  background: rgba(232, 244, 214, .82);
  color: #2f6b35;
  font-size: .82rem;
  font-weight: 950;
  line-height: 1.1;
}

.defi-result-status.is-saving {
  border-color: rgba(177, 134, 50, .35);
  background: rgba(255, 245, 212, .88);
  color: #7c5415;
}

.defi-result-status.is-error {
  border-color: rgba(189, 58, 34, .35);
  background: rgba(255, 225, 218, .88);
  color: #99301c;
}

.defi-online-scores {
  display: none !important;
}

@media (max-width: 760px), (max-height: 740px) {
  .defi-result-status {
    margin: 0 0 6px !important;
    padding: 5px 8px !important;
    font-size: .72rem !important;
  }

  .defi-result-actions .defi-primary-button.hidden {
    display: none !important;
  }

  .defi-result-actions {
    grid-template-columns: 1fr 1fr !important;
  }

  .defi-result-actions .defi-primary-button:not(.hidden) {
    grid-column: 1 / -1 !important;
  }
}

/* Défi v1.21.39 — fin de partie mobile : actions remontées et encyclopédie non répétée */
.defi-result-actions {
  margin-top: 10px !important;
  margin-bottom: 14px !important;
}

.defi-review-block .defi-review-race-grid {
  margin-bottom: 0 !important;
}

@media (max-width: 760px), (max-height: 740px) {
  .defi-result-actions {
    order: 2;
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
    margin-top: 8px !important;
    margin-bottom: 10px !important;
  }

  .defi-result-actions .defi-secondary-button,
  .defi-result-actions .defi-secondary-link {
    min-height: 46px !important;
    padding: 10px 8px !important;
    font-size: .92rem !important;
  }

  .defi-result-actions #defiReplayBtn {
    grid-column: 1 / -1 !important;
    border-color: #2f7d32 !important;
    background: linear-gradient(180deg, #e2f6cc, #d3efb9) !important;
    color: #245f2a !important;
  }

  .defi-review-block {
    margin-top: 10px !important;
  }

  .defi-result-status:not(.hidden) {
    display: inline-flex !important;
    align-self: flex-start !important;
  }
}

/* ─────────────────────────────────────────────────────────────
   Défi v1.21.41 — indice sur la photo et crédit masqué en jeu
   - le crédit auteur n'est plus visible pendant la question ;
   - l'indice demandé apparaît en bas à gauche de la photo ;
   - l'indice ne décale plus les réponses vers le bas.
   ───────────────────────────────────────────────────────────── */

#defiPhotoCredit.defi-photo-credit {
  display: none !important;
}

.defi-photo-frame .defi-hint-box {
  position: absolute !important;
  left: 12px !important;
  bottom: 12px !important;
  z-index: 4 !important;
  display: grid !important;
  gap: 3px !important;
  width: auto !important;
  max-width: min(72%, 420px) !important;
  margin: 0 !important;
  padding: 9px 12px !important;
  border: 1px solid rgba(255, 248, 220, .55) !important;
  border-radius: 14px !important;
  background: rgba(44, 29, 14, .76) !important;
  color: #fff8df !important;
  box-shadow: 0 8px 22px rgba(36, 20, 10, .22) !important;
  backdrop-filter: blur(2px) !important;
  font-weight: 850 !important;
  line-height: 1.18 !important;
}

.defi-photo-frame .defi-hint-box.hidden {
  display: none !important;
}

.defi-hint-label {
  color: #f4d478 !important;
  font-size: .72rem !important;
  font-weight: 1000 !important;
  letter-spacing: .06em !important;
  text-transform: uppercase !important;
}

.defi-hint-text {
  font-size: .92rem !important;
}

@media (max-width: 760px), (max-height: 740px) {
  .defi-photo-frame .defi-hint-box {
    left: 8px !important;
    bottom: 8px !important;
    max-width: 78% !important;
    padding: 7px 9px !important;
    border-radius: 12px !important;
  }

  .defi-hint-label {
    font-size: .62rem !important;
  }

  .defi-hint-text {
    font-size: .78rem !important;
  }
}
