/* ═══════════════════════════════════════════════
   HARMONY REPAIR · BOOSTER LUXE
   Design premium — style jeu mobile haut de gamme
═══════════════════════════════════════════════ */

:root {
  --red:    #c05351;
  --red2:   #e06a50;
  --gold:   #f5c842;
  --blue:   #4aa3ff;
  --purple: #b86dff;
  --bg1:    #04020a;
  --bg2:    #0d0518;
  --text:   #f4f0ee;
  --muted:  rgba(244,240,238,.58);
  --line:   rgba(255,255,255,.10);
  --glass:  rgba(255,255,255,.05);
}

/* ─── Reset ─── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html, body { width:100%; height:100%; overflow:hidden; background:transparent; color:var(--text); }
body { user-select:none; font-family:'Segoe UI', system-ui, sans-serif; }
.hidden { display:none !important; }

/* ─── App shell ─── */
.app { position:relative; width:100%; height:100%; }

.backdrop {
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 80% 60% at 50% -10%, rgba(192,83,81,.28), transparent 55%),
    radial-gradient(ellipse 60% 40% at 85% 10%,  rgba(140,50,90,.18), transparent 45%),
    radial-gradient(ellipse 50% 50% at 10% 90%,  rgba(74,163,255,.10), transparent 50%),
    linear-gradient(180deg, var(--bg2), var(--bg1));
}

/* Animated stars in background */
.backdrop::after {
  content:'';
  position:absolute; inset:0;
  background-image:
    radial-gradient(1px 1px at 10% 15%, rgba(255,255,255,.6) 0%, transparent 100%),
    radial-gradient(1px 1px at 30% 45%, rgba(255,255,255,.4) 0%, transparent 100%),
    radial-gradient(1px 1px at 55% 25%, rgba(255,255,255,.5) 0%, transparent 100%),
    radial-gradient(1px 1px at 75% 60%, rgba(255,255,255,.3) 0%, transparent 100%),
    radial-gradient(1px 1px at 90% 35%, rgba(255,255,255,.5) 0%, transparent 100%),
    radial-gradient(1px 1px at 20% 80%, rgba(255,255,255,.3) 0%, transparent 100%),
    radial-gradient(1px 1px at 65% 85%, rgba(255,255,255,.4) 0%, transparent 100%);
  animation: starsTwinkle 4s ease-in-out infinite alternate;
}
@keyframes starsTwinkle {
  0%   { opacity:.4; }
  100% { opacity:1; }
}

.shell {
  position:relative; z-index:2;
  width: min(1400px, calc(100vw - 32px));
  height: calc(100vh - 32px);
  margin: 16px auto;
  border-radius: 28px;
  border: 1px solid rgba(255,255,255,.08);
  overflow: hidden;
  background: linear-gradient(160deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  box-shadow:
    0 32px 120px rgba(0,0,0,.7),
    0 0 0 1px rgba(255,255,255,.04),
    inset 0 1px 0 rgba(255,255,255,.07);
}

.view, .admin-view {
  width:100%; height:100%;
  display:grid; place-items:center;
  padding: 28px; gap: 20px;
}

/* ─── Typography utils ─── */
.brand-kicker {
  font-size:10px; letter-spacing:.5em; text-transform:uppercase;
  color: rgba(255,255,255,.35);
}

/* ─── Panel ─── */
.panel {
  width: min(780px, 100%);
  padding: 28px 32px;
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,.10);
  background:
    linear-gradient(160deg, rgba(255,255,255,.07) 0%, rgba(255,255,255,.03) 100%);
  box-shadow:
    0 24px 80px rgba(0,0,0,.45),
    inset 0 1px 0 rgba(255,255,255,.07);
  backdrop-filter: blur(20px);
}
.panel.narrow { width: min(840px, 100%); }
.panel.compact { padding: 18px 24px; }

.panel h1 {
  font-size: 44px; line-height:.93;
  font-weight:900; font-style:italic;
  text-transform:uppercase;
  background: linear-gradient(135deg, #fff 40%, rgba(255,255,255,.55));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}
.panel p { margin-top:10px; color:var(--muted); line-height:1.55; font-size:15px; }

/* ─── Form ─── */
.form-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px; margin-top: 20px;
}
.field { display:grid; gap:7px; margin-top:14px; }
.field label {
  font-size:10px; letter-spacing:.35em; text-transform:uppercase;
  color: rgba(255,255,255,.38);
}
.field input, .field textarea, .field select {
  width:100%; border-radius:14px;
  border: 1px solid rgba(255,255,255,.13);
  background: rgba(255,255,255,.06);
  color:white; padding:13px 16px; outline:none;
  font-size:14px;
  transition: border-color .2s, background .2s;
}
.field input:focus, .field textarea:focus, .field select:focus {
  border-color: rgba(192,83,81,.6);
  background: rgba(255,255,255,.09);
}
.field textarea { min-height:88px; resize:vertical; }

.status-line { min-height:22px; margin-top:12px; font-size:14px; color:#ffa0a0; }
.inline-note { font-size:14px; color:rgba(255,255,255,.52); text-align:center; line-height:1.5; }

/* ─── Action row / buttons ─── */
.action-row {
  display:flex; justify-content:center;
  gap:12px; flex-wrap:wrap; margin-top:18px;
}
.primary-btn, .secondary-btn {
  min-width:200px; padding:15px 22px;
  border-radius:16px; font-size:15px; font-weight:700;
  cursor:pointer; letter-spacing:.03em;
  transition: transform .18s ease, filter .18s ease, box-shadow .18s ease;
  position:relative; overflow:hidden;
}
/* shimmer on buttons */
.primary-btn::before, .secondary-btn::before {
  content:'';
  position:absolute; inset:0;
  background: linear-gradient(115deg, transparent 35%, rgba(255,255,255,.14) 50%, transparent 65%);
  transform: translateX(-100%);
  transition: transform .5s ease;
}
.primary-btn:hover::before, .secondary-btn:hover::before { transform: translateX(100%); }

.primary-btn {
  color:white;
  border: 1px solid rgba(224,106,80,.45);
  background: linear-gradient(135deg, rgba(192,83,81,.35), rgba(224,106,80,.25));
  box-shadow: 0 12px 36px rgba(192,83,81,.22), inset 0 1px 0 rgba(255,255,255,.1);
}
.secondary-btn {
  color:white;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.07);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
}
.primary-btn:hover, .secondary-btn:hover {
  transform: translateY(-3px);
  filter: brightness(1.1);
}
.primary-btn:active, .secondary-btn:active { transform: translateY(0); }
.danger-btn { border-color: rgba(255,100,100,.30); color:#ffd4d4; }

/* ═══════════════════════════════════════════════
   BOOSTER PACK
═══════════════════════════════════════════════ */
.booster-pack {
  position:relative;
  width:300px; height:440px;
  border-radius:26px; overflow:hidden;
  cursor:pointer;
  transform-style: preserve-3d;
  transition: transform .28s cubic-bezier(.2,.8,.3,1), filter .28s ease;

  background:
    linear-gradient(145deg, rgba(255,255,255,.08), rgba(255,255,255,.02)),
    linear-gradient(135deg, #4a0f14, #c05351 55%, #8a2020);
  border: 1px solid rgba(255,255,255,.18);
  box-shadow:
    0 40px 120px rgba(0,0,0,.65),
    0 0 60px rgba(192,83,81,.20),
    0 0 120px rgba(192,83,81,.10),
    inset 0 1px 0 rgba(255,255,255,.12);
}
.booster-pack:hover {
  transform: translateY(-10px) scale(1.03) rotateX(4deg);
  filter: brightness(1.12);
  box-shadow:
    0 60px 160px rgba(0,0,0,.7),
    0 0 80px rgba(192,83,81,.30),
    inset 0 1px 0 rgba(255,255,255,.14);
}
.booster-pack.opening {
  animation: packBurst 1s cubic-bezier(.4,0,.6,1) forwards;
}
@keyframes packBurst {
  0%   { transform:scale(1) rotate(0deg); opacity:1; filter:brightness(1); }
  25%  { transform:scale(1.05) rotate(-3deg); filter:brightness(1.3); }
  60%  { transform:scale(.9) rotate(4deg); filter:brightness(1.5); }
  100% { transform:scale(.7) rotate(8deg) translateY(-30px); opacity:0; }
}

/* Diagonal foil lines */
.pack-shine {
  position:absolute; inset:0;
  background:
    repeating-linear-gradient(
      125deg,
      rgba(255,255,255,.04) 0px, rgba(255,255,255,.04) 1px,
      transparent 1px, transparent 14px
    ),
    radial-gradient(ellipse 80% 60% at 30% 20%, rgba(255,255,255,.18), transparent 50%);
  mix-blend-mode: screen;
}
/* Animated sweep */
.booster-pack::after {
  content:'';
  position:absolute; inset:0;
  background: linear-gradient(115deg,
    transparent 0%, transparent 38%,
    rgba(255,255,255,.18) 50%,
    transparent 62%, transparent 100%);
  mix-blend-mode: screen;
  animation: packSweep 3.5s linear infinite;
}
@keyframes packSweep {
  0%   { transform: translateX(-120%) skewX(-18deg); opacity:0; }
  30%  { opacity:1; }
  60%  { opacity:1; }
  100% { transform: translateX(140%) skewX(-18deg); opacity:0; }
}

.pack-content {
  position:absolute; inset:14px;
  border-radius:20px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(0,0,0,.22);
  padding:20px;
  display:flex; flex-direction:column;
  justify-content:center; align-items:center;
  text-align:center;
  backdrop-filter: blur(4px);
}
.pack-kicker {
  font-size:10px; letter-spacing:.42em; text-transform:uppercase;
  color: rgba(255,255,255,.65);
}
.pack-title {
  margin-top:14px;
  font-size:62px; line-height:.9;
  font-weight:900; font-style:italic;
  text-transform:uppercase;
  text-shadow: 0 0 40px rgba(255,255,255,.3);
}
.pack-sub {
  margin-top:16px;
  font-size:15px; color:rgba(255,255,255,.75);
}

/* Corner accents on pack */
.pack-content::before, .pack-content::after {
  content:'';
  position:absolute;
  width:20px; height:20px;
  border-color:rgba(255,255,255,.35);
  border-style:solid;
}
.pack-content::before { top:-1px; left:-1px; border-width:2px 0 0 2px; border-radius:4px 0 0 0; }
.pack-content::after  { bottom:-1px; right:-1px; border-width:0 2px 2px 0; border-radius:0 0 4px 0; }

/* ═══════════════════════════════════════════════
   CARD REVEAL STAGE
═══════════════════════════════════════════════ */
.progress-label {
  font-size:12px; letter-spacing:.4em; text-transform:uppercase;
  color:rgba(255,255,255,.45); text-align:center; min-height:18px;
  text-shadow: 0 0 20px rgba(255,255,255,.1);
}

/* outer wrap */
.single-card-wrap {
  position:relative;
  width:340px; height:510px;
  perspective:1600px;
}
.single-card-wrap.clickable { cursor:pointer; }
.single-card-wrap.busy { cursor:progress; }
.single-card-wrap.revealed-mode { cursor:pointer; }

/* ── FX Stage (behind card) ── */
.fx-stage {
  position:absolute;
  inset:-35%;
  z-index:0; pointer-events:none;
}
.fx-aura, .fx-rays, .fx-burst {
  position:absolute;
  left:50%; top:50%;
  transform:translate(-50%,-50%);
  pointer-events:none;
}
.fx-aura  { width:640px; height:640px; border-radius:50%; opacity:0; filter:blur(52px); }
.fx-rays  { width:780px; height:780px; border-radius:50%; opacity:0; mix-blend-mode:screen; }
.fx-lightning {
  position:absolute;
  left:50%; top:50%;
  transform:translate(-50%,-50%);
  width:900px; height:900px;
  pointer-events:none;
  mix-blend-mode:screen;
  opacity:0;
}
.fx-burst { width:560px; height:560px; border-radius:50%; opacity:0; mix-blend-mode:screen; }

/* Legendary : classe standard */
.fx-stage.impact .fx-aura  { animation: fxAura  1.4s ease-out forwards; }
.fx-stage.impact .fx-rays  { animation: fxRays  1.6s ease-out forwards; }
/* fx-bolts remplacé par canvas lightning */
.fx-stage.impact .fx-burst { animation: fxBurst  .9s ease-out forwards; }

/* Mythic : classe dédiée — override les animations */
.fx-stage.impact-mythic .fx-aura  { animation: fxAura       1.6s ease-out forwards; }
.fx-stage.impact-mythic .fx-rays  { animation: fxRaysMythic 2.0s ease-out forwards; }

.fx-stage.impact-mythic .fx-burst { animation: fxBurstMythic 1.1s ease-out forwards; }

@keyframes fxAura  { 0%{opacity:0;transform:translate(-50%,-50%) scale(.4)}  18%{opacity:.98} 100%{opacity:0;transform:translate(-50%,-50%) scale(1.35)} }
@keyframes fxRays  { 0%{opacity:0;transform:translate(-50%,-50%) scale(.5) rotate(0deg)} 18%{opacity:.9} 100%{opacity:0;transform:translate(-50%,-50%) scale(1.28) rotate(28deg)} }

/* fxBolts remplacé par canvas */
  10%  { opacity:1; }
  40%  { opacity:.75; }
  100% { opacity:0; transform:translate(-50%,-50%) scale(1.14); }
}

/* Mythic : croix lumineuse large + bloom prismé — élégant, pas chargé */
@keyframes fxBoltsMythic {
  0%   { opacity:0; transform:translate(-50%,-50%) scale(.55); filter:saturate(1) brightness(1); }
  12%  { opacity:1; transform:translate(-50%,-50%) scale(1.00); filter:saturate(2.2) brightness(1.5); }
  35%  { opacity:.8; filter:saturate(1.8) brightness(1.2); }
  65%  { opacity:.4; transform:translate(-50%,-50%) scale(1.12); filter:saturate(1.4) brightness(1.1); }
  100% { opacity:0; transform:translate(-50%,-50%) scale(1.30); filter:saturate(1) brightness(1); }
}

/* Mythic rays : rotation plus rapide + plus large */
@keyframes fxRaysMythic {
  0%   { opacity:0; transform:translate(-50%,-50%) scale(.45) rotate(0deg); filter:hue-rotate(0deg); }
  14%  { opacity:1; }
  100% { opacity:0; transform:translate(-50%,-50%) scale(1.40) rotate(45deg); filter:hue-rotate(90deg); }
}

/* Mythic burst : plus grand, double expansion */
@keyframes fxBurstMythic {
  0%   { opacity:0; transform:translate(-50%,-50%) scale(.14); }
  16%  { opacity:1; transform:translate(-50%,-50%) scale(.90); }
  45%  { opacity:.6; transform:translate(-50%,-50%) scale(1.10); }
  100% { opacity:0; transform:translate(-50%,-50%) scale(1.80); }
}

@keyframes fxBurst { 0%{opacity:0;transform:translate(-50%,-50%) scale(.18)} 18%{opacity:1} 100%{opacity:0;transform:translate(-50%,-50%) scale(1.6)} }

.fx-particles { position:absolute; inset:0; overflow:visible; pointer-events:none; }
.fx-particle {
  position:absolute; width:8px; height:8px; border-radius:999px;
  opacity:0; animation: fxParticleRise var(--dur,1.2s) ease-out forwards;
  box-shadow: 0 0 16px currentColor;
}
@keyframes fxParticleRise {
  0%   { transform:translateY(28px) scale(.35); opacity:0; }
  18%  { opacity:1; }
  100% { transform:translateY(-130px) scale(1.2); opacity:0; }
}

/* ── Card Glow (ambient) ── */
.card-glow {
  position:absolute; inset:-40px; border-radius:64px;
  background: radial-gradient(circle at center, rgba(255,255,255,.15), transparent 68%);
  filter: blur(28px); z-index:0;
  transition: background .6s ease, opacity .4s ease;
}
.card-glow.common    { background: radial-gradient(circle at center, rgba(154,162,172,.22), transparent 65%); }
.card-glow.rare      { background: radial-gradient(circle at center, rgba(74,163,255,.32),  transparent 65%); }
.card-glow.epic      { background: radial-gradient(circle at center, rgba(184,109,255,.36), transparent 65%); }
.card-glow.legendary { background: radial-gradient(circle at center, rgba(255,141,71,.40),  transparent 65%); }
.card-glow.mythic    { background: radial-gradient(circle at center, rgba(255,219,87,.46),  transparent 65%); }

/* ── SUSPENSE overlay ── */
.suspense-overlay {
  position:absolute; inset:-12%;
  z-index:1; pointer-events:none;
  opacity:0; transition: opacity .2s ease;
  mix-blend-mode: screen;
}
.single-card-wrap.suspense .suspense-overlay { opacity:1; }
.single-card-wrap.revealed-mode .suspense-overlay { opacity:0 !important; }

/* Corner shimmer pulses */
.suspense-overlay::before {
  content:'';
  position:absolute; inset:8%;
  border-radius:28px;
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 0 32px rgba(255,255,255,.07), inset 0 0 24px rgba(255,255,255,.04);
  animation: suspFrame .55s ease-in-out infinite;
}
@keyframes suspFrame {
  0%,100% { transform:scale(.985); opacity:.28; }
  50%      { transform:scale(1.015); opacity:.95; }
}

/* Coloured bloom */
.suspense-overlay::after {
  content:'';
  position:absolute; inset:6%;
  border-radius:24px;
  background: radial-gradient(circle at 50% 50%, rgba(255,255,255,.08), transparent 34%);
  filter: blur(28px);
  animation: suspBloom .82s ease-in-out infinite;
}
@keyframes suspBloom {
  0%,100% { opacity:.32; transform:scale(.96); }
  50%      { opacity:1;   transform:scale(1.06); }
}

/* Sparks */
.suspense-sparks {
  position:absolute; width:100%; height:100%;
  left:0; top:0; overflow:visible;
}
.suspense-spark {
  position:absolute;
  width:3px; height:80px;
  border-radius:999px;
  background: linear-gradient(to top, transparent, currentColor, transparent);
  box-shadow: 0 0 14px currentColor, 0 0 28px currentColor;
  opacity:0;
  animation: suspSpark .75s ease-out infinite;
}
@keyframes suspSpark {
  0%   { transform:translateY(10px) scaleY(.18) rotate(var(--rot)); opacity:0; }
  18%  { opacity:1; }
  100% { transform:translateY(-96px) scaleY(1.3) rotate(var(--rot)); opacity:0; }
}

/* Suspense back-card shake */
.single-card-wrap.suspense .card-back {
  animation: backPulse .52s ease-in-out infinite, backShake .11s linear infinite !important;
}
@keyframes backPulse {
  0%,100% { filter:brightness(1) saturate(1); }
  50%      { filter:brightness(1.22) saturate(1.08); }
}
@keyframes backShake {
  0%,100% { transform:translateX(0)   translateY(0)  rotate(0deg); }
  20%      { transform:translateX(-1px) translateY(1px) rotate(-.28deg); }
  40%      { transform:translateX(1px)  translateY(-1px) rotate(.25deg); }
  60%      { transform:translateX(-1px) translateY(0)  rotate(-.2deg); }
  80%      { transform:translateX(1px)  translateY(1px) rotate(.18deg); }
}

/* ── Card single (the actual card) ── */
.card-single, .card-inspect {
  position:relative; width:100%; height:100%;
  border-radius:22px; overflow:hidden;
  border: 1px solid rgba(255,255,255,.13);
  background: #080710;
  transform-style: preserve-3d;
  transition: transform .12s ease, box-shadow .25s ease, filter .25s ease;
  isolation: isolate;
  box-shadow:
    0 32px 90px rgba(0,0,0,.6),
    0 0 0 1px rgba(255,255,255,.04),
    inset 0 1px 0 rgba(255,255,255,.06);
}
/* Rarity tints */
.rarity-common    { box-shadow:0 28px 76px rgba(0,0,0,.5),  0 0 0 1px rgba(154,162,172,.20); }
.rarity-rare      { box-shadow:0 30px 86px rgba(0,0,0,.52), 0 0 32px rgba(74,163,255,.24),   0 0 0 1px rgba(74,163,255,.26); }
.rarity-epic      { box-shadow:0 30px 90px rgba(0,0,0,.54), 0 0 42px rgba(184,109,255,.30),  0 0 0 1px rgba(184,109,255,.26); }
.rarity-legendary { box-shadow:0 34px 110px rgba(0,0,0,.58),0 0 56px rgba(255,141,71,.36),   0 0 0 1px rgba(255,141,71,.30); }
.rarity-mythic    { box-shadow:0 38px 130px rgba(0,0,0,.62),0 0 72px rgba(255,219,87,.44),   0 0 0 1px rgba(255,219,87,.34); }

/* Prevent spoiler before flip */
.card-single.preview-hidden .card-face {
  visibility:hidden; opacity:0;
}
.single-card-wrap.suspense    .card-single.preview-hidden .card-face,
.single-card-wrap.revealed-mode .card-single.preview-hidden .card-face {
  visibility:visible; opacity:1;
}

/* ── Flip shell ── */
.card-flip-shell {
  position:relative; width:100%; height:100%;
  transform-style: preserve-3d;
  transition: transform .95s cubic-bezier(.16,.88,.18,1);
}
.card-flip-shell.revealed { transform: rotateY(180deg); }

/* Reveal burst on face */
.card-flip-shell.revealed .card-side.card-face::before {
  animation: faceBurst .9s ease-out forwards;
}
@keyframes faceBurst {
  0%   { opacity:0; transform:scale(.55); }
  18%  { opacity:1; }
  100% { opacity:0; transform:scale(1.24) rotate(14deg); }
}
.card-side.card-face::before {
  content:''; position:absolute; inset:-12%;
  pointer-events:none; z-index:2; opacity:0;
  mix-blend-mode:screen;
  background:
    radial-gradient(circle at center, rgba(255,255,255,.2), transparent 40%),
    conic-gradient(from 0deg,
      rgba(255,80,120,.10), rgba(255,210,90,.10), rgba(120,255,220,.10),
      rgba(90,170,255,.10), rgba(200,120,255,.10), rgba(255,80,120,.10));
}
/* Light sweep */
.card-flip-shell.revealed .card-side.card-face::after {
  animation: faceSweep 1.05s ease-out forwards;
}
@keyframes faceSweep {
  0%   { opacity:0; transform:translateX(-50%) skewX(-18deg); }
  12%  { opacity:1; }
  100% { opacity:0; transform:translateX(60%) skewX(-18deg); }
}
.card-side.card-face::after {
  content:''; position:absolute; inset:0;
  pointer-events:none; z-index:4; opacity:0; mix-blend-mode:screen;
  background:
    linear-gradient(115deg,
      transparent 0% 42%,
      rgba(255,255,255,.0) 48%,
      rgba(255,255,255,.45) 50%,
      rgba(255,255,255,.0) 52%,
      transparent 58% 100%);
}

/* ── Card sides ── */
.card-side {
  position:absolute; inset:0;
  border-radius:22px; overflow:hidden;
  backface-visibility:hidden; -webkit-backface-visibility:hidden;
}

/* BACK */
.card-back {
  transform: rotateY(0deg);
  background:
    radial-gradient(ellipse 80% 50% at 50% 0%, rgba(255,255,255,.14), transparent 40%),
    repeating-linear-gradient(128deg,
      rgba(255,255,255,.04) 0px, rgba(255,255,255,.04) 1px,
      transparent 1px, transparent 12px),
    linear-gradient(145deg, #4a0f14, #c05351 55%, #7a1818);
  border: 1px solid rgba(255,255,255,.15);
  box-shadow: 0 28px 80px rgba(0,0,0,.55);
}
/* Animated diagonal glint on back */
.card-back::after {
  content:'';
  position:absolute; inset:0;
  background: linear-gradient(115deg,
    transparent 0% 38%,
    rgba(255,255,255,.14) 50%,
    transparent 62% 100%);
  mix-blend-mode:screen;
  animation: backGlint 4s linear infinite;
}
@keyframes backGlint {
  0%   { transform:translateX(-130%) skewX(-16deg); opacity:0; }
  20%  { opacity:1; }
  60%  { opacity:1; }
  100% { transform:translateX(150%) skewX(-16deg); opacity:0; }
}

.card-back-inner {
  position:absolute; inset:12px;
  border-radius:16px;
  border: 1px solid rgba(255,255,255,.14);
  display:grid; place-items:center; text-align:center;
  background: rgba(0,0,0,.2);
}
.card-back-kicker {
  position:absolute; top:16px; left:16px;
  font-size:9px; letter-spacing:.38em; text-transform:uppercase;
  color:rgba(255,255,255,.55);
}
.card-back-title {
  font-size:46px; line-height:.9;
  font-weight:900; font-style:italic; text-transform:uppercase;
  text-shadow: 0 0 40px rgba(255,255,255,.25);
}
.card-back-sub { margin-top:10px; font-size:13px; color:rgba(255,255,255,.65); }

/* FACE */
.card-face { transform: rotateY(180deg); }

.card-art, .card-inspect-art {
  position:absolute; inset:0;
  display:grid; place-items:center;
  font-size:140px;
  background: linear-gradient(135deg, #2c0c16, #bf5850);
}
.card-inspect-art { font-size:200px; }

.card-shade.top {
  position:absolute; top:0; left:0; right:0; height:140px;
  background: linear-gradient(to bottom, rgba(0,0,0,.85), transparent);
}
.card-shade.bottom {
  position:absolute; left:0; right:0; bottom:0; height:230px;
  background: linear-gradient(to top, rgba(0,0,0,.95), rgba(0,0,0,.75) 40%, transparent);
}

/* Inner border frame */
.card-border {
  position:absolute; inset:7px; border-radius:16px;
  border: 1px solid rgba(255,255,255,.16);
  box-shadow: inset 0 0 30px rgba(255,255,255,.04);
  pointer-events:none;
}
/* Corner accents */
.card-border::before, .card-border::after {
  content:'';
  position:absolute;
  width:16px; height:16px;
  border-style:solid;
  border-color:rgba(255,255,255,.4);
}
.card-border::before { top:-1px; left:-1px; border-width:2px 0 0 2px; border-radius:4px 0 0 0; }
.card-border::after  { bottom:-1px; right:-1px; border-width:0 2px 2px 0; border-radius:0 0 4px 0; }

.card-ui {
  position:absolute; top:16px; left:16px; right:16px; z-index:3;
  display:flex; justify-content:space-between; align-items:flex-start;
}
.card-rarity {
  font-size:9px; letter-spacing:.38em; text-transform:uppercase;
  font-weight:800; color:var(--red2);
}
.card-number { font-size:12px; font-weight:800; color:rgba(255,255,255,.5); }

.card-bottom {
  position:absolute; left:0; right:0; bottom:0; z-index:3; padding:18px 20px;
}
.card-role {
  font-size:9px; letter-spacing:.38em; text-transform:uppercase;
  color:var(--red2);
}
.card-name {
  margin-top:5px;
  font-size:40px; line-height:.95;
  font-weight:900; font-style:italic; text-transform:uppercase;
  text-shadow: 0 2px 20px rgba(0,0,0,.6);
}
.card-desc {
  margin-top:8px; font-size:13px; line-height:1.45;
  color:rgba(255,255,255,.60);
}

/* ── Holographic hover effect ── */
.card-holo-hover {
  position:absolute; inset:0; z-index:4;
  pointer-events:none; border-radius:22px;
  opacity:0; transition:opacity .2s ease;
  mix-blend-mode:screen;
  background:
    radial-gradient(circle at var(--mx,50%) var(--my,50%),
      rgba(255,255,255,.22), transparent 20%),
    conic-gradient(from var(--ha,0deg) at var(--mx,50%) var(--my,50%),
      rgba(255,80,120,.14),
      rgba(255,210,90,.12),
      rgba(120,255,220,.12),
      rgba(90,170,255,.14),
      rgba(200,120,255,.14),
      rgba(255,80,120,.14));
}
.single-card-wrap.revealed-mode:hover .card-holo-hover,
.card-inspect-wrap:hover .card-holo-hover { opacity:.95; }

/* ── Hover particles ── */
.hover-particles {
  position:absolute; inset:0; z-index:5;
  pointer-events:none; overflow:hidden;
  border-radius:22px;
  opacity:0; transition:opacity .2s ease;
}
.single-card-wrap.revealed-mode:hover .hover-particles,
.card-inspect-wrap:hover .hover-particles { opacity:1; }

.hover-particle {
  position:absolute; width:5px; height:5px;
  border-radius:999px;
  background: rgba(255,255,255,.9);
  box-shadow: 0 0 12px currentColor;
  animation: hoverFloat var(--dur,2.4s) ease-in-out infinite;
  animation-delay: var(--delay,0s);
}
@keyframes hoverFloat {
  0%,100% { transform:translateY(0) scale(.5); opacity:0; }
  50%      { transform:translateY(-22px) scale(1); opacity:.95; }
}

/* ── Reveal burst ── */
.reveal-burst {
  position:absolute; inset:-22%; z-index:6;
  pointer-events:none; opacity:0; mix-blend-mode:screen;
}
.reveal-burst.active { animation: revealBurst .95s ease-out forwards; }
@keyframes revealBurst {
  0%   { opacity:0; transform:scale(.6); }
  15%  { opacity:1; }
  100% { opacity:0; transform:scale(1.3); }
}

/* ── Rarity particles ── */
.rarity-particles { position:absolute; inset:0; overflow:hidden; pointer-events:none; z-index:5; }
.rarity-particle {
  position:absolute; width:8px; height:8px; border-radius:999px;
  opacity:0; box-shadow:0 0 12px currentColor;
  animation: rarityUp var(--dur,1.2s) ease-out forwards;
}
@keyframes rarityUp {
  0%   { transform:translateY(18px) scale(.5); opacity:0; }
  20%  { opacity:1; }
  100% { transform:translateY(-95px) scale(1.15); opacity:0; }
}

/* Hover brightness */
.single-card-wrap.revealed-mode:hover .card-single,
.card-inspect-wrap:hover .card-inspect { filter:brightness(1.07); }

/* ── Screen flash ── */
.reveal-screen-flash {
  position:absolute; inset:0;
  pointer-events:none; z-index:20;
  opacity:0; mix-blend-mode:screen;
}
.reveal-screen-flash.active         { animation: screenFlash .7s ease-out forwards; }
.reveal-screen-flash.active-mythic  { animation: screenFlashMythic 1.4s ease-out forwards; }
@keyframes screenFlash {
  0%  { opacity:0; }
  12% { opacity:1; }
  100%{ opacity:0; }
}
@keyframes screenFlashMythic {
  0%   { opacity:0; }
  8%   { opacity:1; }
  28%  { opacity:.18; }
  42%  { opacity:.82; }
  100% { opacity:0; }
}

/* ── Shell impact shakes ── */
.shell.impact-rare      { animation: hitRare      .36s ease; }
.shell.impact-epic      { animation: hitEpic      .48s ease; }
.shell.impact-legendary { animation: hitLegendary .64s ease; }
.shell.impact-mythic    { animation: hitMythic    1.10s ease; }

@keyframes hitRare      { 0%,100%{transform:translateX(0); filter:brightness(1)} 20%{transform:translateX(-3px); filter:brightness(1.08)} 40%{transform:translateX(3px)} 60%{transform:translateX(-2px)} }
@keyframes hitEpic      { 0%,100%{transform:translate(0,0); filter:brightness(1)} 18%{transform:translate(-5px,1px); filter:brightness(1.12)} 36%{transform:translate(5px,-1px)} 54%{transform:translate(-4px,1px)} 72%{transform:translate(3px,-1px)} }
@keyframes hitLegendary { 0%,100%{transform:translate(0,0) scale(1); filter:brightness(1)} 14%{transform:translate(-9px,2px) scale(1.006); filter:brightness(1.20) saturate(1.04)} 28%{transform:translate(9px,-2px) scale(1.006)} 42%{transform:translate(-7px,2px) scale(1.003)} 56%{transform:translate(7px,-2px)} 70%{transform:translate(-3px,1px)} }
@keyframes hitMythic    {
  0%   { transform:translate(0,0)       scale(1);     filter:brightness(1)  saturate(1); }
  8%   { transform:translate(-18px,4px) scale(1.014); filter:brightness(1.45) saturate(1.3); }
  16%  { transform:translate(18px,-4px) scale(1.014); filter:brightness(1.30) saturate(1.2); }
  26%  { transform:translate(-14px,3px) scale(1.010); filter:brightness(1.20) saturate(1.1); }
  36%  { transform:translate(14px,-3px) scale(1.010); filter:brightness(1.15); }
  46%  { transform:translate(-10px,2px) scale(1.006); filter:brightness(1.38) saturate(1.2); }
  56%  { transform:translate(10px,-2px) scale(1.006); filter:brightness(1.10); }
  68%  { transform:translate(-5px,1px)  scale(1.002); }
  80%  { transform:translate(5px,-1px)  scale(1.001); }
  100% { transform:translate(0,0)       scale(1);     filter:brightness(1)  saturate(1); }
}

/* ═══════════════════════════════════════════════
   SUMMARY SCREEN
═══════════════════════════════════════════════ */
.summary-head { text-align:center; }
.summary-title {
  font-size:48px; line-height:.93;
  font-weight:900; font-style:italic; text-transform:uppercase;
  background: linear-gradient(135deg, #fff 50%, rgba(255,255,255,.5));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text;
}

.summary-grid {
  width: min(1280px, 100%);
  display: grid;
  grid-template-columns: repeat(5, minmax(170px, 1fr));
  gap: 14px; align-items:start;
}

.mini-card {
  position:relative; aspect-ratio:2/3;
  border-radius:18px; overflow:hidden;
  border: 1px solid rgba(255,255,255,.12);
  background: #080710;
  cursor:pointer;
  transition: transform .2s cubic-bezier(.2,.8,.3,1), box-shadow .2s ease;
  box-shadow: 0 20px 56px rgba(0,0,0,.5);
}
.mini-card:hover {
  transform: translateY(-8px) scale(1.04);
  box-shadow: 0 28px 72px rgba(0,0,0,.55), 0 0 28px rgba(255,255,255,.08);
}
/* Rarity border glow on mini cards */
.mini-card.rarity-rare      { box-shadow:0 20px 56px rgba(0,0,0,.5), 0 0 18px rgba(74,163,255,.20); }
.mini-card.rarity-epic      { box-shadow:0 20px 56px rgba(0,0,0,.5), 0 0 22px rgba(184,109,255,.24); }
.mini-card.rarity-legendary { box-shadow:0 20px 56px rgba(0,0,0,.5), 0 0 28px rgba(255,141,71,.28); }
.mini-card.rarity-mythic    { box-shadow:0 20px 56px rgba(0,0,0,.5), 0 0 34px rgba(255,219,87,.34); }

.mini-art {
  position:absolute; inset:0;
  display:grid; place-items:center;
  font-size:72px;
}
.mini-shade {
  position:absolute; inset:0;
  background: linear-gradient(to top, rgba(0,0,0,.92), rgba(0,0,0,.22), transparent);
}
.mini-meta { position:absolute; left:0; right:0; bottom:0; padding:12px; z-index:2; }
.mini-rarity { font-size:8px; letter-spacing:.3em; text-transform:uppercase; font-weight:800; }
.mini-name {
  margin-top:5px; font-size:20px; line-height:.95;
  font-weight:900; font-style:italic; text-transform:uppercase;
}

/* ═══════════════════════════════════════════════
   CARD INSPECT MODAL
═══════════════════════════════════════════════ */
.card-inspect-modal {
  position:absolute; inset:0; z-index:30;
  display:grid; place-items:center;
}
.card-inspect-backdrop {
  position:absolute; inset:0;
  background: rgba(4,2,10,.78);
  backdrop-filter: blur(14px);
}
.card-inspect-shell {
  position:relative; z-index:2;
  display:grid; place-items:center; gap:18px;
}
.card-inspect-wrap {
  position:relative;
  width: min(520px, calc(100vw - 80px));
  aspect-ratio:2/3;
  perspective:1600px;
  cursor:grab;
}
.card-inspect-wrap:active { cursor:grabbing; }
.card-inspect-glow {
  position:absolute; inset:-52px; border-radius:72px;
  filter: blur(36px); z-index:0;
  background: radial-gradient(circle at center, rgba(255,255,255,.22), transparent 68%);
}

/* ═══════════════════════════════════════════════
   ADMIN PANEL
═══════════════════════════════════════════════ */
.admin-layout {
  width: min(1300px,100%);
  display: grid;
  grid-template-columns: 400px 1fr;
  gap: 18px;
}
.admin-card {
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.10);
  background:
    linear-gradient(160deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  padding: 20px 22px;
  box-shadow: 0 20px 60px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.06);
}
.admin-card h2 {
  font-size:22px; font-style:italic; text-transform:uppercase;
  margin-bottom:4px;
}
.admin-card h3 {
  font-size:11px; text-transform:uppercase; letter-spacing:.28em;
  color:rgba(255,255,255,.38); margin-bottom:12px;
}
.mt { margin-top:20px; }
.table-wrap {
  max-height:280px; overflow:auto;
  border-radius:14px; border:1px solid rgba(255,255,255,.08);
}
.data-table { width:100%; border-collapse:collapse; }
.data-table th, .data-table td {
  padding:10px 12px; border-bottom:1px solid rgba(255,255,255,.06);
  text-align:left; font-size:13px; vertical-align:top;
}
.data-table th {
  position:sticky; top:0; background:#0e0518;
  color:rgba(255,255,255,.65);
  text-transform:uppercase; letter-spacing:.18em; font-size:10px;
}
.code-row { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.code-pill {
  display:inline-flex; padding:6px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  font-size:12px; font-family:monospace;
}
.copy-code-btn {
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.06);
  color:white; border-radius:10px;
  padding:5px 10px; font-size:12px; cursor:pointer;
  transition:filter .15s;
}
.copy-code-btn:hover { filter:brightness(1.1); }

/* ═══════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════ */
@media (max-width:1200px) {
  .summary-grid { grid-template-columns:repeat(3, minmax(170px,1fr)); }
  .admin-layout  { grid-template-columns:1fr; }
}
@media (max-width:780px) {
  .shell         { width:calc(100vw - 16px); height:calc(100vh - 16px); margin:8px auto; }
  .summary-grid  { grid-template-columns:repeat(2, minmax(150px,1fr)); }
  .single-card-wrap { width:300px; height:450px; }
  .booster-pack  { width:270px; height:400px; }
  .form-grid     { grid-template-columns:1fr; }
  .pack-title    { font-size:52px; }
}

/* Card manager in admin */
.admin-card-full{grid-column:1 / -1}
.card-manager-grid{display:grid;grid-template-columns:minmax(380px,480px) 1fr;gap:18px;align-items:start}
.card-manager-form{display:grid;grid-template-columns:1fr 1fr;gap:12px 14px}
.card-manager-form .field-span-2{grid-column:span 2}
.card-manager-side{display:grid;gap:14px}
.card-manager-preview-wrap{display:grid;place-items:center;min-height:560px;padding:8px;border-radius:20px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.03)}
.preview-card-wrap{width:min(360px,100%);cursor:default}
.card-manager-list-wrap{max-height:560px}
.card-thumb-mini{width:42px;height:58px;border-radius:10px;background-size:cover;background-position:center;background-repeat:no-repeat;border:1px solid rgba(255,255,255,.08)}
.card-row-actions-inline{display:flex;gap:8px;flex-wrap:wrap}
.card-row-actions-inline .secondary-btn,.card-row-actions-inline .danger-btn{min-width:0;padding:8px 10px;border-radius:10px;font-size:12px}
.card-image-cell{display:flex;align-items:center;gap:10px}
.card-name-stack{display:grid;gap:2px}
.card-name-stack small{color:rgba(255,255,255,.5)}
.preview-card-wrap .card-inspect{pointer-events:none}
.card-inspect-art.is-image,.card-art.is-image{background-size:cover!important;background-position:center!important;background-repeat:no-repeat!important;font-size:0!important;color:transparent!important}
@media (max-width:1100px){
  .card-manager-grid{grid-template-columns:1fr}
  .card-manager-preview-wrap{min-height:0}
  .card-manager-form{grid-template-columns:1fr}
  .card-manager-form .field-span-2{grid-column:auto}
}


/* Admin accessibility + auth */
.admin-root {
  width: 100%;
  height: 100%;
  overflow: auto;
}
.admin-view {
  display: block;
  width: 100%;
  height: auto;
  min-height: 100%;
  padding: 24px;
}
.admin-layout {
  align-items: start;
}
.shell.admin-mode {
  overflow: auto;
}
.shell.admin-mode .admin-root {
  overflow: visible;
}
.shell.admin-mode .admin-view {
  padding-bottom: 42px;
}
.admin-card-full {
  margin-top: 12px;
}

.admin-auth-modal {
  position: absolute;
  inset: 0;
  z-index: 40;
  display: grid;
  place-items: center;
  background: rgba(4, 2, 10, .72);
  backdrop-filter: blur(14px);
}
.admin-auth-card {
  width: min(480px, calc(100vw - 48px));
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,.10);
  background: linear-gradient(160deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
  padding: 26px 28px;
  box-shadow: 0 28px 90px rgba(0,0,0,.55), inset 0 1px 0 rgba(255,255,255,.06);
}
.admin-auth-card h2 {
  margin-top: 8px;
  font-size: 30px;
  font-style: italic;
  text-transform: uppercase;
}
.admin-auth-card p {
  margin-top: 10px;
  color: rgba(255,255,255,.58);
  line-height: 1.5;
}

/* Card manager section lock */
.card-manager-grid {
  position: relative;
}
.card-manager-lock {
  position: absolute;
  inset: 0;
  z-index: 12;
  display: grid;
  place-items: center;
  background: rgba(4, 2, 10, .72);
  backdrop-filter: blur(10px);
  border-radius: 22px;
}
.card-manager-lock-card {
  width: min(440px, calc(100% - 32px));
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.10);
  background: linear-gradient(160deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
  padding: 24px 26px;
  box-shadow: 0 24px 80px rgba(0,0,0,.55), inset 0 1px 0 rgba(255,255,255,.06);
}
.card-manager-lock-card h3 {
  margin-top: 8px;
  font-size: 28px;
  font-style: italic;
  text-transform: uppercase;
}
.card-manager-lock-card p {
  margin-top: 10px;
  color: rgba(255,255,255,.58);
  line-height: 1.5;
}


.admin-pulls-toolbar {
  display: grid;
  gap: 8px;
  margin: 10px 0 14px;
}

.admin-pulls-search {
  width: 100%;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.13);
  background: rgba(255,255,255,.06);
  color: white;
  padding: 13px 16px;
  outline: none;
  font-size: 14px;
}

.admin-pulls-hint {
  font-size: 12px;
  color: rgba(255,255,255,.42);
}

.admin-compact-player {
  display: grid;
  gap: 5px;
}

.admin-compact-player strong {
  color: white;
  font-size: 14px;
}

.admin-compact-player small {
  color: rgba(255,255,255,.5);
  font-size: 12px;
}

.admin-compact-summary {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.admin-compact-summary strong {
  color: #fff;
  font-size: 15px;
}

.admin-compact-summary span {
  color: rgba(255,255,255,.55);
  font-size: 13px;
}

.admin-view-cards-btn {
  min-width: 120px;
  padding: 9px 12px;
  border-radius: 12px;
  font-size: 13px;
}

.admin-cards-modal {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: grid;
  place-items: center;
  padding: 28px;
}

.admin-cards-modal.hidden {
  display: none !important;
}

.admin-cards-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.72);
  backdrop-filter: blur(12px);
}

.admin-cards-modal-panel {
  position: relative;
  z-index: 1;
  width: min(1180px, calc(100vw - 44px));
  max-height: calc(100vh - 54px);
  overflow: auto;
  border-radius: 26px;
  border: 1px solid rgba(255,255,255,.12);
  background:
    radial-gradient(ellipse 80% 50% at 50% 0%, rgba(192,83,81,.18), transparent 60%),
    linear-gradient(160deg, rgba(32,22,36,.96), rgba(10,6,16,.98));
  box-shadow: 0 40px 140px rgba(0,0,0,.72);
  padding: 24px;
}

.admin-cards-modal-head {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: flex-start;
  margin-bottom: 20px;
}

.admin-cards-modal-head h3 {
  margin-top: 6px;
  color: white;
  font-size: 28px;
  font-style: italic;
  text-transform: uppercase;
}

.admin-cards-modal-head p {
  margin-top: 8px;
  color: rgba(255,255,255,.56);
  font-size: 14px;
}

.admin-cards-modal-close {
  min-width: 120px;
}

.admin-cards-modal-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(155px, 1fr));
  gap: 16px;
}

.admin-owned-card {
  position: relative;
  border-radius: 18px;
  border: 1px solid color-mix(in srgb, var(--rarity-color) 38%, rgba(255,255,255,.10));
  background: rgba(255,255,255,.045);
  overflow: hidden;
  box-shadow: 0 18px 44px rgba(0,0,0,.28), 0 0 22px color-mix(in srgb, var(--rarity-color) 18%, transparent);
}

.admin-owned-card-art {
  position: relative;
  aspect-ratio: 3 / 4;
  background-size: cover !important;
  background-position: center !important;
  display: grid;
  place-items: center;
  font-size: 48px;
}

.admin-owned-card-art::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 45%, rgba(0,0,0,.5));
  pointer-events: none;
}

.admin-owned-card-count {
  position: absolute;
  top: 8px;
  right: 8px;
  z-index: 2;
  min-width: 34px;
  height: 34px;
  padding: 0 9px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: color-mix(in srgb, var(--rarity-color) 78%, #111);
  color: #07040a;
  font-weight: 900;
  font-size: 13px;
  border: 2px solid rgba(255,255,255,.65);
  box-shadow: 0 8px 24px rgba(0,0,0,.34);
}

.admin-owned-card-info {
  padding: 12px;
  display: grid;
  gap: 4px;
}

.admin-owned-card-info strong {
  color: white;
  font-size: 14px;
  line-height: 1.1;
}

.admin-owned-card-info small {
  color: rgba(255,255,255,.48);
  font-size: 11px;
  text-transform: uppercase;
}

.admin-owned-card-info span {
  color: var(--rarity-color);
  font-size: 12px;
  font-weight: 800;
}

.empty-pulls-state {
  padding: 20px;
  color: rgba(255,255,255,.5);
  text-align: center;
}

@media (max-width: 700px) {
  .admin-cards-modal-grid {
    grid-template-columns: repeat(auto-fill, minmax(128px, 1fr));
  }

  .admin-cards-modal-head {
    display: grid;
  }
}


/* Admin V4 fixes */
.admin-pulls-toolbar {
  display: grid !important;
  gap: 8px;
  margin: 12px 0 16px !important;
  position: relative;
  z-index: 3;
}

.admin-pulls-search {
  display: block !important;
  width: 100% !important;
  min-height: 44px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.075);
  color: white;
  padding: 13px 16px;
  outline: none;
  font-size: 14px;
}

.admin-pulls-hint {
  color: rgba(255,255,255,.48);
  font-size: 12px;
}

/* évite que le bouton remonte dans la ligne de titre */
.data-table td {
  vertical-align: middle;
}

.admin-compact-summary {
  display: grid !important;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 10px 12px;
  min-width: 280px;
}

.admin-compact-summary strong {
  color: #fff;
  font-size: 15px;
}

.admin-compact-summary span {
  color: rgba(255,255,255,.58);
  font-size: 13px;
  white-space: nowrap;
}

.admin-view-cards-btn {
  min-width: 118px !important;
  padding: 10px 14px !important;
  border-radius: 13px !important;
  font-size: 13px !important;
  position: relative;
  z-index: 1;
}

.admin-cards-modal-search {
  width: 100%;
  margin: 0 0 18px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.07);
  color: white;
  padding: 13px 16px;
  outline: none;
  font-size: 14px;
}

.admin-owned-card.hidden {
  display: none !important;
}

.admin-owned-card-art {
  min-height: 205px;
  background-size: cover !important;
  background-position: center !important;
}

.admin-owned-card-art span {
  filter: none;
  opacity: .9;
}

@media (max-width: 950px) {
  .admin-compact-summary {
    grid-template-columns: 1fr;
  }
}

/* ===== V9 BIG REFONTE: responsive + admin pro ===== */
html, body {
  min-height: 100%;
  height: auto !important;
  margin: 0 !important;
  overflow-x: hidden !important;
  overflow-y: auto !important;
  background: #04020a !important;
}

body {
  min-height: 100dvh;
}

.app {
  min-height: 100dvh;
  height: auto !important;
  overflow: visible !important;
}

.backdrop {
  position: fixed !important;
  min-height: 100dvh;
}

.shell {
  width: min(1400px, calc(100vw - 24px)) !important;
  min-height: calc(100dvh - 24px) !important;
  height: auto !important;
  margin: 12px auto !important;
  overflow: visible !important;
}

.player-root, .admin-root {
  min-height: calc(100dvh - 24px);
}

.view {
  min-height: calc(100dvh - 24px) !important;
  height: auto !important;
  display: flex !important;
  flex-direction: column;
  justify-content: center !important;
  align-items: center !important;
  padding: clamp(16px, 3vw, 32px) !important;
}

#boosterView {
  justify-content: center !important;
}

.admin-view {
  min-height: calc(100dvh - 24px) !important;
  height: auto !important;
  overflow: visible !important;
  display: block !important;
  padding: clamp(14px, 2vw, 28px) !important;
}

.admin-layout {
  width: 100%;
  display: grid;
  grid-template-columns: minmax(320px, .9fr) minmax(460px, 1.4fr);
  gap: 18px;
  align-items: start;
}

.admin-card-full {
  grid-column: 1 / -1;
}

.table-wrap {
  max-width: 100%;
  overflow: auto;
}

.data-table {
  min-width: 760px;
}

.booster-pack {
  width: clamp(230px, 30vw, 300px) !important;
  height: clamp(340px, 44vw, 440px) !important;
}

.single-card-wrap {
  width: clamp(250px, 44vw, 340px) !important;
  height: clamp(375px, 66vw, 510px) !important;
}

.summary-grid {
  width: 100%;
}

.form-grid {
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)) !important;
}

.admin-login-overlay-v9 {
  position: fixed;
  inset: 0;
  z-index: 100000;
  display: grid;
  place-items: center;
  padding: 24px;
  background: radial-gradient(ellipse at top, rgba(192,83,81,.18), transparent 55%), rgba(4,2,10,.92);
  backdrop-filter: blur(14px);
}

.admin-login-card-v9 {
  width: min(430px, 100%);
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,.12);
  background: linear-gradient(160deg, rgba(255,255,255,.08), rgba(255,255,255,.035));
  padding: 28px;
  box-shadow: 0 30px 100px rgba(0,0,0,.58);
}

.admin-login-card-v9 h2 {
  color: white;
  font-size: 34px;
  text-transform: uppercase;
  font-style: italic;
  margin-top: 8px;
}

.admin-login-card-v9 p {
  color: rgba(255,255,255,.58);
  margin: 10px 0 18px;
}

.admin-login-card-v9 input,
.quick-edit-grid-v9 input,
.quick-edit-grid-v9 textarea,
.quick-edit-grid-v9 select,
.admin-pulls-search-v9,
.admin-modal-search-v9 {
  width: 100%;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.075);
  color: white;
  padding: 13px 16px;
  outline: none;
  font-size: 14px;
}

.admin-pulls-toolbar-v9 {
  display: grid;
  gap: 8px;
  margin: 12px 0 16px;
}

.admin-pulls-hint-v9 {
  color: rgba(255,255,255,.48);
  font-size: 12px;
}

.admin-compact-player-v9 {
  display: grid;
  gap: 5px;
}

.admin-compact-player-v9 strong { color: white; font-size: 14px; }
.admin-compact-player-v9 small { color: rgba(255,255,255,.5); font-size: 12px; }

.admin-compact-summary-v9 {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 10px 12px;
  min-width: 280px;
}

.admin-compact-summary-v9 strong { color: #fff; font-size: 15px; }
.admin-compact-summary-v9 span { color: rgba(255,255,255,.58); font-size: 13px; white-space: nowrap; }

.admin-view-details-btn-v9 {
  min-width: 128px !important;
  padding: 10px 14px !important;
  border-radius: 13px !important;
  font-size: 13px !important;
}

.admin-modal-v9 {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: grid;
  place-items: center;
  padding: 24px;
}

.admin-modal-v9.hidden { display: none !important; }

.admin-modal-backdrop-v9 {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.72);
  backdrop-filter: blur(12px);
}

.admin-modal-panel-v9 {
  position: relative;
  z-index: 1;
  width: min(1220px, calc(100vw - 44px));
  max-height: calc(100dvh - 54px);
  overflow: auto;
  border-radius: 26px;
  border: 1px solid rgba(255,255,255,.12);
  background: radial-gradient(ellipse 80% 50% at 50% 0%, rgba(192,83,81,.18), transparent 60%), linear-gradient(160deg, rgba(32,22,36,.96), rgba(10,6,16,.98));
  box-shadow: 0 40px 140px rgba(0,0,0,.72);
  padding: 24px;
}

.admin-modal-head-v9 {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: flex-start;
  margin-bottom: 16px;
}

.admin-modal-head-v9 h3 {
  margin-top: 6px;
  color: white;
  font-size: 28px;
  font-style: italic;
  text-transform: uppercase;
}

.admin-modal-head-v9 p {
  margin-top: 8px;
  color: rgba(255,255,255,.56);
  font-size: 14px;
}

.admin-player-code-list-v9 {
  display: flex;
  gap: 10px;
  overflow-x: auto;
  padding: 4px 2px 10px;
}

.admin-player-code-card-v9 {
  min-width: 230px;
  text-align: left;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.11);
  background: rgba(255,255,255,.055);
  color: white;
  cursor: pointer;
  display: grid;
  gap: 5px;
}

.admin-player-code-card-v9.is-active {
  border-color: rgba(224,106,80,.58);
  background: rgba(192,83,81,.16);
}

.admin-player-code-card-v9 span,
.admin-player-code-card-v9 small {
  color: rgba(255,255,255,.56);
  font-size: 12px;
}

.admin-player-code-detail-head-v9 {
  margin: 6px 0 14px;
}

.admin-player-code-detail-head-v9 h4 { color: white; font-size: 18px; }
.admin-player-code-detail-head-v9 p { color: rgba(255,255,255,.55); margin-top: 4px; }

.admin-cards-grid-v9 {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(155px, 1fr));
  gap: 16px;
}

.admin-owned-card-v9 {
  position: relative;
  border-radius: 18px;
  border: 1px solid color-mix(in srgb, var(--rarity-color) 38%, rgba(255,255,255,.10));
  background: rgba(255,255,255,.045);
  overflow: hidden;
  box-shadow: 0 18px 44px rgba(0,0,0,.28), 0 0 22px color-mix(in srgb, var(--rarity-color) 18%, transparent);
}

.admin-owned-card-v9.hidden,
.admin-player-code-card-v9.hidden { display: none !important; }

.admin-owned-card-art-v9 {
  position: relative;
  aspect-ratio: 3 / 4;
  min-height: 205px;
  background-size: cover !important;
  background-position: center !important;
  display: grid;
  place-items: center;
  font-size: 48px;
}

.admin-owned-card-art-v9::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 45%, rgba(0,0,0,.5));
  pointer-events: none;
}

.admin-owned-card-count-v9 {
  position: absolute;
  top: 8px;
  right: 8px;
  z-index: 2;
  min-width: 34px;
  height: 34px;
  padding: 0 9px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: color-mix(in srgb, var(--rarity-color) 78%, #111);
  color: #07040a;
  font-weight: 900;
  font-size: 13px;
  border: 2px solid rgba(255,255,255,.65);
  box-shadow: 0 8px 24px rgba(0,0,0,.34);
}

.admin-owned-card-info-v9 {
  padding: 12px;
  display: grid;
  gap: 4px;
}

.admin-owned-card-info-v9 strong { color: white; font-size: 14px; line-height: 1.1; }
.admin-owned-card-info-v9 small { color: rgba(255,255,255,.48); font-size: 11px; text-transform: uppercase; }
.admin-owned-card-info-v9 span { color: var(--rarity-color); font-size: 12px; font-weight: 800; }

.quick-edit-grid-v9 {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 12px;
}

.quick-edit-grid-v9 label {
  display: grid;
  gap: 7px;
  color: rgba(255,255,255,.55);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.quick-edit-grid-v9 textarea {
  min-height: 80px;
  resize: vertical;
}

.replace-preview-grid-v9 {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 16px;
}

.replace-preview-grid-v9 h4 {
  color: rgba(255,255,255,.6);
  margin-bottom: 8px;
}

.replace-mini-card-v9 {
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 18px;
  padding: 12px;
  background: rgba(255,255,255,.04);
  display: grid;
  gap: 8px;
}

.replace-mini-art-v9 {
  aspect-ratio: 3 / 4;
  border-radius: 14px;
  background-size: cover !important;
  background-position: center !important;
  display: grid;
  place-items: center;
  font-size: 38px;
}

.replace-mini-card-v9 strong { color: white; }
.replace-mini-card-v9 small { color: rgba(255,255,255,.55); }

.booster-backs-panel-v9 {
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid rgba(255,255,255,.08);
}

.booster-backs-panel-v9 p {
  color: rgba(255,255,255,.52);
  margin-top: 6px;
}

.booster-back-preview-v9 {
  margin-top: 12px;
  width: 150px;
  aspect-ratio: 3 / 4;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.12);
  background: linear-gradient(135deg, rgba(192,83,81,.34), rgba(20,10,20,.9));
  background-size: cover !important;
  background-position: center !important;
  display: grid;
  place-items: center;
  color: rgba(255,255,255,.65);
  font-weight: 900;
  text-transform: uppercase;
}

.empty-pulls-state-v9 {
  padding: 20px;
  color: rgba(255,255,255,.5);
  text-align: center;
}

@media (max-width: 1050px) {
  .admin-layout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 700px) {
  .shell {
    width: 100vw !important;
    min-height: 100dvh !important;
    margin: 0 !important;
    border-radius: 0 !important;
  }

  .view, .admin-view {
    min-height: 100dvh !important;
    padding: 14px !important;
  }

  .panel {
    padding: 20px !important;
  }

  .panel h1 {
    font-size: 34px !important;
  }

  .admin-card {
    padding: 16px !important;
  }

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

  .primary-btn, .secondary-btn {
    width: 100% !important;
    min-width: 0 !important;
  }

  .data-table {
    min-width: 650px;
  }

  .admin-compact-summary-v9,
  .admin-compact-summary {
    grid-template-columns: 1fr !important;
    min-width: 0 !important;
  }

  .admin-modal-panel-v9 {
    width: calc(100vw - 18px);
    max-height: calc(100dvh - 18px);
    padding: 16px;
    border-radius: 18px;
  }

  .admin-modal-head-v9 {
    display: grid;
  }

  .quick-edit-grid-v9,
  .replace-preview-grid-v9 {
    grid-template-columns: 1fr;
  }

  .admin-cards-grid-v9 {
    grid-template-columns: repeat(auto-fill, minmax(128px, 1fr));
  }
}

/* V10 VOID rebrand + input fixes */
html, body {
  background: #030108 !important;
  margin: 0 !important;
}

input, textarea, select {
  color-scheme: dark;
}

input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus {
  -webkit-text-fill-color: #fff !important;
  -webkit-box-shadow: 0 0 0px 1000px rgba(40,32,48,.98) inset !important;
  transition: background-color 9999s ease-in-out 0s;
}

button:disabled {
  opacity: .55;
  cursor: wait;
}

/* V11 VOID Studio brand */
.void-brand-logo {
  position: fixed;
  top: 18px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 20;
  pointer-events: none;
  opacity: .88;
}
.void-brand-logo img {
  width: min(220px, 42vw);
  height: auto;
  display: block;
  filter: drop-shadow(0 12px 34px rgba(0,0,0,.5));
}
@media (max-width: 700px) {
  .void-brand-logo { top: 10px; opacity: .78; }
  .void-brand-logo img { width: min(150px, 48vw); }
}


/* V12 CRITICAL FIX — les vues cachées doivent rester cachées */
.hidden,
.view.hidden,
.player-root.hidden,
.admin-root.hidden,
#redeemView.hidden,
#boosterView.hidden,
#openingView.hidden,
#summaryView.hidden,
#adminRoot.hidden,
#playerRoot.hidden,
.admin-modal-v9.hidden,
.admin-cards-modal.hidden {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

.view:not(.hidden) {
  visibility: visible;
}


/* ===== CLAUDE VOID RARITY FX PATCH START ===== */
/* ═══════════════════════════════════════════════
   VOID — RARITY FX PATCH
   Coller À LA FIN de style.css (remplace void_glitter_effects.css si déjà présent)
   Différenciation complète des 5 raretés
═══════════════════════════════════════════════ */

/* ── 1. COMMON — aucun holo, aucune particule hover ── */
/* L'effet holo hover est désactivé pour Common et Rare */
.rarity-common .card-holo-hover  { display: none !important; }
.rarity-common .hover-particles   { display: none !important; }
.rarity-rare   .card-holo-hover  { display: none !important; }
.rarity-rare   .hover-particles   { display: none !important; }

/* Common : pas d'animation sur la carte elle-même */
.rarity-common.card-single,
.rarity-common.card-inspect {
  animation: none !important;
}

/* ── 2. RARE — Légère lueur bleue, pas d'holo ── */
/* La box-shadow déjà définie dans le CSS de base suffit.
   Juste un très léger reflet diagonal discret sur hover. */
.rarity-rare.card-single::after,
.rarity-rare.card-inspect::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 22px;
  pointer-events: none;
  z-index: 5;
  mix-blend-mode: screen;
  background: linear-gradient(
    125deg,
    transparent 0% 40%,
    rgba(74, 163, 255, .07) 50%,
    transparent 60% 100%
  );
  opacity: 0;
  transition: opacity .3s ease;
}
.rarity-rare.card-single:hover::after,
.rarity-rare.card-inspect:hover::after { opacity: 1; }

/* Rare : animation de respiration douce */
.rarity-rare.card-single,
.rarity-rare.card-inspect {
  animation: rareBreath 5s ease-in-out infinite;
}
@keyframes rareBreath {
  0%,100% { box-shadow: 0 30px 86px rgba(0,0,0,.52), 0 0 24px rgba(74,163,255,.18), 0 0 0 1px rgba(74,163,255,.22); }
  50%      { box-shadow: 0 30px 86px rgba(0,0,0,.52), 0 0 38px rgba(74,163,255,.30), 0 0 0 1px rgba(74,163,255,.30); }
}

/* Rare : border discrète sans animation */
.rarity-rare .card-border {
  border-color: rgba(74, 163, 255, .28);
  box-shadow: inset 0 0 14px rgba(74,163,255,.07);
}

/* ── 3. EPIC — Holo violet présent uniquement au hover, foil léger ── */
/* Foil diagonal violet subtil */
.rarity-epic.card-single::after,
.rarity-epic.card-inspect::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 22px;
  pointer-events: none;
  z-index: 5;
  mix-blend-mode: screen;
  background: repeating-linear-gradient(
    122deg,
    transparent 0px,
    transparent 22px,
    rgba(184, 109, 255, .045) 23px,
    rgba(184, 109, 255, .045) 24px
  );
  animation: epicFoilPulse 4.5s ease-in-out infinite;
}
@keyframes epicFoilPulse {
  0%,100% { opacity: .45; }
  50%      { opacity: .9; }
}

/* Epic holo — uniquement visible au hover, plus discret qu'Epic+ */
.rarity-epic .card-holo-hover {
  background:
    radial-gradient(circle at var(--mx,50%) var(--my,50%),
      rgba(255,255,255,.14), transparent 18%),
    conic-gradient(from var(--ha,0deg) at var(--mx,50%) var(--my,50%),
      rgba(184,109,255,.14),
      rgba(130,200,255,.10),
      rgba(255,100,200,.12),
      rgba(184,109,255,.14));
}

/* Epic hover particles actives mais couleur froide */
.rarity-epic .hover-particles { opacity: 0; transition: opacity .2s; }
.single-card-wrap.revealed-mode:hover .rarity-epic .hover-particles,
.card-inspect-wrap:hover .rarity-epic .hover-particles { opacity: .65; }

/* Epic border : violet doux */
.rarity-epic .card-border {
  border-color: rgba(184, 109, 255, .38);
  box-shadow: inset 0 0 18px rgba(184,109,255,.10), 0 0 12px rgba(184,109,255,.14);
}
.rarity-epic .card-border::before,
.rarity-epic .card-border::after {
  border-color: rgba(184, 109, 255, .60);
}

/* Epic respiration */
.rarity-epic.card-single,
.rarity-epic.card-inspect {
  animation: epicBreath 3.6s ease-in-out infinite;
}
@keyframes epicBreath {
  0%,100% { box-shadow: 0 30px 90px rgba(0,0,0,.54), 0 0 36px rgba(184,109,255,.24), 0 0 0 1px rgba(184,109,255,.24); }
  50%      { box-shadow: 0 30px 90px rgba(0,0,0,.54), 0 0 60px rgba(184,109,255,.40), 0 0 0 1px rgba(184,109,255,.36); }
}

/* ── 4. LEGENDARY — Foil doré + paillettes + holo doré ── */
/* Foil strié doré */
.rarity-legendary.card-single::after,
.rarity-legendary.card-inspect::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 22px;
  pointer-events: none;
  z-index: 6;
  mix-blend-mode: screen;
  background: repeating-linear-gradient(
    118deg,
    transparent 0px,
    transparent 14px,
    rgba(255, 210, 90, .06) 15px,
    rgba(255, 210, 90, .06) 16px
  );
  animation: legendaryFoilPulse 3.2s ease-in-out infinite;
}
@keyframes legendaryFoilPulse {
  0%,100% { opacity: .55; }
  50%      { opacity: 1; }
}

/* Legendary : holo doré chaud, toujours visible en hover */
.rarity-legendary .card-holo-hover {
  background:
    radial-gradient(circle at var(--mx,50%) var(--my,50%),
      rgba(255,240,120,.22), transparent 24%),
    conic-gradient(from var(--ha,0deg) at var(--mx,50%) var(--my,50%),
      rgba(255,200,60,.20),
      rgba(255,255,180,.14),
      rgba(255,160,30,.20),
      rgba(255,240,120,.14),
      rgba(255,200,60,.20));
}
.single-card-wrap.revealed-mode:hover .rarity-legendary .card-holo-hover,
.card-inspect-wrap:hover .rarity-legendary .card-holo-hover { opacity: 1; }

/* Legendary border : or shimmer */
.rarity-legendary .card-border {
  border-color: rgba(255, 200, 70, .50);
  box-shadow: inset 0 0 22px rgba(255,200,60,.14), 0 0 18px rgba(255,180,40,.24);
  animation: legendaryBorderShimmer 2.8s linear infinite;
}
@keyframes legendaryBorderShimmer {
  0%   { border-color: rgba(255,200,70,.38); box-shadow: inset 0 0 18px rgba(255,200,60,.10), 0 0 14px rgba(255,180,40,.18); }
  33%  { border-color: rgba(255,240,120,.65); box-shadow: inset 0 0 28px rgba(255,230,90,.22), 0 0 24px rgba(255,210,60,.32); }
  66%  { border-color: rgba(220,155,28,.42);  box-shadow: inset 0 0 14px rgba(210,140,28,.10), 0 0 12px rgba(190,120,18,.16); }
  100% { border-color: rgba(255,200,70,.38); box-shadow: inset 0 0 18px rgba(255,200,60,.10), 0 0 14px rgba(255,180,40,.18); }
}
.rarity-legendary .card-border::before,
.rarity-legendary .card-border::after {
  border-color: rgba(255, 220, 90, .85);
  filter: drop-shadow(0 0 4px rgba(255, 210, 60, .8));
  animation: legendaryCornerPulse 2.2s ease-in-out infinite;
}
@keyframes legendaryCornerPulse {
  0%,100% { border-color: rgba(255,200,80,.70); filter: drop-shadow(0 0 3px rgba(255,180,50,.65)); }
  50%      { border-color: rgba(255,245,140,1);  filter: drop-shadow(0 0 9px rgba(255,235,90,1)); }
}

/* Legendary respiration ambrée */
.rarity-legendary.card-single,
.rarity-legendary.card-inspect {
  animation: legendaryCardBreath 3s ease-in-out infinite;
}
@keyframes legendaryCardBreath {
  0%,100% { box-shadow: 0 34px 110px rgba(0,0,0,.58), 0 0 52px rgba(255,141,71,.30), 0 0 0 1px rgba(255,141,71,.28); }
  50%      { box-shadow: 0 34px 120px rgba(0,0,0,.62), 0 0 88px rgba(255,210,60,.54), 0 0 0 1px rgba(255,210,80,.48); }
}

/* Legendary paillettes */
.legendary-glitter {
  position: absolute; inset: 0;
  border-radius: 22px; overflow: hidden;
  pointer-events: none; z-index: 7;
}
.glitter-dot {
  position: absolute; border-radius: 50%;
  pointer-events: none;
  animation: glitterSpark var(--dur, 2s) ease-in-out infinite;
  animation-delay: var(--delay, 0s);
}
.legendary-glitter .glitter-dot {
  width: var(--size, 4px); height: var(--size, 4px);
  background: radial-gradient(circle, #fff9cc 0%, #ffd97a 50%, transparent 100%);
  box-shadow: 0 0 6px 2px rgba(255, 210, 80, .7);
}
@keyframes glitterSpark {
  0%   { opacity: 0;   transform: scale(.3)  rotate(0deg); }
  20%  { opacity: 1;   transform: scale(1.1) rotate(45deg); }
  50%  { opacity: .75; transform: scale(.85) rotate(90deg); }
  80%  { opacity: 1;   transform: scale(1)   rotate(135deg); }
  100% { opacity: 0;   transform: scale(.4)  rotate(180deg); }
}

/* Legendary label */
.rarity-legendary .card-rarity,
.rarity-legendary .mini-rarity {
  color: #ffd97a;
  text-shadow: 0 0 12px rgba(255, 210, 80, .65);
}

/* ── 5. MYTHIC — Tout ce qu'a Legendary × 2 + prismatique ── */

/* Foil prismatique dense double grille */
.rarity-mythic.card-single::after,
.rarity-mythic.card-inspect::after {
  content: '';
  position: absolute; inset: 0;
  border-radius: 22px;
  pointer-events: none; z-index: 6;
  mix-blend-mode: screen;
  background:
    repeating-linear-gradient(
      118deg,
      rgba(255,100,180,.05) 0px,
      rgba(255,100,180,.05) 2px,
      transparent 2px,
      transparent 10px
    ),
    repeating-linear-gradient(
      48deg,
      rgba(80,200,255,.04) 0px,
      rgba(80,200,255,.04) 2px,
      transparent 2px,
      transparent 10px
    );
  animation: mythicFoilShift 4s linear infinite;
}
@keyframes mythicFoilShift {
  0%   { opacity: .45; filter: hue-rotate(0deg); }
  50%  { opacity: 1;   filter: hue-rotate(180deg); }
  100% { opacity: .45; filter: hue-rotate(360deg); }
}

/* Deuxième couche : sweep prismatique continu */
.rarity-mythic.card-single::before,
.rarity-mythic.card-inspect::before {
  content: '';
  position: absolute; inset: 0;
  border-radius: 22px;
  pointer-events: none; z-index: 7;
  mix-blend-mode: screen;
  background: linear-gradient(
    115deg,
    transparent 0% 30%,
    rgba(255,100,200,.10) 38%,
    rgba(120,220,255,.10) 46%,
    rgba(200,120,255,.08) 54%,
    transparent 62% 100%
  );
  animation: mythicSweepLoop 2.8s linear infinite;
}
@keyframes mythicSweepLoop {
  0%   { transform: translateX(-80%) skewX(-12deg); opacity: 0; }
  15%  { opacity: 1; }
  85%  { opacity: 1; }
  100% { transform: translateX(100%) skewX(-12deg); opacity: 0; }
}

/* Mythic holo — arc-en-ciel saturé, toujours visible en hover, pulse */
.rarity-mythic .card-holo-hover {
  background:
    radial-gradient(circle at var(--mx,50%) var(--my,50%),
      rgba(255,255,255,.30), transparent 26%),
    conic-gradient(from var(--ha,0deg) at var(--mx,50%) var(--my,50%),
      rgba(255,80,160,.26),
      rgba(255,200,60,.20),
      rgba(60,230,200,.22),
      rgba(80,160,255,.26),
      rgba(200,100,255,.26),
      rgba(255,80,160,.26));
  animation: mythicHoloBreath 2.4s ease-in-out infinite;
}
.single-card-wrap.revealed-mode .rarity-mythic .card-holo-hover,
.card-inspect-wrap .rarity-mythic .card-holo-hover { opacity: 1 !important; }
@keyframes mythicHoloBreath {
  0%,100% { filter: saturate(1.2) brightness(1); }
  50%      { filter: saturate(2) brightness(1.18); }
}

/* Mythic border prismatique */
.rarity-mythic .card-border {
  animation: mythicBorderPrism 1.8s linear infinite;
}
@keyframes mythicBorderPrism {
  0%   { border-color: rgba(255,200,80,.58);  box-shadow: inset 0 0 24px rgba(255,200,80,.16),  0 0 20px rgba(255,200,80,.30); }
  16%  { border-color: rgba(255,100,180,.58); box-shadow: inset 0 0 24px rgba(255,100,180,.16), 0 0 20px rgba(255,100,180,.30); }
  33%  { border-color: rgba(100,200,255,.58); box-shadow: inset 0 0 24px rgba(100,200,255,.16), 0 0 20px rgba(100,200,255,.30); }
  50%  { border-color: rgba(160,100,255,.58); box-shadow: inset 0 0 24px rgba(160,100,255,.16), 0 0 20px rgba(160,100,255,.30); }
  66%  { border-color: rgba(100,255,200,.58); box-shadow: inset 0 0 24px rgba(100,255,200,.16), 0 0 20px rgba(100,255,200,.30); }
  83%  { border-color: rgba(255,180,60,.55);  box-shadow: inset 0 0 24px rgba(255,180,60,.14),  0 0 20px rgba(255,180,60,.28); }
  100% { border-color: rgba(255,100,180,.58); box-shadow: inset 0 0 24px rgba(255,100,180,.16), 0 0 20px rgba(255,100,180,.30); }
}
.rarity-mythic .card-border::before,
.rarity-mythic .card-border::after {
  animation: mythicCornerPrism 1.8s linear infinite;
}
@keyframes mythicCornerPrism {
  0%   { border-color: rgba(255,220,90,.95);  filter: drop-shadow(0 0 6px rgba(255,220,90,1)); }
  25%  { border-color: rgba(255,100,200,.95); filter: drop-shadow(0 0 6px rgba(255,100,200,1)); }
  50%  { border-color: rgba(100,210,255,.95); filter: drop-shadow(0 0 6px rgba(100,210,255,1)); }
  75%  { border-color: rgba(200,120,255,.95); filter: drop-shadow(0 0 6px rgba(200,120,255,1)); }
  100% { border-color: rgba(255,220,90,.95);  filter: drop-shadow(0 0 6px rgba(255,220,90,1)); }
}

/* Mythic aura arc-en-ciel */
.rarity-mythic.card-single,
.rarity-mythic.card-inspect {
  animation: mythicCardAura 2.2s ease-in-out infinite;
}
@keyframes mythicCardAura {
  0%   { box-shadow: 0 38px 130px rgba(0,0,0,.62), 0 0 65px rgba(255,219,87,.40),  0 0 0 1px rgba(255,219,87,.34); }
  25%  { box-shadow: 0 38px 130px rgba(0,0,0,.62), 0 0 90px rgba(255,100,200,.46), 0 0 0 1px rgba(255,100,200,.40); }
  50%  { box-shadow: 0 38px 130px rgba(0,0,0,.62), 0 0 100px rgba(100,200,255,.48), 0 0 0 1px rgba(100,200,255,.42); }
  75%  { box-shadow: 0 38px 130px rgba(0,0,0,.62), 0 0 90px rgba(180,100,255,.46), 0 0 0 1px rgba(180,100,255,.40); }
  100% { box-shadow: 0 38px 130px rgba(0,0,0,.62), 0 0 65px rgba(255,219,87,.40),  0 0 0 1px rgba(255,219,87,.34); }
}

/* Mythic paillettes arc-en-ciel */
.mythic-glitter {
  position: absolute; inset: 0;
  border-radius: 22px; overflow: hidden;
  pointer-events: none; z-index: 8;
}
.mythic-glitter .glitter-dot {
  width: var(--size, 5px); height: var(--size, 5px);
  background: radial-gradient(circle, #fff 0%, var(--color, #ff80d5) 55%, transparent 100%);
  box-shadow: 0 0 8px 2px var(--color, rgba(255,120,200,.8));
  animation: mythicGlitterPop var(--dur, 1.5s) ease-in-out infinite;
  animation-delay: var(--delay, 0s);
}
@keyframes mythicGlitterPop {
  0%   { opacity: 0;   transform: scale(.2) rotate(0deg); }
  15%  { opacity: 1;   transform: scale(1.4) rotate(60deg); }
  45%  { opacity: .85; transform: scale(.9)  rotate(120deg); }
  75%  { opacity: 1;   transform: scale(1.15) rotate(165deg); }
  100% { opacity: 0;   transform: scale(.3)  rotate(230deg); }
}

/* Mythic label arc-en-ciel animé */
.rarity-mythic .card-rarity,
.rarity-mythic .mini-rarity {
  background: linear-gradient(90deg, #ff80d5, #ffe070, #80e8ff, #c080ff, #ff80d5);
  background-size: 200% auto;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: mythicLabelShift 2s linear infinite;
  filter: drop-shadow(0 0 6px rgba(255,160,220,.55));
}
@keyframes mythicLabelShift {
  0%   { background-position: 0% center; }
  100% { background-position: 200% center; }
}

/* ── SUSPENSE : différenciation visuelle forte ── */

/* Common : overlay suspense très atténué, monochrome */
.single-card-wrap.suspense .rarity-common ~ .suspense-overlay,
.suspense-overlay.suspense-common {
  opacity: .35 !important;
  filter: saturate(0);
}

/* Rare : suspense bleu discret */
.suspense-overlay.suspense-rare::after {
  background:
    radial-gradient(circle at 50% 50%, rgba(74,163,255,.22), transparent 28%) !important;
  filter: blur(28px) !important;
  animation: suspBloom 1.0s ease-in-out infinite !important;
  background:
    radial-gradient(circle at 14% 18%, rgba(74,163,255,.18), transparent 20%),
    radial-gradient(circle at 86% 80%, rgba(74,163,255,.16), transparent 20%),
    radial-gradient(circle at 50% 50%, rgba(255,255,255,.08), transparent 26%);
}

/* Epic : violet + aura plus large */
.suspense-overlay.suspense-epic::after {
  background:
    radial-gradient(circle at 22% 28%, rgba(184,109,255,.35), transparent 24%),
    radial-gradient(circle at 78% 72%, rgba(130,80,255,.30),  transparent 24%),
    radial-gradient(circle at 50% 50%, rgba(255,255,255,.10), transparent 28%) !important;
  filter: blur(26px) saturate(1.5) !important;
  animation: suspBloom .75s ease-in-out infinite !important;
}

/* Legendary : or + plus d'éclats */
.suspense-overlay.suspense-legendary::after {
  background:
    radial-gradient(circle at 14% 18%, rgba(255,200,60,.38), transparent 22%),
    radial-gradient(circle at 86% 22%, rgba(255,140,40,.30), transparent 22%),
    radial-gradient(circle at 14% 84%, rgba(255,230,100,.32), transparent 22%),
    radial-gradient(circle at 86% 80%, rgba(255,180,60,.36), transparent 22%),
    radial-gradient(circle at 50% 50%, rgba(255,255,200,.22), transparent 28%);
  filter: blur(24px) saturate(1.6);
  animation: suspBloom .60s ease-in-out infinite;
}

/* Mythic : full arc-en-ciel, animation ultra-rapide */
.suspense-overlay.suspense-mythic::after {
  background:
    radial-gradient(circle at 14% 18%, rgba(255,80,150,.42),  transparent 22%),
    radial-gradient(circle at 86% 22%, rgba(80,170,255,.40),  transparent 22%),
    radial-gradient(circle at 14% 84%, rgba(255,220,90,.38),  transparent 22%),
    radial-gradient(circle at 86% 80%, rgba(180,120,255,.40), transparent 22%),
    radial-gradient(circle at 50% 50%, rgba(255,255,255,.22), transparent 28%);
  filter: blur(22px) saturate(2) brightness(1.15);
  animation: suspBloomMythic .48s ease-in-out infinite;
}
@keyframes suspBloomMythic {
  0%,100% { opacity: .42; transform: scale(.94); filter: hue-rotate(0deg) blur(22px) saturate(2); }
  50%      { opacity: 1;   transform: scale(1.08); filter: hue-rotate(30deg) blur(18px) saturate(2.4); }
}

/* Mythic frame suspense plus intense */
.suspense-overlay.suspense-mythic::before {
  box-shadow: 0 0 48px rgba(255,255,255,.15), inset 0 0 36px rgba(255,255,255,.08);
  animation: suspFrameMythic .42s ease-in-out infinite;
}
@keyframes suspFrameMythic {
  0%,100% { transform: scale(.982); opacity: .35; }
  50%      { transform: scale(1.018); opacity: 1; }
}

/* ===== CLAUDE VOID RARITY FX PATCH END ===== */


/* ===== V15 RARITY FX TUNING =====
   - Legendary redevient orange/ambre au lieu de jaune
   - Les particules ne doivent pas suggérer une rareté sur le dos
   - Mythic reste premium mais lisible sans hover
*/

/* Legendary orange / amber, not yellow */
.rarity-legendary.card-single::after,
.rarity-legendary.card-inspect::after {
  background: repeating-linear-gradient(
    118deg,
    transparent 0px,
    transparent 14px,
    rgba(255, 141, 71, .075) 15px,
    rgba(255, 141, 71, .075) 16px
  ) !important;
}

.rarity-legendary .card-holo-hover {
  background:
    radial-gradient(circle at var(--mx,50%) var(--my,50%),
      rgba(255,170,80,.18), transparent 24%),
    conic-gradient(from var(--ha,0deg) at var(--mx,50%) var(--my,50%),
      rgba(255,120,55,.22),
      rgba(255,170,80,.14),
      rgba(255,95,45,.22),
      rgba(255,145,65,.14),
      rgba(255,120,55,.22)) !important;
}

.rarity-legendary .card-border {
  border-color: rgba(255, 141, 71, .56) !important;
  box-shadow: inset 0 0 22px rgba(255,120,55,.14), 0 0 20px rgba(255,95,45,.24) !important;
}

@keyframes legendaryBorderShimmer {
  0%   { border-color: rgba(255,120,55,.42); box-shadow: inset 0 0 18px rgba(255,120,55,.10), 0 0 14px rgba(255,95,45,.18); }
  33%  { border-color: rgba(255,170,80,.68); box-shadow: inset 0 0 28px rgba(255,140,65,.24), 0 0 24px rgba(255,95,45,.34); }
  66%  { border-color: rgba(210,80,40,.46);  box-shadow: inset 0 0 14px rgba(210,80,40,.12), 0 0 12px rgba(190,70,35,.18); }
  100% { border-color: rgba(255,120,55,.42); box-shadow: inset 0 0 18px rgba(255,120,55,.10), 0 0 14px rgba(255,95,45,.18); }
}

.rarity-legendary .card-border::before,
.rarity-legendary .card-border::after {
  border-color: rgba(255, 141, 71, .88) !important;
  filter: drop-shadow(0 0 5px rgba(255, 95, 45, .75)) !important;
}

@keyframes legendaryCornerPulse {
  0%,100% { border-color: rgba(255,120,55,.72); filter: drop-shadow(0 0 3px rgba(255,95,45,.65)); }
  50%      { border-color: rgba(255,170,80,1);  filter: drop-shadow(0 0 9px rgba(255,120,55,1)); }
}

@keyframes legendaryCardBreath {
  0%,100% { box-shadow: 0 34px 110px rgba(0,0,0,.58), 0 0 46px rgba(255,95,45,.30), 0 0 0 1px rgba(255,95,45,.26); }
  50%      { box-shadow: 0 34px 120px rgba(0,0,0,.62), 0 0 76px rgba(255,141,71,.48), 0 0 0 1px rgba(255,141,71,.42); }
}

.legendary-glitter .glitter-dot {
  background: radial-gradient(circle, #fff2de 0%, #ff8d47 52%, transparent 100%) !important;
  box-shadow: 0 0 6px 2px rgba(255, 95, 45, .65) !important;
}

.rarity-legendary .card-rarity,
.rarity-legendary .mini-rarity {
  color: #ff8d47 !important;
  text-shadow: 0 0 12px rgba(255, 95, 45, .65) !important;
  -webkit-text-fill-color: #ff8d47 !important;
}

/* No rare/special particles visible on the unrevealed back */
.card-single.preview-hidden .legendary-glitter,
.card-single.preview-hidden .mythic-glitter,
.card-single.preview-hidden .hover-particles,
.single-card-wrap:not(.revealed-mode) .hover-particles,
.single-card-wrap:not(.revealed-mode) .legendary-glitter,
.single-card-wrap:not(.revealed-mode) .mythic-glitter {
  display: none !important;
}

/* Mythic readability: less veil, less rainbow opacity, keep the premium border/aura */
.rarity-mythic.card-single::after,
.rarity-mythic.card-inspect::after {
  opacity: .22 !important;
  mix-blend-mode: soft-light !important;
}

.rarity-mythic.card-single::before,
.rarity-mythic.card-inspect::before {
  opacity: .26 !important;
  mix-blend-mode: screen !important;
}

@keyframes mythicFoilShift {
  0%   { opacity: .18; filter: hue-rotate(0deg); }
  50%  { opacity: .34; filter: hue-rotate(120deg); }
  100% { opacity: .18; filter: hue-rotate(240deg); }
}

@keyframes mythicSweepLoop {
  0%   { transform: translateX(-90%) skewX(-12deg); opacity: 0; }
  18%  { opacity: .28; }
  70%  { opacity: .22; }
  100% { transform: translateX(105%) skewX(-12deg); opacity: 0; }
}

.rarity-mythic .card-holo-hover {
  opacity: .18 !important;
  mix-blend-mode: screen !important;
  animation: mythicHoloBreath 3.8s ease-in-out infinite !important;
}

.single-card-wrap.revealed-mode:hover .rarity-mythic .card-holo-hover,
.card-inspect-wrap:hover .rarity-mythic .card-holo-hover {
  opacity: .72 !important;
}

.mythic-glitter {
  opacity: .62 !important;
}

.mythic-glitter .glitter-dot {
  opacity: .7;
  filter: saturate(.9) brightness(.9);
}

@keyframes mythicCardAura {
  0%   { box-shadow: 0 38px 130px rgba(0,0,0,.62), 0 0 44px rgba(255,219,87,.28),  0 0 0 1px rgba(255,219,87,.24); }
  25%  { box-shadow: 0 38px 130px rgba(0,0,0,.62), 0 0 55px rgba(255,100,200,.26), 0 0 0 1px rgba(255,100,200,.24); }
  50%  { box-shadow: 0 38px 130px rgba(0,0,0,.62), 0 0 60px rgba(100,200,255,.28), 0 0 0 1px rgba(100,200,255,.24); }
  75%  { box-shadow: 0 38px 130px rgba(0,0,0,.62), 0 0 55px rgba(180,100,255,.26), 0 0 0 1px rgba(180,100,255,.24); }
  100% { box-shadow: 0 38px 130px rgba(0,0,0,.62), 0 0 44px rgba(255,219,87,.28),  0 0 0 1px rgba(255,219,87,.24); }
}


/* ===== V17 CLEAN BACKS + MYTHIC READABILITY ===== */

/* Enlève les textes utilitaires sur les dos : "GARAGE RED", "CARTE", etc. */
.card-back .card-back-title,
.card-back .card-back-sub,
.card-back .card-back-kicker,
.card-back .back-title,
.card-back .back-sub,
.card-back .back-kicker,
.card-back h2,
.card-back h3,
.card-back p,
.card-back span,
.booster-pack .pack-kicker,
.booster-pack .pack-title,
.booster-pack .pack-sub,
.booster-pack .pack-meta,
.booster-pack h2,
.booster-pack h3,
.booster-pack p,
.booster-pack span {
  color: transparent !important;
  text-shadow: none !important;
}

/* Garde le visuel du dos propre quand une image de dos est appliquée */
.card-back,
.booster-pack,
.pack-card,
.booster-card,
.card-backface {
  background-size: cover !important;
  background-position: center !important;
}

/* Mythic : lisibilité sans hover — moins de voile, moins de particules visibles */
.rarity-mythic .card-art::after,
.rarity-mythic .card-image::after,
.rarity-mythic .card-media::after {
  opacity: .08 !important;
}

.rarity-mythic.card-single::after,
.rarity-mythic.card-inspect::after {
  opacity: .12 !important;
  mix-blend-mode: soft-light !important;
}

.rarity-mythic.card-single::before,
.rarity-mythic.card-inspect::before {
  opacity: .12 !important;
  mix-blend-mode: screen !important;
}

.rarity-mythic .card-holo-hover {
  opacity: .08 !important;
  pointer-events: none;
}

.single-card-wrap.revealed-mode:hover .rarity-mythic .card-holo-hover,
.card-inspect-wrap:hover .rarity-mythic .card-holo-hover {
  opacity: .42 !important;
}

.rarity-mythic .mythic-glitter {
  opacity: .38 !important;
}

.rarity-mythic .glitter-dot {
  opacity: .48 !important;
  transform: scale(.8);
}

/* Renforce les textes des cartes mythic */
.rarity-mythic .card-name,
.rarity-mythic .card-title,
.rarity-mythic .card-role,
.rarity-mythic .card-quote,
.rarity-mythic .card-id,
.rarity-mythic .card-rarity {
  text-shadow:
    0 2px 8px rgba(0,0,0,.82),
    0 0 16px rgba(0,0,0,.64) !important;
}

.rarity-mythic .card-name,
.rarity-mythic .card-title {
  filter: drop-shadow(0 3px 10px rgba(0,0,0,.78));
}

/* Mythic aura plus premium mais pas envahissante */
@keyframes mythicCardAura {
  0%   { box-shadow: 0 38px 120px rgba(0,0,0,.62), 0 0 34px rgba(255,219,87,.18),  0 0 0 1px rgba(255,219,87,.20); }
  25%  { box-shadow: 0 38px 120px rgba(0,0,0,.62), 0 0 40px rgba(255,100,200,.18), 0 0 0 1px rgba(255,100,200,.20); }
  50%  { box-shadow: 0 38px 120px rgba(0,0,0,.62), 0 0 44px rgba(100,200,255,.20), 0 0 0 1px rgba(100,200,255,.20); }
  75%  { box-shadow: 0 38px 120px rgba(0,0,0,.62), 0 0 40px rgba(180,100,255,.18), 0 0 0 1px rgba(180,100,255,.20); }
  100% { box-shadow: 0 38px 120px rgba(0,0,0,.62), 0 0 34px rgba(255,219,87,.18),  0 0 0 1px rgba(255,219,87,.20); }
}

/* Si le front ajoute le nom du type directement dans ces éléments */
.pack-type,
.booster-type-label,
.back-booster-type {
  display: none !important;
}


/* V22b — canvas visible + premium, pas d'éclairs cheap */
.fx-lightning {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  pointer-events: none !important;
  z-index: 30 !important;
  mix-blend-mode: screen !important;
  opacity: 0;
  overflow: visible !important;
  filter: saturate(1.08) contrast(1.04);
}

.single-card-wrap {
  position: relative;
  isolation: isolate;
}


/* V22c — correction position canvas : plus de bloc FX en haut à gauche */
.fx-lightning {
  position: fixed !important;
  inset: auto !important;
  left: -9999px;
  top: -9999px;
  pointer-events: none !important;
  z-index: 999 !important;
  mix-blend-mode: screen !important;
  opacity: 0;
  overflow: visible !important;
  filter: saturate(1.05) contrast(1.03);
}


/* V22d — plus de marge autour du canvas FX pour éviter les effets coupés */
.fx-lightning {
  overflow: visible !important;
  contain: none !important;
}
.opening-view,
.single-card-wrap,
.card-stage,
.reveal-stage {
  overflow: visible !important;
}


/* ═══════════════════════════════════════════════════════
   V23 CLEAN REVEAL SYSTEM — card anchored, no global canvas
═══════════════════════════════════════════════════════ */

.fx-lightning {
  display: none !important;
}

.single-card-wrap {
  position: relative !important;
  overflow: visible !important;
  isolation: isolate;
}

.v23-card-fx {
  position: absolute;
  inset: -28%;
  z-index: 7;
  pointer-events: none;
  display: grid;
  place-items: center;
  overflow: visible;
  mix-blend-mode: screen;
  opacity: 1;
  transition: opacity .65s ease, transform .65s ease;
}

.v23-card-fx.v23-fade {
  opacity: 0;
  transform: scale(1.04);
}

.v23-ring {
  position: absolute;
  width: 72%;
  aspect-ratio: 1 / 1;
  border-radius: 999px;
  border: 2px solid color-mix(in srgb, var(--fx-color) 70%, white 30%);
  opacity: 0;
  box-shadow:
    0 0 22px color-mix(in srgb, var(--fx-color) 70%, transparent),
    inset 0 0 22px color-mix(in srgb, var(--fx-color) 45%, transparent);
  animation: v23Ring 900ms cubic-bezier(.16,.88,.24,1) var(--delay) forwards;
}

.v23-arc {
  position: absolute;
  width: 78%;
  aspect-ratio: 1 / 1;
  border-radius: 999px;
  transform: rotate(var(--rot)) scale(var(--scale));
  opacity: 0;
  background:
    conic-gradient(
      from 0deg,
      transparent 0deg,
      transparent 18deg,
      color-mix(in srgb, var(--fx-color) 70%, white 30%) 42deg,
      white 48deg,
      color-mix(in srgb, var(--fx-color) 70%, white 30%) 56deg,
      transparent 82deg,
      transparent 360deg
    );
  mask: radial-gradient(circle, transparent 58%, black 60%, black 63%, transparent 66%);
  filter: blur(.15px) drop-shadow(0 0 10px var(--fx-color));
  animation: v23Arc 820ms cubic-bezier(.2,.9,.25,1) var(--delay) forwards;
}

.v23-spark {
  position: absolute;
  left: 50%;
  top: 50%;
  width: var(--size);
  height: var(--size);
  border-radius: 999px;
  background: white;
  box-shadow:
    0 0 8px white,
    0 0 16px var(--fx-color),
    0 0 24px var(--fx-color);
  opacity: 0;
  animation: v23Spark 900ms cubic-bezier(.14,.86,.28,1) var(--delay) forwards;
}

.v23-legendary .v23-ring,
.v23-legendary .v23-arc,
.v23-legendary .v23-spark {
  --fx-color: #ff8d47;
}

.v23-mythic .v23-ring {
  animation-duration: 1100ms;
}

.v23-mythic .v23-arc {
  filter:
    hue-rotate(0deg)
    blur(.15px)
    drop-shadow(0 0 10px #d98cff)
    drop-shadow(0 0 18px rgba(120,210,255,.6));
}

.v23-mythic .v23-spark:nth-child(3n) {
  background: #82eaff;
  box-shadow: 0 0 8px #82eaff, 0 0 18px #d98cff;
}

.v23-mythic .v23-spark:nth-child(4n) {
  background: #ff9eea;
  box-shadow: 0 0 8px #ff9eea, 0 0 18px #82eaff;
}

@keyframes v23Ring {
  0% {
    opacity: 0;
    transform: scale(.42);
    filter: blur(5px);
  }
  18% {
    opacity: .88;
  }
  100% {
    opacity: 0;
    transform: scale(1.28);
    filter: blur(.6px);
  }
}

@keyframes v23Arc {
  0% {
    opacity: 0;
    transform: rotate(var(--rot)) scale(.70);
  }
  18% {
    opacity: .74;
  }
  100% {
    opacity: 0;
    transform: rotate(calc(var(--rot) + 58deg)) scale(1.22);
  }
}

@keyframes v23Spark {
  0% {
    opacity: 0;
    transform: translate(-50%, -50%) scale(.5);
  }
  14% {
    opacity: .95;
  }
  100% {
    opacity: 0;
    transform: translate(calc(-50% + var(--x)), calc(-50% + var(--y))) scale(.2);
  }
}

/* keep permanent card readable; reveal FX never covers text too much */
.rarity-mythic.card-single::after,
.rarity-mythic.card-inspect::after {
  opacity: .10 !important;
}

.rarity-mythic .card-holo-hover {
  opacity: .08 !important;
}

.rarity-legendary.card-single::after,
.rarity-legendary.card-inspect::after {
  opacity: .16 !important;
}


/* V24 — Mythic only: éclairs premium discrets derrière la carte */
.v23-card-fx .v23-bg-bolt {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 46%;
  height: 2px;
  transform:
    translate(calc(-50% + var(--x)), calc(-50% + var(--y)))
    rotate(var(--rot))
    scaleX(.15);
  transform-origin: center;
  border-radius: 999px;
  opacity: 0;
  z-index: -1;
  background:
    linear-gradient(
      90deg,
      transparent 0%,
      rgba(140, 230, 255, .00) 8%,
      rgba(140, 230, 255, .55) 18%,
      rgba(255, 255, 255, .95) 26%,
      rgba(216, 140, 255, .88) 38%,
      rgba(255, 255, 255, .96) 49%,
      rgba(216, 140, 255, .72) 62%,
      rgba(140, 230, 255, .45) 78%,
      transparent 100%
    );
  box-shadow:
    0 0 10px rgba(216, 140, 255, .72),
    0 0 24px rgba(140, 230, 255, .42);
  filter: blur(.2px);
  animation: v24MythicBgBolt 980ms cubic-bezier(.16,.88,.24,1) var(--delay) forwards;
}

.v23-card-fx .v23-bg-bolt::before,
.v23-card-fx .v23-bg-bolt::after {
  content: "";
  position: absolute;
  top: 50%;
  width: 38%;
  height: 2px;
  border-radius: inherit;
  background: inherit;
  box-shadow: inherit;
  opacity: .72;
}

.v23-card-fx .v23-bg-bolt::before {
  left: 28%;
  transform: translateY(-50%) rotate(24deg);
  transform-origin: left center;
}

.v23-card-fx .v23-bg-bolt::after {
  right: 18%;
  transform: translateY(-50%) rotate(-20deg);
  transform-origin: right center;
}

@keyframes v24MythicBgBolt {
  0% {
    opacity: 0;
    transform:
      translate(calc(-50% + var(--x)), calc(-50% + var(--y)))
      rotate(var(--rot))
      scaleX(.12);
  }
  14% {
    opacity: .72;
  }
  28% {
    opacity: .34;
  }
  46% {
    opacity: .58;
  }
  100% {
    opacity: 0;
    transform:
      translate(calc(-50% + var(--x)), calc(-50% + var(--y)))
      rotate(var(--rot))
      scaleX(1);
  }
}

/* Les bolts restent derrière la carte et ne bouffent pas la lisibilité */
.v23-mythic {
  z-index: 6;
}


/* ═══════════════════════════════════════════════════════
   V25 FX TUNING
   - éclairs Mythic derrière la carte, plus visibles, mieux orientés
   - Epic et Legendary plus différenciés
═══════════════════════════════════════════════════════ */

/* La carte passe au-dessus des éclairs de fond */
.single-card-wrap {
  position: relative !important;
  overflow: visible !important;
  isolation: isolate;
}

.card-single {
  position: relative !important;
  z-index: 5 !important;
}

/* Le layer FX reste autour de la carte, mais ses bolts de fond passent derrière */
.v23-card-fx {
  inset: -42% !important;
  z-index: 3 !important;
}

.v23-bg-bolt {
  z-index: 1 !important;
}

.v23-ring,
.v23-arc,
.v23-spark {
  z-index: 6;
}

/* Eclairs Mythic : derrière, plus larges, plus premium, moins "trait posé sur la carte" */
.v23-mythic .v23-bg-bolt {
  width: 62% !important;
  height: 3px !important;
  opacity: 0;
  transform:
    translate(calc(-50% + var(--x)), calc(-50% + var(--y)))
    rotate(var(--rot))
    scaleX(.08);
  background:
    linear-gradient(
      90deg,
      transparent 0%,
      rgba(130, 235, 255, 0) 7%,
      rgba(130, 235, 255, .42) 16%,
      rgba(255, 255, 255, .90) 25%,
      rgba(216, 140, 255, .98) 39%,
      rgba(255, 255, 255, .96) 50%,
      rgba(216, 140, 255, .86) 64%,
      rgba(130, 235, 255, .45) 82%,
      transparent 100%
    ) !important;
  box-shadow:
    0 0 12px rgba(216, 140, 255, .78),
    0 0 28px rgba(130, 235, 255, .45),
    0 0 44px rgba(216, 140, 255, .22) !important;
  filter: blur(.45px) saturate(1.15);
  mix-blend-mode: screen;
  animation: v25MythicBackBolt 1050ms cubic-bezier(.16,.88,.24,1) var(--delay) forwards !important;
}

.v23-mythic .v23-bg-bolt::before,
.v23-mythic .v23-bg-bolt::after {
  height: 3px !important;
  opacity: .78 !important;
}

@keyframes v25MythicBackBolt {
  0% {
    opacity: 0;
    transform:
      translate(calc(-50% + var(--x)), calc(-50% + var(--y)))
      rotate(var(--rot))
      scaleX(.10);
  }
  12% { opacity: .72; }
  24% { opacity: .36; }
  38% { opacity: .62; }
  72% { opacity: .28; }
  100% {
    opacity: 0;
    transform:
      translate(calc(-50% + var(--x)), calc(-50% + var(--y)))
      rotate(var(--rot))
      scaleX(1.18);
  }
}

/* Mythic : moins de voile devant la carte */
.v23-mythic .v23-arc {
  opacity: .82;
}

.v23-mythic .v23-spark {
  opacity: .92;
}

/* Epic = violet propre, plus sobre, un seul anneau/arc */
.v23-epic .v23-ring {
  border-color: rgba(184, 109, 255, .50) !important;
  box-shadow:
    0 0 16px rgba(184, 109, 255, .35),
    inset 0 0 14px rgba(184, 109, 255, .18) !important;
  animation-duration: 720ms !important;
}

.v23-epic .v23-arc {
  opacity: .55 !important;
  filter: drop-shadow(0 0 8px rgba(184, 109, 255, .65)) !important;
}

.v23-epic .v23-spark {
  box-shadow:
    0 0 8px rgba(184, 109, 255, .8),
    0 0 14px rgba(184, 109, 255, .45) !important;
}

/* Legendary = identité braise/orange, pas "Epic plus fort" */
.v23-legendary .v23-ring {
  border-color: rgba(255, 141, 71, .64) !important;
  box-shadow:
    0 0 24px rgba(255, 95, 45, .45),
    inset 0 0 18px rgba(255, 141, 71, .25) !important;
}

.v23-legendary .v23-arc {
  background:
    conic-gradient(
      from 0deg,
      transparent 0deg,
      transparent 24deg,
      rgba(255, 95, 45, .60) 42deg,
      rgba(255, 236, 190, .95) 48deg,
      rgba(255, 141, 71, .78) 58deg,
      transparent 82deg,
      transparent 360deg
    ) !important;
  filter:
    blur(.10px)
    drop-shadow(0 0 10px rgba(255, 95, 45, .8))
    drop-shadow(0 0 18px rgba(255, 141, 71, .32)) !important;
}

.v23-legendary .v23-spark {
  background: #ffb061 !important;
  box-shadow:
    0 0 8px #ffd0a0,
    0 0 16px rgba(255, 95, 45, .75),
    0 0 24px rgba(255, 141, 71, .40) !important;
  animation-duration: 1050ms !important;
}

/* Plus de petites braises Legendary vers le bas */
.v23-legendary .v23-spark:nth-child(odd) {
  filter: blur(.25px);
}


/* ═══════════════════════════════════════════════════════
   V26 MYTHIC PREMIUM BOLTS
   Objectif : éclairs derrière la carte, organiques, visibles,
   sans lignes droites qui traversent la carte.
═══════════════════════════════════════════════════════ */

/* Désactive les anciens traits droits V24/V25 */
.v23-bg-bolt {
  display: none !important;
}

/* Le layer FX respire mieux mais reste centré sur la carte */
.v23-card-fx {
  inset: -48% !important;
  z-index: 3 !important;
}

/* Carte au-dessus de tous les éclairs de fond */
.card-single {
  position: relative !important;
  z-index: 8 !important;
}

/* SVG d'éclairs uniquement Mythic, derrière la carte */
.v26-mythic-bolts {
  position: absolute;
  inset: -8%;
  width: 116%;
  height: 116%;
  z-index: 1;
  overflow: visible;
  pointer-events: none;
  opacity: .98;
  filter: saturate(1.14) contrast(1.08);
}

/* Halo large, doux, premium */
.v26-bolt-glow {
  fill: none;
  stroke: rgba(196, 118, 255, .95);
  stroke-width: 2.8;
  stroke-linecap: round;
  stroke-linejoin: round;
  opacity: 0;
  filter:
    drop-shadow(0 0 7px rgba(216, 140, 255, .95))
    drop-shadow(0 0 16px rgba(130, 235, 255, .48))
    drop-shadow(0 0 28px rgba(216, 140, 255, .28));
  stroke-dasharray: 34 90;
  stroke-dashoffset: 120;
  animation: v26BoltReveal 1150ms cubic-bezier(.16,.88,.24,1) var(--delay) forwards;
}

/* Coeur fin et blanc/bleuté, pas cartoon */
.v26-bolt-core {
  fill: none;
  stroke: rgba(255,255,255,.92);
  stroke-width: .55;
  stroke-linecap: round;
  stroke-linejoin: round;
  opacity: 0;
  filter: drop-shadow(0 0 5px rgba(160, 235, 255, .72));
  stroke-dasharray: 26 110;
  stroke-dashoffset: 110;
  animation: v26BoltCore 980ms cubic-bezier(.16,.88,.24,1) var(--delay) forwards;
}

@keyframes v26BoltReveal {
  0% {
    opacity: 0;
    stroke-dashoffset: 120;
  }
  12% {
    opacity: .82;
  }
  24% {
    opacity: .38;
  }
  40% {
    opacity: .68;
  }
  68% {
    opacity: .24;
  }
  100% {
    opacity: 0;
    stroke-dashoffset: 0;
  }
}

@keyframes v26BoltCore {
  0% {
    opacity: 0;
    stroke-dashoffset: 110;
  }
  10% {
    opacity: .96;
  }
  22% {
    opacity: .28;
  }
  36% {
    opacity: .80;
  }
  100% {
    opacity: 0;
    stroke-dashoffset: 0;
  }
}

/* Mythic : un peu moins de voile devant, plus de bord lumineux */
.rarity-mythic.card-single::after,
.rarity-mythic.card-inspect::after {
  opacity: .08 !important;
}

.rarity-mythic .card-holo-hover {
  opacity: .06 !important;
}

.rarity-mythic .card-border {
  box-shadow:
    inset 0 0 22px rgba(216, 140, 255, .18),
    0 0 22px rgba(216, 140, 255, .30),
    0 0 44px rgba(130, 235, 255, .14) !important;
}

/* Epic encore plus distinct : plus calme, moins de gros halo */
.v23-epic .v23-ring {
  opacity: .72 !important;
  transform: scale(.86);
}

.v23-epic .v23-arc {
  opacity: .38 !important;
}

.v23-epic .v23-spark {
  opacity: .72 !important;
}

/* Legendary : plus braises, moins violet/arc */
.v23-legendary .v23-ring {
  transform: scale(.95);
}

.v23-legendary .v23-spark {
  background: #ff9a3d !important;
}


/* ═══════════════════════════════════════════════════════
   V27 ORBITAL SUMMON FX
   Mythic: plus d'éclairs latéraux. Energie orbitale derrière la carte.
═══════════════════════════════════════════════════════ */

.v26-mythic-bolts,
.v26-bolt-glow,
.v26-bolt-core,
.v23-bg-bolt {
  display: none !important;
}

.v23-card-fx {
  inset: -46% !important;
  z-index: 3 !important;
}

.card-single {
  position: relative !important;
  z-index: 9 !important;
}

/* Layer orbital derrière la carte */
.v27-mythic-orbit {
  position: absolute;
  inset: 4%;
  z-index: 1;
  pointer-events: none;
  border-radius: 999px;
  opacity: 1;
  filter: saturate(1.12) contrast(1.05);
}

/* Arcs orbitaux : fragments courbes autour de la carte, pas lignes latérales */
.v27-orbit-arc {
  position: absolute;
  inset: 0;
  border-radius: 999px;
  transform: rotate(var(--rot)) scale(var(--scale));
  opacity: 0;
  background:
    conic-gradient(
      from 0deg,
      transparent 0deg,
      transparent 16deg,
      rgba(116, 226, 255, .00) 24deg,
      rgba(116, 226, 255, .45) 34deg,
      rgba(255,255,255,.86) 40deg,
      rgba(216,140,255,.92) 48deg,
      rgba(255,255,255,.74) 55deg,
      rgba(216,140,255,.32) 68deg,
      transparent 84deg,
      transparent 360deg
    );
  mask:
    radial-gradient(
      ellipse at center,
      transparent 0%,
      transparent 56%,
      #000 59%,
      #000 62%,
      transparent 66%
    );
  filter:
    blur(.15px)
    drop-shadow(0 0 8px rgba(216,140,255,.70))
    drop-shadow(0 0 18px rgba(116,226,255,.32));
  animation: v27OrbitArc 1180ms cubic-bezier(.16,.88,.24,1) var(--delay) forwards;
}

/* Strikes verticaux/diagonaux courts qui "summon" depuis le bas/arrière */
.v27-summon-strike {
  position: absolute;
  left: calc(50% + var(--x));
  bottom: 8%;
  width: 2px;
  height: 38%;
  transform: rotate(var(--rot)) scaleY(.08);
  transform-origin: bottom center;
  opacity: 0;
  border-radius: 999px;
  background:
    linear-gradient(
      0deg,
      transparent 0%,
      rgba(216,140,255,.18) 14%,
      rgba(116,226,255,.46) 34%,
      rgba(255,255,255,.92) 52%,
      rgba(216,140,255,.70) 68%,
      transparent 100%
    );
  box-shadow:
    0 0 8px rgba(216,140,255,.78),
    0 0 20px rgba(116,226,255,.34);
  filter: blur(.25px);
  animation: v27SummonStrike 860ms cubic-bezier(.16,.88,.24,1) var(--delay) forwards;
}

.v27-summon-strike::before,
.v27-summon-strike::after {
  content: "";
  position: absolute;
  width: 2px;
  height: 34%;
  left: 0;
  top: 34%;
  border-radius: 999px;
  background: inherit;
  box-shadow: inherit;
  opacity: .55;
}

.v27-summon-strike::before {
  transform-origin: top center;
  transform: rotate(24deg);
}

.v27-summon-strike::after {
  transform-origin: bottom center;
  transform: rotate(-20deg);
}

/* petit flash derrière la carte, seulement Mythic */
.v23-mythic::before {
  content: "";
  position: absolute;
  inset: 18%;
  z-index: 0;
  border-radius: 999px;
  background:
    radial-gradient(circle, rgba(255,255,255,.22), rgba(216,140,255,.18) 24%, rgba(116,226,255,.10) 45%, transparent 70%);
  opacity: 0;
  filter: blur(14px);
  animation: v27BackPulse 1150ms ease-out 90ms forwards;
}

@keyframes v27OrbitArc {
  0% {
    opacity: 0;
    transform: rotate(var(--rot)) scale(.82);
  }
  13% { opacity: .78; }
  28% { opacity: .36; }
  48% { opacity: .56; }
  100% {
    opacity: 0;
    transform: rotate(calc(var(--rot) + 74deg)) scale(1.08);
  }
}

@keyframes v27SummonStrike {
  0% {
    opacity: 0;
    transform: rotate(var(--rot)) scaleY(.06) translateY(24px);
  }
  14% {
    opacity: .78;
  }
  34% {
    opacity: .28;
  }
  52% {
    opacity: .62;
  }
  100% {
    opacity: 0;
    transform: rotate(var(--rot)) scaleY(1) translateY(-18px);
  }
}

@keyframes v27BackPulse {
  0% {
    opacity: 0;
    transform: scale(.65);
  }
  18% {
    opacity: .86;
  }
  100% {
    opacity: 0;
    transform: scale(1.28);
  }
}

/* Mythic : garder lisible, les effets sont derrière */
.v23-mythic .v23-arc {
  opacity: .62 !important;
}

.v23-mythic .v23-spark {
  opacity: .82 !important;
}

/* Epic encore discret, Legendary clairement braise */
.v23-epic .v23-arc {
  opacity: .30 !important;
}

.v23-epic .v23-ring {
  opacity: .62 !important;
}

.v23-legendary .v23-arc {
  opacity: .72 !important;
  background:
    conic-gradient(
      from 0deg,
      transparent 0deg,
      transparent 24deg,
      rgba(255,95,45,.55) 42deg,
      rgba(255,230,190,.92) 50deg,
      rgba(255,141,71,.72) 60deg,
      transparent 88deg,
      transparent 360deg
    ) !important;
}
