/* ═══════════════════════════════════════════════════════════
   QUIZ-MAGNOLIA.CSS V2 — Académie Pirate
   🐉 Magnolia · Histoire · Dragon Ball Z
   Préfixe : hist-
   ═══════════════════════════════════════════════════════════ */

/* ── Fond animé ─────────────────────────────────────────── */
#hist-bg {
  position:fixed; inset:0; z-index:0;
  display:flex; opacity:0; transition:opacity 1s;
  pointer-events:none; overflow:hidden;
}
#hist-bg.visible { opacity:1; }

@keyframes hist-scroll-up   { from{transform:translateY(0)} to{transform:translateY(-50%)} }
@keyframes hist-scroll-down { from{transform:translateY(-50%)} to{transform:translateY(0)} }

.hist-bg-strip {
  flex:1; display:flex; flex-direction:column;
  animation:hist-scroll-up 36s linear infinite;
}
.hist-bg-strip:nth-child(even) { animation-name:hist-scroll-down; }
.hist-bg-strip img {
  width:100%; aspect-ratio:3/4;
  object-fit:cover; object-position:center top; opacity:.45;
}

/* ── Sections ────────────────────────────────────────────── */
#hist-levels-sec, #hist-iles-sec, #hist-quiz-sec {
  display:none; position:relative; z-index:2;
  width:100%; min-height:100vh;
  background:rgba(0,0,0,.6);
  padding-bottom:80px; pointer-events:auto;
}
/* Contenu au-dessus du fond */
.hist-world-header, .hist-levels-grid, .hist-map-header,
.hist-islands-grid, .hist-quiz-header {
  position:relative; z-index:3;
}

/* ── Header monde ────────────────────────────────────────── */
.hist-world-header {
  text-align:center; padding:24px 16px 8px;
  border-bottom:2px solid rgba(249,115,22,.3);
}
.hist-world-title {
  font-family:'Bangers',cursive; font-size:clamp(1.8rem,5vw,2.8rem);
  color:#f97316; letter-spacing:4px;
  text-shadow:0 0 20px #f9731688;
}
.hist-world-sub {
  font-family:'Nunito',sans-serif; font-size:.85rem;
  font-weight:800; color:rgba(255,255,255,.6); margin-top:4px;
}

/* ── Grille niveaux ──────────────────────────────────────── */
.hist-levels-grid {
  display:grid; grid-template-columns:repeat(2,1fr);
  gap:14px; padding:16px; max-width:720px; margin:0 auto;
}
@media (min-width:540px) { .hist-levels-grid { grid-template-columns:repeat(3,1fr); } }

.hist-level-card {
  border-radius:18px; border:2px solid var(--level-color);
  cursor:pointer; padding:22px 14px;
  display:flex; flex-direction:column; align-items:center;
  gap:8px; text-align:center;
  background:rgba(0,0,0,.6);
  transition:transform .2s, box-shadow .2s;
}
.hist-level-card:hover {
  transform:translateY(-4px);
  box-shadow:0 8px 24px var(--level-color,#f97316)44;
}
.hist-level-emoji { font-size:2rem; }
.hist-level-nom {
  font-family:'Bangers',cursive; font-size:1.9rem;
  color:var(--level-color); letter-spacing:3px;
}
.hist-level-desc {
  font-family:'Nunito',sans-serif; font-size:.75rem;
  font-weight:800; color:rgba(255,255,255,.7);
}
.hist-level-btn {
  margin-top:4px; padding:8px 18px; border-radius:24px;
  color:#000; font-family:'Bangers',cursive;
  font-size:1rem; letter-spacing:1px; border:none; cursor:pointer;
}

/* ── Header îles ─────────────────────────────────────────── */
.hist-map-header {
  padding:12px 16px 8px; display:flex; align-items:center;
  gap:12px; flex-wrap:wrap;
  border-bottom:2px solid rgba(249,115,22,.25);
  background:rgba(0,0,0,.7); position:sticky; top:0; z-index:10;
}
.hist-back-btn {
  display:inline-flex; align-items:center; padding:7px 14px;
  border-radius:20px; border:1px solid rgba(249,115,22,.5);
  background:transparent; color:#f97316; cursor:pointer;
  font-family:'Nunito',sans-serif; font-size:.82rem; font-weight:900;
  transition:background .2s;
}
.hist-back-btn:hover { background:rgba(249,115,22,.15); }
.hist-map-title {
  font-family:'Bangers',cursive; font-size:1.5rem;
  color:#f97316; letter-spacing:3px;
}
.hist-map-sub {
  font-family:'Nunito',sans-serif; font-size:.78rem;
  font-weight:800; color:rgba(255,255,255,.55);
}

/* ── Grille îles ─────────────────────────────────────────── */
.hist-islands-grid {
  display:grid; grid-template-columns:repeat(2,1fr);
  gap:12px; padding:12px; max-width:960px; margin:0 auto;
}
@media (min-width:580px) { .hist-islands-grid { grid-template-columns:repeat(3,1fr); } }
@media (min-width:900px) { .hist-islands-grid { grid-template-columns:repeat(4,1fr); } }

.hist-isle-card {
  border-radius:16px; overflow:hidden; cursor:pointer;
  border:2px solid rgba(255,255,255,.15);
  background:rgba(0,0,0,.5);
  transition:transform .2s, border-color .2s;
}
.hist-isle-card:hover { transform:translateY(-3px); border-color:var(--isle-color); }
.hist-isle-card.done { border-color:var(--isle-color); opacity:.85; }
.hist-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,.45) 100%);
  overflow:hidden;
}
.hist-isle-img {
  width:100%; height:100%;
  object-fit:contain; object-position:center bottom;
  padding:8px 6px 0; box-sizing:border-box;
  display:block; transition:transform .4s ease;
  mix-blend-mode:lighten;
}
.hist-isle-card:hover .hist-isle-img { transform:scale(1.06); }
.hist-isle-img-fallback {
  display:none; position:absolute; inset:0;
  align-items:center; justify-content:center; font-size:3rem;
}
.hist-isle-overlay {
  position:absolute; inset:0; pointer-events:none;
}
.hist-isle-body { padding:10px 12px; }
.hist-isle-num {
  font-family:'Nunito',sans-serif; font-size:.68rem;
  font-weight:900; color:rgba(255,255,255,.45); text-transform:uppercase;
}
.hist-isle-name {
  font-family:'Bangers',cursive; font-size:1.15rem;
  letter-spacing:2px; line-height:1.2; margin:2px 0;
}
.hist-isle-topic {
  font-family:'Nunito',sans-serif; font-size:.72rem;
  font-weight:700; color:rgba(255,255,255,.6);
}
.hist-isle-level {
  display:inline-block; margin-top:6px; padding:2px 8px;
  border-radius:10px; border:1px solid; font-family:'Nunito',sans-serif;
  font-size:.68rem; font-weight:900;
}
.hist-isle-stars {
  font-family:'Nunito',sans-serif; font-size:.75rem;
  font-weight:800; color:#fbbf24; margin-top:4px;
}

/* ── Header quiz ─────────────────────────────────────────── */
.hist-quiz-header {
  position:sticky; top:0; z-index:100;
  background:rgba(0,0,0,.96);
  border-bottom:2px solid #f97316;
  padding:10px 16px 8px;
}
.hist-quiz-title {
  font-family:'Bangers',cursive; font-size:1.2rem;
  color:#f97316; letter-spacing:2px;
}
.hist-prog-bar {
  width:100%; height:7px; background:rgba(255,255,255,.15);
  border-radius:8px; margin-top:6px; overflow:hidden;
}
.hist-prog-fill {
  height:100%; background:#f97316;
  border-radius:8px; transition:width .4s;
}
.hist-prog-lbl {
  font-family:'Nunito',sans-serif; font-size:.8rem;
  font-weight:800; color:rgba(255,255,255,.6); margin-top:3px;
}

/* ── Cinématique ─────────────────────────────────────────── */
#hist-cine-overlay { position:fixed; inset:0; z-index:9500; display:flex; }
.hist-cine-inner {
  position:relative; flex:1; overflow:hidden;
  display:flex; align-items:stretch;
}
.hist-cine-char-wrap {
  position:absolute; right:0; top:0; bottom:0;
  display:flex; align-items:flex-end; z-index:1;
}
.hist-cine-char {
  height:95%; max-width:55vw; object-fit:contain; object-position:bottom;
  filter:drop-shadow(-8px 0 30px rgba(139,92,246,.8)) saturate(1.3);
  animation:hist-char-enter .6s ease .2s both;
}
@keyframes hist-char-enter {
  from { opacity:0; transform:translateX(40px) scale(.95); }
  to   { opacity:1; transform:none; }
}
.hist-cine-char-emoji {
  display:none; font-size:clamp(5rem,18vw,10rem);
  animation:hist-char-enter .5s ease .2s both;
}
.hist-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);
}
.hist-cine-kanji {
  font-family:'Bangers',cursive; font-size:clamp(2.5rem,10vw,6rem);
  font-weight:900; letter-spacing:4px;
  text-shadow:4px 4px 0 #000, 0 0 50px currentColor; line-height:1;
  animation:hist-kanji-pop .5s cubic-bezier(.17,.67,.3,1.3) both;
}
@keyframes hist-kanji-pop {
  from { opacity:0; transform:scale(.5); }
  to   { opacity:1; transform:none; }
}
.hist-cine-lines { display:flex; flex-direction:column; gap:4px; }
.hist-cine-line {
  font-family:'Bangers',cursive; font-size:clamp(1.2rem,4vw,2.2rem);
  color:#fff; letter-spacing:4px; text-shadow:3px 3px 0 #000;
  animation:hist-line-in .4s ease both;
}
@keyframes hist-line-in {
  from { opacity:0; transform:translateX(-20px); }
  to   { opacity:1; transform:none; }
}
.hist-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,2vw,.9rem); font-weight:800;
  max-width:340px; line-height:1.5;
}
.hist-cine-char-name {
  display:block; font-family:'Bangers',cursive;
  font-size:1rem; letter-spacing:2px; margin-bottom:4px;
}
.hist-skip-btn {
  position:fixed; bottom:20px; right:20px; z-index:10;
  background:rgba(0,0,0,.7); color:#fff;
  border:1px solid rgba(255,255,255,.3); border-radius:20px;
  padding:8px 18px; font-family:'Nunito',sans-serif;
  font-size:.85rem; font-weight:900; cursor:pointer;
}
