/* ==========================================================================
   Le Révélateur : styles du jeu (vanilla, aucun framework)
   Réutilise les tokens de /assets/css/site.css (var(--teal), var(--orange)...).
   Aucune couleur en dur : tout passe par les variables du design system.
   Destination : /assets/css/revelateur.css
   ========================================================================== */

#revelateur-app{ display:block; }

.rv-root{
  /* mapping des 6 caractères vers les tokens du site */
  --c-explorateur: var(--orange);
  --c-volcan:      var(--coral-deep);
  --c-reveur:      var(--lav);
  --c-gardien:     var(--sky);
  --c-diplomate:   var(--mint);
  --c-stratege:    var(--honey);
  --rv-leader:     var(--honey);

  position:relative;
  max-width:480px;
  margin:0 auto;
  padding:22px 18px 28px;
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  border:1px solid var(--border);
  border-radius:24px;
  box-shadow:var(--shadow-md);
  overflow:hidden;
}
/* lueur réactive derrière le jeu, teintée par le caractère en tête */
.rv-root::before{
  content:""; position:absolute; inset:0; pointer-events:none; z-index:0;
  background:radial-gradient(120% 55% at 50% 0%, var(--rv-leader), transparent 62%);
  opacity:.14; transition:opacity .6s;
}
.rv-root > *{ position:relative; z-index:1; }

.rv-root h1,.rv-root h2,.rv-root h3{ font-family:var(--serif); color:var(--ink); line-height:1.12; letter-spacing:-.01em; margin:0; }
.rv-center{ text-align:center; }

/* ---- boutons / champs ---- */
.rv-btn{ width:100%; border:none; border-radius:20px; padding:15px 18px; font-family:var(--sans);
  font-size:1.05rem; font-weight:700; cursor:pointer; transition:transform .15s, box-shadow .2s, background .2s; }
.rv-btn:active{ transform:scale(.96); }
.rv-btn-primary{ background:var(--coral); color:#fff; box-shadow:0 10px 24px rgba(199,90,72,.28); }
.rv-btn-primary:hover{ background:var(--coral-deep); }
.rv-btn-teal{ background:var(--teal); color:#fff; }
.rv-btn-teal:hover{ background:var(--teal-deep); }
.rv-btn-ghost{ background:var(--paper); color:var(--teal-deep); border:1.6px solid var(--teal); }
.rv-input{ width:100%; text-align:center; border:2px solid var(--border); background:var(--cream);
  border-radius:18px; padding:13px 16px; font-size:1.05rem; font-family:var(--sans); color:var(--ink); outline:none; }
.rv-input:focus-visible{ border-color:var(--teal); }
.rv-link{ background:none; border:none; color:var(--mid); font-size:.9rem; font-weight:600;
  text-decoration:underline; cursor:pointer; font-family:var(--sans); }

/* ---- mute ---- */
.rv-mute{ position:absolute; right:14px; top:14px; width:36px; height:36px; border-radius:50%;
  background:var(--paper); border:1px solid var(--border); cursor:pointer; font-size:1rem; z-index:5; }

/* ---- intro ---- */
.rv-eyebrow{ font-size:.72rem; font-weight:800; letter-spacing:.18em; text-transform:uppercase; color:var(--teal-deep); }
.rv-title{ font-size:1.85rem; margin:8px 0 6px; }
.rv-title em{ color:var(--coral-deep); font-style:normal; }
.rv-sub{ color:var(--ink-soft); font-size:1.02rem; line-height:1.55; }
.rv-fine{ color:var(--mid); font-size:.78rem; }

/* ---- progression + compteur ---- */
.rv-bar-wrap{ display:flex; align-items:center; gap:12px; margin-bottom:8px; }
.rv-bar{ flex:1; height:9px; border-radius:99px; background:var(--border); overflow:hidden; }
.rv-bar-fill{ height:100%; border-radius:99px; background:var(--coral); width:0; transition:width .5s ease; }
.rv-count{ font-size:.78rem; font-weight:800; color:var(--teal-deep); }

/* ---- scène Zenio + œuf + bulle ---- */
.rv-stage{ position:relative; display:flex; align-items:center; justify-content:center; gap:4px; min-height:108px; }
.rv-zenio svg{ display:block; }
.rv-egg{ position:relative; }
.rv-bubble{ position:absolute; right:0; top:6px; max-width:172px; background:var(--paper);
  border:2px solid var(--honey); border-radius:18px; padding:8px 12px; font-size:.86rem; font-weight:700;
  color:var(--ink); box-shadow:var(--shadow-sm); }
.rv-combo{ position:absolute; left:50%; top:-2px; transform:translateX(20px); background:var(--rv-leader);
  color:#fff; font-weight:800; font-size:.72rem; padding:3px 9px; border-radius:99px; box-shadow:var(--shadow-sm); }

/* ---- la course des 6 caractères ---- */
.rv-race{ display:flex; gap:6px; justify-content:center; margin:6px 0 14px; height:66px; }
.rv-col{ width:42px; display:flex; flex-direction:column; justify-content:flex-end; }
.rv-track{ position:relative; width:100%; height:54px; background:var(--cream); border:1px solid var(--border);
  border-radius:13px; display:flex; align-items:flex-end; overflow:visible; }
.rv-fill{ width:100%; border-radius:13px; height:0; transform-origin:bottom; transition:height .5s ease; }
.rv-runner{ position:absolute; left:0; right:0; top:-11px; text-align:center; font-size:14px; }
.rv-crown{ position:absolute; left:0; right:0; top:-25px; text-align:center; font-size:12px; display:none;
  animation:rvCrown 1.4s ease-in-out infinite; }
.rv-col.lead .rv-crown{ display:block; }
.rv-plus{ position:absolute; left:0; right:0; top:2px; text-align:center; font-size:13px; font-weight:800; }

/* ---- question + options ---- */
.rv-q{ font-size:1.35rem; line-height:1.25; margin-bottom:12px; }
.rv-opts{ display:flex; flex-direction:column; gap:10px; }
.rv-opt{ text-align:left; border:2px solid var(--border); background:var(--paper); color:var(--ink);
  border-radius:18px; padding:13px 16px; font-size:1rem; font-weight:600; font-family:var(--sans);
  cursor:pointer; transition:transform .12s, opacity .2s, background .15s, border-color .15s; }
.rv-opt:active{ transform:scale(.97); }
.rv-opt.sel{ color:#fff; box-shadow:var(--shadow-sm); }
.rv-opt.dim{ opacity:.45; }

/* ---- thinking ---- */
.rv-think{ text-align:center; padding:18px 0 8px; }
.rv-dots{ display:flex; justify-content:center; gap:8px; margin-top:10px; }
.rv-dots i{ width:10px; height:10px; border-radius:50%; background:var(--rv-leader); display:inline-block;
  animation:rvDot 1.2s infinite; opacity:.3; }

/* ---- résultat : carte ---- */
.rv-result{ text-align:center; }
.rv-card{ border:3px solid var(--rv-leader); background:var(--paper); border-radius:24px; overflow:hidden;
  margin-top:10px; box-shadow:var(--shadow-md); text-align:left; }
.rv-card-head{ background:var(--rv-leader); color:#fff; text-align:center; padding:18px 14px; position:relative; }
.rv-rare{ position:absolute; right:12px; top:12px; background:var(--paper); color:var(--ink);
  border:1.5px solid #fff; font-size:.72rem; font-weight:800; padding:3px 9px; border-radius:99px; }
.rv-creature{ font-size:54px; line-height:1; }
.rv-card-name{ font-size:1.55rem; color:#fff; }
.rv-card-tag{ font-weight:700; opacity:.92; }
.rv-card-body{ padding:16px 18px; }
.rv-stats{ display:flex; flex-direction:column; gap:8px; margin-bottom:12px; }
.rv-stat{ display:flex; align-items:center; gap:8px; }
.rv-stat b{ width:84px; font-size:.78rem; color:var(--teal-deep); font-weight:800; }
.rv-stat .meter{ flex:1; height:11px; border-radius:99px; background:var(--cream); overflow:hidden; }
.rv-stat .meter i{ display:block; height:100%; border-radius:99px; background:var(--rv-leader); width:0; }
.rv-stat span{ width:30px; font-size:.78rem; font-weight:800; color:var(--rv-leader); text-align:right; }
.rv-card-body p{ font-size:1rem; color:var(--ink-soft); margin:8px 0 0; line-height:1.6; }
.rv-card-body p b{ color:var(--rv-leader); }
.rv-zquote{ margin-top:12px; background:var(--cream); border-radius:16px; padding:11px 13px; display:flex; gap:8px; }
.rv-zquote em{ font-style:italic; color:var(--teal-deep); font-size:.92rem; }
.rv-zsign{ display:block; margin-top:4px; font-style:normal; font-weight:800; color:var(--teal-deep); }

/* ---- gate email / app / partage ---- */
.rv-gate{ margin-top:16px; text-align:left; }
.rv-gate p{ font-size:.92rem; font-weight:600; color:var(--ink); margin:0 0 8px; }
.rv-consent{ display:flex; align-items:flex-start; gap:8px; margin-top:10px; }
.rv-consent input{ margin-top:2px; width:16px; height:16px; flex-shrink:0; accent-color:var(--teal); cursor:pointer; }
.rv-consent label{ font-size:.8rem; font-weight:500; color:var(--ink-soft); line-height:1.45; }
.rv-consent a{ color:var(--teal-deep); text-decoration:underline; }
.rv-err{ margin-top:8px; font-size:.82rem; font-weight:600; color:#C0392B; }
.rv-sent{ background:var(--paper); border:2px solid var(--teal); color:var(--teal-deep);
  border-radius:18px; padding:12px 14px; font-weight:700; }
.rv-fiche{ background:var(--paper); border:1px solid var(--border); border-radius:14px; padding:8px 12px;
  font-size:.9rem; display:flex; align-items:center; gap:8px; }
.rv-fiche b{ color:var(--rv-leader); }
.rv-share{ background:var(--teal); border-radius:20px; padding:13px 15px; margin-top:16px; color:#fff; }
.rv-share p{ margin:0; }
.rv-share .t1{ font-weight:800; font-size:.92rem; }
.rv-share .t2{ font-size:.78rem; opacity:.9; margin-bottom:8px; }

/* ---- confettis ---- */
.rv-rain{ position:absolute; inset:0; overflow:hidden; pointer-events:none; z-index:3; }
.rv-rain span{ position:absolute; top:-14px; }

/* ==== animations ==== */
@keyframes rvFloat{ 0%,100%{transform:translateY(0)} 50%{transform:translateY(-7px)} }
@keyframes rvHop{ 0%{transform:translateY(0) scale(1)} 30%{transform:translateY(-12px) scale(1.06)} 60%{transform:translateY(0) scale(.97)} 100%{transform:translateY(0) scale(1)} }
@keyframes rvShake{ 0%,100%{transform:rotate(0)} 25%{transform:rotate(-6deg)} 75%{transform:rotate(6deg)} }
@keyframes rvSlide{ from{opacity:0;transform:translateX(32px)} to{opacity:1;transform:translateX(0)} }
@keyframes rvBubble{ 0%{opacity:0;transform:scale(.6) translateY(8px)} 60%{transform:scale(1.08)} 100%{opacity:1;transform:scale(1)} }
@keyframes rvBump{ 0%{transform:scaleY(1)} 40%{transform:scaleY(1.25)} 70%{transform:scaleY(.94)} 100%{transform:scaleY(1)} }
@keyframes rvJump{ 0%{transform:translateY(0)} 40%{transform:translateY(-12px) scale(1.25)} 100%{transform:translateY(0)} }
@keyframes rvPlus{ 0%{opacity:0;transform:translateY(0) scale(.6)} 20%{opacity:1;transform:scale(1.1)} 100%{opacity:0;transform:translateY(-44px) scale(1)} }
@keyframes rvBurst{ 0%{opacity:1;transform:translate(0,0) scale(1)} 100%{opacity:0;transform:translate(var(--dx),var(--dy)) scale(.4) rotate(var(--r))} }
@keyframes rvFall{ 0%{opacity:1;transform:translateY(-10px) rotate(0)} 100%{opacity:0;transform:translate(var(--dx),110vh) rotate(var(--r))} }
@keyframes rvCrown{ 0%,100%{transform:translateY(0)} 50%{transform:translateY(-3px)} }
@keyframes rvDot{ 0%,80%,100%{opacity:.25;transform:translateY(0)} 40%{opacity:1;transform:translateY(-4px)} }
@keyframes rvPop{ 0%{opacity:0;transform:scale(.5)} 60%{transform:scale(1.08)} 100%{opacity:1;transform:scale(1)} }
@keyframes rvEgg{ 0%{transform:rotate(0)} 20%{transform:rotate(-5deg) scale(1.03)} 45%{transform:rotate(4deg)} 70%{transform:rotate(-2deg)} 100%{transform:rotate(0) scale(1)} }
@keyframes rvGlow{ 0%,100%{opacity:.2;transform:scale(1)} 50%{opacity:.42;transform:scale(1.25)} }
@keyframes rvBar{ from{width:0} }

.rv-float{ animation:rvFloat 3.4s ease-in-out infinite; }
.rv-hop{ animation:rvHop .6s cubic-bezier(.2,1.2,.4,1); }
.rv-shake{ animation:rvShake .5s ease-in-out infinite; }
.rv-slide{ animation:rvSlide .36s cubic-bezier(.2,.9,.3,1) both; }
.rv-bubble{ animation:rvBubble .38s cubic-bezier(.2,1.3,.4,1) both; }
.rv-combo{ animation:rvPop .4s cubic-bezier(.2,1.4,.4,1) both; }
.rv-pop{ animation:rvPop .5s cubic-bezier(.2,1.3,.4,1) both; }
.rv-egg-svg{ animation:rvEgg .6s ease; }
.rv-egg-glow{ transform-origin:center; animation:rvGlow 2.2s ease-in-out infinite; }
.rv-dots i:nth-child(2){ animation-delay:.18s; }
.rv-dots i:nth-child(3){ animation-delay:.36s; }

@media (prefers-reduced-motion: reduce){
  .rv-root *{ animation-duration:.01ms !important; animation-iteration-count:1 !important; transition-duration:.01ms !important; }
}
