/* ═══════════════════════════════════════════════════════════
   QUIZ-PAYS-DU-FEU.CSS — Académie Pirate
   Univers : NARUTO — Orange feu · Noir · Konoha vert
   Règle CS-04 : mobile-first
   ═══════════════════════════════════════════════════════════ */

:root {
  --naruto-orange: #F97316;
  --naruto-red:    #DC2626;
  --naruto-dark:   #0d0805;
  --naruto-panel:  rgba(20,8,4,.94);
  --naruto-border: rgba(249,115,22,.4);
  --naruto-glow:   rgba(249,115,22,.5);
  --naruto-green:  #16A34A;
}

/* ══════════════════════════════════
   FOND ANIMÉ
   ══════════════════════════════════ */
#pdf-bg {
  position: fixed; inset: 0; z-index: 0;
  display: flex; gap: 0; overflow: hidden;
  pointer-events: none; opacity: 0;
  transition: opacity 1s ease;
}
#pdf-bg.visible { opacity: 1; }

.pdf-bg-strip {
  flex: 1; display: flex; flex-direction: column; gap: 4px;
  animation: pdf-strip-scroll 32s linear infinite;
  will-change: transform;
}
.pdf-bg-strip:nth-child(even) { animation-direction: reverse; animation-duration: 40s; }
.pdf-bg-strip:nth-child(3)    { animation-duration: 26s; }
.pdf-bg-strip:nth-child(5)    { animation-duration: 44s; }

@keyframes pdf-strip-scroll {
  from { transform: translateY(0); }
  to   { transform: translateY(-50%); }
}
.pdf-bg-strip img {
  width: 100%; aspect-ratio: 3/4; object-fit: cover;
  display: block; border-radius: 4px; opacity: .55;
  filter: saturate(1.4) brightness(.6) hue-rotate(5deg);
}

/* ══════════════════════════════════
   SECTIONS
   ══════════════════════════════════ */
#pdf-iles-sec,
#pdf-quiz-sec {
  display: none; position: relative; z-index: 2;
  width: 100%; min-height: 100vh; padding-bottom: 80px;
  pointer-events: auto;
}

/* Overlay sombre — règle CS-03 : z-index enfants > 1 */
#pdf-iles-sec::before,
#pdf-quiz-sec::before {
  content: ''; position: fixed; inset: 0; z-index: 1;
  background: linear-gradient(160deg,rgba(13,8,4,.65) 0%,rgba(20,8,4,.55) 50%,rgba(13,8,4,.65) 100%);
  pointer-events: none;
}
.pdf-map-header, .pdf-islands-grid,
.pdf-quiz-header, #pdf-qContainer {
  position: relative; z-index: 3;
}

/* ══════════════════════════════════
   HEADER GRILLE
   ══════════════════════════════════ */
.pdf-map-header { text-align: center; padding: 24px 16px 16px; }
.pdf-map-title {
  font-family: 'Bangers', cursive;
  font-size: clamp(1.8rem, 7vw, 2.8rem);
  color: var(--naruto-orange); letter-spacing: 4px;
  text-shadow: 3px 3px 0 #000, 0 0 30px var(--naruto-glow);
}
.pdf-map-sub {
  font-family: 'Nunito', sans-serif; font-size: .85rem; font-weight: 800;
  color: rgba(255,255,255,.7); letter-spacing: 2px; text-transform: uppercase; margin-top: 4px;
}

/* ══════════════════════════════════
   GRILLE DES ÎLES
   ══════════════════════════════════ */
.pdf-islands-grid {
  display: grid; grid-template-columns: repeat(2, 1fr);
  gap: 12px; padding: 12px 14px 32px;
  max-width: 960px; margin: 0 auto;
}
@media (min-width: 580px) { .pdf-islands-grid { grid-template-columns: repeat(3,1fr); } }
@media (min-width: 900px) { .pdf-islands-grid { grid-template-columns: repeat(4,1fr); } }

.pdf-isle-card {
  position: relative; border-radius: 16px; overflow: hidden;
  cursor: pointer; background: var(--naruto-panel);
  border: 2px solid rgba(249,115,22,.2);
  box-shadow: 0 4px 24px rgba(0,0,0,.7);
  transition: transform .2s, box-shadow .2s, border-color .2s;
  -webkit-tap-highlight-color: transparent;
}
.pdf-isle-card:hover {
  transform: translateY(-4px) scale(1.02);
  border-color: var(--isle-color, var(--naruto-orange));
  box-shadow: 0 8px 32px rgba(0,0,0,.7), 0 0 20px var(--isle-color, var(--naruto-glow));
}
.pdf-isle-card:active { transform: scale(.97); }
.pdf-isle-card.done {
  border-color: var(--isle-color, var(--naruto-orange));
  box-shadow: 0 0 20px var(--isle-color, var(--naruto-glow));
}

.pdf-isle-img-wrap {
  position: relative; width: 100%; aspect-ratio: 3/4;
  background: linear-gradient(180deg,rgba(0,0,0,.1) 0%,rgba(0,0,0,.5) 100%);
  overflow: hidden;
}
.pdf-isle-img {
  width: 100%; height: 100%; object-fit: cover;
  object-position: center top; display: block;
  transition: transform .4s ease;
}
.pdf-isle-card:hover .pdf-isle-img { transform: scale(1.06); }
.pdf-isle-img-fallback {
  display: none; position: absolute; inset: 0;
  align-items: center; justify-content: center;
  font-size: clamp(3rem,10vw,5rem);
}
.pdf-isle-img-fallback[style*="flex"] { display: flex !important; }
.pdf-isle-overlay {
  position: absolute; bottom: 0; left: 0; right: 0; height: 45%; pointer-events: none;
}
.pdf-isle-body {
  padding: 10px 12px 14px; background: rgba(15,6,2,.95);
  border-top: 1px solid rgba(249,115,22,.2);
}
.pdf-isle-num { font-family:'Nunito',sans-serif; font-size:.7rem; font-weight:900; color:rgba(255,255,255,.85); letter-spacing:2px; text-transform:uppercase; }
.pdf-isle-name { font-family:'Bangers',cursive; font-size:clamp(1rem,3vw,1.2rem); letter-spacing:2px; line-height:1.1; margin:2px 0; text-shadow:1px 1px 0 #000; }
.pdf-isle-topic { font-family:'Nunito',sans-serif; font-size:.72rem; font-weight:800; color:rgba(255,255,255,.9); text-transform:uppercase; line-height:1.3; }
.pdf-isle-level { display:inline-block; font-family:'Nunito',sans-serif; font-size:.68rem; font-weight:900; padding:2px 8px; border-radius:20px; border:1px solid; margin-top:5px; letter-spacing:1px; }
.pdf-isle-stars { font-size:.78rem; color:var(--naruto-orange); margin-top:5px; line-height:1; }

/* ══════════════════════════════════
   HEADER QUIZ STICKY
   ══════════════════════════════════ */
#pdf-quiz-sec { padding-top: 0; }
.pdf-quiz-header {
  position: sticky; top: 0; z-index: 100;
  background: rgba(13,8,4,.96);
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  border-bottom: 2px solid rgba(249,115,22,.5);
  padding: 10px 16px 8px; box-shadow: 0 4px 20px rgba(0,0,0,.6);
}
.pdf-quiz-title {
  font-family:'Bangers',cursive; font-size:clamp(1rem,4vw,1.5rem);
  color:var(--naruto-orange); letter-spacing:2px; text-shadow:2px 2px 0 #000;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.pdf-prog-bar { width:100%; height:7px; background:rgba(255,255,255,.15); border-radius:8px; margin-top:6px; overflow:hidden; }
.pdf-prog-fill { height:100%; background:linear-gradient(90deg,var(--naruto-orange),var(--naruto-red)); border-radius:8px; transition:width .4s ease; box-shadow:0 0 8px var(--naruto-glow); }
.pdf-prog-lbl { font-family:'Nunito',sans-serif; font-size:.72rem; font-weight:800; color:rgba(255,255,255,.7); margin-top:3px; text-align:right; }

/* ══════════════════════════════════
   CARTE QUESTION
   ══════════════════════════════════ */
.pdf-q-card {
  margin: 14px 12px; background: var(--naruto-panel);
  border-radius: 18px; border: 2px solid var(--naruto-border);
  padding: 0 0 16px; box-shadow: 0 6px 28px rgba(0,0,0,.8);
  overflow: hidden; transition: border-color .3s;
}
.pdf-boss-card { border-color: var(--naruto-red); box-shadow: 0 0 30px rgba(220,38,38,.4); }

.pdf-boss-banner {
  background: linear-gradient(135deg,#7f1d1d,#dc2626);
  padding: 10px 16px; text-align: center;
}
.pdf-boss-label { font-family:'Nunito',sans-serif; font-size:.7rem; font-weight:900; color:rgba(255,255,255,.7); letter-spacing:3px; text-transform:uppercase; }
.pdf-boss-name  { font-family:'Bangers',cursive; font-size:1.4rem; letter-spacing:3px; color:#fff; text-shadow:2px 2px 0 rgba(0,0,0,.5); }

/* Panneau personnage */
.pdf-char-panel { display:flex; height:100px; border-bottom:2px solid var(--naruto-border); }
.pdf-char-img { width:90px; flex-shrink:0; overflow:hidden; border-right:2px solid var(--naruto-border); }
.pdf-char-img img { width:100%; height:100%; object-fit:cover; object-position:top; display:block; }
.pdf-char-speech { flex:1; padding:10px 12px; background:linear-gradient(135deg,#0c0603,#150a04); display:flex; flex-direction:column; justify-content:center; gap:5px; }
.pdf-char-name { font-family:'Bangers',cursive; font-size:.75rem; letter-spacing:2px; color:var(--naruto-orange); border-bottom:1px solid rgba(249,115,22,.3); padding-bottom:2px; width:fit-content; }
.pdf-speech-bubble { background:rgba(255,255,255,.92); color:#1a1a2e; border:2px solid #000; border-radius:12px 12px 12px 3px; padding:6px 10px; font-size:.78rem; font-weight:800; line-height:1.3; font-family:'Nunito',sans-serif; box-shadow:2px 2px 0 rgba(0,0,0,.5); }

/* Corps question */
.pdf-q-body { padding:14px; }
.pdf-q-num { font-size:.62rem; color:#374151; text-transform:uppercase; letter-spacing:2px; font-weight:800; margin-bottom:8px; }
.pdf-q-txt { font-size:1rem; font-weight:800; line-height:1.6; color:#e2e8f0; margin-bottom:14px; border-left:3px solid var(--naruto-orange); padding-left:10px; font-family:'Nunito',sans-serif; }

/* Options */
.pdf-opts { display:flex; flex-direction:column; gap:8px; }
.pdf-opt {
  display:flex; align-items:center; gap:10px; width:100%;
  padding:11px 12px; background:rgba(255,255,255,.04);
  border:2px solid rgba(255,255,255,.08); border-radius:0;
  cursor:pointer; transition:all .15s; font-size:.9rem; font-weight:800;
  font-family:'Nunito',sans-serif; color:#fff; -webkit-tap-highlight-color:transparent;
}
.pdf-opt:hover { border-color:var(--naruto-orange); transform:translateX(4px); }
.pdf-opt:disabled { cursor:default; transform:none !important; }
.pdf-opt-key { width:28px; height:28px; background:rgba(255,255,255,.08); border:2px solid rgba(255,255,255,.12); display:flex; align-items:center; justify-content:center; font-family:'Bangers',cursive; font-size:.85rem; flex-shrink:0; color:var(--naruto-orange); }
.pdf-opt.pdf-selected { border-color:var(--naruto-orange); background:rgba(249,115,22,.15); }
.pdf-opt.pdf-correct   { border-color:#06d6a0 !important; background:rgba(6,214,160,.2) !important; }
.pdf-opt.pdf-wrong     { border-color:#ef4444 !important; background:rgba(239,68,68,.2) !important; }

/* Feedback & explication */
.pdf-feedback { display:none; margin:8px 14px 0; padding:6px 12px; border-radius:8px; font-family:'Nunito',sans-serif; font-size:.82rem; font-weight:800; }
.pdf-feedback.pdf-ok { display:block; background:rgba(6,214,160,.25); border:1px solid rgba(6,214,160,.6); color:#fff; }
.pdf-feedback.pdf-ko { display:block; background:rgba(239,68,68,.25); border:1px solid rgba(239,68,68,.6); color:#fff; }
.pdf-expl { display:none; margin:8px 14px 0; padding:9px 12px; border-radius:10px; background:rgba(249,115,22,.12); border:1px solid rgba(249,115,22,.4); font-family:'Nunito',sans-serif; font-size:clamp(.78rem,2vw,.86rem); font-weight:700; color:rgba(255,255,255,.95); line-height:1.5; }
.pdf-expl.pdf-show { display:block; }

/* Submit */
.pdf-submit-wrap { text-align:center; padding:22px 16px 48px; }

/* ══════════════════════════════════
   BOUTONS
   ══════════════════════════════════ */
.pdf-btn {
  display:inline-block; padding:13px 26px; border-radius:14px; border:none;
  cursor:pointer; font-family:'Bangers',cursive; font-size:clamp(1rem,3.5vw,1.2rem);
  letter-spacing:2px; transition:transform .15s, box-shadow .15s; min-height:48px;
  -webkit-tap-highlight-color:transparent;
}
.pdf-btn:hover  { transform:translateY(-2px); }
.pdf-btn:active { transform:scale(.97); }
.pdf-btn-orange {
  background:linear-gradient(135deg,var(--naruto-orange),var(--naruto-red));
  color:#fff; box-shadow:0 4px 20px var(--naruto-glow);
  width:100%; max-width:380px; display:block; margin:0 auto 12px;
}
.pdf-btn-outline {
  background:transparent; border:2px solid rgba(249,115,22,.5);
  color:var(--naruto-orange); width:100%; max-width:380px;
  display:block; margin:0 auto;
}

/* ══════════════════════════════════
   RÉSULTATS
   ══════════════════════════════════ */
.pdf-result-card {
  margin:20px 12px; border-radius:20px; overflow:hidden;
  border:2px solid var(--isle-color,var(--naruto-orange));
  box-shadow:0 8px 40px rgba(0,0,0,.8), 0 0 30px var(--isle-color,var(--naruto-glow));
  background:var(--naruto-panel);
  animation:pdf-res-appear .5s cubic-bezier(.34,1.56,.64,1) both;
}
@keyframes pdf-res-appear {
  from { opacity:0; transform:scale(.9) translateY(20px); }
  to   { opacity:1; transform:scale(1) translateY(0); }
}
.pdf-result-banner { position:relative; display:flex; align-items:flex-end; height:clamp(140px,35vw,180px); overflow:hidden; background:linear-gradient(135deg,rgba(249,115,22,.2),rgba(13,8,4,.9)); }
.pdf-result-avatar { height:100%; object-fit:contain; object-position:bottom; filter:drop-shadow(-4px 0 20px rgba(249,115,22,.6)); }
.pdf-result-score-wrap { flex:1; padding:16px; }
.pdf-result-score { font-family:'Bangers',cursive; font-size:clamp(2.5rem,10vw,4rem); color:var(--naruto-orange); text-shadow:2px 2px 0 #000; }
.pdf-result-title { font-family:'Nunito',sans-serif; font-size:clamp(.85rem,2.5vw,1rem); font-weight:900; color:#fff; }
.pdf-result-body { padding:16px; }
.pdf-result-topic { font-family:'Nunito',sans-serif; font-size:.82rem; font-weight:800; color:rgba(255,255,255,.7); text-transform:uppercase; letter-spacing:1px; margin-bottom:8px; }
.pdf-result-stars { font-size:.85rem; color:var(--naruto-orange); margin-bottom:12px; }
.pdf-result-gif { width:100%; max-height:180px; object-fit:contain; border-radius:12px; margin-bottom:12px; }
.pdf-result-xp { font-family:'Nunito',sans-serif; font-size:.85rem; font-weight:900; color:var(--naruto-orange); margin-bottom:16px; }

/* ══════════════════════════════════
   CINÉMATIQUE
   ══════════════════════════════════ */
#pdf-cine-overlay { position:fixed; inset:0; z-index:9500; display:flex; }
.pdf-cine-inner { position:relative; flex:1; overflow:hidden; display:flex; align-items:stretch; }
.pdf-cine-char-wrap { position:absolute; right:0; top:0; bottom:0; display:flex; align-items:flex-end; z-index:1; }
.pdf-cine-char { height:95%; max-width:55vw; object-fit:contain; object-position:bottom; filter:drop-shadow(-8px 0 30px rgba(249,115,22,.8)) saturate(1.4); mix-blend-mode:lighten; animation:pdf-char-enter .6s ease .2s both; }
.pdf-cine-char-emoji { font-size:clamp(5rem,18vw,10rem); animation:pdf-char-enter .5s ease .2s both; }
@keyframes pdf-char-enter { from{transform:translateX(80px) scale(.85);opacity:0;} to{transform:translateX(0) scale(1);opacity:1;} }
.pdf-cine-content { position:relative; z-index:2; display:flex; flex-direction:column; justify-content:center; padding:clamp(20px,5vw,60px); max-width:55vw; gap:clamp(10px,2vh,20px); }
.pdf-cine-kanji { font-family:'Bangers',cursive; font-size:clamp(2.5rem,12vw,7rem); font-weight:900; text-shadow:4px 4px 0 #000, 0 0 50px currentColor; line-height:1; animation:pdf-kanji-pop .5s cubic-bezier(.17,.67,.3,1.3) both; }
@keyframes pdf-kanji-pop { from{transform:scale(0) rotate(-20deg);opacity:0;} to{transform:scale(1) rotate(0);opacity:1;} }
.pdf-cine-line { font-family:'Bangers',cursive; font-size:clamp(1.2rem,5vw,2.2rem); color:#fff; letter-spacing:4px; text-shadow:3px 3px 0 #000; animation:pdf-line-in .4s ease both; }
@keyframes pdf-line-in { from{opacity:0;transform:translateX(-30px);} to{opacity:1;transform:translateX(0);} }
.pdf-cine-bubble { background:rgba(255,255,255,.95); color:#1a1a2e; border:3px solid #000; border-radius:14px; padding:10px 14px; font-family:'Nunito',sans-serif; font-size:clamp(.75rem,2.5vw,.9rem); font-weight:800; max-width:320px; }
.pdf-cine-char-name { display:block; font-family:'Bangers',cursive; font-size:1rem; letter-spacing:2px; margin-bottom:4px; }
.pdf-skip-btn { position:absolute; bottom:16px; right:16px; z-index:3; background:rgba(0,0,0,.5); border:1px solid rgba(255,255,255,.3); color:rgba(255,255,255,.7); font-family:'Nunito',sans-serif; font-size:.75rem; font-weight:800; padding:6px 14px; border-radius:20px; cursor:pointer; }

/* ══════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════ */
@media (min-width: 600px) {
  .pdf-char-panel { height:110px; }
  .pdf-char-img { width:100px; }
  .pdf-q-txt { font-size:1.05rem; }
}
@media (min-width: 1024px) {
  #pdf-quiz-sec { max-width:680px; margin:0 auto; }
}
@media (max-width: 380px) {
  .pdf-opt { font-size:.82rem; padding:9px 10px; }
  .pdf-isle-name { font-size:.95rem; }
}