

/* ===== style.css ===== */

/* ═══════════════════════════════════════════════
   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,.08) 0%, transparent 100%),
    radial-gradient(1px 1px at 30% 45%, rgba(255,255,255,.08) 0%, transparent 100%),
    radial-gradient(1px 1px at 55% 25%, rgba(255,255,255,.08) 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,.08) 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,.08) 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,.08));
  -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,.08);
}
.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,.08); 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,.08);
}
.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,.08);
}

/* 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,.08); 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,.08) 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,.08);
}
.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,.08); }

/* 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,.08);
}
.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,.08); }

.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,.08);
}

/* ── 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,.08);
  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,.08));
  -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,.08); 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,.08);
  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,.08)}
.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,.08);
  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,.08);
  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,.08);
}

.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,.08);
  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,.08);
  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,.08);
  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,.08);
  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,.08);
  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,.08);
  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,.08);
  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,.08);
  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,.08);
  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,.08);
  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,.08); 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,.08); 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,.08);
  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,.08);
  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,.08); 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,.08);
  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,.08); 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,.08);
  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,.08);
  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,.08); }

.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,.08);
  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,.08);
  font-weight: 900;
  text-transform: uppercase;
}

.empty-pulls-state-v9 {
  padding: 20px;
  color: rgba(255,255,255,.08);
  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;
}



/* ═══════════════════════════════════════════════════════
   V31 — FX SYSTEM (3 couches, 0 bruit)
   1. Canvas background  : bloom + shock rings + particules
   2. DOM strikes        : traits depuis le BORD vers l'extérieur
   3. Flash plein écran  : fixed, instantané, coloré
═══════════════════════════════════════════════════════ */

/* ── Canvas background ─────────────────────────────── */
.v31-canvas {
  position: fixed;
  pointer-events: none;
  z-index: 50;
  mix-blend-mode: screen;
  opacity: 0;
  transition: opacity .08s;
}

/* ── Conteneur strikes (ancré sur la carte) ─────────── */
.v31-strikes {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 20;
  overflow: visible;
}

/* Chaque strike part du bord de la carte vers l'extérieur */
.v31-strike {
  position: absolute;
  left: 50%;
  top: 50%;
  width: var(--len, 120px);
  height: var(--w, 2.5px);
  border-radius: 99px;

  /* transform-origin au CENTRE GAUCHE = part du centre carte, file vers l'extérieur */
  transform-origin: left center;
  transform:
    translate(var(--ox, 0px), var(--oy, 0px))
    rotate(var(--rot, 0deg))
    scaleX(0);

  background: linear-gradient(
    90deg,
    rgba(255,255,255,0)   0%,
    var(--c2, rgba(255,255,255,.08)) 15%,
    white                 42%,
    white                 58%,
    var(--c2, rgba(255,255,255,.08)) 85%,
    rgba(255,255,255,0)   100%
  );
  box-shadow:
    0 0 5px  2px var(--glow),
    0 0 12px 3px var(--glow),
    0 0 28px 5px color-mix(in srgb, var(--glow) 50%, transparent);

  opacity: 0;
  animation: v31Strike var(--dur, .42s) cubic-bezier(.06,.94,.18,1) var(--delay, 0s) forwards;
}

/* Halo flou derrière chaque strike */
.v31-strike::after {
  content: '';
  position: absolute;
  inset: -5px 0;
  border-radius: 99px;
  background: inherit;
  filter: blur(6px);
  opacity: .45;
}

/* Branche secondaire (effet crackle) */
.v31-strike::before {
  content: '';
  position: absolute;
  right: 20%;
  top: 50%;
  width: 36%;
  height: var(--w, 2.5px);
  border-radius: 99px;
  background: inherit;
  transform-origin: left center;
  transform: translateY(-50%) rotate(var(--branch-rot, 28deg));
  opacity: .55;
}

@keyframes v31Strike {
  0%   { opacity: 0;   transform: translate(var(--ox), var(--oy)) rotate(var(--rot)) scaleX(0); }
  6%   { opacity: 1;   transform: translate(var(--ox), var(--oy)) rotate(var(--rot)) scaleX(1.06); }
  22%  { opacity: .85; transform: translate(var(--ox), var(--oy)) rotate(var(--rot)) scaleX(.96); }
  100% { opacity: 0;   transform: translate(var(--ox), var(--oy)) rotate(var(--rot)) scaleX(1.18); }
}

/* ── Flash plein écran ──────────────────────────────── */
.v31-flash {
  position: fixed;
  inset: 0;
  z-index: 9999;
  pointer-events: none;
  opacity: 0;
  background: white;
}

/* Rare : 1 flash rapide */
.v31-flash.rare {
  animation: v31FlashRare .36s ease-out forwards;
}
/* Epic : 1 flash violet + rebond */
.v31-flash.epic {
  background: radial-gradient(ellipse at center, #e8d0ff 0%, white 45%);
  animation: v31FlashDouble .52s ease-out forwards;
}
/* Legendary : flash chaud double */
.v31-flash.legendary {
  background: radial-gradient(ellipse at center, #fff0d0 0%, white 45%);
  animation: v31FlashDouble .68s ease-out forwards;
}
/* Mythic : triple flash prismé */
.v31-flash.mythic {
  animation: v31FlashMythic .95s ease-out forwards;
}

@keyframes v31FlashRare {
  0%   { opacity: .60; }
  100% { opacity: 0; }
}
@keyframes v31FlashDouble {
  0%   { opacity: .80; }
  20%  { opacity: .06; }
  38%  { opacity: .52; }
  100% { opacity: 0; }
}
@keyframes v31FlashMythic {
  0%   { opacity: 1;   background: white; }
  10%  { opacity: .04; }
  24%  { opacity: .75; background: #f0e0ff; }
  38%  { opacity: .02; }
  55%  { opacity: .42; background: #d0f0ff; }
  100% { opacity: 0; }
}

/* ── Shake + punch de la carte ─────────────────────── */
.single-card-wrap.v31-shake {
  animation: v31Shake var(--shake-dur, .40s) ease forwards;
}
.card-flip-shell.v31-punch {
  animation: v31Punch var(--punch-dur, .35s) cubic-bezier(.1,.9,.2,1) forwards;
}

@keyframes v31Shake {
  0%,100% { transform: translate(0,0) scale(1) rotate(0); }
  10% { transform: translate(var(--sx1, -10px), var(--sy1, 4px)) scale(var(--ss, 1.020)) rotate(var(--sr, -.3deg)); }
  24% { transform: translate(calc(var(--sx1)*-1), calc(var(--sy1)*-1)) scale(var(--ss)) rotate(calc(var(--sr)*-1)); }
  40% { transform: translate(calc(var(--sx1)*.7), calc(var(--sy1)*.7)) scale(calc((var(--ss) - 1)*.6 + 1)); }
  58% { transform: translate(calc(var(--sx1)*-.5), calc(var(--sy1)*.5)) scale(calc((var(--ss) - 1)*.3 + 1)); }
  75% { transform: translate(calc(var(--sx1)*.25), 0) scale(1.002); }
}

@keyframes v31Punch {
  0%   { transform: rotateY(180deg) scale(var(--punch-start, .82)); }
  28%  { transform: rotateY(180deg) scale(var(--punch-peak,  1.10)); }
  62%  { transform: rotateY(180deg) scale(.99); }
  100% { transform: rotateY(180deg) scale(1); }
}

/* ── Orbit Mythic — pleine intensité ───────────────── */
.v27-mythic-orbit {
  opacity: .88 !important;
  filter: saturate(1.15) contrast(1.05) !important;
}
.v27-orbit-arc {
  opacity: .72 !important;
  animation-duration: 820ms !important;
}
.v27-summon-strike {
  opacity: .68 !important;
  height: 42% !important;
}

/* Rings et sparks V23 : désactivés, remplacés par canvas V31 */
.v23-ring   { display: none !important; }
.v23-arc    { display: none !important; }
.v23-spark  { display: none !important; }

/* Conteneur FX : juste pour l'orbit Mythic */
.v23-card-fx {
  position: absolute;
  inset: -28%;
  z-index: 4;
  pointer-events: none;
  overflow: visible;
  mix-blend-mode: screen;
}
.v23-card-fx.v23-fade {
  opacity: 0;
  transform: scale(1.04);
  transition: opacity .6s ease, transform .6s ease;
}

/* Mythic : orbit devant, card lisible */
.card-single {
  position: relative !important;
  z-index: 8 !important;
}
.single-card-wrap {
  position: relative !important;
  overflow: visible !important;
  isolation: isolate;
}


/* V31 FIX CRITICAL HIDDEN */
.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;
}


/* ═══════════════════════════════════════════════════════
   V32 — No White Flash + Premium Micro Bolts
   - Epic/Legendary: suppression du flash blanc agressif
   - conserve l'impact V31
   - ajoute petits arcs/éclairs premium en soutien
═══════════════════════════════════════════════════════ */

/* Réduction drastique du flash blanc fullscreen sur Epic/Legendary */
.v31-screen-flash.epic,
.v31-screen-flash.legendary,
.screen-flash.epic,
.screen-flash.legendary,
.fx-screen-flash.epic,
.fx-screen-flash.legendary,
.v31-flash.epic,
.v31-flash.legendary {
  background:
    radial-gradient(circle at center,
      color-mix(in srgb, var(--fx-color, #b86dff) 26%, transparent) 0%,
      color-mix(in srgb, var(--fx-color, #b86dff) 13%, transparent) 28%,
      transparent 62%) !important;
  opacity: .18 !important;
  mix-blend-mode: screen !important;
}

/* Si Claude utilise une classe générique sur body/app pendant le reveal */
body.rarity-epic .v31-screen-flash,
body.rarity-legendary .v31-screen-flash,
.app.rarity-epic .v31-screen-flash,
.app.rarity-legendary .v31-screen-flash {
  background: transparent !important;
  opacity: .12 !important;
}

/* Les impacts DOM V28/V31 restent colorés, mais pas blancs */
.v28-impact-epic .v28-flash,
.v31-impact-epic .v31-flash,
.v31-epic .v31-flash {
  background:
    radial-gradient(circle,
      rgba(184,109,255,.44) 0%,
      rgba(158,99,255,.25) 22%,
      rgba(158,99,255,.10) 42%,
      transparent 70%) !important;
  opacity: .46 !important;
}

.v28-impact-legendary .v28-flash,
.v31-impact-legendary .v31-flash,
.v31-legendary .v31-flash {
  background:
    radial-gradient(circle,
      rgba(255,141,71,.55) 0%,
      rgba(255,95,45,.32) 22%,
      rgba(255,141,71,.12) 42%,
      transparent 70%) !important;
  opacity: .58 !important;
}

/* Micro FX layer: derrière les gros impacts mais devant le bloom */
.v32-micro-fx {
  position: absolute;
  inset: -18%;
  z-index: 3;
  pointer-events: none;
  border-radius: 999px;
  mix-blend-mode: screen;
}

.v32-micro-arc {
  position: absolute;
  inset: 10%;
  border-radius: 999px;
  transform: rotate(var(--rot)) scale(var(--scale));
  opacity: 0;
  background:
    conic-gradient(
      from 0deg,
      transparent 0deg,
      transparent 20deg,
      color-mix(in srgb, var(--fx-color) 55%, transparent) 34deg,
      rgba(255,255,255,.08) 42deg,
      color-mix(in srgb, var(--fx-color) 70%, white 10%) 48deg,
      color-mix(in srgb, var(--fx-color) 32%, transparent) 60deg,
      transparent 78deg,
      transparent 360deg
    );
  mask:
    radial-gradient(
      ellipse at center,
      transparent 0%,
      transparent 58%,
      black 60%,
      black 63%,
      transparent 66%
    );
  filter:
    blur(.12px)
    drop-shadow(0 0 7px var(--fx-color))
    drop-shadow(0 0 14px color-mix(in srgb, var(--fx-color) 50%, transparent));
  animation: v32MicroArc 920ms cubic-bezier(.16,.88,.24,1) var(--delay) forwards;
}

.v32-energy-tick {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 2px;
  height: 13%;
  border-radius: 999px;
  transform:
    rotate(var(--rot))
    translateY(calc(-1 * var(--dist)))
    scaleY(.12);
  transform-origin: center bottom;
  opacity: 0;
  background:
    linear-gradient(
      180deg,
      transparent,
      rgba(255,255,255,.08),
      var(--fx-color),
      transparent
    );
  box-shadow:
    0 0 6px rgba(255,255,255,.08),
    0 0 14px var(--fx-color);
  animation: v32EnergyTick 760ms cubic-bezier(.16,.88,.24,1) var(--delay) forwards;
}

/* Couleurs par rareté */
.v32-epic {
  --fx-color: #9e63ff;
}
.v32-legendary {
  --fx-color: #ff8d47;
}
.v32-mythic {
  --fx-color: #d98cff;
}

.v32-legendary .v32-energy-tick {
  background:
    linear-gradient(180deg, transparent, rgba(255,238,190,.78), #ff8d47, transparent);
  box-shadow:
    0 0 7px rgba(255,220,180,.55),
    0 0 16px rgba(255,95,45,.72);
}

.v32-mythic .v32-energy-tick:nth-child(3n) {
  --fx-color: #74e2ff;
}

@keyframes v32MicroArc {
  0% {
    opacity: 0;
    transform: rotate(var(--rot)) scale(.72);
  }
  16% {
    opacity: .58;
  }
  42% {
    opacity: .22;
  }
  100% {
    opacity: 0;
    transform: rotate(calc(var(--rot) + 46deg)) scale(1.12);
  }
}

@keyframes v32EnergyTick {
  0% {
    opacity: 0;
    transform:
      rotate(var(--rot))
      translateY(calc(-1 * var(--dist)))
      scaleY(.12);
  }
  18% {
    opacity: .68;
  }
  54% {
    opacity: .34;
  }
  100% {
    opacity: 0;
    transform:
      rotate(var(--rot))
      translateY(calc(-1 * var(--dist)))
      scaleY(1.0);
  }
}

/* Epic ne doit pas devenir jackpot */
.v32-epic .v32-micro-arc {
  opacity: .70;
  animation-duration: 760ms;
}
.v32-epic .v32-energy-tick {
  opacity: .70;
  height: 10%;
}

/* Legendary garde plus de présence */
.v32-legendary .v32-micro-arc {
  filter:
    blur(.12px)
    drop-shadow(0 0 8px rgba(255,141,71,.82))
    drop-shadow(0 0 18px rgba(255,95,45,.34));
}

/* Mythic reste au-dessus */
.v32-mythic .v32-micro-arc {
  filter:
    blur(.10px)
    drop-shadow(0 0 8px rgba(216,140,255,.82))
    drop-shadow(0 0 18px rgba(116,226,255,.42));
}


/* ═══════════════════════════════════════════════════════
   V33 — Booster image séparée + animation d'ouverture
   - Le booster peut avoir son propre visuel.
   - Les dos de cartes gardent leur image séparée.
   - Petite ouverture: shake, tear, burst, shards.
═══════════════════════════════════════════════════════ */

.booster-pack {
  isolation: isolate;
}

.booster-pack.has-pack-image {
  background:
    radial-gradient(circle at 50% 12%, rgba(255,255,255,.12), transparent 34%),
    linear-gradient(145deg, rgba(255,255,255,.08), rgba(255,255,255,.02)) !important;
  border: 1px solid rgba(245,200,66,.38);
  box-shadow:
    0 30px 80px rgba(0,0,0,.48),
    0 0 42px rgba(184,109,255,.16),
    inset 0 0 0 1px rgba(255,255,255,.08);
}

.pack-art-img {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: inherit;
  pointer-events: none;
  transform: scale(1.012);
  filter: saturate(1.04) contrast(1.04);
}

.booster-pack.has-pack-image .pack-content {
  opacity: 0;
  visibility: hidden;
}

.booster-pack.has-pack-image .pack-shine {
  z-index: 2;
  opacity: .55;
}

.pack-tear-line {
  position: absolute;
  left: 5%;
  right: 5%;
  top: 11.5%;
  height: 2px;
  z-index: 3;
  opacity: 0;
  pointer-events: none;
  background:
    linear-gradient(90deg,
      transparent,
      rgba(255,255,255,.22),
      rgba(245,200,66,.88),
      rgba(255,255,255,.22),
      transparent);
  box-shadow:
    0 0 10px rgba(245,200,66,.55),
    0 0 22px rgba(184,109,255,.34);
}

.v33-pack-opening {
  animation: v33PackRip 980ms cubic-bezier(.13,.9,.2,1) forwards !important;
}

.v33-pack-opening .pack-art-img {
  animation: v33FoilCrunch 980ms cubic-bezier(.13,.9,.2,1) forwards;
}

.v33-pack-opening .pack-tear-line {
  animation: v33TearLine 620ms ease-out 70ms forwards;
}

.v33-pack-burst {
  position: absolute;
  inset: 0;
  z-index: 6;
  pointer-events: none;
  border-radius: inherit;
  overflow: visible;
}

.v33-pack-burst::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 13%;
  width: 72%;
  aspect-ratio: 1 / .38;
  transform: translate(-50%, -50%) scale(.4);
  border-radius: 999px;
  opacity: 0;
  background:
    radial-gradient(ellipse,
      rgba(255,255,255,.08),
      rgba(245,200,66,.48) 20%,
      rgba(184,109,255,.24) 48%,
      transparent 72%);
  filter: blur(8px);
  animation: v33PackFlash 520ms ease-out 90ms forwards;
}

.v33-pack-shard {
  position: absolute;
  left: 50%;
  top: 13%;
  width: 8px;
  height: 28px;
  border-radius: 2px;
  opacity: 0;
  transform: translate(-50%, -50%) rotate(var(--rot));
  background:
    linear-gradient(135deg,
      rgba(245,200,66,.95),
      rgba(255,255,255,.08),
      rgba(80,32,104,.82));
  box-shadow:
    0 0 8px rgba(245,200,66,.42),
    0 0 14px rgba(184,109,255,.22);
  animation: v33ShardFly 780ms cubic-bezier(.12,.84,.2,1) var(--delay) forwards;
}

@keyframes v33PackRip {
  0% {
    transform: translateY(0) scale(1) rotateX(0deg);
    filter: brightness(1) saturate(1);
  }
  12% { transform: translateY(-2px) scale(1.018) rotateZ(-.55deg); }
  20% { transform: translateY(2px) scale(1.02) rotateZ(.65deg); }
  34% {
    transform: translateY(-8px) scale(1.045) rotateZ(-.25deg);
    filter: brightness(1.38) saturate(1.16);
  }
  58% {
    transform: translateY(-4px) scale(.96) rotateZ(.25deg);
    filter: brightness(1.05) saturate(1.06);
  }
  100% {
    transform: translateY(24px) scale(.78) rotateX(12deg);
    opacity: 0;
    filter: brightness(.7) blur(2px);
  }
}

@keyframes v33FoilCrunch {
  0%, 100% { clip-path: inset(0 0 0 0); }
  28% { clip-path: polygon(0 0,100% 0,100% 100%,0 100%); }
  48% { clip-path: polygon(0 0,100% 0,96% 100%,3% 100%); }
}

@keyframes v33TearLine {
  0% { opacity: 0; transform: scaleX(.16); }
  24% { opacity: 1; transform: scaleX(1); }
  100% { opacity: 0; transform: scaleX(1.08) translateY(-16px); }
}

@keyframes v33PackFlash {
  0% { opacity: 0; transform: translate(-50%, -50%) scale(.36); }
  26% { opacity: 1; transform: translate(-50%, -50%) scale(.92); }
  100% { opacity: 0; transform: translate(-50%, -50%) scale(1.45); }
}

@keyframes v33ShardFly {
  0% {
    opacity: 0;
    transform: translate(-50%, -50%) rotate(var(--rot)) scale(.4);
  }
  15% { opacity: .92; }
  100% {
    opacity: 0;
    transform:
      translate(calc(-50% + var(--x)), calc(-50% + var(--y)))
      rotate(calc(var(--rot) + 220deg))
      scale(.84);
  }
}

/* Pendant l'ouverture du booster, on prépare l'écran reveal derrière */
#boosterView:has(.v33-pack-opening) {
  filter: saturate(1.08);
}


/* ═══════════════════════════════════════════════════════
   V34 — Admin image booster séparée + rendu pack corrigé
═══════════════════════════════════════════════════════ */

.booster-pack.has-pack-image {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
}

.booster-pack.has-pack-image .pack-art-img {
  object-fit: contain !important;
  transform: none !important;
  filter:
    drop-shadow(0 30px 42px rgba(0,0,0,.48))
    drop-shadow(0 0 34px rgba(184,109,255,.22)) !important;
}

.booster-pack.has-pack-image .pack-shine {
  border-radius: 24px;
  opacity: .24 !important;
}

.booster-assets-grid-v34 {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  margin-top: 12px;
}

.booster-asset-card-v34 {
  padding: 14px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 18px;
  background: rgba(255,255,255,.04);
}

.booster-asset-card-v34 h4 {
  margin: 0 0 10px;
  font-size: 14px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(255,255,255,.08);
}

.booster-pack-preview-v34 {
  width: 160px;
  height: 230px;
  margin: 12px auto;
  display: grid;
  place-items: center;
  border-radius: 18px;
  border: 1px solid rgba(245,200,66,.28);
  color: rgba(255,255,255,.08);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  background-color: rgba(0,0,0,.24);
}

.booster-back-preview-v9 {
  background-size: cover !important;
  background-position: center !important;
}

@media (max-width: 820px) {
  .booster-assets-grid-v34 {
    grid-template-columns: 1fr;
  }
}


/* ═══════════════════════════════════════════════
V35 CLEAN BOOSTER OPENING
═══════════════════════════════════════════════ */

.booster-pack {
  transform-origin: center center;
  transition: transform .35s ease, filter .35s ease, opacity .35s ease;
  will-change: transform, opacity;
}

.booster-pack.opening {
  animation: boosterShakeV35 .42s ease-in-out 1,
             boosterRipV35 .72s cubic-bezier(.2,.8,.2,1) .34s forwards;
}

.booster-pack.opening::before {
  content:'';
  position:absolute;
  inset:-10%;
  background:
    radial-gradient(circle at 50% 22%, rgba(255,255,255,.08), rgba(255,255,255,.18) 18%, transparent 46%);
  opacity:0;
  animation: boosterFlashV35 .8s ease-out .36s forwards;
  pointer-events:none;
}

.booster-pack.opening::after {
  content:'';
  position:absolute;
  left:8%;
  right:8%;
  top:18%;
  height:2px;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.08), transparent);
  box-shadow:0 0 16px rgba(255,255,255,.08);
  opacity:0;
  animation: boosterTearLineV35 .36s ease .42s forwards;
  pointer-events:none;
}

@keyframes boosterShakeV35 {
  0% { transform: translateY(0) rotate(0deg) scale(1); }
  20% { transform: translateX(-2px) rotate(-1deg) scale(1.01); }
  40% { transform: translateX(2px) rotate(1deg) scale(1.01); }
  60% { transform: translateX(-2px) rotate(-1deg) scale(1.015); }
  100% { transform: translateX(0) rotate(0deg) scale(1.02); }
}

@keyframes boosterFlashV35 {
  0% { opacity:0; transform:scale(.6); }
  35% { opacity:1; transform:scale(1); }
  100% { opacity:0; transform:scale(1.25); }
}

@keyframes boosterTearLineV35 {
  0% { opacity:0; transform:scaleX(.1); }
  100% { opacity:1; transform:scaleX(1); }
}

@keyframes boosterRipV35 {
  0% {
    transform: translateY(0) scale(1.02);
    opacity:1;
    filter:brightness(1);
  }
  55% {
    transform: translateY(-18px) scale(1.06);
    opacity:1;
    filter:brightness(1.18);
  }
  100% {
    transform: translateY(-58px) scale(.92);
    opacity:0;
    filter:brightness(1.6) blur(1px);
  }
}

/* cards reveal cleaner */
.cards-stage.reveal,
.cards-container.reveal,
.reveal-cards {
  animation: cardsFadeInV35 .45s ease-out both;
}

@keyframes cardsFadeInV35 {
  from { opacity:0; transform:translateY(18px) scale(.98); }
  to { opacity:1; transform:translateY(0) scale(1); }
}


/* ═══════════════════════════════════════════════════════
   V36 FULL OPENING REWORK
   Clone pack -> tear -> glow -> 5 cartes en éventail -> reveal.
═══════════════════════════════════════════════════════ */

#boosterView { position: relative; }

.v36-real-pack-hidden {
  opacity: 0 !important;
  pointer-events: none !important;
}

.v36-opening-stage {
  position: fixed;
  inset: 0;
  z-index: 80;
  display: none;
  place-items: center;
  pointer-events: none;
  overflow: hidden;
}

.v36-opening-stage.is-active { display: grid; }

.v36-opening-stage::before {
  content: "";
  position: absolute;
  inset: 0;
  opacity: 0;
  background:
    radial-gradient(circle at 50% 45%, rgba(184,109,255,.22), transparent 34%),
    radial-gradient(circle at 50% 55%, rgba(245,200,66,.12), transparent 28%);
  animation: v36StageBloom 1700ms ease-out forwards;
}

.v36-opening-stage.is-leaving {
  animation: v36StageLeave 280ms ease-in forwards;
}

.v36-cinematic {
  position: relative;
  width: min(420px, 76vw);
  height: min(560px, 78vh);
  display: grid;
  place-items: center;
  perspective: 1000px;
  transform: translateY(-18px);
}

.v36-pack-clone {
  position: absolute;
  width: min(260px, 48vw);
  height: min(390px, 62vh);
  display: grid;
  place-items: center;
  transform-origin: 50% 58%;
  animation:
    v36PackEnter 360ms cubic-bezier(.16,.9,.22,1) both,
    v36PackTension 520ms ease-in-out 360ms both,
    v36PackOpen 900ms cubic-bezier(.13,.85,.18,1) 880ms forwards;
  z-index: 4;
}

.v36-pack-clone img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  filter:
    drop-shadow(0 28px 38px rgba(0,0,0,.52))
    drop-shadow(0 0 24px rgba(184,109,255,.22));
}

.v36-tear {
  position: absolute;
  top: 21%;
  left: 50%;
  width: min(210px, 42vw);
  height: 3px;
  transform: translateX(-50%) scaleX(.05);
  opacity: 0;
  z-index: 8;
  background:
    linear-gradient(90deg,
      transparent,
      rgba(255,255,255,.08) 24%,
      rgba(245,200,66,.98) 50%,
      rgba(255,255,255,.08) 76%,
      transparent);
  box-shadow:
    0 0 12px rgba(255,255,255,.08),
    0 0 28px rgba(184,109,255,.48);
  animation: v36Tear 620ms cubic-bezier(.16,.9,.2,1) 720ms forwards;
}

.v36-inner-glow {
  position: absolute;
  top: 33%;
  left: 50%;
  width: min(280px, 58vw);
  height: min(190px, 30vh);
  transform: translate(-50%, -50%) scale(.35);
  border-radius: 999px;
  opacity: 0;
  z-index: 2;
  background:
    radial-gradient(ellipse,
      rgba(255,255,255,.08) 0%,
      rgba(245,200,66,.48) 18%,
      rgba(184,109,255,.28) 46%,
      transparent 72%);
  filter: blur(10px);
  animation: v36InnerGlow 1120ms ease-out 820ms forwards;
}

.v36-fan-cards {
  position: absolute;
  left: 50%;
  top: 45%;
  width: min(310px, 62vw);
  height: min(360px, 54vh);
  transform: translate(-50%, -50%);
  z-index: 3;
}

.v36-fan-card {
  position: absolute;
  left: 50%;
  top: 58%;
  width: min(118px, 23vw);
  aspect-ratio: .70;
  border-radius: 12px;
  background:
    linear-gradient(145deg, rgba(255,255,255,.10), rgba(0,0,0,.30)),
    linear-gradient(135deg, #201229, #05040a);
  background-size: cover;
  background-position: center;
  border: 1px solid rgba(245,200,66,.34);
  box-shadow:
    0 16px 28px rgba(0,0,0,.44),
    0 0 18px rgba(184,109,255,.20),
    inset 0 0 0 1px rgba(255,255,255,.07);
  opacity: 0;
  transform: translate(-50%, -50%) translateY(110px) rotate(0deg) scale(.42);
  animation: v36CardEject 860ms cubic-bezier(.12,.88,.18,1) calc(980ms + var(--i) * 62ms) forwards;
}

.v36-fan-card:nth-child(1) { --spread-x: -118px; --spread-y: 14px; --rot: -18deg; }
.v36-fan-card:nth-child(2) { --spread-x: -58px; --spread-y: -14px; --rot: -8deg; }
.v36-fan-card:nth-child(3) { --spread-x: 0px; --spread-y: -24px; --rot: 0deg; }
.v36-fan-card:nth-child(4) { --spread-x: 58px; --spread-y: -14px; --rot: 8deg; }
.v36-fan-card:nth-child(5) { --spread-x: 118px; --spread-y: 14px; --rot: 18deg; }

.v36-dust {
  position: absolute;
  inset: 0;
  z-index: 7;
  pointer-events: none;
}

.v36-dust i {
  position: absolute;
  left: 50%;
  top: 25%;
  width: 5px;
  height: 5px;
  border-radius: 999px;
  background: rgba(245,200,66,.86);
  box-shadow:
    0 0 8px rgba(245,200,66,.62),
    0 0 14px rgba(184,109,255,.34);
  opacity: 0;
  animation: v36DustFly 760ms cubic-bezier(.12,.8,.18,1) calc(820ms + var(--d)) forwards;
}

@keyframes v36StageBloom {
  0% { opacity: 0; }
  28% { opacity: 1; }
  100% { opacity: .35; }
}

@keyframes v36StageLeave {
  from { opacity: 1; transform: scale(1); }
  to { opacity: 0; transform: scale(1.04); }
}

@keyframes v36PackEnter {
  from { opacity: 0; transform: translateY(52px) scale(.82) rotateX(16deg); }
  to { opacity: 1; transform: translateY(0) scale(1) rotateX(0deg); }
}

@keyframes v36PackTension {
  0% { transform: translateX(0) scale(1); filter: brightness(1); }
  18% { transform: translateX(-3px) rotate(-.7deg) scale(1.015); }
  36% { transform: translateX(3px) rotate(.7deg) scale(1.018); }
  54% { transform: translateX(-2px) rotate(-.4deg) scale(1.02); }
  76% { transform: translateX(2px) rotate(.4deg) scale(1.022); }
  100% { transform: translateX(0) scale(1.025); filter: brightness(1.14); }
}

@keyframes v36Tear {
  0% { opacity: 0; transform: translateX(-50%) scaleX(.05); }
  22% { opacity: 1; transform: translateX(-50%) scaleX(.45); }
  68% { opacity: 1; transform: translateX(-50%) scaleX(1); }
  100% { opacity: 0; transform: translateX(-50%) scaleX(1.12) translateY(-20px); }
}

@keyframes v36InnerGlow {
  0% { opacity: 0; transform: translate(-50%, -50%) scale(.35); }
  28% { opacity: 1; transform: translate(-50%, -50%) scale(1); }
  100% { opacity: 0; transform: translate(-50%, -50%) scale(1.48); }
}

@keyframes v36PackOpen {
  0% { transform: translateY(0) scale(1.025); opacity: 1; }
  34% { transform: translateY(-14px) scale(1.05); opacity: 1; }
  72% { transform: translateY(28px) scale(.92) rotateX(8deg); opacity: .42; }
  100% { transform: translateY(80px) scale(.74) rotateX(16deg); opacity: 0; }
}

@keyframes v36CardEject {
  0% {
    opacity: 0;
    transform: translate(-50%, -50%) translateY(110px) rotate(0deg) scale(.42);
    filter: brightness(1.8) blur(1px);
  }
  22% {
    opacity: 1;
    filter: brightness(1.35) blur(0);
  }
  100% {
    opacity: 1;
    transform: translate(-50%, -50%) translate(var(--spread-x), var(--spread-y)) rotate(var(--rot)) scale(1);
    filter: brightness(1);
  }
}

@keyframes v36DustFly {
  0% { opacity: 0; transform: translate(0,0) scale(.4); }
  18% { opacity: .92; }
  100% { opacity: 0; transform: translate(var(--x), var(--y)) scale(.9); }
}

@media (max-width: 620px) {
  .v36-cinematic { width: 96vw; height: 72vh; }
  .v36-fan-card:nth-child(1) { --spread-x: -86px; --spread-y: 18px; --rot: -16deg; }
  .v36-fan-card:nth-child(2) { --spread-x: -42px; --spread-y: -8px; --rot: -7deg; }
  .v36-fan-card:nth-child(3) { --spread-x: 0px; --spread-y: -16px; --rot: 0deg; }
  .v36-fan-card:nth-child(4) { --spread-x: 42px; --spread-y: -8px; --rot: 7deg; }
  .v36-fan-card:nth-child(5) { --spread-x: 86px; --spread-y: 18px; --rot: 16deg; }
}


/* ═══════════════════════════════════════════════════════
   V37 SMOOTH OPENING POLISH
   - reflet uniquement sur le booster
   - timings fusionnés, moins saccadés
   - cards fan plus naturel
═══════════════════════════════════════════════════════ */

/* Supprime le gros reflet diagonal qui traversait l'écran */
.booster-pack.has-pack-image .pack-shine,
.booster-pack .pack-shine {
  display: none !important;
}

/* Reflet contrôlé uniquement sur le clone du booster pendant l'ouverture */
.v36-pack-clone::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  border-radius: 20px;
  opacity: 0;
  background:
    linear-gradient(
      112deg,
      transparent 0%,
      transparent 38%,
      rgba(255,255,255,.08) 46%,
      rgba(255,255,255,.12) 51%,
      transparent 62%,
      transparent 100%
    );
  mix-blend-mode: screen;
  transform: translateX(-115%) skewX(-10deg);
  clip-path: inset(0 0 0 0 round 20px);
  animation: v37PackGlint 900ms cubic-bezier(.18,.82,.22,1) 260ms forwards;
}

/* La stage doit être invisible, pas ajouter un voile trop visible */
.v36-opening-stage::before {
  animation: v37StageBloom 2050ms ease-out forwards !important;
}

/* Même objet, même animation globale : plus de cuts évidents */
.v36-pack-clone {
  animation: v37PackMaster 1860ms cubic-bezier(.13,.86,.18,1) forwards !important;
  will-change: transform, opacity, filter;
}

.v36-tear {
  top: 20.4% !important;
  animation: v37Tear 620ms cubic-bezier(.16,.9,.2,1) 680ms forwards !important;
}

.v36-inner-glow {
  animation: v37InnerGlow 1200ms cubic-bezier(.15,.85,.2,1) 760ms forwards !important;
}

/* Les cartes sortent plus tard, en continuité avec l'ouverture */
.v36-fan-card {
  animation: v37CardEject 940ms cubic-bezier(.12,.88,.18,1) calc(980ms + var(--i) * 54ms) forwards !important;
}

.v36-dust i {
  animation: v37DustFly 860ms cubic-bezier(.12,.8,.18,1) calc(720ms + var(--d)) forwards !important;
}

/* Le leave est plus court, moins "changement de scène" */
.v36-opening-stage.is-leaving {
  animation: v37StageLeave 220ms ease-out forwards !important;
}

@keyframes v37PackGlint {
  0% {
    opacity: 0;
    transform: translateX(-115%) skewX(-10deg);
  }
  18% {
    opacity: .42;
  }
  100% {
    opacity: 0;
    transform: translateX(115%) skewX(-10deg);
  }
}

@keyframes v37StageBloom {
  0% { opacity: 0; }
  18% { opacity: .72; }
  56% { opacity: .46; }
  100% { opacity: .16; }
}

@keyframes v37StageLeave {
  from { opacity: 1; }
  to { opacity: 0; }
}

@keyframes v37PackMaster {
  0% {
    opacity: 0;
    transform: translateY(42px) scale(.86) rotateX(12deg);
    filter: brightness(.92) saturate(1);
  }
  12% {
    opacity: 1;
    transform: translateY(0) scale(1) rotateX(0);
    filter: brightness(1) saturate(1.02);
  }
  24% {
    transform: translateX(-2px) rotate(-.55deg) scale(1.012);
  }
  34% {
    transform: translateX(2px) rotate(.55deg) scale(1.018);
  }
  44% {
    transform: translateX(0) rotate(0deg) scale(1.028);
    filter: brightness(1.10) saturate(1.08);
  }
  56% {
    transform: translateY(-12px) scale(1.052);
    filter: brightness(1.25) saturate(1.12);
  }
  72% {
    transform: translateY(4px) scale(.98) rotateX(4deg);
    opacity: .78;
    filter: brightness(1.12) saturate(1.08);
  }
  88% {
    transform: translateY(36px) scale(.84) rotateX(10deg);
    opacity: .26;
    filter: brightness(.92) blur(.5px);
  }
  100% {
    transform: translateY(64px) scale(.74) rotateX(14deg);
    opacity: 0;
    filter: brightness(.65) blur(1px);
  }
}

@keyframes v37Tear {
  0% {
    opacity: 0;
    transform: translateX(-50%) scaleX(.08);
  }
  24% {
    opacity: .95;
    transform: translateX(-50%) scaleX(.72);
  }
  62% {
    opacity: .75;
    transform: translateX(-50%) scaleX(1.04);
  }
  100% {
    opacity: 0;
    transform: translateX(-50%) scaleX(1.10) translateY(-16px);
  }
}

@keyframes v37InnerGlow {
  0% {
    opacity: 0;
    transform: translate(-50%, -50%) scale(.34);
  }
  24% {
    opacity: .95;
    transform: translate(-50%, -50%) scale(.92);
  }
  58% {
    opacity: .62;
    transform: translate(-50%, -50%) scale(1.22);
  }
  100% {
    opacity: 0;
    transform: translate(-50%, -50%) scale(1.58);
  }
}

@keyframes v37CardEject {
  0% {
    opacity: 0;
    transform: translate(-50%, -50%) translateY(92px) rotate(0deg) scale(.48);
    filter: brightness(1.65) blur(.8px);
  }
  20% {
    opacity: 1;
    filter: brightness(1.28) blur(0);
  }
  64% {
    transform:
      translate(-50%, -50%)
      translate(calc(var(--spread-x) * .92), calc(var(--spread-y) + 10px))
      rotate(calc(var(--rot) * .82))
      scale(1.04);
  }
  100% {
    opacity: 1;
    transform:
      translate(-50%, -50%)
      translate(var(--spread-x), var(--spread-y))
      rotate(var(--rot))
      scale(1);
    filter: brightness(1);
  }
}

@keyframes v37DustFly {
  0% { opacity: 0; transform: translate(0,0) scale(.4); }
  14% { opacity: .75; }
  100% { opacity: 0; transform: translate(var(--x), var(--y)) scale(.86); }
}

/* Petit effet de profondeur au moment où les cartes sortent */
.v36-fan-cards {
  filter: drop-shadow(0 24px 34px rgba(0,0,0,.42));
}


/* ═══════════════════════════════════════════════════════
   V38 — NO SCREEN REFLECT + SMOOTHER OPENING
   Fix réel: l'ancien .booster-pack::after avait un sweep full-size visible.
═══════════════════════════════════════════════════════ */

/* Kill définitif du reflet diagonal original sur le booster DOM */
.booster-pack::after,
.booster-pack.has-pack-image::after,
.booster-pack.opening::after,
.booster-pack.v33-pack-opening::after,
.booster-pack.v36-real-pack-hidden::after {
  content: none !important;
  display: none !important;
  animation: none !important;
  background: none !important;
  opacity: 0 !important;
}

.booster-pack::before,
.booster-pack.has-pack-image::before,
.booster-pack.opening::before,
.booster-pack.v33-pack-opening::before {
  content: none !important;
  display: none !important;
  animation: none !important;
  background: none !important;
  opacity: 0 !important;
}

.booster-pack.has-pack-image .pack-shine,
.booster-pack .pack-shine {
  display: none !important;
  opacity: 0 !important;
}

/* Le reflet existe uniquement sur l'image clone du pack, pas sur l'écran */
.v36-pack-clone {
  overflow: hidden !important;
  border-radius: 22px;
  animation: v38PackMaster 1720ms cubic-bezier(.16,.84,.18,1) forwards !important;
}

.v36-pack-clone::after {
  content: "";
  position: absolute;
  top: 7%;
  bottom: 7%;
  left: 8%;
  right: 8%;
  border-radius: 18px;
  opacity: 0;
  pointer-events: none;
  background:
    linear-gradient(
      112deg,
      transparent 0%,
      transparent 42%,
      rgba(255,255,255,.34) 49%,
      rgba(255,255,255,.10) 54%,
      transparent 63%,
      transparent 100%
    );
  mix-blend-mode: screen;
  transform: translateX(-120%) skewX(-12deg);
  animation: v38PackGlint 760ms cubic-bezier(.18,.82,.22,1) 260ms forwards;
}

.v36-pack-clone img {
  display: block;
  position: relative;
  z-index: 1;
}

.v36-tear {
  top: 20% !important;
  height: 2px !important;
  animation: v38Tear 520ms cubic-bezier(.16,.9,.2,1) 620ms forwards !important;
}

.v36-inner-glow {
  animation: v38InnerGlow 980ms cubic-bezier(.15,.85,.2,1) 720ms forwards !important;
}

.v36-fan-card {
  animation: v38CardEject 860ms cubic-bezier(.12,.88,.18,1) calc(890ms + var(--i) * 48ms) forwards !important;
}

.v36-dust i {
  animation: v38DustFly 760ms cubic-bezier(.12,.8,.18,1) calc(640ms + var(--d)) forwards !important;
}

.v36-opening-stage::before {
  animation: v38StageBloom 1850ms ease-out forwards !important;
}

.v36-opening-stage.is-leaving {
  animation: v38StageLeave 180ms ease-out forwards !important;
}

/* moins d'effet "cut": les cartes restent le point focal et la stage s'efface doux */
@keyframes v38StageBloom {
  0% { opacity: 0; }
  20% { opacity: .62; }
  58% { opacity: .36; }
  100% { opacity: .10; }
}

@keyframes v38StageLeave {
  from { opacity: 1; }
  to { opacity: 0; }
}

@keyframes v38PackGlint {
  0% { opacity: 0; transform: translateX(-120%) skewX(-12deg); }
  20% { opacity: .38; }
  100% { opacity: 0; transform: translateX(120%) skewX(-12deg); }
}

@keyframes v38PackMaster {
  0% {
    opacity: 0;
    transform: translateY(36px) scale(.88) rotateX(10deg);
    filter: brightness(.92) saturate(1);
  }
  12% {
    opacity: 1;
    transform: translateY(0) scale(1) rotateX(0);
    filter: brightness(1) saturate(1.02);
  }
  24% { transform: translateX(-2px) rotate(-.45deg) scale(1.010); }
  33% { transform: translateX(2px) rotate(.45deg) scale(1.016); }
  43% {
    transform: translateX(0) rotate(0deg) scale(1.026);
    filter: brightness(1.10) saturate(1.08);
  }
  56% {
    transform: translateY(-10px) scale(1.050);
    filter: brightness(1.24) saturate(1.12);
  }
  70% {
    transform: translateY(2px) scale(.99) rotateX(3deg);
    opacity: .66;
    filter: brightness(1.08) saturate(1.08);
  }
  84% {
    transform: translateY(28px) scale(.86) rotateX(8deg);
    opacity: .22;
    filter: brightness(.88) blur(.45px);
  }
  100% {
    transform: translateY(54px) scale(.76) rotateX(12deg);
    opacity: 0;
    filter: brightness(.65) blur(1px);
  }
}

@keyframes v38Tear {
  0% { opacity: 0; transform: translateX(-50%) scaleX(.08); }
  26% { opacity: .92; transform: translateX(-50%) scaleX(.68); }
  64% { opacity: .72; transform: translateX(-50%) scaleX(1); }
  100% { opacity: 0; transform: translateX(-50%) scaleX(1.08) translateY(-14px); }
}

@keyframes v38InnerGlow {
  0% { opacity: 0; transform: translate(-50%, -50%) scale(.32); }
  26% { opacity: .9; transform: translate(-50%, -50%) scale(.9); }
  62% { opacity: .50; transform: translate(-50%, -50%) scale(1.18); }
  100% { opacity: 0; transform: translate(-50%, -50%) scale(1.46); }
}

@keyframes v38CardEject {
  0% {
    opacity: 0;
    transform: translate(-50%, -50%) translateY(80px) rotate(0deg) scale(.50);
    filter: brightness(1.45) blur(.6px);
  }
  18% {
    opacity: 1;
    filter: brightness(1.18) blur(0);
  }
  68% {
    transform:
      translate(-50%, -50%)
      translate(calc(var(--spread-x) * .94), calc(var(--spread-y) + 8px))
      rotate(calc(var(--rot) * .88))
      scale(1.035);
  }
  100% {
    opacity: 1;
    transform:
      translate(-50%, -50%)
      translate(var(--spread-x), var(--spread-y))
      rotate(var(--rot))
      scale(1);
    filter: brightness(1);
  }
}

@keyframes v38DustFly {
  0% { opacity: 0; transform: translate(0,0) scale(.4); }
  16% { opacity: .58; }
  100% { opacity: 0; transform: translate(var(--x), var(--y)) scale(.82); }
}


/* ═══════════════════════════════════════════════════════
   V39 — Stack-to-card opening polish
   - le booster ne rétrécit plus bizarrement
   - les 5 cartes sont plus grandes
   - elles se regroupent en pile pour annoncer la carte à retourner
═══════════════════════════════════════════════════════ */

.v36-pack-clone {
  animation: v39PackOpenNoTiny 1500ms cubic-bezier(.16,.84,.18,1) forwards !important;
}

.v36-fan-cards {
  top: 49% !important;
  width: min(420px, 78vw) !important;
  height: min(500px, 70vh) !important;
  z-index: 6 !important;
}

.v36-fan-card {
  width: min(170px, 34vw) !important;
  border-radius: 16px !important;
  transform: translate(-50%, -50%) translateY(90px) rotate(0deg) scale(.58);
  animation:
    v39CardFanThenStack 1450ms cubic-bezier(.13,.86,.18,1)
    calc(820ms + var(--i) * 52ms)
    forwards !important;
}

/* éventail plus large au début, puis pile centrée */
.v36-fan-card:nth-child(1) { --spread-x: -160px; --spread-y: 12px; --rot: -20deg; --stack-x: -8px; --stack-y: 8px; --stack-r: -3deg; }
.v36-fan-card:nth-child(2) { --spread-x: -78px; --spread-y: -18px; --rot: -10deg; --stack-x: -4px; --stack-y: 4px; --stack-r: -1.4deg; }
.v36-fan-card:nth-child(3) { --spread-x: 0px; --spread-y: -30px; --rot: 0deg; --stack-x: 0px; --stack-y: 0px; --stack-r: 0deg; }
.v36-fan-card:nth-child(4) { --spread-x: 78px; --spread-y: -18px; --rot: 10deg; --stack-x: 4px; --stack-y: 4px; --stack-r: 1.4deg; }
.v36-fan-card:nth-child(5) { --spread-x: 160px; --spread-y: 12px; --rot: 20deg; --stack-x: 8px; --stack-y: 8px; --stack-r: 3deg; }

/* La stage part seulement une fois que la pile est formée */
.v36-opening-stage.is-leaving {
  animation: v39StageLeaveToReveal 180ms ease-out forwards !important;
}

@keyframes v39PackOpenNoTiny {
  0% {
    opacity: 0;
    transform: translateY(36px) scale(.88) rotateX(10deg);
    filter: brightness(.92) saturate(1);
  }
  12% {
    opacity: 1;
    transform: translateY(0) scale(1) rotateX(0);
    filter: brightness(1) saturate(1.02);
  }
  24% { transform: translateX(-2px) rotate(-.45deg) scale(1.010); }
  33% { transform: translateX(2px) rotate(.45deg) scale(1.016); }
  43% {
    transform: translateX(0) rotate(0deg) scale(1.026);
    filter: brightness(1.10) saturate(1.08);
  }
  56% {
    transform: translateY(-14px) scale(1.045);
    filter: brightness(1.24) saturate(1.12);
    opacity: 1;
  }
  72% {
    transform: translateY(-34px) scale(1.03) rotateX(-3deg);
    opacity: .82;
    filter: brightness(1.10);
  }
  100% {
    transform: translateY(-76px) scale(1.00) rotateX(-8deg);
    opacity: 0;
    filter: brightness(.7) blur(.7px);
  }
}

@keyframes v39CardFanThenStack {
  0% {
    opacity: 0;
    transform: translate(-50%, -50%) translateY(92px) rotate(0deg) scale(.50);
    filter: brightness(1.45) blur(.6px);
  }

  /* sortie du booster */
  18% {
    opacity: 1;
    filter: brightness(1.18) blur(0);
  }

  /* éventail visible */
  48% {
    opacity: 1;
    transform:
      translate(-50%, -50%)
      translate(var(--spread-x), var(--spread-y))
      rotate(var(--rot))
      scale(1);
    filter: brightness(1);
  }

  /* micro pause lisible */
  64% {
    transform:
      translate(-50%, -50%)
      translate(calc(var(--spread-x) * .96), calc(var(--spread-y) + 2px))
      rotate(calc(var(--rot) * .96))
      scale(1.015);
  }

  /* regroupement en pile */
  100% {
    opacity: 1;
    transform:
      translate(-50%, -50%)
      translate(var(--stack-x), var(--stack-y))
      rotate(var(--stack-r))
      scale(1.08);
    filter: brightness(1.03);
  }
}

@keyframes v39StageLeaveToReveal {
  from {
    opacity: 1;
    transform: scale(1);
  }
  to {
    opacity: 0;
    transform: scale(1.02);
  }
}

@media (max-width: 620px) {
  .v36-fan-card {
    width: min(145px, 38vw) !important;
  }

  .v36-fan-card:nth-child(1) { --spread-x: -108px; --spread-y: 14px; --rot: -17deg; }
  .v36-fan-card:nth-child(2) { --spread-x: -54px; --spread-y: -10px; --rot: -8deg; }
  .v36-fan-card:nth-child(3) { --spread-x: 0px; --spread-y: -20px; --rot: 0deg; }
  .v36-fan-card:nth-child(4) { --spread-x: 54px; --spread-y: -10px; --rot: 8deg; }
  .v36-fan-card:nth-child(5) { --spread-x: 108px; --spread-y: 14px; --rot: 17deg; }
}


/* ═══════════════════════════════════════════════════════
   V43 — RESTORE V39 + BIGGER FINAL STACK
   Base stable V39. Aucun tilt/highlight concurrent.
   Fix: les 5 cartes restent visibles et se regroupent plus grandes.
═══════════════════════════════════════════════════════ */

.v36-fan-cards {
  top: 50% !important;
  width: min(520px, 86vw) !important;
  height: min(600px, 76vh) !important;
  z-index: 6 !important;
}

/* Taille proche de la vraie carte retournée, sans casser l'animation */
.v36-fan-card {
  width: min(235px, 41vw) !important;
  border-radius: 18px !important;
  animation:
    v43CardFanThenStack 1450ms cubic-bezier(.13,.86,.18,1)
    calc(820ms + var(--i) * 52ms)
    forwards !important;
}

/* Éventail large, puis stack centrée lisible */
.v36-fan-card:nth-child(1) { --spread-x: -170px; --spread-y: 14px; --rot: -19deg; --stack-x: -9px; --stack-y: 8px; --stack-r: -3deg; }
.v36-fan-card:nth-child(2) { --spread-x: -84px; --spread-y: -18px; --rot: -9deg; --stack-x: -4px; --stack-y: 4px; --stack-r: -1.4deg; }
.v36-fan-card:nth-child(3) { --spread-x: 0px; --spread-y: -30px; --rot: 0deg; --stack-x: 0px; --stack-y: 0px; --stack-r: 0deg; }
.v36-fan-card:nth-child(4) { --spread-x: 84px; --spread-y: -18px; --rot: 9deg; --stack-x: 4px; --stack-y: 4px; --stack-r: 1.4deg; }
.v36-fan-card:nth-child(5) { --spread-x: 170px; --spread-y: 14px; --rot: 19deg; --stack-x: 9px; --stack-y: 8px; --stack-r: 3deg; }

@keyframes v43CardFanThenStack {
  0% {
    opacity: 0;
    transform: translate(-50%, -50%) translateY(92px) rotate(0deg) scale(.48);
    filter: brightness(1.45) blur(.6px);
  }

  18% {
    opacity: 1;
    filter: brightness(1.16) blur(0);
  }

  48% {
    opacity: 1;
    transform:
      translate(-50%, -50%)
      translate(var(--spread-x), var(--spread-y))
      rotate(var(--rot))
      scale(.94);
    filter: brightness(1);
  }

  66% {
    transform:
      translate(-50%, -50%)
      translate(calc(var(--spread-x) * .92), calc(var(--spread-y) + 4px))
      rotate(calc(var(--rot) * .90))
      scale(.98);
  }

  88% {
    transform:
      translate(-50%, -50%)
      translate(var(--stack-x), var(--stack-y))
      rotate(var(--stack-r))
      scale(1.03);
  }

  100% {
    opacity: 1;
    transform:
      translate(-50%, -50%)
      translate(var(--stack-x), var(--stack-y))
      rotate(var(--stack-r))
      scale(1);
    filter: brightness(1.02);
  }
}

/* petite mise en valeur sans toucher au transform */
.v36-fan-card:nth-child(3)::after {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  pointer-events: none;
  opacity: 0;
  background:
    linear-gradient(115deg,
      transparent 0%,
      transparent 42%,
      rgba(255,255,255,.08) 49%,
      rgba(245,200,66,.20) 54%,
      transparent 64%);
  mix-blend-mode: screen;
  transform: translateX(-120%);
  animation: v43SafeSheen 560ms cubic-bezier(.18,.82,.22,1) 2180ms forwards;
}

@keyframes v43SafeSheen {
  0% { opacity: 0; transform: translateX(-120%); }
  24% { opacity: .62; }
  100% { opacity: 0; transform: translateX(120%); }
}

@media (max-width: 620px) {
  .v36-fan-card {
    width: min(210px, 56vw) !important;
  }

  .v36-fan-card:nth-child(1) { --spread-x: -112px; --spread-y: 16px; --rot: -16deg; }
  .v36-fan-card:nth-child(2) { --spread-x: -56px; --spread-y: -10px; --rot: -8deg; }
  .v36-fan-card:nth-child(3) { --spread-x: 0px; --spread-y: -22px; --rot: 0deg; }
  .v36-fan-card:nth-child(4) { --spread-x: 56px; --spread-y: -10px; --rot: 8deg; }
  .v36-fan-card:nth-child(5) { --spread-x: 112px; --spread-y: 16px; --rot: 16deg; }
}


/* ═══════════════════════════════════════════════════════
   V44 — SCALE BRIDGE
   But: les 5 cartes de l'opening et la carte à retourner ont la même taille perçue.
   Solution: on agrandit la pile opening ET on réduit très légèrement la carte reveal.
═══════════════════════════════════════════════════════ */

/* Carte à retourner un poil plus compacte, pour rejoindre l'opening au bon milieu */
.single-card-wrap {
  width: 320px !important;
  height: 480px !important;
}

/* Pile opening à la même taille réelle: 320x~457, très proche du 320x480 avec bord + perspective */
.v36-fan-card {
  width: 320px !important;
  max-width: min(320px, 52vw) !important;
  border-radius: 20px !important;
}

/* Container plus large pour que l'éventail respire même avec les cartes plus grandes */
.v36-fan-cards {
  width: min(760px, 96vw) !important;
  height: min(620px, 82vh) !important;
  top: 50% !important;
}

/* Spread adapté à la nouvelle taille */
.v36-fan-card:nth-child(1) { --spread-x: -245px; --spread-y: 24px; --rot: -18deg; --stack-x: -10px; --stack-y: 8px; --stack-r: -2.4deg; }
.v36-fan-card:nth-child(2) { --spread-x: -122px; --spread-y: -18px; --rot: -9deg; --stack-x: -5px; --stack-y: 4px; --stack-r: -1.2deg; }
.v36-fan-card:nth-child(3) { --spread-x: 0px; --spread-y: -34px; --rot: 0deg; --stack-x: 0px; --stack-y: 0px; --stack-r: 0deg; }
.v36-fan-card:nth-child(4) { --spread-x: 122px; --spread-y: -18px; --rot: 9deg; --stack-x: 5px; --stack-y: 4px; --stack-r: 1.2deg; }
.v36-fan-card:nth-child(5) { --spread-x: 245px; --spread-y: 24px; --rot: 18deg; --stack-x: 10px; --stack-y: 8px; --stack-r: 2.4deg; }

/* Force le final stack à taille 1, donc pas de rétrécissement avant handoff */
@keyframes v43CardFanThenStack {
  0% {
    opacity: 0;
    transform: translate(-50%, -50%) translateY(92px) rotate(0deg) scale(.46);
    filter: brightness(1.45) blur(.6px);
  }

  18% {
    opacity: 1;
    filter: brightness(1.16) blur(0);
  }

  48% {
    opacity: 1;
    transform:
      translate(-50%, -50%)
      translate(var(--spread-x), var(--spread-y))
      rotate(var(--rot))
      scale(.82);
    filter: brightness(1);
  }

  66% {
    transform:
      translate(-50%, -50%)
      translate(calc(var(--spread-x) * .92), calc(var(--spread-y) + 4px))
      rotate(calc(var(--rot) * .90))
      scale(.88);
  }

  88% {
    transform:
      translate(-50%, -50%)
      translate(var(--stack-x), var(--stack-y))
      rotate(var(--stack-r))
      scale(1.02);
  }

  100% {
    opacity: 1;
    transform:
      translate(-50%, -50%)
      translate(var(--stack-x), var(--stack-y))
      rotate(var(--stack-r))
      scale(1);
    filter: brightness(1.02);
  }
}

/* Mobile: garder lisible sans exploser l'écran */
@media (max-width: 620px) {
  .single-card-wrap {
    width: min(320px, 76vw) !important;
    height: calc(min(320px, 76vw) * 1.5) !important;
  }

  .v36-fan-card {
    width: min(320px, 76vw) !important;
    max-width: min(320px, 76vw) !important;
  }

  .v36-fan-card:nth-child(1) { --spread-x: -138px; --spread-y: 22px; --rot: -15deg; }
  .v36-fan-card:nth-child(2) { --spread-x: -70px; --spread-y: -10px; --rot: -7deg; }
  .v36-fan-card:nth-child(3) { --spread-x: 0px; --spread-y: -20px; --rot: 0deg; }
  .v36-fan-card:nth-child(4) { --spread-x: 70px; --spread-y: -10px; --rot: 7deg; }
  .v36-fan-card:nth-child(5) { --spread-x: 138px; --spread-y: 22px; --rot: 15deg; }
}


/* ═══════════════════════════════════════════════════════
   V45 — SEAMLESS HANDOFF + BETTER BOOSTER RIP
   - transition pile -> carte à retourner moins choppy
   - la pile reste au centre et crossfade très court
   - déchirure booster plus crédible: ouverture en deux lèvres + lumière interne
═══════════════════════════════════════════════════════ */

/* On laisse la pile mourir en place, sans zoom/fade long */
.v36-opening-stage.is-leaving {
  animation: v45HandoffFade 90ms linear forwards !important;
}

@keyframes v45HandoffFade {
  from { opacity: 1; }
  to { opacity: 0; }
}

/* Apparition de la vraie carte plus douce pour cacher le swap DOM */
#openingView:not(.hidden) .single-card-wrap {
  animation: v45RealCardArrive 220ms cubic-bezier(.18,.82,.22,1) both;
}

@keyframes v45RealCardArrive {
  from {
    opacity: 0;
    transform: translateY(4px) scale(.992);
    filter: brightness(1.18);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
    filter: brightness(1);
  }
}

/* Le booster ne doit pas juste "se réduire": il s'ouvre vers le haut */
.v36-pack-clone {
  overflow: visible !important;
  animation: v45PackShell 1420ms cubic-bezier(.16,.84,.18,1) forwards !important;
}

/* Masque le pack original au moment de l'ouverture pour afficher les moitiés */
.v36-pack-clone img {
  animation: v45PackImageFade 1420ms cubic-bezier(.16,.84,.18,1) forwards !important;
}

/* Deux lèvres de foil qui s'écartent: illusion de déchirure */
.v36-pack-clone::before,
.v36-pack-clone::after {
  content: "";
  position: absolute;
  left: 7%;
  right: 7%;
  height: 17%;
  z-index: 6;
  pointer-events: none;
  opacity: 0;
  border-radius: 14px 14px 8px 8px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.18), rgba(0,0,0,.16)),
    linear-gradient(135deg, rgba(72,30,86,.92), rgba(12,8,16,.96));
  border: 1px solid rgba(245,200,66,.34);
  box-shadow:
    0 10px 20px rgba(0,0,0,.34),
    inset 0 1px 0 rgba(255,255,255,.18);
}

.v36-pack-clone::before {
  top: 6%;
  transform-origin: 50% 100%;
  animation: v45TopLipRip 720ms cubic-bezier(.12,.84,.18,1) 610ms forwards;
}

.v36-pack-clone::after {
  top: 19%;
  height: 8%;
  transform-origin: 50% 0%;
  border-radius: 8px 8px 14px 14px;
  animation: v45BottomLipRip 640ms cubic-bezier(.12,.84,.18,1) 650ms forwards;
}

/* La ligne de tear devient moins laser, plus "foil crack" */
.v36-tear {
  top: 20.5% !important;
  height: 5px !important;
  background:
    linear-gradient(90deg,
      transparent,
      rgba(245,200,66,.35) 16%,
      rgba(255,255,255,.08) 31%,
      rgba(184,109,255,.62) 52%,
      rgba(255,255,255,.08) 70%,
      transparent) !important;
  clip-path: polygon(0 42%, 9% 30%, 18% 60%, 29% 34%, 41% 58%, 53% 36%, 66% 62%, 78% 34%, 91% 56%, 100% 42%);
  box-shadow:
    0 0 10px rgba(255,255,255,.08),
    0 0 24px rgba(184,109,255,.42),
    0 0 18px rgba(245,200,66,.34) !important;
  animation: v45JaggedTear 620ms cubic-bezier(.16,.9,.2,1) 560ms forwards !important;
}

/* Glow plus vertical: ça donne l'impression que les cartes sortent du booster */
.v36-inner-glow {
  top: 29% !important;
  height: min(260px, 38vh) !important;
  width: min(250px, 54vw) !important;
  background:
    radial-gradient(ellipse at 50% 20%,
      rgba(255,255,255,.08) 0%,
      rgba(245,200,66,.50) 16%,
      rgba(184,109,255,.30) 42%,
      transparent 72%) !important;
  animation: v45InnerGlow 920ms cubic-bezier(.15,.85,.2,1) 650ms forwards !important;
}

/* Stack final un peu plus stable/visible avant le handoff */
@keyframes v43CardFanThenStack {
  0% {
    opacity: 0;
    transform: translate(-50%, -50%) translateY(92px) rotate(0deg) scale(.46);
    filter: brightness(1.45) blur(.6px);
  }
  18% { opacity: 1; filter: brightness(1.16) blur(0); }
  48% {
    opacity: 1;
    transform:
      translate(-50%, -50%)
      translate(var(--spread-x), var(--spread-y))
      rotate(var(--rot))
      scale(.82);
    filter: brightness(1);
  }
  66% {
    transform:
      translate(-50%, -50%)
      translate(calc(var(--spread-x) * .92), calc(var(--spread-y) + 4px))
      rotate(calc(var(--rot) * .90))
      scale(.88);
  }
  86% {
    transform:
      translate(-50%, -50%)
      translate(var(--stack-x), var(--stack-y))
      rotate(var(--stack-r))
      scale(1.015);
  }
  100% {
    opacity: 1;
    transform:
      translate(-50%, -50%)
      translate(var(--stack-x), var(--stack-y))
      rotate(var(--stack-r))
      scale(1);
    filter: brightness(1.02);
  }
}

@keyframes v45PackShell {
  0% {
    opacity: 0;
    transform: translateY(36px) scale(.88) rotateX(10deg);
    filter: brightness(.92) saturate(1);
  }
  12% { opacity: 1; transform: translateY(0) scale(1) rotateX(0); filter: brightness(1); }
  25% { transform: translateX(-2px) rotate(-.45deg) scale(1.012); }
  34% { transform: translateX(2px) rotate(.45deg) scale(1.018); }
  48% { transform: translateX(0) rotate(0) scale(1.032); filter: brightness(1.18); }
  63% { transform: translateY(-8px) scale(1.042); opacity: 1; }
  82% { transform: translateY(-26px) scale(1.02); opacity: .44; filter: brightness(.92); }
  100% { transform: translateY(-48px) scale(1); opacity: 0; filter: brightness(.55) blur(.5px); }
}

@keyframes v45PackImageFade {
  0%, 54% { opacity: 1; }
  72% { opacity: .26; }
  100% { opacity: 0; }
}

@keyframes v45TopLipRip {
  0% { opacity: 0; transform: translateY(0) rotateX(0deg) scaleX(.92); }
  18% { opacity: 1; }
  100% { opacity: 0; transform: translateY(-44px) rotateX(-58deg) rotateZ(-2deg) scaleX(1.06); }
}

@keyframes v45BottomLipRip {
  0% { opacity: 0; transform: translateY(0) rotateX(0deg) scaleX(.92); }
  20% { opacity: .92; }
  100% { opacity: 0; transform: translateY(22px) rotateX(46deg) rotateZ(1.4deg) scaleX(1.03); }
}

@keyframes v45JaggedTear {
  0% { opacity: 0; transform: translateX(-50%) scaleX(.08); }
  24% { opacity: 1; transform: translateX(-50%) scaleX(.72); }
  64% { opacity: .92; transform: translateX(-50%) scaleX(1); }
  100% { opacity: 0; transform: translateX(-50%) scaleX(1.06) translateY(-12px); }
}

@keyframes v45InnerGlow {
  0% { opacity: 0; transform: translate(-50%, -50%) scale(.30); }
  26% { opacity: .95; transform: translate(-50%, -50%) scale(.95); }
  62% { opacity: .55; transform: translate(-50%, -50%) scale(1.18); }
  100% { opacity: 0; transform: translate(-50%, -50%) scale(1.38); }
}


/* V47 admin-safe instant response */
#openBoosterBtn.is-opening {
  transform: scale(.97);
  filter: brightness(1.14);
  pointer-events: none;
}
.v36-tear {
  height: 6px !important;
  clip-path: polygon(0 45%,8% 25%,16% 60%,24% 35%,33% 62%,43% 30%,55% 66%,68% 34%,80% 60%,92% 28%,100% 45%) !important;
}


/* ═══════════════════════════════════════════════
   V48 — Discord profile + collection UI
═══════════════════════════════════════════════ */

.user-profile-bar {
  width: min(820px, 92vw);
  margin: 0 auto 18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:12px 14px;
  border:1px solid rgba(255,255,255,.11);
  border-radius:22px;
  background:rgba(255,255,255,.045);
  backdrop-filter: blur(18px);
  box-shadow:0 20px 70px rgba(0,0,0,.28);
}

.user-profile-left {
  display:flex;
  align-items:center;
  gap:12px;
  min-width:0;
}

.user-avatar {
  width:44px;
  height:44px;
  border-radius:50%;
  object-fit:cover;
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 0 18px rgba(184,109,255,.22);
}

.user-name {
  font-weight:800;
  color:var(--text);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:280px;
}

.user-sub {
  font-size:12px;
  color:var(--muted);
}

.user-profile-actions {
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.small-btn {
  padding:9px 12px !important;
  font-size:12px !important;
}

.collection-head {
  width:min(980px,94vw);
  margin:0 auto 18px;
  display:flex;
  justify-content:space-between;
  align-items:end;
  gap:16px;
}

.collection-stats {
  width:min(980px,94vw);
  margin:0 auto 16px;
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:12px;
}

.collection-stats > div {
  padding:14px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.045);
  text-align:center;
}

.collection-stats strong {
  display:block;
  font-size:26px;
  line-height:1;
}

.collection-stats span {
  display:block;
  margin-top:6px;
  font-size:11px;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.12em;
}

.collection-toolbar {
  width:min(980px,94vw);
  margin:0 auto 18px;
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  justify-content:center;
}

.filter-pill {
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.045);
  color:rgba(255,255,255,.08);
  border-radius:999px;
  padding:9px 13px;
  cursor:pointer;
  font-weight:700;
}

.filter-pill.active {
  border-color:rgba(245,200,66,.42);
  color:#fff;
  background:rgba(245,200,66,.12);
  box-shadow:0 0 20px rgba(245,200,66,.10);
}

.collection-grid {
  width:min(980px,94vw);
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(155px, 1fr));
  gap:14px;
  padding-bottom:32px;
}

.collection-card {
  border:1px solid rgba(255,255,255,.10);
  border-radius:20px;
  overflow:hidden;
  background:rgba(255,255,255,.045);
  box-shadow:0 18px 50px rgba(0,0,0,.34);
}

.collection-art {
  aspect-ratio:.72;
  display:grid;
  place-items:center;
  background-size:cover !important;
  background-position:center !important;
}

.collection-art span {
  font-size:42px;
}

.collection-meta {
  padding:10px;
}

.collection-rarity {
  font-size:10px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--gold);
  font-weight:900;
}

.collection-name {
  margin-top:5px;
  font-size:15px;
  line-height:1.05;
  font-weight:900;
  color:#fff;
}

.collection-role,
.collection-date {
  margin-top:4px;
  font-size:11px;
  color:var(--muted);
}

@media (max-width:700px) {
  .user-profile-bar {
    align-items:flex-start;
    flex-direction:column;
  }
  .user-profile-actions {
    width:100%;
    justify-content:flex-start;
  }
  .collection-stats {
    grid-template-columns:repeat(2,1fr);
  }
}


/* ═══════════════════════════════════════════════
   V49 — Premium player profile
═══════════════════════════════════════════════ */

.collection-stats {
  grid-template-columns: repeat(4, minmax(0,1fr));
}

.profile-hero-v49,
.profile-top-v49 {
  grid-column: 1 / -1;
  border: 1px solid rgba(245,200,66,.18) !important;
  background:
    radial-gradient(circle at 12% 0%, rgba(184,109,255,.22), transparent 34%),
    linear-gradient(135deg, rgba(255,255,255,.075), rgba(255,255,255,.025)) !important;
  box-shadow:
    0 22px 70px rgba(0,0,0,.34),
    inset 0 1px 0 rgba(255,255,255,.08);
}

.profile-hero-v49 {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  text-align:left !important;
}

.profile-hero-left-v49 {
  display:flex;
  align-items:center;
  gap:16px;
  min-width:0;
}

.profile-hero-avatar-v49 {
  width:72px;
  height:72px;
  border-radius:22px;
  object-fit:cover;
  border:1px solid rgba(255,255,255,.18);
  box-shadow:
    0 0 0 1px rgba(245,200,66,.16),
    0 0 34px rgba(184,109,255,.24);
  flex:0 0 auto;
}

.profile-hero-avatar-v49.ghost {
  display:grid;
  place-items:center;
  font-size:13px;
  font-weight:900;
  letter-spacing:.16em;
  background:linear-gradient(135deg, rgba(184,109,255,.32), rgba(245,200,66,.18));
}

.profile-kicker-v49 {
  font-size:11px;
  color:var(--gold);
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
}

.profile-name-v49 {
  margin-top:4px;
  font-size:28px;
  line-height:1;
  font-weight:950;
  color:#fff;
}

.profile-sub-v49 {
  margin-top:6px;
  font-size:12px;
  color:var(--muted);
}

.profile-progress-v49 {
  margin-top:12px;
  width:min(360px, 52vw);
  height:8px;
  border-radius:999px;
  overflow:hidden;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.08);
}

.profile-progress-v49 i {
  display:block;
  height:100%;
  border-radius:inherit;
  background:linear-gradient(90deg, var(--purple), var(--gold));
  box-shadow:0 0 18px rgba(245,200,66,.38);
}

.profile-completion-v49 {
  text-align:center;
  padding:12px 18px;
  border-radius:18px;
  background:rgba(0,0,0,.22);
  border:1px solid rgba(255,255,255,.10);
}

.profile-completion-v49 strong {
  display:block;
  font-size:38px;
  line-height:1;
  color:#fff;
}

.profile-completion-v49 span {
  display:block;
  margin-top:6px;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:11px;
}

.profile-top-v49 {
  text-align:left !important;
}

.profile-top-v49 h3 {
  margin:0 0 12px;
  font-size:14px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(255,255,255,.08);
}

.profile-top-list-v49 {
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:12px;
}

.profile-top-card-v49 {
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px;
  border-radius:16px;
  background:rgba(0,0,0,.22);
  border:1px solid rgba(255,255,255,.09);
}

.profile-top-art-v49 {
  width:54px;
  height:74px;
  border-radius:10px;
  background:
    radial-gradient(circle at 50% 18%, rgba(255,255,255,.16), transparent 40%),
    linear-gradient(135deg, #251332, #05040a);
  background-size:cover;
  background-position:center;
  display:grid;
  place-items:center;
  flex:0 0 auto;
  font-size:24px;
}

.profile-top-card-v49 b {
  display:block;
  font-size:13px;
  color:#fff;
  line-height:1.1;
}

.profile-top-card-v49 span {
  display:block;
  margin-top:4px;
  font-size:11px;
  color:var(--muted);
}

.profile-empty-v49 {
  grid-column:1 / -1;
  color:var(--muted);
  font-size:13px;
}

.collection-card.rarity-mythic {
  border-color:rgba(255,219,87,.34);
  box-shadow:0 20px 60px rgba(255,219,87,.08), 0 0 34px rgba(184,109,255,.10);
}

.collection-card.rarity-legendary {
  border-color:rgba(255,141,71,.30);
}

.collection-card.rarity-epic {
  border-color:rgba(184,109,255,.28);
}

@media (max-width:760px) {
  .profile-hero-v49 {
    flex-direction:column;
    align-items:flex-start;
  }
  .profile-top-list-v49 {
    grid-template-columns:1fr;
  }
  .profile-name-v49 {
    font-size:23px;
  }
  .profile-completion-v49 {
    width:100%;
  }
}

/* V50 profile setup */
.two-cols-v50{grid-template-columns:repeat(2,minmax(0,1fr))!important}
.code-only-v50{grid-column:1/-1}
#redeemView .form-grid{grid-template-columns:1fr!important}
#redeemView .panel.narrow{max-width:620px}
.code-only-v50 input{text-align:center;letter-spacing:.08em;font-weight:800}
@media(max-width:700px){.two-cols-v50{grid-template-columns:1fr!important}}

/* V51 login-first landing */
.login-landing-panel-v51{
  max-width:620px;
  text-align:left;
}
.login-landing-panel-v51 .action-row{
  margin-top:26px;
}
#loginLandingView{
  min-height:60vh;
  display:grid;
  place-items:center;
}
#loginLandingView.hidden{display:none!important}

/* V62 gamified collection + comfort reveal */
body{background:radial-gradient(circle at 50% -10%,rgba(120,42,128,.32),transparent 38%),radial-gradient(circle at 8% 18%,rgba(255,80,92,.12),transparent 28%),linear-gradient(180deg,#180720,#07030d 52%,#030207)!important}
body::before{content:"";position:fixed;inset:0;pointer-events:none;opacity:.18;background:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.018) 1px,transparent 1px);background-size:48px 48px;mask-image:radial-gradient(circle at center,black,transparent 78%);z-index:0}
.user-profile-bar{position:sticky;top:10px;z-index:80;border-color:rgba(245,200,66,.18)!important;background:linear-gradient(135deg,rgba(255,255,255,.09),rgba(255,255,255,.035))!important;box-shadow:0 18px 70px rgba(0,0,0,.34),0 0 34px rgba(184,109,255,.10),inset 0 1px 0 rgba(255,255,255,.10)!important}
#topOpenBoostersBtn{border-color:rgba(255,116,93,.34)!important;background:linear-gradient(135deg,rgba(117,40,45,.78),rgba(64,34,48,.72))!important;box-shadow:0 0 22px rgba(255,95,77,.12)}
.panel,.collection-card,.collection-stats>div{background:radial-gradient(circle at 12% 0%,rgba(184,109,255,.11),transparent 36%),linear-gradient(145deg,rgba(255,255,255,.075),rgba(255,255,255,.025))!important;border-color:rgba(255,255,255,.12)!important}
.collection-grid{grid-template-columns:repeat(auto-fill,minmax(172px,1fr))!important}
.collection-card{position:relative;transform:translateZ(0);transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}
.collection-card:hover{transform:translateY(-5px) scale(1.015);box-shadow:0 24px 74px rgba(0,0,0,.44),0 0 28px rgba(184,109,255,.12)}
.collection-art{position:relative;overflow:hidden}
.collection-art::after{content:"";position:absolute;inset:0;background:linear-gradient(115deg,transparent 0%,rgba(255,255,255,.10) 44%,transparent 60%);transform:translateX(-140%);transition:transform .65s cubic-bezier(.18,.82,.22,1)}
.collection-card:hover .collection-art::after{transform:translateX(140%)}
.collection-count-badge-v62{position:absolute;right:10px;top:10px;z-index:2;padding:5px 8px;border-radius:999px;font-size:12px;font-weight:950;color:#fff;background:rgba(0,0,0,.62);border:1px solid rgba(255,255,255,.20);box-shadow:0 0 18px rgba(245,200,66,.16)}
.collection-rarity::before{content:"";display:inline-block;width:7px;height:7px;border-radius:50%;background:currentColor;box-shadow:0 0 12px currentColor;margin-right:6px}
.v31-flash,.v32-white-flash,.v36-white-flash,.reveal-white-flash,.flash-white,.screen-flash,.rarity-flash{opacity:0!important;display:none!important}
.card-inspect.rarity-mythic,.collection-card.rarity-mythic{box-shadow:0 24px 76px rgba(0,0,0,.42),0 0 38px rgba(217,140,255,.18),0 0 20px rgba(245,200,66,.12)!important}
.card-inspect.rarity-rare,.collection-card.rarity-rare{box-shadow:0 20px 62px rgba(0,0,0,.38),0 0 28px rgba(99,179,255,.14)!important}
.primary-btn{letter-spacing:.02em;box-shadow:0 12px 34px rgba(255,93,80,.22),inset 0 1px 0 rgba(255,255,255,.10)!important}
@media(max-width:720px){.user-profile-bar{position:relative;top:auto}}


/* V63 — Level achievement + collection card zoom */
.level-achievement-v63{
  position:fixed;
  left:50%;
  top:84px;
  transform:translateX(-50%) translateY(-22px) scale(.96);
  z-index:9999;
  min-width:280px;
  padding:18px 22px 18px 76px;
  border-radius:22px;
  border:1px solid rgba(245,200,66,.36);
  background:
    radial-gradient(circle at 24px 50%, rgba(245,200,66,.28), transparent 34%),
    linear-gradient(135deg, rgba(44,20,56,.96), rgba(18,8,22,.96));
  box-shadow:0 24px 80px rgba(0,0,0,.44),0 0 44px rgba(245,200,66,.18);
  opacity:0;
  pointer-events:none;
  transition:opacity .28s ease, transform .38s cubic-bezier(.18,.82,.22,1);
}
.level-achievement-v63.show{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}
.level-achievement-ring-v63{
  position:absolute;left:18px;top:50%;width:42px;height:42px;border-radius:50%;
  transform:translateY(-50%);
  border:2px solid rgba(245,200,66,.78);
  box-shadow:0 0 22px rgba(245,200,66,.32), inset 0 0 18px rgba(245,200,66,.18);
}
.level-achievement-ring-v63::after{content:"★";position:absolute;inset:0;display:grid;place-items:center;color:#ffd86b;font-size:18px}
.level-achievement-kicker-v63{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.62);font-weight:900}
.level-achievement-title-v63{margin-top:3px;font-size:24px;line-height:1;font-weight:950;color:#fff}
.level-achievement-sub-v63{margin-top:5px;font-size:12px;color:rgba(255,255,255,.68)}

.collection-card{cursor:pointer}

.collection-card-modal-v63.hidden{display:none!important}
.collection-card-modal-v63{position:fixed;inset:0;z-index:9998;display:grid;place-items:center;padding:24px}
.collection-card-modal-backdrop-v63{position:absolute;inset:0;background:rgba(3,2,7,.78);backdrop-filter:blur(12px)}
.collection-card-modal-panel-v63{
  position:relative;
  width:min(860px,94vw);
  min-height:520px;
  display:grid;
  grid-template-columns:minmax(260px,390px) 1fr;
  gap:24px;
  padding:22px;
  border-radius:28px;
  border:1px solid rgba(255,255,255,.14);
  background:linear-gradient(135deg,rgba(255,255,255,.09),rgba(255,255,255,.035));
  box-shadow:0 36px 120px rgba(0,0,0,.62),0 0 54px rgba(184,109,255,.16);
  animation:collectionModalInV63 .28s cubic-bezier(.18,.82,.22,1) both;
}
@keyframes collectionModalInV63{from{opacity:0;transform:translateY(18px) scale(.97)}to{opacity:1;transform:none}}
.collection-card-modal-close-v63{
  position:absolute;right:14px;top:12px;width:38px;height:38px;border-radius:50%;
  border:1px solid rgba(255,255,255,.14);background:rgba(0,0,0,.28);color:#fff;font-size:24px;cursor:pointer;z-index:2
}
.collection-card-modal-art-v63{
  border-radius:22px;
  min-height:500px;
  background:radial-gradient(circle at 50% 18%,rgba(255,255,255,.15),transparent 32%),linear-gradient(135deg,#24112f,#07040a);
  background-size:cover;
  background-position:center;
  display:grid;
  place-items:center;
  font-size:72px;
  border:1px solid rgba(255,255,255,.12);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.10),0 22px 70px rgba(0,0,0,.34);
}
.collection-card-modal-info-v63{align-self:center}
.collection-card-modal-rarity-v63{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:950}
.collection-card-modal-info-v63 h2{margin:10px 0 8px;font-size:42px;line-height:.95;color:#fff}
.collection-card-modal-role-v63{color:rgba(255,255,255,.72);font-weight:800}
.collection-card-modal-quote-v63{margin-top:22px;color:rgba(255,255,255,.70);font-size:16px;line-height:1.5}
.collection-card-modal-count-v63{margin-top:22px;display:inline-flex;padding:9px 13px;border-radius:999px;background:rgba(0,0,0,.28);border:1px solid rgba(255,255,255,.12);font-weight:900}
.collection-card-modal-panel-v63.rarity-mythic{box-shadow:0 36px 120px rgba(0,0,0,.62),0 0 72px rgba(217,140,255,.20),0 0 48px rgba(245,200,66,.12)}
.collection-card-modal-panel-v63.rarity-legendary{box-shadow:0 36px 120px rgba(0,0,0,.62),0 0 64px rgba(255,141,71,.18)}
.collection-card-modal-panel-v63.rarity-epic{box-shadow:0 36px 120px rgba(0,0,0,.62),0 0 64px rgba(184,109,255,.18)}
.collection-card-modal-panel-v63.rarity-rare{box-shadow:0 36px 120px rgba(0,0,0,.62),0 0 60px rgba(99,179,255,.16)}
@media(max-width:760px){
  .collection-card-modal-panel-v63{grid-template-columns:1fr;min-height:0}
  .collection-card-modal-art-v63{min-height:420px}
  .collection-card-modal-info-v63 h2{font-size:32px}
}

/* V65 collection modal click fix */
button.collection-card{
  appearance:none;
  border:1px solid rgba(255,255,255,.10);
  padding:0;
  text-align:left;
  color:inherit;
  font:inherit;
}

/* V66 — Collection opens real booster card */
.collection-real-card-modal-v66{
  place-items:center;
  background:rgba(3,2,7,.66);
}
.collection-real-card-panel-v66{
  position:relative;
  width:min(760px,96vw);
  min-height:min(92vh,900px);
  display:grid;
  place-items:center;
  padding:24px;
  border-radius:28px;
  border:1px solid rgba(255,255,255,.10);
  background:radial-gradient(circle at 50% 12%,rgba(184,109,255,.16),transparent 42%),rgba(5,3,10,.86);
  box-shadow:0 36px 120px rgba(0,0,0,.62);
}
.collection-real-card-stage-v66{
  position:relative;
  display:grid;
  place-items:center;
  gap:18px;
  width:100%;
}
.collection-real-card-stage-v66 .card-single{
  width:min(520px,72vw);
  aspect-ratio:0.68;
  transform:none!important;
}
.collection-real-card-stage-v66 .card-flip-shell{
  transform:rotateY(180deg)!important;
}
.collection-real-card-stage-v66 .card-glow{
  width:min(560px,78vw);
  height:min(760px,112vw);
  opacity:.72;
}
.collection-card-count-v66{
  padding:9px 14px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.055);
  color:#fff;
  font-weight:900;
  box-shadow:0 12px 36px rgba(0,0,0,.28);
}
.collection-real-close-v66{
  width:min(220px,70vw);
}
.collection-real-card-modal-v66 .collection-card-modal-close-v63{
  right:16px;
  top:16px;
}
@media(max-width:720px){
  .collection-real-card-stage-v66 .card-single{width:min(500px,86vw)}
}


/* V67 — collection modal gets real reveal FX layers */
.collection-real-card-stage-v66{
  isolation:isolate;
}
.collection-fx-stage-v67{
  position:absolute;
  inset:50% auto auto 50%;
  width:min(720px,96vw);
  height:min(860px,130vw);
  transform:translate(-50%,-50%);
  pointer-events:none;
  z-index:0;
  opacity:.88;
}
.collection-real-card-stage-v66 .card-glow{z-index:1}
.collection-real-card-stage-v66 .card-single{z-index:2}
.collection-fx-stage-v67 .fx-aura,
.collection-fx-stage-v67 .fx-rays,
.collection-fx-stage-v67 .fx-burst,
.collection-fx-stage-v67 .fx-particles{
  position:absolute;
  inset:0;
  pointer-events:none;
}
.collection-fx-stage-v67 .fx-aura{
  filter:blur(22px);
  opacity:.78;
}
.collection-fx-stage-v67 .fx-rays{
  opacity:.22;
  mix-blend-mode:screen;
  animation:collectionRaysSpinV67 9s linear infinite;
}
@keyframes collectionRaysSpinV67{
  to{transform:rotate(360deg)}
}
.collection-fx-stage-v67 .fx-burst{
  border-radius:50%;
  scale:.3;
  opacity:0;
  background:radial-gradient(circle, rgba(255,255,255,.16), transparent 58%);
}
.collection-fx-stage-v67 .fx-burst.active{
  animation:collectionBurstV67 1.2s cubic-bezier(.18,.82,.22,1) both;
}
@keyframes collectionBurstV67{
  0%{opacity:.55;scale:.22}
  100%{opacity:0;scale:1.08}
}
.collection-fx-stage-v67 .fx-particles i{
  position:absolute;
  left:50%;
  top:50%;
  width:4px;
  height:4px;
  border-radius:50%;
  opacity:0;
  box-shadow:0 0 12px currentColor;
  animation:collectionParticleV67 2.8s ease-in-out infinite;
  animation-delay:var(--d);
}
@keyframes collectionParticleV67{
  0%{opacity:0;transform:translate(0,0) scale(.7)}
  18%{opacity:.85}
  100%{opacity:0;transform:translate(var(--x),var(--y)) scale(.15)}
}
.collection-real-card-stage-v66 .mythic-glitter,
.collection-real-card-stage-v66 .legendary-glitter{
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:5;
}
.collection-real-card-stage-v66 .card-holo-hover{
  opacity:.55;
}


/* V68 — visible collection card FX, idle + hover */
.collection-real-card-modal-v66{
  display:grid;
  place-items:center;
}
.collection-real-card-panel-v66{
  overflow:hidden;
}
.collection-real-card-panel-v66.fx-pop-v68{
  animation:collectionPopV68 .55s cubic-bezier(.18,.82,.22,1) both;
}
@keyframes collectionPopV68{
  0%{transform:translateY(16px) scale(.96);opacity:.75;filter:brightness(.8)}
  65%{transform:translateY(0) scale(1.015);opacity:1;filter:brightness(1.15)}
  100%{transform:translateY(0) scale(1);filter:brightness(1)}
}

.collection-real-card-stage-v66{
  position:relative;
  isolation:isolate;
}

.collection-aura-v68{
  position:absolute;
  left:50%;
  top:46%;
  width:min(760px,105vw);
  height:min(900px,140vw);
  transform:translate(-50%,-50%);
  filter:blur(32px);
  opacity:.68;
  pointer-events:none;
  z-index:0;
  animation:collectionAuraPulseV68 3.2s ease-in-out infinite;
}

@keyframes collectionAuraPulseV68{
  0%,100%{opacity:.46;transform:translate(-50%,-50%) scale(.94)}
  50%{opacity:.82;transform:translate(-50%,-50%) scale(1.05)}
}

.collection-rays-v68{
  position:absolute;
  left:50%;
  top:46%;
  width:min(720px,100vw);
  height:min(720px,100vw);
  transform:translate(-50%,-50%);
  border-radius:50%;
  opacity:.30;
  mix-blend-mode:screen;
  pointer-events:none;
  z-index:1;
  animation:collectionRaysSpinV68 10s linear infinite;
}

@keyframes collectionRaysSpinV68{
  from{transform:translate(-50%,-50%) rotate(0deg)}
  to{transform:translate(-50%,-50%) rotate(360deg)}
}

.collection-sparks-v68{
  position:absolute;
  left:50%;
  top:46%;
  width:1px;
  height:1px;
  pointer-events:none;
  z-index:4;
}

.collection-sparks-v68 i{
  position:absolute;
  width:var(--sz);
  height:var(--sz);
  border-radius:50%;
  opacity:0;
  box-shadow:0 0 12px currentColor, 0 0 22px currentColor;
  animation:collectionSparkFloatV68 3.6s ease-in-out infinite;
  animation-delay:var(--d);
}

@keyframes collectionSparkFloatV68{
  0%{opacity:0;transform:translate(0,0) scale(.5)}
  12%{opacity:.9}
  58%{opacity:.55}
  100%{opacity:0;transform:translate(var(--x),var(--y)) scale(.12)}
}

.collection-orbit-fx-v68{
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:0;
  opacity:.55;
}

.collection-orbit-fx-v68 span{
  position:absolute;
  left:50%;
  top:50%;
  width:560px;
  height:560px;
  border:1px solid rgba(255,255,255,.08);
  border-top-color:rgba(255,255,255,.22);
  border-radius:50%;
  transform:translate(-50%,-50%) rotate(0deg);
  animation:collectionOrbitV68 12s linear infinite;
}

.collection-orbit-fx-v68 span:nth-child(2){
  width:690px;height:690px;animation-duration:18s;animation-direction:reverse;opacity:.55;
}
.collection-orbit-fx-v68 span:nth-child(3){
  width:420px;height:420px;animation-duration:9s;opacity:.38;
}

@keyframes collectionOrbitV68{
  to{transform:translate(-50%,-50%) rotate(360deg)}
}

.collection-real-card-v68{
  position:relative;
  z-index:5!important;
  transition:transform .22s ease, filter .22s ease;
  filter:drop-shadow(0 30px 70px rgba(0,0,0,.62));
}

.collection-real-card-v68 .card-face{
  overflow:hidden;
}

.collection-holo-v68{
  position:absolute;
  inset:-20%;
  z-index:5;
  pointer-events:none;
  opacity:.42;
  mix-blend-mode:screen;
  background:
    radial-gradient(circle at 20% 20%, rgba(255,255,255,.24), transparent 16%),
    linear-gradient(115deg, transparent 0%, rgba(255,255,255,.18) 42%, transparent 54%),
    linear-gradient(40deg, rgba(255,0,180,.12), rgba(0,230,255,.10), rgba(255,220,80,.08));
  transform:translateX(-18%) rotate(8deg);
  animation:collectionHoloIdleV68 4.5s ease-in-out infinite;
}

@keyframes collectionHoloIdleV68{
  0%,100%{transform:translateX(-18%) rotate(8deg);opacity:.26}
  50%{transform:translateX(18%) rotate(8deg);opacity:.50}
}

.collection-scan-v68{
  position:absolute;
  inset:0;
  z-index:6;
  pointer-events:none;
  opacity:.20;
  background:linear-gradient(to bottom, transparent, rgba(255,255,255,.20), transparent);
  transform:translateY(-110%);
  mix-blend-mode:screen;
  animation:collectionScanV68 3.8s ease-in-out infinite;
}

@keyframes collectionScanV68{
  0%,15%{transform:translateY(-110%)}
  55%{transform:translateY(110%)}
  100%{transform:translateY(110%)}
}

.collection-real-card-stage-v66:hover .collection-real-card-v68{
  transform:translateY(-8px) scale(1.025)!important;
  filter:drop-shadow(0 40px 90px rgba(0,0,0,.72)) brightness(1.08);
}

.collection-real-card-stage-v66:hover .collection-holo-v68{
  opacity:.75;
  animation-duration:1.2s;
}

.collection-real-card-stage-v66:hover .collection-aura-v68{
  opacity:.95;
  filter:blur(26px);
}

.collection-real-card-panel-v66.rarity-mythic .collection-holo-v68{
  opacity:.56;
}
.collection-real-card-panel-v66.rarity-mythic .collection-rays-v68{
  opacity:.42;
}
.collection-real-card-panel-v66.rarity-legendary .collection-rays-v68{
  opacity:.38;
}
.collection-real-card-panel-v66.rarity-epic .collection-rays-v68{
  opacity:.34;
}
.collection-real-card-panel-v66.rarity-rare .collection-rays-v68{
  opacity:.28;
}


/* V74 — Fix propre depuis V69 stable
   - modal inspect centré en fixed
   - garde le ratio original 2/3
   - aucun overlay global ajouté
*/
.card-inspect-modal:not(.hidden){
  position:fixed !important;
  inset:0 !important;
  z-index:10000 !important;
  display:grid !important;
  place-items:center !important;
  padding:clamp(14px, 3vw, 34px) !important;
  overflow:hidden !important;
}

.card-inspect-backdrop{
  position:absolute !important;
  inset:0 !important;
}

.card-inspect-shell{
  position:relative !important;
  z-index:2 !important;
  display:grid !important;
  place-items:center !important;
  gap:18px !important;
  width:100% !important;
  height:100% !important;
  margin:0 !important;
  transform:none !important;
}

.card-inspect-wrap{
  position:relative !important;
  width:min(520px, 86vw, calc(86vh * 2 / 3)) !important;
  aspect-ratio:2 / 3 !important;
  height:auto !important;
  max-height:86vh !important;
  perspective:1600px !important;
  margin:0 auto !important;
  transform:none !important;
}

.card-inspect{
  width:100% !important;
  height:100% !important;
  aspect-ratio:2 / 3 !important;
  display:block !important;
  visibility:visible !important;
  opacity:1 !important;
}

.card-inspect-glow{
  position:absolute !important;
  inset:-52px !important;
  z-index:0 !important;
}

#inspectCloseBtn{
  position:fixed !important;
  right:clamp(14px, 3vw, 34px) !important;
  top:clamp(14px, 3vw, 34px) !important;
  z-index:10002 !important;
}

/* Lisibilité SAFE partout: shadows uniquement, pas d'overlay/pseudo element */
.card-rarity,
.card-number,
.card-role,
.card-name,
.card-desc,
#singleRarity,
#singleNumber,
#singleRole,
#singleName,
#singleDesc,
#inspectRarity,
#inspectNumber,
#inspectRole,
#inspectName,
#inspectDesc,
#cardPreviewRarity,
#cardPreviewNumber,
#cardPreviewRole,
#cardPreviewName,
#cardPreviewDesc{
  text-shadow:
    0 2px 3px rgba(0,0,0,.95),
    0 0 9px rgba(0,0,0,.82),
    0 0 18px rgba(0,0,0,.55) !important;
}

.card-rarity,
#singleRarity,
#inspectRarity,
#cardPreviewRarity{
  font-weight:950 !important;
  letter-spacing:.22em !important;
  opacity:1 !important;
}

.card-number,
#singleNumber,
#inspectNumber,
#cardPreviewNumber{
  font-weight:900 !important;
  opacity:.92 !important;
}

.card-role,
#singleRole,
#inspectRole,
#cardPreviewRole{
  font-weight:950 !important;
  letter-spacing:.16em !important;
  text-transform:uppercase !important;
  opacity:1 !important;
}

.card-desc,
#singleDesc,
#inspectDesc,
#cardPreviewDesc{
  opacity:1 !important;
  color:rgba(255,255,255,.86) !important;
  font-weight:650 !important;
}

@media(max-width:720px){
  .card-inspect-wrap{
    width:min(92vw, calc(82vh * 2 / 3)) !important;
    max-height:82vh !important;
  }
}


/* ═══════════════════════════════════════════════
   V75 — READABILITY GODLIKE
   Lisibilité premium partout: reveal, inspect, preview admin, collection modal.
   Aucun overlay global fullscreen.
═══════════════════════════════════════════════ */

/* La face devient le scope local des overlays */
.card-face,
.card-inspect{
  position:relative !important;
}

/* Overlay cinematic local uniquement dans la carte */
.card-face .card-art::after,
.card-inspect .card-art::after{
  content:"" !important;
  position:absolute !important;
  inset:0 !important;
  z-index:2 !important;
  pointer-events:none !important;
  background:
    linear-gradient(180deg,
      rgba(0,0,0,.46) 0%,
      rgba(0,0,0,.14) 14%,
      rgba(0,0,0,.00) 38%,
      rgba(0,0,0,.12) 58%,
      rgba(0,0,0,.58) 82%,
      rgba(0,0,0,.86) 100%) !important;
}

/* Backing top lisible mais discret */
.card-ui{
  z-index:12 !important;
  padding:10px 12px 30px !important;
  border-radius:18px 18px 0 0;
  background:
    linear-gradient(180deg,
      rgba(0,0,0,.48) 0%,
      rgba(0,0,0,.28) 46%,
      transparent 100%) !important;
  backdrop-filter: blur(1.5px);
}

/* Backing bottom premium */
.card-bottom{
  z-index:12 !important;
  left:0 !important;
  right:0 !important;
  bottom:0 !important;
  padding:56px 18px 18px !important;
  background:
    linear-gradient(180deg,
      transparent 0%,
      rgba(0,0,0,.34) 28%,
      rgba(0,0,0,.72) 72%,
      rgba(0,0,0,.92) 100%) !important;
  border-radius:0 0 20px 20px !important;
  backdrop-filter: blur(.7px);
}

/* Priorité des FX: sous l'UI */
.card-art{position:absolute !important; inset:0 !important; z-index:1 !important;}
.card-shade{z-index:3 !important;}
.card-holo-hover,
.collection-holo-v68,
.collection-scan-v68{z-index:4 !important;}
.hover-particles,
.reveal-burst,
.rarity-particles{z-index:5 !important;}
.card-border{z-index:20 !important;}

/* Text shadows plus agressives */
.card-rarity,
.card-number,
.card-role,
.card-name,
.card-desc,
#singleRarity,#singleNumber,#singleRole,#singleName,#singleDesc,
#inspectRarity,#inspectNumber,#inspectRole,#inspectName,#inspectDesc,
#cardPreviewRarity,#cardPreviewNumber,#cardPreviewRole,#cardPreviewName,#cardPreviewDesc{
  text-shadow:
    0 2px 2px rgba(0,0,0,.98),
    0 0 8px rgba(0,0,0,.92),
    0 0 22px rgba(0,0,0,.72),
    0 0 34px rgba(0,0,0,.45) !important;
}

/* Rareté */
.card-rarity,
#singleRarity,#inspectRarity,#cardPreviewRarity{
  font-size:clamp(10px, 1.18vw, 13px) !important;
  font-weight:1000 !important;
  letter-spacing:.26em !important;
  opacity:1 !important;
  filter:saturate(1.45) brightness(1.25) !important;
  -webkit-text-stroke:.25px rgba(255,255,255,.22);
}

/* Numéro */
.card-number,
#singleNumber,#inspectNumber,#cardPreviewNumber{
  font-size:clamp(10px, 1.05vw, 12px) !important;
  font-weight:950 !important;
  opacity:.96 !important;
  color:rgba(255,255,255,.94) !important;
}

/* Rôle / faction */
.card-role,
#singleRole,#inspectRole,#cardPreviewRole{
  font-size:clamp(10px, 1.15vw, 13px) !important;
  font-weight:1000 !important;
  letter-spacing:.18em !important;
  text-transform:uppercase !important;
  opacity:1 !important;
  filter:saturate(1.35) brightness(1.18) !important;
  -webkit-text-stroke:.18px rgba(255,255,255,.18);
}

/* Nom: contour + glow subtil */
.card-name,
#singleName,#inspectName,#cardPreviewName{
  font-weight:1000 !important;
  color:#fff !important;
  -webkit-text-stroke:.55px rgba(0,0,0,.55);
  text-shadow:
    0 3px 2px rgba(0,0,0,1),
    0 0 10px rgba(0,0,0,.94),
    0 0 24px rgba(0,0,0,.76),
    0 0 38px rgba(255,255,255,.10) !important;
}

/* Citation / description */
.card-desc,
#singleDesc,#inspectDesc,#cardPreviewDesc{
  font-size:clamp(11px, 1.18vw, 14px) !important;
  line-height:1.25 !important;
  font-weight:750 !important;
  color:rgba(255,255,255,.94) !important;
  opacity:1 !important;
  max-width:95%;
}

/* Pastilles très discrètes derrière rareté et numéro sur inspect/reveal */
.card-ui .card-rarity,
.card-ui .card-number{
  display:inline-flex;
  align-items:center;
  min-height:18px;
}

/* Boost par rareté pour le nom */
.rarity-mythic .card-name,
.rarity-mythic #inspectName,
.card-single.rarity-mythic .card-name{
  text-shadow:
    0 3px 2px rgba(0,0,0,1),
    0 0 12px rgba(0,0,0,.95),
    0 0 26px rgba(255,219,87,.22),
    0 0 40px rgba(184,109,255,.18) !important;
}

.rarity-legendary .card-name,
.rarity-legendary #inspectName,
.card-single.rarity-legendary .card-name{
  text-shadow:
    0 3px 2px rgba(0,0,0,1),
    0 0 12px rgba(0,0,0,.95),
    0 0 28px rgba(255,141,71,.22) !important;
}

.rarity-epic .card-name,
.rarity-epic #inspectName,
.card-single.rarity-epic .card-name{
  text-shadow:
    0 3px 2px rgba(0,0,0,1),
    0 0 12px rgba(0,0,0,.95),
    0 0 26px rgba(184,109,255,.20) !important;
}

.rarity-rare .card-name,
.rarity-rare #inspectName,
.card-single.rarity-rare .card-name{
  text-shadow:
    0 3px 2px rgba(0,0,0,1),
    0 0 12px rgba(0,0,0,.95),
    0 0 24px rgba(74,163,255,.20) !important;
}

/* Admin preview suit la même lisibilité */
#cardPreviewCard .card-art::after{
  content:"" !important;
  position:absolute !important;
  inset:0 !important;
  pointer-events:none !important;
  background:
    linear-gradient(180deg,
      rgba(0,0,0,.42) 0%,
      transparent 36%,
      rgba(0,0,0,.72) 100%) !important;
}

/* Collection tiles aussi plus lisibles */
.collection-meta{
  background:linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,.52)) !important;
  border-radius:0 0 16px 16px;
}

.collection-rarity,
.collection-name,
.collection-role,
.collection-date{
  text-shadow:
    0 2px 3px rgba(0,0,0,.95),
    0 0 10px rgba(0,0,0,.82) !important;
}

.collection-name{
  font-weight:950 !important;
  color:#fff !important;
}

.collection-role,
.collection-date{
  color:rgba(255,255,255,.78) !important;
}

/* Mobile: garde compact */
@media(max-width:720px){
  .card-bottom{
    padding:44px 14px 14px !important;
  }
  .card-desc,
  #singleDesc,#inspectDesc,#cardPreviewDesc{
    font-size:11px !important;
  }
  .card-rarity,
  #singleRarity,#inspectRarity,#cardPreviewRarity{
    letter-spacing:.20em !important;
  }
}


/* ═══════════════════════════════════════════════
   V76 — CARD AAA REDESIGN
   Direction artistique premium:
   hiérarchie, respiration, meta discrète, nom dominant.
═══════════════════════════════════════════════ */

/* Reset partiel du look V75 trop agressif */
.card-rarity,
.card-number,
.card-role,
.card-name,
.card-desc,
#singleRarity,#singleNumber,#singleRole,#singleName,#singleDesc,
#inspectRarity,#inspectNumber,#inspectRole,#inspectName,#inspectDesc,
#cardPreviewRarity,#cardPreviewNumber,#cardPreviewRole,#cardPreviewName,#cardPreviewDesc{
  -webkit-text-stroke:0 !important;
  filter:none !important;
}

/* Artwork d'abord: overlay plus doux, plus collector */
.card-face .card-art::after,
.card-inspect .card-art::after,
#cardPreviewCard .card-art::after{
  content:"" !important;
  position:absolute !important;
  inset:0 !important;
  z-index:2 !important;
  pointer-events:none !important;
  background:
    linear-gradient(180deg,
      rgba(7,4,12,.34) 0%,
      rgba(7,4,12,.10) 18%,
      rgba(7,4,12,.00) 44%,
      rgba(7,4,12,.14) 68%,
      rgba(5,3,8,.58) 88%,
      rgba(3,2,5,.86) 100%) !important;
}

/* Cadre plus fin / plus luxe */
.card-border{
  opacity:.82 !important;
  filter:drop-shadow(0 0 10px rgba(255,255,255,.10));
}

/* Top UI: flottant, discret, pas bandeau lourd */
.card-ui{
  z-index:14 !important;
  top:0 !important;
  left:0 !important;
  right:0 !important;
  padding:18px 20px 0 !important;
  background:none !important;
  backdrop-filter:none !important;
  display:flex !important;
  align-items:flex-start !important;
  justify-content:space-between !important;
  pointer-events:none;
}

/* Bottom UI: plus d'air, pas tassé */
.card-bottom{
  z-index:14 !important;
  left:0 !important;
  right:0 !important;
  bottom:0 !important;
  padding:78px 22px 22px !important;
  background:
    linear-gradient(180deg,
      transparent 0%,
      rgba(5,3,8,.20) 24%,
      rgba(5,3,8,.62) 70%,
      rgba(5,3,8,.88) 100%) !important;
  border-radius:0 0 20px 20px !important;
  backdrop-filter:none !important;
  pointer-events:none;
}

/* Rarity = bijou, pas gros texte blanc */
.card-rarity,
#singleRarity,#inspectRarity,#cardPreviewRarity{
  display:inline-flex !important;
  align-items:center !important;
  width:auto !important;
  max-width:max-content !important;
  padding:4px 7px 4px 8px !important;
  border-radius:999px !important;
  background:rgba(0,0,0,.34) !important;
  border:1px solid rgba(255,255,255,.14) !important;
  color:#f5d779 !important;
  font-family:Inter, ui-sans-serif, system-ui, sans-serif !important;
  font-size:9px !important;
  line-height:1 !important;
  font-weight:900 !important;
  letter-spacing:.28em !important;
  text-transform:uppercase !important;
  opacity:.98 !important;
  text-shadow:
    0 1px 2px rgba(0,0,0,.90),
    0 0 10px rgba(245,215,121,.16) !important;
}

/* Number = discret mais visible */
.card-number,
#singleNumber,#inspectNumber,#cardPreviewNumber{
  display:inline-flex !important;
  justify-content:flex-end !important;
  width:auto !important;
  padding:4px 7px !important;
  border-radius:999px !important;
  background:rgba(0,0,0,.22) !important;
  border:1px solid rgba(255,255,255,.08) !important;
  color:rgba(255,255,255,.70) !important;
  font-family:Inter, ui-sans-serif, system-ui, sans-serif !important;
  font-size:10px !important;
  line-height:1 !important;
  font-weight:800 !important;
  letter-spacing:.06em !important;
  opacity:.9 !important;
  text-shadow:0 1px 2px rgba(0,0,0,.9) !important;
}

/* Role/faction = petite capsule premium */
.card-role,
#singleRole,#inspectRole,#cardPreviewRole{
  display:inline-flex !important;
  width:auto !important;
  max-width:max-content !important;
  margin-bottom:8px !important;
  padding:5px 8px 4px !important;
  border-radius:999px !important;
  background:rgba(245,215,121,.10) !important;
  border:1px solid rgba(245,215,121,.22) !important;
  color:#f5d779 !important;
  font-family:Inter, ui-sans-serif, system-ui, sans-serif !important;
  font-size:10px !important;
  line-height:1 !important;
  font-weight:900 !important;
  letter-spacing:.16em !important;
  text-transform:uppercase !important;
  opacity:1 !important;
  text-shadow:0 1px 2px rgba(0,0,0,.86), 0 0 12px rgba(245,215,121,.12) !important;
}

/* Nom = star de la carte, mais plus raffiné */
.card-name,
#singleName,#inspectName,#cardPreviewName{
  margin:0 0 7px !important;
  color:#fff !important;
  font-family:Inter, ui-sans-serif, system-ui, sans-serif !important;
  font-size:clamp(30px, 4.15vw, 52px) !important;
  line-height:.88 !important;
  font-weight:1000 !important;
  letter-spacing:-.055em !important;
  font-style:italic !important;
  text-transform:uppercase !important;
  text-shadow:
    0 3px 3px rgba(0,0,0,.96),
    0 0 14px rgba(0,0,0,.88),
    0 0 28px rgba(0,0,0,.56) !important;
}

/* Citation = autre registre, plus élégante */
.card-desc,
#singleDesc,#inspectDesc,#cardPreviewDesc{
  margin-top:0 !important;
  color:rgba(235,231,224,.82) !important;
  font-family:Georgia, "Times New Roman", serif !important;
  font-size:clamp(12px, 1.24vw, 15px) !important;
  line-height:1.35 !important;
  font-weight:500 !important;
  font-style:italic !important;
  letter-spacing:.005em !important;
  opacity:1 !important;
  max-width:92% !important;
  text-shadow:
    0 2px 2px rgba(0,0,0,.90),
    0 0 10px rgba(0,0,0,.72) !important;
}

/* Variation subtile par rareté */
.rarity-mythic .card-rarity,
.card-single.rarity-mythic .card-rarity{
  color:#ffe58a !important;
  border-color:rgba(255,229,138,.30) !important;
  background:rgba(68,35,4,.28) !important;
}

.rarity-mythic .card-role,
.card-single.rarity-mythic .card-role{
  color:#ffe58a !important;
  border-color:rgba(255,229,138,.28) !important;
  background:rgba(255,229,138,.11) !important;
}

.rarity-legendary .card-rarity,
.rarity-legendary .card-role{
  color:#ffb66f !important;
  border-color:rgba(255,182,111,.28) !important;
}

.rarity-epic .card-rarity,
.rarity-epic .card-role{
  color:#d9a8ff !important;
  border-color:rgba(217,168,255,.28) !important;
}

.rarity-rare .card-rarity,
.rarity-rare .card-role{
  color:#9bd1ff !important;
  border-color:rgba(155,209,255,.28) !important;
}

/* Inspect modal: un poil plus respirant */
.card-inspect-wrap{
  width:min(540px, 86vw, calc(88vh * 2 / 3)) !important;
}

.card-inspect .card-bottom{
  padding-left:24px !important;
  padding-right:24px !important;
  padding-bottom:24px !important;
}

/* Reveal card responsive */
.card-single .card-bottom{
  padding-left:22px !important;
  padding-right:22px !important;
}

/* Preview admin conserve la hiérarchie */
.admin-preview .card-name,
#cardPreviewName{
  font-size:clamp(28px, 3.2vw, 44px) !important;
}

/* Collection tile: plus collector et moins bloc texte */
.collection-meta{
  padding:12px 13px 14px !important;
  background:
    linear-gradient(180deg,
      rgba(5,3,8,.08),
      rgba(5,3,8,.68)) !important;
}

.collection-rarity{
  display:inline-flex !important;
  width:auto !important;
  max-width:max-content !important;
  padding:4px 7px !important;
  border-radius:999px !important;
  background:rgba(0,0,0,.28) !important;
  color:#f5d779 !important;
  font-size:9px !important;
  letter-spacing:.18em !important;
  font-weight:950 !important;
}

.collection-name{
  margin-top:8px !important;
  font-size:16px !important;
  line-height:1.05 !important;
  font-weight:950 !important;
  letter-spacing:-.03em !important;
  color:#fff !important;
}

.collection-role{
  margin-top:5px !important;
  color:rgba(245,215,121,.74) !important;
  font-size:11px !important;
  font-weight:800 !important;
  letter-spacing:.06em !important;
  text-transform:uppercase !important;
}

.collection-date{
  margin-top:6px !important;
  color:rgba(255,255,255,.48) !important;
  font-size:11px !important;
}

/* Mobile / petits écrans: évite le tassage */
@media(max-width:720px){
  .card-ui{
    padding:14px 14px 0 !important;
  }
  .card-bottom{
    padding:58px 16px 16px !important;
  }
  .card-name,
  #singleName,#inspectName,#cardPreviewName{
    font-size:clamp(28px, 9vw, 40px) !important;
  }
  .card-desc,
  #singleDesc,#inspectDesc,#cardPreviewDesc{
    font-size:12px !important;
    max-width:96% !important;
  }
  .card-role,
  #singleRole,#inspectRole,#cardPreviewRole{
    font-size:9px !important;
  }
}


/* ═══════════════════════════════════════════════
   V77 — PREMIUM RARITY SYSTEM FULL
   Base V76 complète + raretés réellement différenciées.
═══════════════════════════════════════════════ */

.card-single,
.card-inspect,
#cardPreviewCard,
.collection-card{
  --rarity-main:#d7dbe4;
  --rarity-soft:rgba(215,219,228,.22);
  --rarity-mid:rgba(215,219,228,.36);
  --rarity-deep:rgba(215,219,228,.10);
}

/* COMMON — silver clean */
.rarity-common{
  --rarity-main:#cfd5df;
  --rarity-soft:rgba(207,213,223,.18);
  --rarity-mid:rgba(207,213,223,.30);
  --rarity-deep:rgba(207,213,223,.08);
}

/* RARE — cyan neon */
.rarity-rare{
  --rarity-main:#61d6ff;
  --rarity-soft:rgba(97,214,255,.22);
  --rarity-mid:rgba(97,214,255,.42);
  --rarity-deep:rgba(97,214,255,.12);
}

/* EPIC — violet energy */
.rarity-epic{
  --rarity-main:#be7cff;
  --rarity-soft:rgba(190,124,255,.24);
  --rarity-mid:rgba(190,124,255,.46);
  --rarity-deep:rgba(190,124,255,.14);
}

/* LEGENDARY — molten gold */
.rarity-legendary{
  --rarity-main:#ffb84d;
  --rarity-soft:rgba(255,184,77,.26);
  --rarity-mid:rgba(255,184,77,.52);
  --rarity-deep:rgba(255,184,77,.16);
}

/* MYTHIC — black gold prism */
.rarity-mythic{
  --rarity-main:#ffe27a;
  --rarity-soft:rgba(255,226,122,.30);
  --rarity-mid:rgba(255,226,122,.58);
  --rarity-deep:rgba(255,226,122,.18);
}

/* Border/outer value instantly readable */
.card-single,
.card-inspect,
#cardPreviewCard{
  border-color:color-mix(in srgb, var(--rarity-main) 52%, rgba(255,255,255,.12)) !important;
  box-shadow:
    0 34px 105px rgba(0,0,0,.62),
    0 0 0 1px var(--rarity-mid),
    0 0 32px var(--rarity-soft),
    inset 0 1px 0 rgba(255,255,255,.08) !important;
}

.rarity-mythic.card-single,
.rarity-mythic.card-inspect,
#cardPreviewCard.rarity-mythic{
  box-shadow:
    0 38px 125px rgba(0,0,0,.72),
    0 0 0 1px rgba(255,226,122,.62),
    0 0 34px rgba(255,226,122,.28),
    0 0 64px rgba(190,124,255,.16),
    0 0 84px rgba(97,214,255,.10),
    inset 0 1px 0 rgba(255,255,255,.14) !important;
}

/* Premium foil layer by rarity, local to card */
.card-face::before,
.card-inspect::before{
  content:"" !important;
  position:absolute !important;
  inset:0 !important;
  pointer-events:none !important;
  z-index:6 !important;
  opacity:.18;
  mix-blend-mode:screen;
  background:
    radial-gradient(circle at 18% 16%, var(--rarity-soft), transparent 18%),
    linear-gradient(115deg, transparent 0%, var(--rarity-deep) 42%, transparent 57%);
}

.rarity-common .card-face::before,
.rarity-common.card-inspect::before{
  opacity:.10;
}

.rarity-rare .card-face::before,
.rarity-rare.card-inspect::before{
  opacity:.26;
  background:
    radial-gradient(circle at 20% 18%, rgba(97,214,255,.32), transparent 18%),
    linear-gradient(115deg, transparent 0%, rgba(97,214,255,.20) 44%, transparent 58%);
}

.rarity-epic .card-face::before,
.rarity-epic.card-inspect::before{
  opacity:.30;
  background:
    radial-gradient(circle at 72% 20%, rgba(190,124,255,.34), transparent 20%),
    linear-gradient(115deg, transparent 0%, rgba(190,124,255,.22) 42%, transparent 58%),
    linear-gradient(40deg, rgba(255,100,230,.10), rgba(120,80,255,.12));
}

.rarity-legendary .card-face::before,
.rarity-legendary.card-inspect::before{
  opacity:.32;
  background:
    radial-gradient(circle at 28% 18%, rgba(255,213,117,.36), transparent 18%),
    linear-gradient(115deg, transparent 0%, rgba(255,184,77,.24) 43%, transparent 58%);
}

.rarity-mythic .card-face::before,
.rarity-mythic.card-inspect::before{
  opacity:.44;
  background:
    radial-gradient(circle at 16% 16%, rgba(255,226,122,.36), transparent 18%),
    radial-gradient(circle at 84% 12%, rgba(97,214,255,.25), transparent 18%),
    linear-gradient(115deg, transparent 0%, rgba(255,255,255,.20) 42%, transparent 55%),
    linear-gradient(35deg, rgba(255,216,107,.20), rgba(97,214,255,.14), rgba(255,112,221,.16), rgba(255,216,107,.12));
  animation:mythicPrismV77 5.2s ease-in-out infinite;
}

@keyframes mythicPrismV77{
  0%,100%{filter:hue-rotate(0deg);opacity:.34}
  50%{filter:hue-rotate(18deg);opacity:.54}
}

/* Rarity badge: different materials */
.card-rarity,
#singleRarity,#inspectRarity,#cardPreviewRarity{
  color:var(--rarity-main) !important;
  border-color:var(--rarity-mid) !important;
  background:
    linear-gradient(135deg, rgba(0,0,0,.58), rgba(0,0,0,.30)),
    radial-gradient(circle at 20% 0%, var(--rarity-soft), transparent 62%) !important;
  box-shadow:
    0 0 0 1px rgba(255,255,255,.035),
    0 0 16px var(--rarity-soft) !important;
  text-shadow:
    0 1px 2px rgba(0,0,0,.95),
    0 0 10px var(--rarity-mid) !important;
}

.rarity-mythic .card-rarity,
.rarity-mythic #inspectRarity,
.rarity-mythic #singleRarity,
.rarity-mythic #cardPreviewRarity{
  color:#1c1404 !important;
  background:
    linear-gradient(135deg, #fff0a8, #ffcb47 42%, #fff4bd 70%, #b77a15) !important;
  border-color:rgba(255,242,178,.70) !important;
  text-shadow:0 1px 0 rgba(255,255,255,.36) !important;
  box-shadow:
    0 0 0 1px rgba(255,255,255,.12),
    0 0 22px rgba(255,226,122,.36),
    inset 0 1px 0 rgba(255,255,255,.55) !important;
}

/* Number also follows rarity but remains secondary */
.card-number,
#singleNumber,#inspectNumber,#cardPreviewNumber{
  color:color-mix(in srgb, var(--rarity-main) 55%, white) !important;
  border-color:rgba(255,255,255,.10) !important;
}

/* Role pill = rarity identity */
.card-role,
#singleRole,#inspectRole,#cardPreviewRole{
  color:var(--rarity-main) !important;
  background:
    linear-gradient(135deg, rgba(0,0,0,.46), rgba(0,0,0,.22)),
    radial-gradient(circle at 10% 10%, var(--rarity-deep), transparent 80%) !important;
  border-color:var(--rarity-mid) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.08),
    0 0 16px var(--rarity-soft) !important;
}

.rarity-mythic .card-role,
.rarity-mythic #inspectRole,
.rarity-mythic #singleRole,
.rarity-mythic #cardPreviewRole{
  color:#ffe88f !important;
  background:
    linear-gradient(135deg, rgba(21,13,3,.82), rgba(70,38,4,.45)),
    radial-gradient(circle at 20% 0%, rgba(255,226,122,.24), transparent 70%) !important;
  border-color:rgba(255,226,122,.46) !important;
}

/* Name tint per rarity: not all flat white */
.card-name,
#singleName,#inspectName,#cardPreviewName{
  color:color-mix(in srgb, var(--rarity-main) 16%, white) !important;
  text-shadow:
    0 3px 3px rgba(0,0,0,.98),
    0 0 14px rgba(0,0,0,.90),
    0 0 28px rgba(0,0,0,.62),
    0 0 24px var(--rarity-soft) !important;
}

.rarity-mythic .card-name,
.rarity-mythic #inspectName,
.rarity-mythic #singleName,
.rarity-mythic #cardPreviewName{
  color:#fffdf2 !important;
  text-shadow:
    0 3px 3px rgba(0,0,0,1),
    0 0 14px rgba(0,0,0,.96),
    0 0 28px rgba(255,226,122,.22),
    0 0 44px rgba(190,124,255,.16),
    0 0 60px rgba(97,214,255,.10) !important;
}

/* Bottom treatment per rarity */
.card-bottom{
  background:
    linear-gradient(180deg,
      transparent 0%,
      rgba(5,3,8,.20) 24%,
      rgba(5,3,8,.64) 70%,
      rgba(5,3,8,.90) 100%),
    radial-gradient(circle at 12% 100%, var(--rarity-deep), transparent 50%) !important;
}

/* Animated premium border for mythic/epic only */
.rarity-mythic .card-border,
.rarity-epic .card-border{
  opacity:1 !important;
  filter:
    drop-shadow(0 0 8px var(--rarity-mid))
    drop-shadow(0 0 18px var(--rarity-soft)) !important;
}

.rarity-mythic .card-border{
  animation:mythicBorderPulseV77 2.8s ease-in-out infinite;
}

@keyframes mythicBorderPulseV77{
  0%,100%{opacity:.86;filter:drop-shadow(0 0 8px rgba(255,226,122,.30))}
  50%{opacity:1;filter:drop-shadow(0 0 14px rgba(255,226,122,.52)) drop-shadow(0 0 24px rgba(190,124,255,.18))}
}

/* Collection tiles inherit rarity */
.collection-card{
  border-color:var(--rarity-mid) !important;
  box-shadow:
    0 20px 60px rgba(0,0,0,.34),
    0 0 22px var(--rarity-deep) !important;
}

.collection-card .collection-rarity{
  color:var(--rarity-main) !important;
  border:1px solid var(--rarity-mid) !important;
  background:rgba(0,0,0,.36) !important;
}

.collection-card.rarity-mythic .collection-rarity{
  color:#1c1404 !important;
  background:linear-gradient(135deg,#fff0a8,#ffcb47,#fff4bd) !important;
}

.collection-card .collection-role{
  color:var(--rarity-main) !important;
}

.collection-card.rarity-mythic{
  box-shadow:
    0 24px 74px rgba(0,0,0,.42),
    0 0 32px rgba(255,226,122,.18),
    0 0 48px rgba(190,124,255,.10) !important;
}

/* Reveal/inspect glow stronger by rarity */
.card-glow.rare{background:radial-gradient(circle at center, rgba(97,214,255,.38), transparent 68%) !important}
.card-glow.epic{background:radial-gradient(circle at center, rgba(190,124,255,.42), transparent 68%) !important}
.card-glow.legendary{background:radial-gradient(circle at center, rgba(255,184,77,.45), transparent 68%) !important}
.card-glow.mythic{background:radial-gradient(circle at center, rgba(255,226,122,.42), rgba(190,124,255,.13), transparent 68%) !important}

/* Rarity-specific desc tone */
.rarity-mythic .card-desc,
.rarity-mythic #inspectDesc,
.rarity-mythic #singleDesc{
  color:rgba(255,247,220,.88) !important;
}

.rarity-rare .card-desc,
.rarity-epic .card-desc,
.rarity-legendary .card-desc{
  color:rgba(241,238,235,.84) !important;
}


/* ═══════════════════════════════════════════════
   V78 — Fix MYTHIC lisible + modal close + collection dots
═══════════════════════════════════════════════ */

/* MYTHIC doit être impossible à rater */
.rarity-mythic .card-rarity,
.rarity-mythic #singleRarity,
.rarity-mythic #inspectRarity,
.rarity-mythic #cardPreviewRarity,
.card-single.rarity-mythic .card-rarity,
.card-inspect.rarity-mythic .card-rarity{
  min-width:74px !important;
  justify-content:center !important;
  padding:7px 11px 6px !important;
  border-radius:10px !important;
  color:#ffe27a !important;
  background:
    linear-gradient(135deg, rgba(10,6,2,.96), rgba(55,31,4,.92) 45%, rgba(12,7,2,.96)) !important;
  border:1px solid rgba(255,226,122,.82) !important;
  box-shadow:
    0 0 0 1px rgba(255,255,255,.10),
    0 0 18px rgba(255,226,122,.52),
    0 0 36px rgba(255,226,122,.22),
    inset 0 1px 0 rgba(255,255,255,.24) !important;
  text-shadow:
    0 1px 1px rgba(0,0,0,1),
    0 0 8px rgba(255,226,122,.72),
    0 0 16px rgba(255,226,122,.38) !important;
  font-size:10px !important;
  line-height:1 !important;
  letter-spacing:.20em !important;
  opacity:1 !important;
  filter:none !important;
  -webkit-text-stroke:0 !important;
}

/* Haut de carte: un peu plus d'air pour le badge mythic */
.rarity-mythic .card-ui,
.card-single.rarity-mythic .card-ui,
.card-inspect.rarity-mythic .card-ui{
  padding-top:16px !important;
  padding-left:18px !important;
  padding-right:18px !important;
}

/* Mythic: bordure plus premium et visible */
.rarity-mythic.card-single,
.rarity-mythic.card-inspect,
#cardPreviewCard.rarity-mythic{
  border-color:rgba(255,226,122,.72) !important;
  box-shadow:
    0 38px 125px rgba(0,0,0,.72),
    0 0 0 1px rgba(255,226,122,.72),
    0 0 26px rgba(255,226,122,.28),
    0 0 58px rgba(255,226,122,.14),
    0 0 84px rgba(190,124,255,.10),
    inset 0 1px 0 rgba(255,255,255,.14) !important;
}

/* Collection rarity dot: soit bien centré, soit invisible si ça gêne.
   On le supprime pour éviter l'effet stressant/décalé. */
.collection-rarity::before{
  content:none !important;
  display:none !important;
}

.collection-rarity{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:0 !important;
  line-height:1 !important;
  vertical-align:middle !important;
}

/* Collection mythic badge aussi identifiable */
.collection-card.rarity-mythic .collection-rarity{
  min-width:62px !important;
  justify-content:center !important;
  color:#ffe27a !important;
  background:
    linear-gradient(135deg, rgba(10,6,2,.96), rgba(55,31,4,.90), rgba(10,6,2,.96)) !important;
  border:1px solid rgba(255,226,122,.72) !important;
  box-shadow:0 0 18px rgba(255,226,122,.22) !important;
  text-shadow:0 0 10px rgba(255,226,122,.42) !important;
}


/* ═══════════════════════════════════════════════
   V79 — PREMIUM SUBTLE RARITY
   Corrige V78: moins bordures couleur fixes, badge Mythic lisible mais élégant.
═══════════════════════════════════════════════ */

/* Stop l'effet "bordure jaune fixe" trop cheap */
.card-single,
.card-inspect,
#cardPreviewCard{
  border-color:rgba(255,255,255,.16) !important;
  box-shadow:
    0 34px 105px rgba(0,0,0,.64),
    0 0 0 1px rgba(255,255,255,.055),
    0 0 22px var(--rarity-deep),
    inset 0 1px 0 rgba(255,255,255,.08) !important;
}

/* Raretés: glow ambiance, pas contour fluo permanent */
.rarity-rare.card-single,
.rarity-rare.card-inspect,
#cardPreviewCard.rarity-rare{
  border-color:rgba(150,220,255,.20) !important;
  box-shadow:
    0 34px 105px rgba(0,0,0,.64),
    0 0 0 1px rgba(150,220,255,.12),
    0 0 26px rgba(97,214,255,.13),
    inset 0 1px 0 rgba(255,255,255,.08) !important;
}

.rarity-epic.card-single,
.rarity-epic.card-inspect,
#cardPreviewCard.rarity-epic{
  border-color:rgba(210,160,255,.22) !important;
  box-shadow:
    0 34px 105px rgba(0,0,0,.64),
    0 0 0 1px rgba(210,160,255,.13),
    0 0 30px rgba(190,124,255,.14),
    inset 0 1px 0 rgba(255,255,255,.08) !important;
}

.rarity-legendary.card-single,
.rarity-legendary.card-inspect,
#cardPreviewCard.rarity-legendary{
  border-color:rgba(255,210,130,.24) !important;
  box-shadow:
    0 36px 110px rgba(0,0,0,.66),
    0 0 0 1px rgba(255,210,130,.15),
    0 0 30px rgba(255,184,77,.15),
    inset 0 1px 0 rgba(255,255,255,.09) !important;
}

.rarity-mythic.card-single,
.rarity-mythic.card-inspect,
#cardPreviewCard.rarity-mythic{
  border-color:rgba(255,238,170,.28) !important;
  box-shadow:
    0 38px 126px rgba(0,0,0,.72),
    0 0 0 1px rgba(255,238,170,.18),
    0 0 34px rgba(255,226,122,.16),
    0 0 70px rgba(190,124,255,.08),
    inset 0 1px 0 rgba(255,255,255,.12) !important;
}

/* Card border: beaucoup plus fin, luxueux, pas couleur aplat */
.card-border{
  opacity:.74 !important;
  filter:
    drop-shadow(0 0 4px rgba(255,255,255,.10))
    drop-shadow(0 0 10px var(--rarity-deep)) !important;
}

.rarity-mythic .card-border{
  opacity:.88 !important;
  filter:
    drop-shadow(0 0 5px rgba(255,238,170,.22))
    drop-shadow(0 0 16px rgba(255,226,122,.14))
    drop-shadow(0 0 26px rgba(190,124,255,.08)) !important;
  animation:none !important;
}

/* Badge mythic: lisible, premium, pas bouton jaune cheap */
.rarity-mythic .card-rarity,
.rarity-mythic #singleRarity,
.rarity-mythic #inspectRarity,
.rarity-mythic #cardPreviewRarity,
.card-single.rarity-mythic .card-rarity,
.card-inspect.rarity-mythic .card-rarity{
  min-width:76px !important;
  padding:6px 10px 5px !important;
  border-radius:999px !important;
  color:#ffe89b !important;
  background:
    linear-gradient(135deg, rgba(5,4,7,.86), rgba(27,18,7,.84) 54%, rgba(5,4,7,.86)),
    radial-gradient(circle at 18% 0%, rgba(255,232,155,.22), transparent 60%) !important;
  border:1px solid rgba(255,232,155,.46) !important;
  box-shadow:
    0 8px 22px rgba(0,0,0,.42),
    0 0 18px rgba(255,226,122,.20),
    inset 0 1px 0 rgba(255,255,255,.14) !important;
  text-shadow:
    0 1px 2px rgba(0,0,0,.96),
    0 0 8px rgba(255,232,155,.42) !important;
  font-size:10px !important;
  letter-spacing:.22em !important;
  font-weight:950 !important;
  opacity:1 !important;
}

/* Badges non mythic: plus classe et moins "UI bouton" */
.card-rarity,
#singleRarity,#inspectRarity,#cardPreviewRarity{
  border-radius:999px !important;
  background:
    linear-gradient(135deg, rgba(5,5,9,.62), rgba(16,15,22,.44)),
    radial-gradient(circle at 20% 0%, var(--rarity-deep), transparent 70%) !important;
  box-shadow:
    0 8px 20px rgba(0,0,0,.26),
    inset 0 1px 0 rgba(255,255,255,.08) !important;
}

/* Role pill moins flashy; garde la rareté mais en détail premium */
.card-role,
#singleRole,#inspectRole,#cardPreviewRole{
  background:
    linear-gradient(135deg, rgba(5,5,9,.54), rgba(16,15,22,.30)),
    radial-gradient(circle at 18% 0%, var(--rarity-deep), transparent 80%) !important;
  border-color:color-mix(in srgb, var(--rarity-main) 28%, rgba(255,255,255,.12)) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.07),
    0 0 12px var(--rarity-deep) !important;
}

/* Mythic role: élégant, pas jaune plat */
.rarity-mythic .card-role,
.rarity-mythic #inspectRole,
.rarity-mythic #singleRole,
.rarity-mythic #cardPreviewRole{
  color:#ffe89b !important;
  background:
    linear-gradient(135deg, rgba(7,5,8,.66), rgba(37,24,7,.44)),
    radial-gradient(circle at 16% 0%, rgba(255,232,155,.17), transparent 70%) !important;
  border-color:rgba(255,232,155,.30) !important;
}

/* Mythic foil plus subtil pour ne pas salir l'image */
.rarity-mythic .card-face::before,
.rarity-mythic.card-inspect::before{
  opacity:.26 !important;
}

/* Le nom garde la puissance, mais plus premium/moins lourd */
.card-name,
#singleName,#inspectName,#cardPreviewName{
  text-shadow:
    0 3px 3px rgba(0,0,0,.96),
    0 0 14px rgba(0,0,0,.86),
    0 0 28px rgba(0,0,0,.54),
    0 0 18px var(--rarity-deep) !important;
}

.rarity-mythic .card-name,
.rarity-mythic #inspectName,
.rarity-mythic #singleName,
.rarity-mythic #cardPreviewName{
  text-shadow:
    0 3px 3px rgba(0,0,0,.98),
    0 0 14px rgba(0,0,0,.90),
    0 0 26px rgba(255,232,155,.16),
    0 0 44px rgba(190,124,255,.08) !important;
}

/* Collection badges: clean sans point, aligné */
.collection-rarity::before{
  content:none !important;
  display:none !important;
}

.collection-rarity{
  align-items:center !important;
  justify-content:center !important;
  gap:0 !important;
  line-height:1 !important;
}

.collection-card.rarity-mythic .collection-rarity{
  color:#ffe89b !important;
  background:
    linear-gradient(135deg, rgba(5,4,7,.86), rgba(27,18,7,.84), rgba(5,4,7,.86)) !important;
  border-color:rgba(255,232,155,.42) !important;
  box-shadow:0 0 16px rgba(255,226,122,.14) !important;
}


/* ═══════════════════════════════════════════════
   V80 — LUXURY MINIMAL
   Back to elegance. Artwork first. UI subtle.
═══════════════════════════════════════════════ */

/* Remove overdesigned flashy look */
.card-single,
.card-inspect,
#cardPreviewCard,
.collection-card{
  border:1px solid rgba(255,255,255,.10) !important;
  box-shadow:
    0 28px 88px rgba(0,0,0,.58),
    0 0 0 1px rgba(255,255,255,.025),
    inset 0 1px 0 rgba(255,255,255,.06) !important;
}

/* rarity only through subtle ambience */
.rarity-common{ --lux:#d9dce2; --luxGlow:rgba(255,255,255,.04);}
.rarity-rare{ --lux:#8adfff; --luxGlow:rgba(120,220,255,.07);}
.rarity-epic{ --lux:#c89cff; --luxGlow:rgba(200,156,255,.08);}
.rarity-legendary{ --lux:#ffd07a; --luxGlow:rgba(255,208,122,.08);}
.rarity-mythic{ --lux:#fff0b0; --luxGlow:rgba(255,240,176,.10);}

.rarity-common.card-single,
.rarity-common.card-inspect,
#cardPreviewCard.rarity-common,
.rarity-rare.card-single,
.rarity-rare.card-inspect,
#cardPreviewCard.rarity-rare,
.rarity-epic.card-single,
.rarity-epic.card-inspect,
#cardPreviewCard.rarity-epic,
.rarity-legendary.card-single,
.rarity-legendary.card-inspect,
#cardPreviewCard.rarity-legendary,
.rarity-mythic.card-single,
.rarity-mythic.card-inspect,
#cardPreviewCard.rarity-mythic{
  box-shadow:
    0 30px 95px rgba(0,0,0,.60),
    0 0 0 1px rgba(255,255,255,.03),
    0 0 24px var(--luxGlow),
    inset 0 1px 0 rgba(255,255,255,.07) !important;
}

/* elegant fine border */
.card-border{
  opacity:.52 !important;
  filter:drop-shadow(0 0 3px rgba(255,255,255,.05)) !important;
}

/* mythic gets premium but subtle */
.rarity-mythic .card-border{
  opacity:.74 !important;
  filter:
    drop-shadow(0 0 6px rgba(255,240,176,.14))
    drop-shadow(0 0 18px rgba(255,240,176,.06)) !important;
}

/* remove heavy foil overlays */
.card-face::before,
.card-inspect::before{
  opacity:.08 !important;
  mix-blend-mode:screen !important;
}

.rarity-mythic .card-face::before,
.rarity-mythic.card-inspect::before{
  opacity:.14 !important;
}

/* Top badges refined */
.card-rarity,
#singleRarity,#inspectRarity,#cardPreviewRarity,
.card-number,
#singleNumber,#inspectNumber,#cardPreviewNumber{
  background:rgba(10,10,16,.42) !important;
  border:1px solid rgba(255,255,255,.08) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.06),
    0 8px 20px rgba(0,0,0,.18) !important;
  color:rgba(255,255,255,.92) !important;
  text-shadow:0 1px 2px rgba(0,0,0,.95) !important;
  letter-spacing:.18em !important;
}

/* Mythic tag elegant champagne */
.rarity-mythic .card-rarity,
.rarity-mythic #singleRarity,
.rarity-mythic #inspectRarity,
.rarity-mythic #cardPreviewRarity{
  color:#fff0b0 !important;
  border-color:rgba(255,240,176,.18) !important;
  background:
    linear-gradient(135deg, rgba(12,10,6,.55), rgba(18,16,10,.38)) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.08),
    0 8px 24px rgba(0,0,0,.24),
    0 0 16px rgba(255,240,176,.06) !important;
}

/* Role pills understated */
.card-role,
#singleRole,#inspectRole,#cardPreviewRole{
  background:rgba(8,8,12,.34) !important;
  border:1px solid rgba(255,255,255,.06) !important;
  color:var(--lux) !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04) !important;
}

/* Name remains hero */
.card-name,
#singleName,#inspectName,#cardPreviewName{
  color:#ffffff !important;
  letter-spacing:-.02em !important;
  text-shadow:
    0 3px 6px rgba(0,0,0,.92),
    0 0 22px rgba(0,0,0,.42) !important;
}

/* Mythic name slight noble tint only */
.rarity-mythic .card-name,
.rarity-mythic #singleName,
.rarity-mythic #inspectName,
.rarity-mythic #cardPreviewName{
  color:#fffdf5 !important;
  text-shadow:
    0 3px 6px rgba(0,0,0,.92),
    0 0 18px rgba(255,240,176,.08),
    0 0 28px rgba(0,0,0,.38) !important;
}

/* Citation more elegant */
.card-desc,
#singleDesc,#inspectDesc,#cardPreviewDesc{
  color:rgba(255,255,255,.80) !important;
  font-style:italic !important;
  letter-spacing:.01em !important;
  text-shadow:0 2px 8px rgba(0,0,0,.55) !important;
}

/* bottom fade cleaner */
.card-bottom{
  background:
    linear-gradient(180deg,
      transparent 0%,
      rgba(5,5,8,.12) 34%,
      rgba(5,5,8,.52) 72%,
      rgba(5,5,8,.88) 100%) !important;
}

/* Collection cleaner */
.collection-card{
  border:1px solid rgba(255,255,255,.08) !important;
  box-shadow:
    0 18px 54px rgba(0,0,0,.34),
    0 0 18px var(--luxGlow) !important;
}

.collection-rarity{
  background:rgba(10,10,16,.38) !important;
  border:1px solid rgba(255,255,255,.07) !important;
  color:var(--lux) !important;
}

/* hover classy */
.collection-card:hover{
  transform:translateY(-4px) scale(1.01) !important;
  box-shadow:
    0 26px 72px rgba(0,0,0,.42),
    0 0 24px var(--luxGlow) !important;
}



/* ===== void-da.css ===== */

/* ═══════════════════════════════════════════════════════════════
   VOID STUDIO — DA REFONTE COMPLÈTE
   Fichier à linker après style.css dans index.html
   Ne touche pas au JS. Ne casse pas la logique hidden/visible.
   Surcharge proprement la DA V79 vers une esthétique TCG premium.
═══════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Rajdhani:wght@400;500;600;700&family=Barlow+Condensed:ital,wght@0,300;0,400;0,700;0,900;1,700;1,900&family=Inter:wght@300;400;500;600&display=swap');

/* ─── TOKENS VOID ─────────────────────────────────────────── */
:root {
  /* Couleurs primaires */
  --void-ink:      #05030C;
  --void-deep:     #0A0616;
  --void-surface:  #100C20;
  --void-panel:    rgba(16, 12, 32, 0.82);
  --void-glass:    rgba(255,255,255,0.042);
  --void-glass2:   rgba(255,255,255,0.075);

  /* Accents */
  --void-red:      #C23B2E;
  --void-red2:     #E05840;
  --void-red-dim:  rgba(194,59,46,0.22);
  --void-red-glow: rgba(194,59,46,0.38);

  --void-gold:     #D4A84B;
  --void-gold2:    #F2C96B;
  --void-gold-dim: rgba(212,168,75,0.18);

  --void-silver:   rgba(255,255,255,0.72);
  --void-muted:    rgba(255,255,255,0.36);
  --void-faint:    rgba(255,255,255,0.12);

  /* Lignes */
  --void-line:     rgba(255,255,255,0.08);
  --void-line2:    rgba(255,255,255,0.14);

  /* Typo */
  --font-display:  'Barlow Condensed', 'Rajdhani', sans-serif;
  --font-ui:       'Rajdhani', 'Inter', sans-serif;
  --font-body:     'Inter', sans-serif;
}

/* ─── RESET TYPO GLOBAL ───────────────────────────────────── */
body {
  font-family: var(--font-body) !important;
  background: var(--void-ink) !important;
}

/* ─── BACKDROP ATMOSPHÈRE ─────────────────────────────────── */
.backdrop {
  background:
    radial-gradient(ellipse 70% 50% at 50% -5%,  rgba(180,50,40,0.22),   transparent 55%),
    radial-gradient(ellipse 40% 35% at 92% 8%,   rgba(100,30,80,0.16),   transparent 48%),
    radial-gradient(ellipse 35% 45% at 6% 85%,   rgba(40,20,100,0.14),   transparent 50%),
    radial-gradient(ellipse 55% 40% at 50% 105%,  rgba(15,8,40,0.60),    transparent 60%),
    linear-gradient(180deg, #0D0718 0%, #060310 55%, #040210 100%) !important;
}

/* Grain cosmique */
.backdrop::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(1px 1px at  8% 12%, rgba(255,255,255,0.55) 0%, transparent 100%),
    radial-gradient(1px 1px at 22% 38%, rgba(255,255,255,0.30) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 38% 7%, rgba(255,255,255,0.65) 0%, transparent 100%),
    radial-gradient(1px 1px at 53% 55%, rgba(255,255,255,0.25) 0%, transparent 100%),
    radial-gradient(1px 1px at 68% 20%, rgba(255,255,255,0.45) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 78% 72%, rgba(255,255,255,0.50) 0%, transparent 100%),
    radial-gradient(1px 1px at 90% 42%, rgba(255,255,255,0.35) 0%, transparent 100%),
    radial-gradient(1px 1px at 14% 65%, rgba(255,255,255,0.30) 0%, transparent 100%),
    radial-gradient(1px 1px at 44% 82%, rgba(255,255,255,0.40) 0%, transparent 100%),
    radial-gradient(1px 1px at 62% 90%, rgba(255,255,255,0.28) 0%, transparent 100%),
    radial-gradient(1px 1px at 96% 18%, rgba(255,255,255,0.48) 0%, transparent 100%),
    radial-gradient(1px 1px at 30% 95%, rgba(255,255,255,0.32) 0%, transparent 100%);
  animation: voidStarfield 7s ease-in-out infinite alternate;
  pointer-events: none;
}

@keyframes voidStarfield {
  0%   { opacity: 0.5; }
  100% { opacity: 1; }
}

/* Scanlines ultra-subtiles */
.backdrop::after {
  content: '' !important;
  position: absolute !important;
  inset: 0 !important;
  background:
    repeating-linear-gradient(
      0deg,
      transparent,
      transparent 3px,
      rgba(0,0,0,0.06) 3px,
      rgba(0,0,0,0.06) 4px
    ) !important;
  animation: none !important;
  pointer-events: none !important;
}

/* ─── SHELL ───────────────────────────────────────────────── */
.shell {
  border: 1px solid rgba(255,255,255,0.07) !important;
  border-radius: 20px !important;
  background:
    linear-gradient(160deg, rgba(255,255,255,0.035), rgba(255,255,255,0.012)) !important;
  box-shadow:
    0 40px 140px rgba(0,0,0,0.80),
    0 0 0 1px rgba(255,255,255,0.03),
    inset 0 1px 0 rgba(255,255,255,0.055) !important;
}

/* ─── LOGO VOID ───────────────────────────────────────────── */
.void-brand-logo {
  top: 20px !important;
  filter: drop-shadow(0 0 28px rgba(200,60,40,0.35)) !important;
}

/* ─── USER PROFILE BAR ────────────────────────────────────── */
.user-profile-bar {
  border: 1px solid rgba(255,255,255,0.08) !important;
  background:
    linear-gradient(135deg, rgba(255,255,255,0.055), rgba(255,255,255,0.020)) !important;
  backdrop-filter: blur(24px) !important;
  border-radius: 16px !important;
  box-shadow:
    0 16px 60px rgba(0,0,0,0.42),
    inset 0 1px 0 rgba(255,255,255,0.07) !important;
}

.user-name {
  font-family: var(--font-ui) !important;
  font-weight: 700 !important;
  font-size: 15px !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
}

.user-sub {
  font-family: var(--font-body) !important;
  font-size: 11px !important;
  letter-spacing: 0.06em !important;
}

/* ─── PANELS ──────────────────────────────────────────────── */
.panel {
  border: 1px solid rgba(255,255,255,0.09) !important;
  background:
    radial-gradient(ellipse 80% 50% at 50% -10%, rgba(180,50,40,0.10), transparent 55%),
    linear-gradient(160deg, rgba(255,255,255,0.06), rgba(255,255,255,0.018)) !important;
  border-radius: 20px !important;
  box-shadow:
    0 28px 90px rgba(0,0,0,0.55),
    inset 0 1px 0 rgba(255,255,255,0.06) !important;
  backdrop-filter: blur(24px) !important;
}

/* Ligne décorative en haut du panel */
.panel::before {
  content: '';
  position: absolute;
  top: 0; left: 10%; right: 10%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(194,59,46,0.5), transparent);
  border-radius: 0 0 2px 2px;
  pointer-events: none;
}
.panel { position: relative; overflow: hidden; }

/* ─── TYPO PANELS ─────────────────────────────────────────── */
.panel h1 {
  font-family: var(--font-display) !important;
  font-size: 56px !important;
  font-weight: 900 !important;
  font-style: italic !important;
  letter-spacing: -0.02em !important;
  text-transform: uppercase !important;
  line-height: 0.90 !important;
  background: linear-gradient(135deg, #FFFFFF 30%, rgba(255,255,255,0.55)) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
}

.brand-kicker {
  font-family: var(--font-ui) !important;
  font-size: 10px !important;
  font-weight: 600 !important;
  letter-spacing: 0.5em !important;
  text-transform: uppercase !important;
  color: rgba(212,168,75,0.70) !important;
  margin-bottom: 6px !important;
}

.panel p {
  font-family: var(--font-body) !important;
  font-size: 14px !important;
  line-height: 1.6 !important;
  color: rgba(255,255,255,0.44) !important;
  font-weight: 400 !important;
}

/* ─── INPUTS ──────────────────────────────────────────────── */
.field label {
  font-family: var(--font-ui) !important;
  font-size: 10px !important;
  letter-spacing: 0.4em !important;
  color: rgba(255,255,255,0.24) !important;
  font-weight: 600 !important;
}

.field input,
.field textarea,
.field select {
  border-radius: 10px !important;
  border: 1px solid rgba(255,255,255,0.10) !important;
  background: rgba(255,255,255,0.04) !important;
  color: #fff !important;
  font-family: var(--font-body) !important;
  font-size: 14px !important;
  letter-spacing: 0.02em !important;
  transition: border-color 0.2s, box-shadow 0.2s !important;
}

.field input:focus,
.field textarea:focus,
.field select:focus {
  border-color: rgba(194,59,46,0.55) !important;
  background: rgba(255,255,255,0.06) !important;
  box-shadow: 0 0 0 3px rgba(194,59,46,0.10) !important;
  outline: none !important;
}

/* Input code: style "portail dimensionnel" */
#redeemCode {
  font-family: var(--font-ui) !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  letter-spacing: 0.20em !important;
  text-transform: uppercase !important;
  text-align: center !important;
  border-color: rgba(255,255,255,0.12) !important;
  background:
    linear-gradient(135deg, rgba(255,255,255,0.03), rgba(194,59,46,0.04)) !important;
}

#redeemCode:focus {
  border-color: rgba(194,59,46,0.60) !important;
  box-shadow:
    0 0 0 3px rgba(194,59,46,0.10),
    0 0 24px rgba(194,59,46,0.14) !important;
}

/* ─── BOUTONS ─────────────────────────────────────────────── */
.primary-btn {
  font-family: var(--font-ui) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 0.20em !important;
  text-transform: uppercase !important;
  border-radius: 10px !important;
  border: 1px solid rgba(194,59,46,0.40) !important;
  background:
    linear-gradient(135deg,
      rgba(160,40,30,0.85) 0%,
      rgba(194,59,46,0.70) 50%,
      rgba(140,32,24,0.90) 100%) !important;
  box-shadow:
    0 8px 28px rgba(194,59,46,0.28),
    0 0 0 1px rgba(255,255,255,0.04),
    inset 0 1px 0 rgba(255,255,255,0.10) !important;
  color: #fff !important;
  transition: transform 0.18s, box-shadow 0.18s, filter 0.18s !important;
  position: relative !important;
  overflow: hidden !important;
}

.primary-btn:hover {
  transform: translateY(-2px) !important;
  box-shadow:
    0 14px 40px rgba(194,59,46,0.40),
    0 0 0 1px rgba(255,255,255,0.06),
    inset 0 1px 0 rgba(255,255,255,0.14) !important;
  filter: brightness(1.08) !important;
}

.primary-btn:active {
  transform: translateY(0) !important;
  filter: brightness(0.96) !important;
}

.secondary-btn {
  font-family: var(--font-ui) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase !important;
  border-radius: 10px !important;
  border: 1px solid rgba(255,255,255,0.12) !important;
  background: rgba(255,255,255,0.05) !important;
  color: rgba(255,255,255,0.72) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.04) !important;
  transition: background 0.18s, border-color 0.18s, transform 0.18s !important;
}

.secondary-btn:hover {
  background: rgba(255,255,255,0.09) !important;
  border-color: rgba(255,255,255,0.20) !important;
  color: #fff !important;
  transform: translateY(-1px) !important;
  filter: none !important;
}

/* Bouton "Ouvrir boosters" — accent rouge discret */
#topOpenBoostersBtn {
  border-color: rgba(194,59,46,0.35) !important;
  background:
    linear-gradient(135deg, rgba(120,30,22,0.60), rgba(194,59,46,0.28)) !important;
  color: rgba(255,200,190,0.90) !important;
}

/* ─── BOOSTER PACK ────────────────────────────────────────── */
.booster-pack {
  border-radius: 22px !important;
  background:
    radial-gradient(ellipse 80% 50% at 50% 0%, rgba(255,255,255,0.12), transparent 40%),
    linear-gradient(155deg, #3A0F15, #B03030 50%, #6A1818) !important;
  border: 1px solid rgba(255,255,255,0.16) !important;
  box-shadow:
    0 50px 130px rgba(0,0,0,0.75),
    0 0 60px rgba(180,48,40,0.22),
    0 0 120px rgba(180,48,40,0.08),
    inset 0 1px 0 rgba(255,255,255,0.14) !important;
}

.booster-pack:hover {
  box-shadow:
    0 70px 170px rgba(0,0,0,0.80),
    0 0 80px rgba(180,48,40,0.35),
    inset 0 1px 0 rgba(255,255,255,0.16) !important;
}

.pack-kicker {
  font-family: var(--font-ui) !important;
  font-size: 10px !important;
  letter-spacing: 0.5em !important;
  color: rgba(255,255,255,0.35) !important;
}

.pack-title {
  font-family: var(--font-display) !important;
  font-size: 66px !important;
  font-weight: 900 !important;
  font-style: italic !important;
  letter-spacing: -0.02em !important;
  text-shadow:
    0 0 50px rgba(255,255,255,0.20),
    0 4px 8px rgba(0,0,0,0.60) !important;
}

.pack-sub {
  font-family: var(--font-body) !important;
  font-size: 13px !important;
  color: rgba(255,255,255,0.28) !important;
}

.pack-content {
  background: rgba(0,0,0,0.25) !important;
  border: 1px solid rgba(255,255,255,0.16) !important;
  border-radius: 18px !important;
}

/* ─── PROGRESS LABEL ──────────────────────────────────────── */
.progress-label {
  font-family: var(--font-ui) !important;
  font-size: 11px !important;
  letter-spacing: 0.50em !important;
  color: rgba(255,255,255,0.28) !important;
  text-transform: uppercase !important;
}

/* ─── CARD BACK ───────────────────────────────────────────── */
.card-back {
  background:
    radial-gradient(ellipse 80% 45% at 50% 0%, rgba(255,255,255,0.12), transparent 40%),
    repeating-linear-gradient(
      130deg,
      rgba(255,255,255,0.035) 0px,
      rgba(255,255,255,0.035) 1px,
      transparent 1px,
      transparent 11px
    ),
    linear-gradient(155deg, #3C0F18, #B83232 52%, #6E1A1A) !important;
  border: 1px solid rgba(255,255,255,0.14) !important;
}

.card-back-kicker {
  font-family: var(--font-ui) !important;
  font-size: 9px !important;
  letter-spacing: 0.45em !important;
  color: rgba(255,255,255,0.28) !important;
}

.card-back-title {
  font-family: var(--font-display) !important;
  font-size: 50px !important;
  font-weight: 900 !important;
  font-style: italic !important;
  letter-spacing: 0.04em !important;
  text-shadow: 0 0 40px rgba(255,255,255,0.20) !important;
}

.card-back-sub {
  font-family: var(--font-body) !important;
  font-size: 12px !important;
  color: rgba(255,255,255,0.28) !important;
}

/* ─── CARD FACE — TYPOGRAPHIE ─────────────────────────────── */
.card-name,
#singleName, #inspectName, #cardPreviewName {
  font-family: var(--font-display) !important;
  font-size: clamp(32px, 4.4vw, 54px) !important;
  font-weight: 900 !important;
  font-style: italic !important;
  letter-spacing: -0.02em !important;
  line-height: 0.88 !important;
  text-transform: uppercase !important;
}

.card-desc,
#singleDesc, #inspectDesc, #cardPreviewDesc {
  font-family: var(--font-body) !important;
  font-size: clamp(12px, 1.2vw, 14px) !important;
  font-style: italic !important;
  font-weight: 400 !important;
  letter-spacing: 0.01em !important;
  line-height: 1.40 !important;
  color: rgba(245,240,235,0.78) !important;
}

.card-role,
#singleRole, #inspectRole, #cardPreviewRole {
  font-family: var(--font-ui) !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 0.22em !important;
  text-transform: uppercase !important;
}

.card-rarity,
#singleRarity, #inspectRarity, #cardPreviewRarity {
  font-family: var(--font-ui) !important;
  font-weight: 700 !important;
  letter-spacing: 0.28em !important;
  font-size: 9px !important;
}

.card-number,
#singleNumber, #inspectNumber, #cardPreviewNumber {
  font-family: var(--font-body) !important;
  font-size: 10px !important;
  font-weight: 500 !important;
}

/* ─── SUMMARY ─────────────────────────────────────────────── */
.summary-title {
  font-family: var(--font-display) !important;
  font-size: 52px !important;
  font-weight: 900 !important;
  font-style: italic !important;
  letter-spacing: -0.02em !important;
  text-transform: uppercase !important;
  background: linear-gradient(135deg, #fff 40%, rgba(255,255,255,0.50)) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
}

.summary-head .brand-kicker {
  margin-bottom: 8px !important;
}

/* Mini cards summary */
.mini-card {
  border-radius: 16px !important;
  border: 1px solid rgba(255,255,255,0.10) !important;
}

.mini-name {
  font-family: var(--font-display) !important;
  font-size: 22px !important;
  font-weight: 900 !important;
  font-style: italic !important;
  letter-spacing: -0.01em !important;
  text-transform: uppercase !important;
}

.mini-rarity {
  font-family: var(--font-ui) !important;
  font-size: 8px !important;
  font-weight: 700 !important;
  letter-spacing: 0.28em !important;
}

/* ─── COLLECTION ──────────────────────────────────────────── */
.collection-toolbar {
  gap: 6px !important;
}

.filter-pill {
  font-family: var(--font-ui) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  border-radius: 8px !important;
  padding: 8px 14px !important;
  border: 1px solid rgba(255,255,255,0.10) !important;
  background: rgba(255,255,255,0.04) !important;
  color: rgba(255,255,255,0.36) !important;
  transition: all 0.18s !important;
}

.filter-pill.active {
  border-color: rgba(212,168,75,0.45) !important;
  background: rgba(212,168,75,0.10) !important;
  color: rgba(212,168,75,0.95) !important;
  box-shadow: 0 0 18px rgba(212,168,75,0.10) !important;
}

.filter-pill:hover:not(.active) {
  background: rgba(255,255,255,0.07) !important;
  border-color: rgba(255,255,255,0.18) !important;
  color: rgba(255,255,255,0.60) !important;
}

.collection-card {
  border-radius: 18px !important;
  border: 1px solid rgba(255,255,255,0.09) !important;
  background: rgba(255,255,255,0.04) !important;
  overflow: hidden !important;
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease !important;
}

.collection-card:hover {
  transform: translateY(-5px) scale(1.016) !important;
  box-shadow: 0 22px 70px rgba(0,0,0,0.48), 0 0 24px rgba(194,59,46,0.08) !important;
  border-color: rgba(255,255,255,0.16) !important;
}

.collection-name {
  font-family: var(--font-display) !important;
  font-size: 17px !important;
  font-weight: 900 !important;
  font-style: italic !important;
  letter-spacing: -0.01em !important;
  text-transform: uppercase !important;
}

.collection-role {
  font-family: var(--font-ui) !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
}

.collection-date {
  font-family: var(--font-body) !important;
  font-size: 11px !important;
}

/* Stats collection */
.collection-stats > div {
  border-radius: 14px !important;
  border: 1px solid rgba(255,255,255,0.08) !important;
  background: rgba(255,255,255,0.04) !important;
  transition: border-color 0.2s !important;
}

.collection-stats strong {
  font-family: var(--font-display) !important;
  font-size: 30px !important;
  font-weight: 900 !important;
  letter-spacing: -0.02em !important;
}

.collection-stats span {
  font-family: var(--font-ui) !important;
  font-size: 10px !important;
  letter-spacing: 0.20em !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,0.34) !important;
}

/* ─── PROFILE HERO ────────────────────────────────────────── */
.profile-name-v49 {
  font-family: var(--font-display) !important;
  font-size: 32px !important;
  font-weight: 900 !important;
  font-style: italic !important;
  letter-spacing: -0.02em !important;
  text-transform: uppercase !important;
}

.profile-kicker-v49 {
  font-family: var(--font-ui) !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 0.40em !important;
  text-transform: uppercase !important;
  color: var(--void-gold) !important;
}

.profile-hero-v49,
.profile-top-v49 {
  border: 1px solid rgba(255,255,255,0.09) !important;
  background:
    radial-gradient(circle at 10% 0%, rgba(180,50,40,0.12), transparent 38%),
    linear-gradient(135deg, rgba(255,255,255,0.065), rgba(255,255,255,0.022)) !important;
}

.profile-progress-v49 i {
  background: linear-gradient(90deg, var(--void-red2), var(--void-gold)) !important;
  box-shadow: 0 0 18px rgba(212,168,75,0.30) !important;
}

/* ─── INSPECT MODAL ───────────────────────────────────────── */
.card-inspect-backdrop {
  background: rgba(4,2,12,0.82) !important;
  backdrop-filter: blur(18px) !important;
}

#inspectCloseBtn {
  font-family: var(--font-ui) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  border-radius: 10px !important;
  min-width: 0 !important;
  padding: 12px 24px !important;
}

/* ─── ADMIN ───────────────────────────────────────────────── */
.admin-card {
  border: 1px solid rgba(255,255,255,0.08) !important;
  background: rgba(255,255,255,0.04) !important;
  border-radius: 18px !important;
}

.admin-card h2,
.admin-card h3 {
  font-family: var(--font-display) !important;
  font-style: italic !important;
  text-transform: uppercase !important;
}

.admin-card h2 { font-size: 26px !important; font-weight: 900 !important; }
.admin-card h3 {
  font-family: var(--font-ui) !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 0.30em !important;
  color: rgba(255,255,255,0.25) !important;
  font-style: normal !important;
}

.data-table th {
  font-family: var(--font-ui) !important;
  font-size: 9px !important;
  letter-spacing: 0.25em !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,0.25) !important;
  background: rgba(10,6,20,0.95) !important;
}

.data-table td {
  font-family: var(--font-body) !important;
  font-size: 13px !important;
}

.code-pill {
  font-family: 'Courier New', monospace !important;
  font-size: 12px !important;
  border-radius: 8px !important;
  background: rgba(255,255,255,0.05) !important;
  border: 1px solid rgba(255,255,255,0.10) !important;
}

/* ─── MODAL ADMIN ─────────────────────────────────────────── */
.admin-modal-panel-v9,
.admin-cards-modal-panel {
  border-radius: 22px !important;
  border: 1px solid rgba(255,255,255,0.10) !important;
  background:
    radial-gradient(ellipse 70% 40% at 50% 0%, rgba(180,50,40,0.14), transparent 55%),
    linear-gradient(160deg, rgba(28,16,36,0.97), rgba(8,5,16,0.99)) !important;
}

/* ─── STATUS LINE ─────────────────────────────────────────── */
.status-line {
  font-family: var(--font-body) !important;
  font-size: 13px !important;
  color: rgba(255,150,130,0.90) !important;
  letter-spacing: 0.02em !important;
}

.inline-note {
  font-family: var(--font-body) !important;
  font-size: 13px !important;
  color: rgba(255,255,255,0.22) !important;
}

/* ─── SUSPENSE TEXT ───────────────────────────────────────── */
.suspense-text {
  font-family: var(--font-ui) !important;
  font-size: 11px !important;
  letter-spacing: 0.35em !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,0.45) !important;
}

/* ─── COLLECTION MODAL V63 ────────────────────────────────── */
.collection-card-modal-panel-v63 {
  border-radius: 24px !important;
  border: 1px solid rgba(255,255,255,0.10) !important;
  background:
    linear-gradient(135deg, rgba(255,255,255,0.07), rgba(255,255,255,0.025)) !important;
}

.collection-card-modal-rarity-v63 {
  font-family: var(--font-ui) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.35em !important;
  text-transform: uppercase !important;
}

.collection-card-modal-info-v63 h2 {
  font-family: var(--font-display) !important;
  font-size: 46px !important;
  font-weight: 900 !important;
  font-style: italic !important;
  letter-spacing: -0.02em !important;
  text-transform: uppercase !important;
  line-height: 0.90 !important;
}

.collection-card-modal-role-v63 {
  font-family: var(--font-ui) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
}

.collection-card-modal-quote-v63 {
  font-family: var(--font-body) !important;
  font-size: 15px !important;
  font-style: italic !important;
  line-height: 1.55 !important;
  color: rgba(255,255,255,0.62) !important;
}

/* ─── BODY BACKGROUND OVERRIDE (V62 patch) ────────────────── */
body {
  background:
    radial-gradient(ellipse 65% 45% at 50% -5%, rgba(160,40,30,0.20), transparent 55%),
    radial-gradient(ellipse 35% 40% at 8% 18%,  rgba(80,20,60,0.12),  transparent 48%),
    linear-gradient(180deg, #0D0618 0%, #060210 60%, #030108 100%) !important;
}

body::before {
  content: '' !important;
  position: fixed !important;
  inset: 0 !important;
  pointer-events: none !important;
  z-index: 0 !important;
  background:
    linear-gradient(rgba(255,255,255,0.018) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.014) 1px, transparent 1px) !important;
  background-size: 52px 52px !important;
  mask-image: radial-gradient(ellipse 80% 60% at 50% 50%, black, transparent 75%) !important;
  opacity: 0.24 !important;
}

/* ─── USER PROFILE STICKY ─────────────────────────────────── */
.user-profile-bar {
  position: sticky !important;
  top: 12px !important;
  z-index: 80 !important;
}

/* ─── FORM GRIDS ADMIN ────────────────────────────────────── */
.card-manager-form .field input,
.card-manager-form .field textarea,
.card-manager-form .field select,
.admin-login-card-v9 input,
.quick-edit-grid-v9 input,
.quick-edit-grid-v9 textarea,
.quick-edit-grid-v9 select {
  border-radius: 10px !important;
  border: 1px solid rgba(255,255,255,0.10) !important;
  background: rgba(255,255,255,0.04) !important;
  font-family: var(--font-body) !important;
}

/* ─── BOOSTER PACK — has-pack-image (overrides défensifs) ─── */
.booster-pack.has-pack-image {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

/* ─── ENSURE HIDDEN STAYS HIDDEN ──────────────────────────── */
.hidden,
.view.hidden,
.player-root.hidden,
.admin-root.hidden {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

/* ─── SMALL RESPONSIVE TWEAKS ─────────────────────────────── */
@media (max-width: 700px) {
  .panel h1 {
    font-size: 38px !important;
  }
  .summary-title {
    font-size: 36px !important;
  }
  .collection-card-modal-info-v63 h2 {
    font-size: 34px !important;
  }
}

/* ─── MICRO-DÉTAILS PREMIUM ───────────────────────────────── */

/* Coins angulaires sur le shell (effet cadre TCG) */
.shell::before,
.shell::after {
  content: '';
  position: absolute;
  width: 20px;
  height: 20px;
  border-style: solid;
  border-color: rgba(212,168,75,0.25);
  z-index: 100;
  pointer-events: none;
}
.shell::before {
  top: 12px; left: 12px;
  border-width: 1px 0 0 1px;
  border-radius: 4px 0 0 0;
}
.shell::after {
  bottom: 12px; right: 12px;
  border-width: 0 1px 1px 0;
  border-radius: 0 0 4px 0;
}

/* Coins sur les panels principaux */
.panel.narrow::before {
  background: none !important;
}

/* Ligne d'accent verticale sur user bar */
.user-avatar {
  border: 1px solid rgba(212,168,75,0.22) !important;
  box-shadow: 0 0 20px rgba(180,50,40,0.18) !important;
}



/* ===== void-0-1-supreme.css ===== */


/* ═══════════════════════════════════════════════
   VOID BOOSTER v0.1 SUPREME FINAL OVERLAY
   Fusion: DA Claude + Luxury Minimal + early gameplay UI.
═══════════════════════════════════════════════ */

:root{
  --v01-gold:#d9b461;
  --v01-red:#c34334;
  --v01-violet:#8f4cff;
  --v01-cyan:#5fd0ff;
  --v01-ink:#05030c;
  --v01-glass:rgba(255,255,255,.055);
  --v01-line:rgba(255,255,255,.10);
}

/* keeps V80 card mood above Claude DA */
.card-single,
.card-inspect,
#cardPreviewCard{
  border:1px solid rgba(255,255,255,.10)!important;
  box-shadow:
    0 30px 92px rgba(0,0,0,.62),
    0 0 0 1px rgba(255,255,255,.025),
    inset 0 1px 0 rgba(255,255,255,.06)!important;
}

.rarity-mythic.card-single,
.rarity-mythic.card-inspect,
#cardPreviewCard.rarity-mythic{
  border-color:rgba(255,240,176,.18)!important;
  box-shadow:
    0 34px 110px rgba(0,0,0,.68),
    0 0 0 1px rgba(255,240,176,.09),
    0 0 22px rgba(255,240,176,.08),
    inset 0 1px 0 rgba(255,255,255,.07)!important;
}

.card-rarity,
#singleRarity,#inspectRarity,#cardPreviewRarity{
  background:rgba(10,10,16,.42)!important;
  border:1px solid rgba(255,255,255,.08)!important;
  color:rgba(255,255,255,.90)!important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05),0 8px 20px rgba(0,0,0,.18)!important;
}

.rarity-mythic .card-rarity,
.rarity-mythic #singleRarity,
.rarity-mythic #inspectRarity,
.rarity-mythic #cardPreviewRarity{
  color:#fff0b0!important;
  border-color:rgba(255,240,176,.22)!important;
  background:linear-gradient(135deg,rgba(12,10,6,.62),rgba(18,16,10,.42))!important;
  min-width:auto!important;
}

.card-role,
#singleRole,#inspectRole,#cardPreviewRole{
  background:rgba(8,8,12,.34)!important;
  border:1px solid rgba(255,255,255,.06)!important;
  color:var(--lux,#d9dce2)!important;
}

.card-name,
#singleName,#inspectName,#cardPreviewName{
  color:#fff!important;
  text-shadow:0 3px 6px rgba(0,0,0,.92),0 0 22px rgba(0,0,0,.42)!important;
}

.card-desc,
#singleDesc,#inspectDesc,#cardPreviewDesc{
  color:rgba(255,255,255,.80)!important;
  text-shadow:0 2px 8px rgba(0,0,0,.55)!important;
}

.collection-rarity::before{display:none!important;content:none!important}

/* v0.1 dashboard */
.v01-dashboard{
  width:min(1040px,92vw);
  display:grid;
  grid-template-columns:1.05fr 1.45fr 1fr;
  gap:14px;
  margin:0 auto 22px;
}
.v01-card{
  position:relative;
  overflow:hidden;
  border:1px solid var(--v01-line);
  border-radius:18px;
  background:
    radial-gradient(circle at 12% 0%,rgba(217,180,97,.10),transparent 36%),
    linear-gradient(145deg,rgba(255,255,255,.070),rgba(255,255,255,.025));
  box-shadow:0 20px 70px rgba(0,0,0,.34),inset 0 1px 0 rgba(255,255,255,.06);
  padding:16px 18px;
  backdrop-filter:blur(18px);
}
.v01-kicker{
  font:700 10px/1 var(--font-ui,Inter,sans-serif);
  letter-spacing:.34em;
  text-transform:uppercase;
  color:rgba(217,180,97,.72);
  margin-bottom:8px;
}
.v01-title{
  font:900 italic 28px/.88 var(--font-display,Inter,sans-serif);
  text-transform:uppercase;
  color:#fff;
  letter-spacing:-.02em;
}
.v01-card p{
  margin:8px 0 14px;
  font-size:12px;
  color:rgba(255,255,255,.48);
  line-height:1.45;
}
.v01-level-line{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:14px;
  margin-top:10px;
  color:#fff;
  font-family:var(--font-ui,Inter,sans-serif);
}
.v01-level-line span{color:rgba(255,255,255,.42);font-size:12px}
.v01-xpbar,.v01-mission,.v01-set-bar{
  position:relative;
  overflow:hidden;
  height:8px;
  border-radius:999px;
  background:rgba(255,255,255,.065);
  box-shadow:inset 0 1px 2px rgba(0,0,0,.35);
}
.v01-xpbar{margin-top:12px}
.v01-xpbar i,.v01-mission i,.v01-set-bar i{
  display:block;
  height:100%;
  width:0%;
  border-radius:inherit;
  background:linear-gradient(90deg,var(--v01-red),var(--v01-gold));
  box-shadow:0 0 18px rgba(217,180,97,.28);
  transition:width .55s cubic-bezier(.18,.82,.22,1);
}
.v01-mission{
  height:auto;
  padding:10px 11px 14px;
  margin:8px 0;
  border:1px solid rgba(255,255,255,.07);
  background:rgba(255,255,255,.035);
}
.v01-mission div{
  display:flex;
  justify-content:space-between;
  gap:12px;
  margin-bottom:8px;
  font:700 12px/1.2 var(--font-ui,Inter,sans-serif);
  color:rgba(255,255,255,.82);
}
.v01-mission span{color:rgba(255,255,255,.42)}
.v01-mission.done{
  border-color:rgba(217,180,97,.28);
  background:rgba(217,180,97,.055);
}
.v01-mission.done div b::after{
  content:" ✓";
  color:var(--v01-gold);
}

/* set panel */
.v01-set-panel{
  margin:18px 0 18px;
  border:1px solid var(--v01-line);
  border-radius:20px;
  padding:18px;
  background:linear-gradient(145deg,rgba(255,255,255,.060),rgba(255,255,255,.022));
  box-shadow:0 22px 72px rgba(0,0,0,.32),inset 0 1px 0 rgba(255,255,255,.055);
}
.v01-set-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:20px;
  margin-bottom:14px;
}
.v01-set-total{
  font:900 italic 34px/.8 var(--font-display,Inter,sans-serif);
  color:var(--v01-gold);
}
.v01-set-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
}
.v01-set{
  border:1px solid rgba(255,255,255,.075);
  border-radius:14px;
  padding:12px;
  background:rgba(255,255,255,.035);
}
.v01-set-top{
  display:flex;
  justify-content:space-between;
  gap:10px;
  margin-bottom:10px;
  font:700 12px var(--font-ui,Inter,sans-serif);
  color:#fff;
}
.v01-set-top span{color:rgba(255,255,255,.42)}

.v01-toast{
  position:fixed;
  left:50%;
  top:84px;
  transform:translateX(-50%) translateY(-18px) scale(.96);
  z-index:20000;
  min-width:280px;
  padding:16px 20px;
  border:1px solid rgba(217,180,97,.28);
  border-radius:18px;
  background:linear-gradient(135deg,rgba(20,14,26,.96),rgba(8,5,14,.96));
  box-shadow:0 26px 90px rgba(0,0,0,.50),0 0 34px rgba(217,180,97,.12);
  opacity:0;
  pointer-events:none;
  transition:opacity .22s ease,transform .32s cubic-bezier(.18,.82,.22,1);
}
.v01-toast.show{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}
.v01-toast b{
  display:block;
  font:900 italic 22px/.9 var(--font-display,Inter,sans-serif);
  text-transform:uppercase;
  color:#fff;
}
.v01-toast span{
  display:block;
  margin-top:5px;
  color:rgba(255,255,255,.55);
  font-size:12px;
}

@media(max-width:900px){
  .v01-dashboard{grid-template-columns:1fr}
  .v01-set-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .v01-set-grid{grid-template-columns:1fr}
}


/* ═══════════════════════════════════════════════
   v0.1.1 Polish
═══════════════════════════════════════════════ */

/* Header less clunky */
.user-profile-bar{
  width:min(940px,92vw)!important;
  margin:0 auto!important;
  display:grid!important;
  grid-template-columns:1fr auto!important;
  gap:14px!important;
  align-items:center!important;
  padding:12px 14px!important;
}
.user-profile-actions{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:8px!important;
  min-width:360px!important;
}
.user-profile-actions .small-btn{
  min-height:38px!important;
  padding:9px 14px!important;
}
#logoutBtn{
  grid-column:2;
}
.void-brand-logo{
  opacity:.76!important;
  transform:translateY(2px) scale(.92)!important;
}

/* Make dashboard feel integrated, less "added there" */
.v01-dashboard{
  margin-top:clamp(20px,6vh,84px)!important;
  margin-bottom:28px!important;
  align-items:stretch!important;
}
.v01-card{
  min-height:156px;
}
.v01-card::after{
  content:"";
  position:absolute;
  inset:auto 16px 0;
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(217,180,97,.22),transparent);
}
.v01-mission{
  border-radius:14px!important;
}
.v01-daily .primary-btn,
#dailyOpenBonusBtnV011{
  margin-top:8px!important;
  width:100%!important;
}

/* Set cards are real filters */
.v01-set{
  cursor:pointer;
  transition:transform .16s ease,border-color .16s ease,background .16s ease,box-shadow .16s ease;
}
.v01-set:hover{
  transform:translateY(-2px);
  border-color:rgba(217,180,97,.24);
  background:rgba(217,180,97,.045);
}
.v01-set.active{
  border-color:rgba(217,180,97,.42)!important;
  background:rgba(217,180,97,.075)!important;
  box-shadow:0 0 24px rgba(217,180,97,.10)!important;
}
.v011-clear-set{
  padding:9px 13px!important;
  min-width:0!important;
  font-size:10px!important;
}
.hidden-by-set-v011{
  display:none!important;
}

/* Card design: preserve minimal luxury, less muddy and more readable */
.card-single,
.card-inspect,
#cardPreviewCard{
  border-radius:24px!important;
  border-color:rgba(255,255,255,.115)!important;
  overflow:hidden!important;
}
.card-face .card-art::after,
.card-inspect .card-art::after,
#cardPreviewCard .card-art::after,
.card-inspect-art::after{
  content:""!important;
  position:absolute!important;
  inset:0!important;
  pointer-events:none!important;
  background:
    linear-gradient(180deg,rgba(0,0,0,.26) 0%,transparent 28%,rgba(0,0,0,.12) 58%,rgba(0,0,0,.74) 100%)!important;
}
.card-ui{
  background:none!important;
  padding:16px 18px 0!important;
}
.card-rarity,
.card-number,
#singleRarity,#inspectRarity,#cardPreviewRarity,
#singleNumber,#inspectNumber,#cardPreviewNumber{
  border-radius:999px!important;
  background:rgba(3,3,7,.46)!important;
  border:1px solid rgba(255,255,255,.095)!important;
  backdrop-filter:blur(8px)!important;
}
.card-bottom{
  padding:64px 20px 18px!important;
  background:linear-gradient(180deg,transparent 0%,rgba(3,3,7,.28) 35%,rgba(3,3,7,.84) 100%)!important;
}
.card-role{
  color:rgba(217,180,97,.92)!important;
  border-color:rgba(217,180,97,.18)!important;
}
.card-name{
  font-size:clamp(34px,4.2vw,52px)!important;
  text-shadow:0 4px 8px rgba(0,0,0,.88),0 0 18px rgba(0,0,0,.42)!important;
}
.card-desc{
  color:rgba(255,255,255,.74)!important;
}

/* Mythic visible but not cheap */
.rarity-mythic .card-rarity,
.rarity-mythic #singleRarity,
.rarity-mythic #inspectRarity,
.rarity-mythic #cardPreviewRarity{
  color:#f4d983!important;
  border-color:rgba(244,217,131,.24)!important;
  background:rgba(12,9,4,.54)!important;
  box-shadow:0 0 16px rgba(244,217,131,.10),inset 0 1px 0 rgba(255,255,255,.07)!important;
}
.rarity-mythic.card-single,
.rarity-mythic.card-inspect{
  box-shadow:0 34px 110px rgba(0,0,0,.66),0 0 0 1px rgba(244,217,131,.06),0 0 32px rgba(244,217,131,.07)!important;
}

/* Collection spacing */
.collection-grid{
  gap:18px!important;
}
.collection-card{
  border-radius:18px!important;
}
.collection-card.hidden-by-set-v011{
  display:none!important;
}

@media(max-width:780px){
  .user-profile-bar{
    grid-template-columns:1fr!important;
  }
  .user-profile-actions{
    min-width:0!important;
    width:100%!important;
  }
}


/* ═══════════════════════════════════════════════
   VOID BOOSTER v0.3 — Studio redesign
   Goal: coherent luxury criminal collectible UX.
═══════════════════════════════════════════════ */

:root{
  --v03-bg:#05030b;
  --v03-panel:rgba(16,12,24,.72);
  --v03-panel2:rgba(255,255,255,.045);
  --v03-line:rgba(255,255,255,.095);
  --v03-gold:#d8b15f;
  --v03-red:#c64336;
  --v03-text:#f5f0ea;
  --v03-muted:rgba(245,240,234,.52);
}

/* global rhythm */
.shell{
  width:min(1440px,calc(100vw - 32px))!important;
  min-height:calc(100vh - 18px)!important;
  padding:0 0 80px!important;
  border-radius:28px!important;
  background:
    radial-gradient(ellipse 70% 42% at 50% 0%,rgba(198,67,54,.15),transparent 58%),
    linear-gradient(180deg,rgba(255,255,255,.025),rgba(255,255,255,.008))!important;
}
.player-root{padding-top:18px!important}

/* header: command bar */
.user-profile-bar{
  position:sticky!important;
  top:12px!important;
  z-index:200!important;
  width:min(980px,92vw)!important;
  min-height:76px!important;
  padding:12px 14px!important;
  border-radius:22px!important;
  border:1px solid rgba(255,255,255,.105)!important;
  background:linear-gradient(135deg,rgba(36,25,38,.82),rgba(18,12,24,.72))!important;
  backdrop-filter:blur(26px)!important;
  box-shadow:0 24px 80px rgba(0,0,0,.46),inset 0 1px 0 rgba(255,255,255,.08)!important;
}
.user-profile-left{gap:13px!important}
.user-avatar{width:52px!important;height:52px!important;border-radius:16px!important}
.user-name{font-size:14px!important;letter-spacing:.08em!important}
.user-sub{max-width:240px!important;line-height:1.25!important}
.user-profile-actions{
  display:grid!important;
  grid-template-columns:180px 180px!important;
  gap:8px!important;
  min-width:0!important;
}
.user-profile-actions .small-btn{
  height:38px!important;
  min-height:38px!important;
  padding:0 14px!important;
  border-radius:13px!important;
}
#logoutBtn{grid-column:2!important}
.void-brand-logo{top:14px!important;opacity:.72!important;transform:scale(.88)!important}

/* home hero: main action first */
.v03-hero{
  width:min(1080px,92vw);
  margin:clamp(34px,7vh,96px) auto 22px;
  display:grid;
  grid-template-columns:1.12fr .88fr;
  gap:26px;
  align-items:center;
}
.v03-hero-copy{
  position:relative;
  padding:38px;
  border-radius:30px;
  border:1px solid rgba(255,255,255,.09);
  background:
    radial-gradient(circle at 8% 0%,rgba(216,177,95,.10),transparent 40%),
    linear-gradient(145deg,rgba(255,255,255,.060),rgba(255,255,255,.020));
  box-shadow:0 28px 100px rgba(0,0,0,.42),inset 0 1px 0 rgba(255,255,255,.065);
}
.v03-kicker{
  font-family:var(--font-ui,Inter,sans-serif);
  font-size:11px;
  font-weight:800;
  letter-spacing:.42em;
  color:var(--v03-gold);
  text-transform:uppercase;
}
.v03-hero h1{
  margin:10px 0 12px;
  max-width:660px;
  font-family:var(--font-display,Inter,sans-serif);
  font-weight:950;
  font-style:italic;
  text-transform:uppercase;
  letter-spacing:-.045em;
  font-size:clamp(48px,7vw,92px);
  line-height:.82;
  color:#fff;
}
.v03-hero p{
  max-width:560px;
  color:var(--v03-muted);
  font-size:15px;
  line-height:1.55;
}
.v03-hero-actions{display:flex;gap:12px;margin-top:24px;flex-wrap:wrap}
.v03-hero-actions button{min-width:170px}

/* 3D pack */
.v03-pack-showcase{
  display:grid;
  place-items:center;
  min-height:420px;
  perspective:1200px;
}
.v03-pack-card{
  width:min(300px,72vw);
  aspect-ratio:.68;
  border-radius:28px;
  border:1px solid rgba(216,177,95,.22);
  background:
    radial-gradient(circle at 50% 0%,rgba(255,255,255,.16),transparent 28%),
    repeating-linear-gradient(130deg,rgba(255,255,255,.035) 0 1px,transparent 1px 12px),
    linear-gradient(145deg,#2a0b13,#7f2023 54%,#170710);
  box-shadow:0 42px 120px rgba(0,0,0,.62),0 0 60px rgba(198,67,54,.20),inset 0 1px 0 rgba(255,255,255,.14);
  transform:rotateY(-12deg) rotateX(4deg);
  animation:v03PackFloat 4.4s ease-in-out infinite;
  display:grid;
  place-items:center;
  color:#fff;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.v03-pack-card::after{
  content:"";
  position:absolute;inset:-40%;
  background:linear-gradient(110deg,transparent,rgba(255,255,255,.18),transparent);
  transform:translateX(-70%) rotate(12deg);
  animation:v03PackShine 3.8s ease-in-out infinite;
}
.v03-pack-label,.v03-pack-sub{
  position:absolute;
  font:800 10px var(--font-ui,Inter,sans-serif);
  letter-spacing:.34em;
  text-transform:uppercase;
  color:rgba(255,255,255,.58);
}
.v03-pack-label{top:28px}
.v03-pack-sub{bottom:30px;color:var(--v03-gold)}
.v03-pack-title{
  font:950 italic 76px/.8 var(--font-display,Inter,sans-serif);
  letter-spacing:-.05em;
  text-shadow:0 5px 14px rgba(0,0,0,.55);
}
@keyframes v03PackFloat{0%,100%{transform:rotateY(-12deg) rotateX(4deg) translateY(0)}50%{transform:rotateY(-7deg) rotateX(2deg) translateY(-14px)}}
@keyframes v03PackShine{0%,30%{transform:translateX(-70%) rotate(12deg)}65%,100%{transform:translateX(70%) rotate(12deg)}}

/* dashboard becomes secondary strip */
.v01-dashboard{
  width:min(1080px,92vw)!important;
  grid-template-columns:1fr 1.25fr 1fr!important;
  margin:0 auto 24px!important;
  gap:14px!important;
}
.v01-card{
  min-height:142px!important;
  border-radius:22px!important;
  background:linear-gradient(145deg,rgba(255,255,255,.050),rgba(255,255,255,.018))!important;
}
.v01-title{font-size:24px!important}
.v01-mission{padding:9px 11px 13px!important}

/* code panel is centered but not buried */
#redeemView .panel.narrow{
  width:min(680px,92vw)!important;
  margin:12px auto 0!important;
  border-radius:24px!important;
}
#redeemView .panel h1{font-size:54px!important}

/* collection redesign: sidebar + main */
.collection-head{
  width:min(1080px,92vw)!important;
  margin:42px auto 22px!important;
}
.v03CollectionShell{
  width:min(1080px,92vw);
  margin:0 auto;
  display:grid;
  grid-template-columns:220px 1fr;
  gap:20px;
  align-items:start;
}
.v03-set-sidebar{
  position:sticky;
  top:110px;
  border:1px solid var(--v03-line);
  border-radius:22px;
  padding:14px;
  background:linear-gradient(145deg,rgba(255,255,255,.055),rgba(255,255,255,.018));
  box-shadow:0 22px 70px rgba(0,0,0,.30);
}
.v03-sidebar-title{
  font:900 11px var(--font-ui,Inter,sans-serif);
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--v03-gold);
  margin:4px 6px 12px;
}
.v03-set-link{
  width:100%;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  padding:12px 10px;
  margin:6px 0;
  border-radius:14px;
  border:1px solid transparent;
  background:transparent;
  color:rgba(255,255,255,.62);
  font:800 12px var(--font-ui,Inter,sans-serif);
  cursor:pointer;
  text-align:left;
}
.v03-set-link b{
  color:rgba(255,255,255,.38);
  font-size:11px;
}
.v03-set-link:hover,.v03-set-link.active{
  border-color:rgba(216,177,95,.22);
  background:rgba(216,177,95,.060);
  color:#fff;
}
.v03-set-link.active b{color:var(--v03-gold)}

.v03-collection-main{min-width:0}
.collection-toolbar{
  justify-content:flex-start!important;
  margin:0 0 20px!important;
  gap:8px!important;
}
.collection-grid{
  grid-template-columns:repeat(auto-fill,minmax(190px,1fr))!important;
  gap:22px!important;
}
.collection-card{
  border-radius:22px!important;
  background:rgba(255,255,255,.035)!important;
  box-shadow:0 22px 62px rgba(0,0,0,.32)!important;
}
.collection-art{border-radius:18px 18px 0 0!important}
.collection-count-badge-v62{
  top:12px!important;right:12px!important;
  background:rgba(0,0,0,.62)!important;
  border-color:rgba(255,255,255,.16)!important;
}

/* set progress panel less random */
.v01-set-panel{
  width:min(620px,100%)!important;
  margin:0 auto 26px!important;
  border-radius:22px!important;
}
.v01-set-grid{grid-template-columns:repeat(2,1fr)!important}
.v01-set{cursor:pointer}
.v01-set.active{border-color:rgba(216,177,95,.42)!important;background:rgba(216,177,95,.075)!important}

/* Cards: real visible change, luxury minimal + readable mythic */
.card-single,.card-inspect,#cardPreviewCard{
  border-radius:26px!important;
  border:1px solid rgba(255,255,255,.11)!important;
  background:#06050b!important;
}
.card-face .card-art::after,
.card-inspect .card-inspect-art::after,
.card-inspect .card-art::after,
#cardPreviewCard .card-inspect-art::after{
  content:""!important;
  position:absolute!important;
  inset:0!important;
  pointer-events:none!important;
  background:
    linear-gradient(180deg,rgba(0,0,0,.22) 0%,transparent 30%,rgba(0,0,0,.08) 58%,rgba(0,0,0,.74) 100%),
    radial-gradient(circle at 12% 100%,rgba(24,180,170,.16),transparent 42%)!important;
}
.card-ui{
  padding:18px 18px 0!important;
  background:none!important;
}
.card-rarity,.card-number,#singleRarity,#inspectRarity,#cardPreviewRarity,#singleNumber,#inspectNumber,#cardPreviewNumber{
  border-radius:999px!important;
  background:rgba(3,3,7,.58)!important;
  backdrop-filter:blur(10px)!important;
  border:1px solid rgba(255,255,255,.10)!important;
  color:rgba(255,255,255,.86)!important;
}
.rarity-mythic .card-rarity,
.rarity-mythic #singleRarity,
.rarity-mythic #inspectRarity,
.rarity-mythic #cardPreviewRarity{
  color:#ffe9a3!important;
  background:linear-gradient(135deg,rgba(15,10,4,.72),rgba(40,28,8,.54))!important;
  border-color:rgba(255,233,163,.34)!important;
  box-shadow:0 0 18px rgba(255,233,163,.12),inset 0 1px 0 rgba(255,255,255,.08)!important;
  letter-spacing:.24em!important;
}
.card-bottom{
  padding:74px 22px 20px!important;
  background:linear-gradient(180deg,transparent 0%,rgba(4,4,8,.24) 33%,rgba(4,4,8,.86) 100%)!important;
}
.card-role,#singleRole,#inspectRole,#cardPreviewRole{
  background:rgba(216,177,95,.10)!important;
  border:1px solid rgba(216,177,95,.20)!important;
  color:#dfc276!important;
}
.card-name,#singleName,#inspectName,#cardPreviewName{
  font-size:clamp(36px,4.8vw,58px)!important;
  letter-spacing:-.04em!important;
  color:#fff!important;
  text-shadow:0 4px 10px rgba(0,0,0,.95),0 0 18px rgba(0,0,0,.50)!important;
}
.card-desc,#singleDesc,#inspectDesc,#cardPreviewDesc{
  color:rgba(255,255,255,.78)!important;
}

@media(max-width:960px){
  .v03-hero{grid-template-columns:1fr}
  .v03-pack-showcase{min-height:300px}
  .v01-dashboard{grid-template-columns:1fr!important}
  .v03CollectionShell{grid-template-columns:1fr}
  .v03-set-sidebar{position:relative;top:auto;display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
  .v03-sidebar-title{grid-column:1/-1}
}
@media(max-width:560px){
  .v03-hero-copy{padding:26px}
  .v03-set-sidebar{grid-template-columns:1fr}
  .collection-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:14px!important}
  .user-profile-actions{grid-template-columns:1fr!important}
  #logoutBtn{grid-column:auto!important}
}


/* ═══════════════════════════════════════════════
   VOID BOOSTER v0.31 — Clean build fixes
═══════════════════════════════════════════════ */

/* Home: remove redundancy, keep hero + compact dashboard + code */
#redeemView .v01-daily{display:none!important}
.v01-dashboard{
  grid-template-columns:1.15fr .85fr!important;
  width:min(860px,92vw)!important;
}
.v01-dashboard .v01-missions{min-height:150px!important}
.v01-dashboard .v01-profile-xp{min-height:150px!important}
#redeemView .panel.narrow{margin-top:28px!important}

/* Header: reduce logo overlap */
.void-brand-logo{top:8px!important;z-index:60!important;opacity:.62!important}
.user-profile-bar{margin-top:22px!important}
.user-profile-actions{grid-template-columns:170px 170px!important}

/* Collection: one filter system */
#setProgressPanelV01{display:none!important}
.v031-collection-tools{
  display:flex;
  gap:10px;
  margin:0 0 14px;
}
.v031-collection-tools input,
.v031-collection-tools select{
  height:42px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.045);
  color:#fff;
  padding:0 14px;
  font:700 12px var(--font-ui,Inter,sans-serif);
  letter-spacing:.08em;
  outline:none;
}
.v031-collection-tools input{flex:1}
.v031-collection-tools select{width:190px}
.v031-empty{
  grid-column:1/-1;
  padding:34px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;
  color:rgba(255,255,255,.48);
  text-align:center;
}

/* Sidebar: clearer active */
.v03-set-link.active{
  border-color:rgba(216,177,95,.44)!important;
  background:linear-gradient(135deg,rgba(216,177,95,.12),rgba(255,255,255,.025))!important;
  box-shadow:0 0 20px rgba(216,177,95,.08)!important;
}

/* DEFINITIVE CARD SYSTEM v0.31 */
.card-single,
.card-inspect,
#cardPreviewCard{
  --r-main:#d8dde8;
  --r-aura:rgba(255,255,255,.06);
  border-radius:24px!important;
  border:1px solid rgba(255,255,255,.12)!important;
  box-shadow:0 34px 110px rgba(0,0,0,.64),0 0 0 1px rgba(255,255,255,.035),0 0 26px var(--r-aura)!important;
}
.rarity-common{--r-main:#d8dde8;--r-aura:rgba(255,255,255,.06)}
.rarity-rare{--r-main:#80d8ff;--r-aura:rgba(80,216,255,.12)}
.rarity-epic{--r-main:#c08cff;--r-aura:rgba(192,140,255,.14)}
.rarity-legendary{--r-main:#ffc26d;--r-aura:rgba(255,194,109,.15)}
.rarity-mythic{--r-main:#f4d37c;--r-aura:rgba(244,211,124,.16)}

.rarity-mythic.card-single,
.rarity-mythic.card-inspect,
#cardPreviewCard.rarity-mythic{
  border-color:rgba(244,211,124,.22)!important;
  box-shadow:0 36px 120px rgba(0,0,0,.68),0 0 0 1px rgba(244,211,124,.12),0 0 34px rgba(244,211,124,.12)!important;
}

.card-face .card-art::after,
.card-inspect .card-inspect-art::after,
.card-inspect .card-art::after,
#cardPreviewCard .card-inspect-art::after{
  content:""!important;
  position:absolute!important;
  inset:0!important;
  pointer-events:none!important;
  z-index:2!important;
  background:
    linear-gradient(180deg,rgba(0,0,0,.20) 0%,transparent 34%,rgba(0,0,0,.10) 58%,rgba(0,0,0,.76) 100%),
    radial-gradient(circle at 8% 100%,rgba(0,190,180,.14),transparent 44%)!important;
}
.card-ui{
  z-index:12!important;
  padding:18px 18px 0!important;
  background:none!important;
}
.card-bottom{
  z-index:12!important;
  padding:72px 22px 20px!important;
  background:linear-gradient(180deg,transparent 0%,rgba(4,4,8,.22) 32%,rgba(4,4,8,.88) 100%)!important;
}
.card-rarity,
#singleRarity,#inspectRarity,#cardPreviewRarity{
  min-width:76px!important;
  justify-content:center!important;
  padding:7px 10px 6px!important;
  border-radius:999px!important;
  color:var(--r-main)!important;
  background:rgba(3,3,7,.70)!important;
  border:1px solid color-mix(in srgb,var(--r-main) 34%,rgba(255,255,255,.08))!important;
  box-shadow:0 10px 26px rgba(0,0,0,.34),0 0 18px var(--r-aura),inset 0 1px 0 rgba(255,255,255,.08)!important;
  text-shadow:0 1px 2px rgba(0,0,0,.95),0 0 8px var(--r-aura)!important;
  opacity:1!important;
  letter-spacing:.20em!important;
}
.rarity-mythic .card-rarity,
.rarity-mythic #singleRarity,
.rarity-mythic #inspectRarity,
.rarity-mythic #cardPreviewRarity{
  color:#1b1204!important;
  background:linear-gradient(135deg,#f7dda0,#c79534 52%,#fff1bd)!important;
  border-color:rgba(255,238,186,.48)!important;
  text-shadow:0 1px 0 rgba(255,255,255,.32)!important;
  box-shadow:0 0 22px rgba(244,211,124,.20),inset 0 1px 0 rgba(255,255,255,.30)!important;
}
.card-number,#singleNumber,#inspectNumber,#cardPreviewNumber{
  color:rgba(255,255,255,.78)!important;
  background:rgba(3,3,7,.55)!important;
}
.card-role,#singleRole,#inspectRole,#cardPreviewRole{
  color:var(--r-main)!important;
  border-color:color-mix(in srgb,var(--r-main) 24%,rgba(255,255,255,.08))!important;
  background:rgba(3,3,7,.42)!important;
}
.card-name,#singleName,#inspectName,#cardPreviewName{
  color:#fff!important;
  text-shadow:0 4px 10px rgba(0,0,0,.96),0 0 18px rgba(0,0,0,.55)!important;
}
.card-desc,#singleDesc,#inspectDesc,#cardPreviewDesc{
  color:rgba(255,255,255,.82)!important;
}

/* Collection cards: stable with same rarity language */
.collection-card.v031-card{
  --r-main:#d8dde8;
  --r-aura:rgba(255,255,255,.05);
  padding:0!important;
  text-align:left!important;
  color:inherit!important;
}
.collection-card.rarity-common{--r-main:#d8dde8;--r-aura:rgba(255,255,255,.05)}
.collection-card.rarity-rare{--r-main:#80d8ff;--r-aura:rgba(80,216,255,.09)}
.collection-card.rarity-epic{--r-main:#c08cff;--r-aura:rgba(192,140,255,.10)}
.collection-card.rarity-legendary{--r-main:#ffc26d;--r-aura:rgba(255,194,109,.12)}
.collection-card.rarity-mythic{--r-main:#f4d37c;--r-aura:rgba(244,211,124,.13)}
.collection-rarity{
  color:var(--r-main)!important;
  border-color:color-mix(in srgb,var(--r-main) 28%,rgba(255,255,255,.08))!important;
  background:rgba(0,0,0,.42)!important;
}
.collection-rarity::before{display:none!important;content:none!important}

@media(max-width:760px){
  .v01-dashboard{grid-template-columns:1fr!important}
  .v031-collection-tools{flex-direction:column}
  .v031-collection-tools select{width:100%}
  .user-profile-actions{grid-template-columns:1fr!important}
}



/* ===== void-v032-clean.css ===== */


/* VOID BOOSTER v0.32 — loaded last */
#redeemView #dailyRewardPanelV01,#setProgressPanelV01,#collectionView .v031-collection-tools,#collectionView .v01-set-panel{display:none!important}
.void-brand-logo{top:10px!important;opacity:.58!important;pointer-events:none!important}
.user-profile-bar{margin-top:26px!important;width:min(920px,92vw)!important;grid-template-columns:minmax(0,1fr) auto!important}
.user-profile-actions{grid-template-columns:160px 160px!important;min-width:0!important}
.v03CollectionShell{width:min(1120px,92vw)!important;margin:0 auto!important;display:grid!important;grid-template-columns:230px minmax(0,1fr)!important;gap:22px!important}
.v03-set-sidebar{position:sticky!important;top:116px!important;border:1px solid rgba(255,255,255,.095)!important;border-radius:22px!important;padding:14px!important;background:linear-gradient(145deg,rgba(255,255,255,.052),rgba(255,255,255,.018))!important}
.v03-sidebar-title{margin:6px 8px 12px!important;font:900 11px var(--font-ui,Inter,sans-serif)!important;letter-spacing:.32em!important;text-transform:uppercase!important;color:#d8b15f!important}
.v03-set-link{width:100%!important;display:flex!important;align-items:center!important;justify-content:space-between!important;padding:12px 11px!important;margin:6px 0!important;border-radius:14px!important;border:1px solid transparent!important;background:transparent!important;color:rgba(255,255,255,.58)!important;font:800 12px var(--font-ui,Inter,sans-serif)!important;cursor:pointer!important}
.v03-set-link b{color:rgba(255,255,255,.38)!important}
.v03-set-link.active,.v03-set-link:hover{border-color:rgba(216,177,95,.36)!important;background:rgba(216,177,95,.075)!important;color:#fff!important}
.v03-set-link.active b{color:#d8b15f!important}
.v032-tools{display:flex!important;gap:10px!important;margin:0 0 14px!important}
.v032-tools input,.v032-tools select{height:42px!important;border-radius:12px!important;border:1px solid rgba(255,255,255,.10)!important;background:rgba(255,255,255,.045)!important;color:#fff!important;padding:0 14px!important;font:700 12px var(--font-ui,Inter,sans-serif)!important;letter-spacing:.08em!important;outline:none!important}
.v032-tools input{flex:1!important}.v032-tools select{width:170px!important}
.v032-empty{grid-column:1/-1!important;padding:34px!important;border:1px solid rgba(255,255,255,.08)!important;border-radius:18px!important;color:rgba(255,255,255,.50)!important;text-align:center!important}
.collection-grid{display:grid!important;grid-template-columns:repeat(auto-fill,minmax(190px,1fr))!important;gap:22px!important}
.card-single,.card-inspect,#cardPreviewCard,.collection-card{--r-main:#d8dde8;--r-aura:rgba(255,255,255,.06)}
.rarity-common{--r-main:#d8dde8;--r-aura:rgba(255,255,255,.06)}.rarity-rare{--r-main:#80d8ff;--r-aura:rgba(80,216,255,.13)}.rarity-epic{--r-main:#c08cff;--r-aura:rgba(192,140,255,.15)}.rarity-legendary{--r-main:#ffc26d;--r-aura:rgba(255,194,109,.16)}.rarity-mythic{--r-main:#f4d37c;--r-aura:rgba(244,211,124,.18)}
.card-single,.card-inspect,#cardPreviewCard{border-radius:24px!important;border:1px solid rgba(255,255,255,.12)!important;background:#06050b!important;box-shadow:0 34px 110px rgba(0,0,0,.64),0 0 0 1px rgba(255,255,255,.035),0 0 28px var(--r-aura)!important;overflow:hidden!important}
.rarity-mythic.card-single,.rarity-mythic.card-inspect,#cardPreviewCard.rarity-mythic{border-color:rgba(244,211,124,.24)!important;box-shadow:0 36px 120px rgba(0,0,0,.70),0 0 0 1px rgba(244,211,124,.14),0 0 36px rgba(244,211,124,.16)!important}
.card-face .card-art::after,.card-inspect .card-inspect-art::after,.card-inspect .card-art::after,#cardPreviewCard .card-inspect-art::after{content:""!important;position:absolute!important;inset:0!important;pointer-events:none!important;z-index:2!important;background:linear-gradient(180deg,rgba(0,0,0,.18) 0%,transparent 35%,rgba(0,0,0,.10) 58%,rgba(0,0,0,.80) 100%),radial-gradient(circle at 8% 100%,rgba(0,190,180,.13),transparent 46%)!important}
.card-ui{position:absolute!important;z-index:20!important;inset:0 0 auto 0!important;padding:18px 18px 0!important;display:flex!important;justify-content:space-between!important;align-items:flex-start!important;background:none!important;pointer-events:none!important}
.card-bottom{position:absolute!important;z-index:20!important;left:0!important;right:0!important;bottom:0!important;padding:72px 22px 20px!important;background:linear-gradient(180deg,transparent 0%,rgba(4,4,8,.24) 32%,rgba(4,4,8,.90) 100%)!important;pointer-events:none!important}
.card-rarity,#singleRarity,#inspectRarity,#cardPreviewRarity{min-width:76px!important;justify-content:center!important;padding:7px 10px 6px!important;border-radius:999px!important;color:var(--r-main)!important;background:rgba(3,3,7,.72)!important;border:1px solid color-mix(in srgb,var(--r-main) 34%,rgba(255,255,255,.08))!important;box-shadow:0 10px 26px rgba(0,0,0,.34),0 0 18px var(--r-aura),inset 0 1px 0 rgba(255,255,255,.08)!important;text-shadow:0 1px 2px rgba(0,0,0,.95),0 0 8px var(--r-aura)!important;opacity:1!important;letter-spacing:.20em!important}
.rarity-mythic .card-rarity,.rarity-mythic #singleRarity,.rarity-mythic #inspectRarity,.rarity-mythic #cardPreviewRarity{color:#1b1204!important;background:linear-gradient(135deg,#f7dda0,#c79534 52%,#fff1bd)!important;border-color:rgba(255,238,186,.50)!important;text-shadow:0 1px 0 rgba(255,255,255,.32)!important;box-shadow:0 0 24px rgba(244,211,124,.22),inset 0 1px 0 rgba(255,255,255,.32)!important}
.card-number,#singleNumber,#inspectNumber,#cardPreviewNumber{padding:7px 10px 6px!important;border-radius:999px!important;color:rgba(255,255,255,.78)!important;background:rgba(3,3,7,.58)!important;border:1px solid rgba(255,255,255,.10)!important}
.card-role,#singleRole,#inspectRole,#cardPreviewRole{display:inline-flex!important;width:auto!important;max-width:max-content!important;padding:5px 8px 4px!important;border-radius:999px!important;color:var(--r-main)!important;border:1px solid color-mix(in srgb,var(--r-main) 28%,rgba(255,255,255,.08))!important;background:rgba(3,3,7,.44)!important}
.card-name,#singleName,#inspectName,#cardPreviewName{color:#fff!important;font-size:clamp(36px,4.8vw,58px)!important;letter-spacing:-.04em!important;text-shadow:0 4px 10px rgba(0,0,0,.96),0 0 18px rgba(0,0,0,.55)!important}
.card-desc,#singleDesc,#inspectDesc,#cardPreviewDesc{color:rgba(255,255,255,.82)!important}
.collection-card.v032-card{appearance:none!important;border-radius:22px!important;border:1px solid rgba(255,255,255,.10)!important;background:rgba(255,255,255,.035)!important;padding:0!important;text-align:left!important;color:inherit!important;overflow:hidden!important;cursor:pointer!important;box-shadow:0 22px 62px rgba(0,0,0,.32),0 0 20px var(--r-aura)!important}
.collection-card.v032-card:hover{transform:translateY(-5px) scale(1.012)!important;border-color:color-mix(in srgb,var(--r-main) 24%,rgba(255,255,255,.12))!important}
.collection-rarity{display:inline-flex!important;align-items:center!important;justify-content:center!important;gap:0!important;line-height:1!important;color:var(--r-main)!important;border:1px solid color-mix(in srgb,var(--r-main) 30%,rgba(255,255,255,.08))!important;background:rgba(0,0,0,.42)!important}
.collection-rarity::before{display:none!important;content:none!important}
@media(max-width:900px){.v03CollectionShell{grid-template-columns:1fr!important}.v03-set-sidebar{position:relative!important;top:auto!important}}
@media(max-width:760px){.v032-tools{flex-direction:column!important}.v032-tools select{width:100%!important}.user-profile-actions{grid-template-columns:1fr!important}}



/* ===== void-v033-fixes.css ===== */


/* VOID BOOSTER v0.33 — real visible fixes loaded last */

/* Header: no overlap, clean command bar */
.user-profile-bar{
  width:min(1040px,92vw)!important;
  max-width:1040px!important;
  margin:20px auto 0!important;
  padding:12px 14px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:18px!important;
  min-height:72px!important;
  border-radius:22px!important;
  overflow:visible!important;
}
.user-profile-left{
  min-width:0!important;
  flex:1 1 auto!important;
}
.user-profile-actions{
  flex:0 0 auto!important;
  min-width:0!important;
  width:auto!important;
  display:grid!important;
  grid-template-columns:170px 170px!important;
  grid-auto-rows:38px!important;
  gap:8px!important;
}
.user-profile-actions .small-btn{
  width:170px!important;
  height:38px!important;
  min-height:38px!important;
  padding:0 10px!important;
  white-space:nowrap!important;
}
#logoutBtn{grid-column:2!important}
.void-brand-logo{
  position:absolute!important;
  top:8px!important;
  left:50%!important;
  transform:translateX(-50%) scale(.82)!important;
  opacity:.55!important;
  z-index:50!important;
  pointer-events:none!important;
}

/* Remove home redundancy: hero + code only */
#redeemView #v01Dashboard,
#redeemView .v01-dashboard,
#redeemView #dailyRewardPanelV01,
#redeemView #missionsPanelV01,
#redeemView #profileXpPanelV01{
  display:none!important;
}
.v03-hero{
  margin-top:clamp(38px,7vh,96px)!important;
  margin-bottom:34px!important;
}
#redeemView .panel.narrow{
  margin-top:0!important;
}

/* Card readability: MYTHIC must be unmistakable */
.card-ui{
  padding:18px 18px 0!important;
}
.card-rarity,
#singleRarity,
#inspectRarity,
#cardPreviewRarity{
  min-width:96px!important;
  height:26px!important;
  padding:0 13px!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  border-radius:999px!important;
  font-size:11px!important;
  font-weight:950!important;
  letter-spacing:.22em!important;
  line-height:1!important;
  opacity:1!important;
  backdrop-filter:blur(10px)!important;
}
.rarity-mythic .card-rarity,
.rarity-mythic #singleRarity,
.rarity-mythic #inspectRarity,
.rarity-mythic #cardPreviewRarity,
.card-single.rarity-mythic .card-rarity,
.card-inspect.rarity-mythic .card-rarity{
  color:#211303!important;
  background:
    linear-gradient(135deg,#fff2b8 0%,#d5a13c 46%,#fff6c8 100%)!important;
  border:1px solid rgba(255,245,196,.76)!important;
  box-shadow:
    0 0 0 1px rgba(0,0,0,.28),
    0 0 22px rgba(255,218,107,.34),
    0 10px 22px rgba(0,0,0,.32),
    inset 0 1px 0 rgba(255,255,255,.45)!important;
  text-shadow:0 1px 0 rgba(255,255,255,.38)!important;
}

/* Less muddy card overlay */
.card-face .card-art::after,
.card-inspect .card-inspect-art::after,
.card-inspect .card-art::after,
#cardPreviewCard .card-inspect-art::after{
  content:""!important;
  position:absolute!important;
  inset:0!important;
  pointer-events:none!important;
  z-index:2!important;
  background:
    linear-gradient(180deg,rgba(0,0,0,.12) 0%,transparent 42%,rgba(0,0,0,.08) 62%,rgba(0,0,0,.78) 100%),
    radial-gradient(circle at 8% 100%,rgba(0,140,145,.10),transparent 44%)!important;
}
.card-bottom{
  padding:70px 22px 20px!important;
  background:linear-gradient(180deg,transparent 0%,rgba(3,3,7,.18) 36%,rgba(3,3,7,.88) 100%)!important;
}

/* Filters: remove duplicate/confusing Mythic album, keep Mythic as rarity */
.v03-set-link[data-set="mythic"]{
  display:none!important;
}
.collection-toolbar{
  margin-bottom:18px!important;
}
.v032-tools{
  margin-bottom:14px!important;
}

/* Active states clearer */
.filter-pill.active,
.v03-set-link.active{
  border-color:rgba(216,177,95,.55)!important;
  background:rgba(216,177,95,.12)!important;
  color:#f3d487!important;
}

.v032-empty{
  min-height:180px!important;
  display:grid!important;
  place-items:center!important;
}

@media(max-width:820px){
  .user-profile-bar{
    align-items:stretch!important;
    flex-direction:column!important;
  }
  .user-profile-actions{
    grid-template-columns:1fr 1fr!important;
    width:100%!important;
  }
  .user-profile-actions .small-btn{
    width:100%!important;
  }
}



/* ===== void-v034-hard-clean.css ===== */


/* VOID BOOSTER v0.34 — actual clean override */

/* Header rebuilt */
.void-brand-logo{position:absolute!important;top:10px!important;left:50%!important;transform:translateX(-50%) scale(.78)!important;opacity:.48!important;z-index:30!important;pointer-events:none!important}
.user-profile-bar{width:min(980px,92vw)!important;margin:22px auto 0!important;padding:12px 14px!important;display:flex!important;align-items:center!important;justify-content:space-between!important;gap:18px!important;min-height:72px!important;border-radius:22px!important;overflow:visible!important}
.user-profile-left{flex:1 1 auto!important;min-width:0!important}
.user-profile-actions{flex:0 0 auto!important;display:grid!important;grid-template-columns:160px 160px!important;grid-auto-rows:38px!important;gap:8px!important;width:auto!important;min-width:0!important}
.user-profile-actions .small-btn{width:160px!important;height:38px!important;min-height:38px!important;padding:0 10px!important}
#logoutBtn{grid-column:2!important}

/* Home: hero only + collapsed code panel */
#redeemView #v01Dashboard,#redeemView .v01-dashboard{display:none!important}
#redeemView .panel.narrow{display:none!important}
body.v034-code-open #redeemView .panel.narrow{display:block!important}
.v03-hero{margin-top:clamp(42px,8vh,104px)!important;margin-bottom:26px!important}
.v03-hero-copy{padding:42px!important}
.v03-pack-showcase{min-height:430px!important}

/* Card mythic readability: impossible to miss */
.card-rarity,#singleRarity,#inspectRarity,#cardPreviewRarity{min-width:108px!important;height:30px!important;padding:0 14px!important;display:inline-flex!important;align-items:center!important;justify-content:center!important;border-radius:999px!important;font-size:12px!important;font-weight:1000!important;letter-spacing:.20em!important;line-height:1!important;opacity:1!important;backdrop-filter:blur(10px)!important}
.rarity-mythic .card-rarity,.rarity-mythic #singleRarity,.rarity-mythic #inspectRarity,.rarity-mythic #cardPreviewRarity,.card-single.rarity-mythic .card-rarity,.card-inspect.rarity-mythic .card-rarity{color:#1d1203!important;background:linear-gradient(135deg,#fff4c6 0%,#d9a541 46%,#fff8d4 100%)!important;border:1px solid rgba(255,246,202,.82)!important;box-shadow:0 0 0 1px rgba(0,0,0,.30),0 0 26px rgba(255,218,107,.38),0 12px 26px rgba(0,0,0,.34),inset 0 1px 0 rgba(255,255,255,.50)!important;text-shadow:0 1px 0 rgba(255,255,255,.42)!important}
.card-face .card-art::after,.card-inspect .card-inspect-art::after,.card-inspect .card-art::after,#cardPreviewCard .card-inspect-art::after{content:""!important;position:absolute!important;inset:0!important;pointer-events:none!important;z-index:2!important;background:linear-gradient(180deg,rgba(0,0,0,.08) 0%,transparent 46%,rgba(0,0,0,.08) 64%,rgba(0,0,0,.78) 100%)!important}
.card-bottom{padding:70px 22px 20px!important;background:linear-gradient(180deg,transparent 0%,rgba(3,3,7,.16) 36%,rgba(3,3,7,.90) 100%)!important}

/* Collection clean renderer only */
#setProgressPanelV01,#collectionView .v032-tools,#collectionView .v031-collection-tools,#collectionView .collection-toolbar:not(#v034RarityBar){display:none!important}
.v03CollectionShell{width:min(1120px,92vw)!important;margin:0 auto!important;display:grid!important;grid-template-columns:230px minmax(0,1fr)!important;gap:22px!important}
.v034-sidebar{position:sticky!important;top:116px!important;border:1px solid rgba(255,255,255,.095)!important;border-radius:22px!important;padding:14px!important;background:linear-gradient(145deg,rgba(255,255,255,.052),rgba(255,255,255,.018))!important}
.v034-tools{display:flex!important;gap:10px!important;margin:0 0 14px!important}
.v034-tools input,.v034-tools select{height:42px!important;border-radius:12px!important;border:1px solid rgba(255,255,255,.10)!important;background:rgba(255,255,255,.045)!important;color:#fff!important;padding:0 14px!important;font:700 12px var(--font-ui,Inter,sans-serif)!important;letter-spacing:.08em!important;outline:none!important}
.v034-tools input{flex:1!important}.v034-tools select{width:170px!important}
#v034RarityBar{display:flex!important;margin:0 0 18px!important;gap:8px!important}
.v03-set-link.active,#v034RarityBar .filter-pill.active{border-color:rgba(216,177,95,.55)!important;background:rgba(216,177,95,.12)!important;color:#f3d487!important}
.collection-grid{display:grid!important;grid-template-columns:repeat(auto-fill,minmax(190px,1fr))!important;gap:22px!important}
.v034-card{appearance:none!important;border-radius:22px!important;border:1px solid rgba(255,255,255,.10)!important;background:rgba(255,255,255,.035)!important;padding:0!important;text-align:left!important;color:inherit!important;overflow:hidden!important;cursor:pointer!important;box-shadow:0 22px 62px rgba(0,0,0,.32)!important}
.v034-card:hover{transform:translateY(-5px) scale(1.012)!important}
.v034-empty{grid-column:1/-1!important;min-height:180px!important;display:grid!important;place-items:center!important;border:1px solid rgba(255,255,255,.08)!important;border-radius:18px!important;color:rgba(255,255,255,.50)!important}

@media(max-width:900px){.v03CollectionShell{grid-template-columns:1fr!important}.v034-sidebar{position:relative!important;top:auto!important}}
@media(max-width:820px){.user-profile-bar{flex-direction:column!important;align-items:stretch!important}.user-profile-actions{grid-template-columns:1fr 1fr!important;width:100%!important}.user-profile-actions .small-btn{width:100%!important}}



/* ===== void-v037-rollback-clean.css ===== */


/* VOID BOOSTER v0.37 — rollback visual + clean UX */

/* Bring back the big animated pack / our previous visual mood */
.v03-hero{
  width:min(1080px,92vw)!important;
  margin:clamp(34px,7vh,96px) auto 34px!important;
  display:grid!important;
  grid-template-columns:1.12fr .88fr!important;
  gap:26px!important;
  align-items:center!important;
}
.v03-hero-copy{
  position:relative!important;
  padding:38px!important;
  border-radius:30px!important;
  border:1px solid rgba(255,255,255,.09)!important;
  background:
    radial-gradient(circle at 8% 0%,rgba(216,177,95,.10),transparent 40%),
    linear-gradient(145deg,rgba(255,255,255,.060),rgba(255,255,255,.020))!important;
  box-shadow:0 28px 100px rgba(0,0,0,.42),inset 0 1px 0 rgba(255,255,255,.065)!important;
}
.v03-hero h1{
  margin:10px 0 12px!important;
  max-width:660px!important;
  font-family:var(--font-display,Inter,sans-serif)!important;
  font-weight:950!important;
  font-style:italic!important;
  text-transform:uppercase!important;
  letter-spacing:-.045em!important;
  font-size:clamp(48px,7vw,92px)!important;
  line-height:.82!important;
  color:#fff!important;
}
.v03-pack-showcase{
  display:grid!important;
  place-items:center!important;
  min-height:420px!important;
  perspective:1200px!important;
}
.v03-pack-card{
  width:min(300px,72vw)!important;
  aspect-ratio:.68!important;
  border-radius:28px!important;
  border:1px solid rgba(216,177,95,.22)!important;
  background:
    radial-gradient(circle at 50% 0%,rgba(255,255,255,.16),transparent 28%),
    repeating-linear-gradient(130deg,rgba(255,255,255,.035) 0 1px,transparent 1px 12px),
    linear-gradient(145deg,#2a0b13,#7f2023 54%,#170710)!important;
  box-shadow:0 42px 120px rgba(0,0,0,.62),0 0 60px rgba(198,67,54,.20),inset 0 1px 0 rgba(255,255,255,.14)!important;
  transform:rotateY(-12deg) rotateX(4deg)!important;
  animation:v037PackFloat 4.4s ease-in-out infinite!important;
}
@keyframes v037PackFloat{
  0%,100%{transform:rotateY(-12deg) rotateX(4deg) translateY(0)}
  50%{transform:rotateY(-7deg) rotateX(2deg) translateY(-14px)}
}

/* Stop homepage redundancy: code is hidden until click */
#redeemView #v01Dashboard,
#redeemView .v01-dashboard,
#setProgressPanelV01{
  display:none!important;
}
#redeemView .panel.narrow{
  display:none!important;
}
body.v037-code-open #redeemView .panel.narrow,
body.v034-code-open #redeemView .panel.narrow{
  display:block!important;
}

/* Keep header from our cleaner version */
.user-profile-bar{
  width:min(980px,92vw)!important;
  margin:22px auto 0!important;
  padding:12px 14px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:18px!important;
  min-height:72px!important;
  border-radius:22px!important;
}
.user-profile-actions{
  display:grid!important;
  grid-template-columns:160px 160px!important;
  grid-auto-rows:38px!important;
  gap:8px!important;
}
.user-profile-actions .small-btn{width:160px!important;height:38px!important;min-height:38px!important}
#logoutBtn{grid-column:2!important}

/* Real booster filters, not random albums */
#collectionView .v031-collection-tools,
#collectionView #v032Tools,
#collectionView #v034Tools,
#collectionView #v036Tools,
#collectionView .collection-toolbar:not(#v037RarityBar){
  display:none!important;
}
.v03CollectionShell{
  display:grid!important;
  grid-template-columns:210px minmax(0,1fr)!important;
  gap:24px!important;
  width:min(1100px,96vw)!important;
  margin:0 auto!important;
}
.v037-sidebar{position:sticky!important;top:80px!important}
.v037-tools{
  display:flex!important;
  gap:10px!important;
  margin-bottom:18px!important;
  flex-wrap:wrap!important;
}
.v037-tools input,.v037-tools select{
  flex:1!important;
  min-width:140px!important;
  padding:10px 14px!important;
  border-radius:12px!important;
}
#v037RarityBar{
  display:flex!important;
  gap:6px!important;
  flex-wrap:wrap!important;
  margin-bottom:20px!important;
  justify-content:flex-start!important;
}
.v037-empty{
  grid-column:1/-1!important;
  text-align:center!important;
  color:rgba(255,255,255,.45)!important;
  padding:60px 0!important;
}

/* Mythic readability, independent from chosen DA */
.card-rarity,#singleRarity,#inspectRarity,#cardPreviewRarity{
  min-width:96px!important;
  height:28px!important;
  padding:0 12px!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  font-size:10px!important;
  font-weight:800!important;
  letter-spacing:.20em!important;
  opacity:1!important;
}
.rarity-mythic .card-rarity,
.rarity-mythic #singleRarity,
.rarity-mythic #inspectRarity,
.rarity-mythic #cardPreviewRarity,
.card-single.rarity-mythic .card-rarity,
.card-inspect.rarity-mythic .card-rarity{
  color:#1c1103!important;
  background:linear-gradient(135deg,#fff0b6 0%,#d5a13c 48%,#fff8d4 100%)!important;
  border:1px solid rgba(255,245,196,.75)!important;
  box-shadow:
    0 0 0 1px rgba(0,0,0,.28),
    0 0 22px rgba(255,218,107,.32),
    0 8px 22px rgba(0,0,0,.34),
    inset 0 1px 0 rgba(255,255,255,.42)!important;
  text-shadow:0 1px 0 rgba(255,255,255,.36)!important;
}

.v037-card{appearance:none!important;text-align:left!important;color:inherit!important;padding:0!important}

@media(max-width:960px){
  .v03-hero{grid-template-columns:1fr!important}
  .v03-pack-showcase{min-height:300px!important}
  .v03CollectionShell{grid-template-columns:1fr!important}
  .v037-sidebar{position:relative!important;top:auto!important}
}
@media(max-width:820px){
  .user-profile-bar{flex-direction:column!important;align-items:stretch!important}
  .user-profile-actions{grid-template-columns:1fr 1fr!important;width:100%!important}
  .user-profile-actions .small-btn{width:100%!important}
}



/* ===== void-v038-fixes.css ===== */


/* VOID BOOSTER v0.38 — targeted fixes */

/* Header: simple row, no overlay */
.void-brand-logo{
  display:none!important;
}
.user-profile-bar{
  width:min(980px,92vw)!important;
  margin:22px auto 0!important;
  padding:14px 16px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:18px!important;
  min-height:72px!important;
  border-radius:22px!important;
  overflow:visible!important;
}
.user-profile-left{
  flex:1 1 auto!important;
  min-width:0!important;
}
.user-profile-actions{
  flex:0 0 auto!important;
  display:flex!important;
  align-items:center!important;
  justify-content:flex-end!important;
  gap:10px!important;
  width:auto!important;
  min-width:0!important;
}
.user-profile-actions .small-btn{
  width:160px!important;
  height:38px!important;
  min-height:38px!important;
  padding:0 12px!important;
  white-space:nowrap!important;
}

/* Home: remove duplicated code panel until click */
#redeemView #v01Dashboard,
#redeemView .v01-dashboard,
#setProgressPanelV01{
  display:none!important;
}
#redeemView .panel.narrow{
  display:none!important;
}
body.v038-code-open #redeemView .panel.narrow{
  display:block!important;
}

/* Collection: keep stats/profile top, fix only grid/filter area */
#collectionView .v031-collection-tools,
#collectionView #v032Tools,
#collectionView #v034Tools,
#collectionView #v036Tools,
#collectionView #v037Tools,
#collectionView .collection-toolbar:not(#v038RarityBar){
  display:none!important;
}
.v03CollectionShell{
  display:grid!important;
  grid-template-columns:210px minmax(0,1fr)!important;
  gap:24px!important;
  width:min(1100px,96vw)!important;
  margin:0 auto!important;
}
.v038-sidebar{
  position:sticky!important;
  top:80px!important;
}
.v038-tools{
  display:flex!important;
  gap:10px!important;
  margin-bottom:18px!important;
  flex-wrap:wrap!important;
}
.v038-tools input,
.v038-tools select{
  flex:1!important;
  min-width:140px!important;
  padding:10px 14px!important;
  border-radius:12px!important;
}
#v038RarityBar{
  display:flex!important;
  gap:6px!important;
  flex-wrap:wrap!important;
  margin-bottom:20px!important;
  justify-content:flex-start!important;
}
.v038-empty{
  grid-column:1/-1!important;
  text-align:center!important;
  color:rgba(255,255,255,.45)!important;
  padding:60px 0!important;
}
.v038-card{
  appearance:none!important;
  text-align:left!important;
  color:inherit!important;
  padding:0!important;
}

/* MYTHIC: user asked white text, basta */
.rarity-mythic .card-rarity,
.rarity-mythic #singleRarity,
.rarity-mythic #inspectRarity,
.rarity-mythic #cardPreviewRarity,
.card-single.rarity-mythic .card-rarity,
.card-inspect.rarity-mythic .card-rarity,
.collection-card.rarity-mythic .collection-rarity{
  color:#fff!important;
  background:rgba(0,0,0,.68)!important;
  border:1px solid rgba(255,255,255,.22)!important;
  text-shadow:0 2px 5px rgba(0,0,0,.95),0 0 10px rgba(255,255,255,.30)!important;
  box-shadow:0 0 0 1px rgba(0,0,0,.25),0 0 16px rgba(255,255,255,.10)!important;
}
.card-rarity,
#singleRarity,
#inspectRarity,
#cardPreviewRarity{
  min-width:86px!important;
  height:26px!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  opacity:1!important;
  font-weight:900!important;
}

@media(max-width:960px){
  .v03CollectionShell{grid-template-columns:1fr!important}
  .v038-sidebar{position:relative!important;top:auto!important}
}
@media(max-width:820px){
  .user-profile-bar{flex-direction:column!important;align-items:stretch!important}
  .user-profile-actions{width:100%!important;justify-content:stretch!important}
  .user-profile-actions .small-btn{width:100%!important}
}



/* ===== void-v039-fixes.css ===== */


/* VOID BOOSTER v0.39 — mythic rainbow badge + faster perceived collection */

/* Mythic badge: rainbow bg + white text */
.rarity-mythic .card-rarity,
.rarity-mythic #singleRarity,
.rarity-mythic #inspectRarity,
.rarity-mythic #cardPreviewRarity,
.card-single.rarity-mythic .card-rarity,
.card-inspect.rarity-mythic .card-rarity{
  color:#fff!important;
  background:
    linear-gradient(115deg,#ff4fd8 0%,#7d5cff 22%,#37d9ff 44%,#49ffb3 63%,#ffe66d 82%,#ff6b4a 100%)!important;
  border:1px solid rgba(255,255,255,.55)!important;
  box-shadow:
    0 0 0 1px rgba(0,0,0,.35),
    0 0 18px rgba(255,79,216,.28),
    0 0 26px rgba(55,217,255,.20),
    0 8px 20px rgba(0,0,0,.35),
    inset 0 1px 0 rgba(255,255,255,.38)!important;
  text-shadow:
    0 1px 2px rgba(0,0,0,.95),
    0 0 7px rgba(0,0,0,.55)!important;
  filter:saturate(1.15)!important;
  animation:mythicRainbowV039 6s linear infinite!important;
  background-size:220% 100%!important;
}

@keyframes mythicRainbowV039{
  0%{background-position:0% 50%}
  100%{background-position:220% 50%}
}

/* Collection mini badges: same language, smaller */
.collection-card.rarity-mythic .collection-rarity,
.v038-card.rarity-mythic .collection-rarity{
  color:#fff!important;
  background:
    linear-gradient(115deg,#ff4fd8,#7d5cff,#37d9ff,#49ffb3,#ffe66d,#ff6b4a)!important;
  border-color:rgba(255,255,255,.45)!important;
  text-shadow:0 1px 2px rgba(0,0,0,.95)!important;
  background-size:220% 100%!important;
}

/* Avoid the empty-looking delay: keep stats area visible while JS fills it */
#collectionView .collection-profile,
#collectionView .collection-stats,
#collectionView .top-cards,
#collectionView [class*="profile"],
#collectionView [class*="stats"]{
  transition:opacity .18s ease!important;
}



/* ===== void-v040-header-xp.css ===== */


/* VOID BOOSTER v0.40 — Header XP */

/* MYTHIC badge: rainbow background, pure white readable text */
.rarity-mythic .card-rarity,
.rarity-mythic #singleRarity,
.rarity-mythic #inspectRarity,
.rarity-mythic #cardPreviewRarity,
.card-single.rarity-mythic .card-rarity,
.card-inspect.rarity-mythic .card-rarity{
  color:#fff!important;
  -webkit-text-fill-color:#fff!important;
  background:
    linear-gradient(115deg,#ff48d7 0%,#845cff 22%,#2dd7ff 45%,#4cffb2 64%,#ffe66d 82%,#ff684a 100%)!important;
  background-size:220% 100%!important;
  border:1px solid rgba(255,255,255,.58)!important;
  text-shadow:
    0 1px 2px rgba(0,0,0,.95),
    0 0 7px rgba(0,0,0,.70)!important;
  box-shadow:
    0 0 0 1px rgba(0,0,0,.34),
    0 0 20px rgba(255,72,215,.25),
    0 0 26px rgba(45,215,255,.18),
    inset 0 1px 0 rgba(255,255,255,.36)!important;
  animation:mythicRainbowV040 5.5s linear infinite!important;
}
@keyframes mythicRainbowV040{
  from{background-position:0% 50%}
  to{background-position:220% 50%}
}

/* Header XP integrated */
.user-profile-left{
  display:grid!important;
  grid-template-columns:auto minmax(0,1fr)!important;
  column-gap:12px!important;
  row-gap:4px!important;
  align-items:center!important;
}
.user-avatar{
  grid-row:1 / span 2!important;
}
.v040-header-xp{
  grid-column:2!important;
  width:min(320px,100%)!important;
  margin-top:4px!important;
}
.v040-level-line{
  display:flex!important;
  justify-content:space-between!important;
  gap:12px!important;
  align-items:center!important;
  font-family:var(--font-ui,Inter,sans-serif)!important;
  font-size:10px!important;
  letter-spacing:.12em!important;
  text-transform:uppercase!important;
}
.v040-level-line b{
  color:#fff!important;
  font-weight:900!important;
}
.v040-level-line span{
  color:rgba(255,255,255,.48)!important;
  font-weight:700!important;
}
.v040-xpbar{
  width:100%!important;
  height:5px!important;
  margin-top:5px!important;
  overflow:hidden!important;
  border-radius:999px!important;
  background:rgba(255,255,255,.08)!important;
  box-shadow:inset 0 1px 2px rgba(0,0,0,.45)!important;
}
.v040-xpbar i{
  display:block!important;
  height:100%!important;
  width:0%;
  border-radius:inherit!important;
  background:linear-gradient(90deg,#e64b38,#f2c363)!important;
  box-shadow:0 0 16px rgba(242,195,99,.32)!important;
  transition:width .45s cubic-bezier(.18,.82,.22,1)!important;
}

/* Since XP is now in header, make collection progression block less visually dominant */
#collectionView .collection-profile,
#collectionView [class*="collection-profile"],
#collectionView [class*="profile-card"]{
  margin-top:18px!important;
}

/* Avoid old delayed/progression block feeling broken */
#collectionView .profile-xp,
#collectionView .collection-xp,
#collectionView .xp-row{
  opacity:.82!important;
}

@media(max-width:820px){
  .user-profile-left{
    grid-template-columns:auto minmax(0,1fr)!important;
  }
  .v040-header-xp{
    width:100%!important;
  }
}


/* ===== v0.47 clean fixes ===== */

/* One clean visual source after consolidation */
:root{
  --void-gold:#d8b15f;
  --void-red:#d84835;
}

/* Keep the working filter layout from v0.38/v0.40 */
#v03SetSidebar,
.v03-set-sidebar{
  display:block!important;
}
#v037BoosterSidebar,
#v038Sidebar,
#v036BoosterSidebar,
#v034Sidebar,
#v032Tools,
#v034Tools,
#v036Tools,
#v037Tools,
#v038Tools,
.v037-sidebar,
.v038-sidebar,
.v036-sidebar,
.v034-sidebar{
  display:none!important;
}

/* Hero inline code: use the real code panel, inside the hero only */
.v047-hero-copy{
  position:relative!important;
  overflow:hidden!important;
}
.v047-state{display:none!important;animation:v047In .22s ease both}
.v047-state.is-active{display:block!important}
@keyframes v047In{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

.v047-inline-code-panel{
  display:block!important;
  width:100%!important;
  max-width:100%!important;
  margin:0!important;
  padding:0!important;
  border:0!important;
  background:transparent!important;
  box-shadow:none!important;
}
.v047-inline-code-panel input{
  width:100%!important;
  box-sizing:border-box!important;
}
.v047-back-btn{
  margin-left:10px!important;
  height:48px!important;
  padding:0 20px!important;
  border-radius:14px!important;
  border:1px solid rgba(255,255,255,.12)!important;
  background:rgba(255,255,255,.035)!important;
  color:#fff!important;
  font-weight:900!important;
  letter-spacing:.14em!important;
  cursor:pointer!important;
}

/* Hide only lower legacy code panel after it has been moved. */
#redeemView .v047-moved-placeholder,
#redeemView > .panel.narrow,
#redeemView > .panel:has(#redeemCode){
  display:none!important;
}

/* Collection header/top cards must stay visible */
#collectionView .collection-profile,
#collectionView .collection-stats,
#collectionView .top-cards,
#collectionView [class*="profile"],
#collectionView [class*="stats"],
#collectionView [class*="top"]{
  opacity:1!important;
  visibility:visible!important;
  animation-delay:0s!important;
}

/* MYTHIC: rainbow bg but white text, no black text */
.rarity-mythic .card-rarity,
.rarity-mythic #singleRarity,
.rarity-mythic #inspectRarity,
.rarity-mythic #cardPreviewRarity,
.card-single.rarity-mythic .card-rarity,
.card-inspect.rarity-mythic .card-rarity,
.collection-card.rarity-mythic .collection-rarity{
  color:#fff!important;
  -webkit-text-fill-color:#fff!important;
  background:linear-gradient(115deg,#ff48d7 0%,#845cff 22%,#2dd7ff 45%,#4cffb2 64%,#ffe66d 82%,#ff684a 100%)!important;
  background-size:220% 100%!important;
  border:1px solid rgba(255,255,255,.58)!important;
  text-shadow:0 1px 2px rgba(0,0,0,.95),0 0 7px rgba(0,0,0,.70)!important;
  box-shadow:0 0 0 1px rgba(0,0,0,.34),0 0 20px rgba(255,72,215,.25),0 0 26px rgba(45,215,255,.18),inset 0 1px 0 rgba(255,255,255,.36)!important;
}


/* ===== v0.48 fixes ===== */

/* Hero title overflow fix */
.v03-hero h1,
#v047HeroDefault h1,
#v045HeroDefault h1,
.v03-hero-copy h1{
  font-size:clamp(44px,6.2vw,78px)!important;
  line-height:.86!important;
  max-width:100%!important;
  overflow-wrap:normal!important;
  word-break:normal!important;
}
.v03-hero-copy{
  overflow:hidden!important;
}

/* Collection stats/progression/top cards must display immediately */
#collectionStats{
  display:grid!important;
  opacity:1!important;
  visibility:visible!important;
  min-height:unset!important;
}
#collectionStats .profile-hero-v49,
#collectionStats .profile-top-v49,
#collectionStats .profile-top-list-v49,
#collectionStats > div{
  opacity:1!important;
  visibility:visible!important;
}

/* Restore the working filters sidebar */
#v03SetSidebar{
  display:block!important;
  opacity:1!important;
  visibility:visible!important;
}
.v03CollectionShell{
  display:grid!important;
  grid-template-columns:210px minmax(0,1fr)!important;
  gap:24px!important;
}
.v03-collection-main .collection-toolbar,
.v03-collection-main .v031-collection-tools{
  display:flex!important;
}

/* Do not show injected duplicate booster menus */
#v037BoosterSidebar,#v038Sidebar,#v036BoosterSidebar,#v034Sidebar,
#v032Tools,#v034Tools,#v036Tools,#v037Tools,#v038Tools,
.v037-sidebar,.v038-sidebar,.v036-sidebar,.v034-sidebar{
  display:none!important;
}

/* Inline code panel, no lower duplicate */
#redeemView > .panel.narrow,
#redeemView > .panel:has(#redeemCode){
  display:none!important;
}
.v047-inline-code-panel{
  display:block!important;
}

/* Mythic text remains white */
.rarity-mythic .card-rarity,
.rarity-mythic #singleRarity,
.rarity-mythic #inspectRarity,
.rarity-mythic #cardPreviewRarity,
.collection-card.rarity-mythic .collection-rarity{
  color:#fff!important;
  -webkit-text-fill-color:#fff!important;
}


/* ===== v0.49 fixes ===== */

/* Hero title fixed: no overflow, intended line breaks */
.v03-hero-copy,
.v049-hero-fixed{
  overflow:hidden!important;
}
.v03-hero-copy h1,
#v047HeroDefault h1,
#v045HeroDefault h1{
  font-size:clamp(42px,5.4vw,72px)!important;
  line-height:.88!important;
  max-width:100%!important;
  white-space:normal!important;
  word-break:normal!important;
  overflow-wrap:normal!important;
}

/* Inline code panel keeps the same card size/spacing */
#v047HeroCode .v047-inline-code-panel,
#v045HeroCode .v045-inline-code-panel{
  min-height:0!important;
}
.v047-inline-code-panel h2,
.v045-inline-code-panel h2{
  font-size:clamp(38px,4.6vw,58px)!important;
  line-height:.9!important;
}

/* Restore correct role filters, not albums */
#v03SetSidebar{
  display:block!important;
}
#v03SetSidebar .v03-sidebar-title{
  text-transform:uppercase!important;
}
#v03SetSidebar .v03-set-link{
  display:flex!important;
}

/* Never show the wrong injected booster sidebar/tools */
#v037BoosterSidebar,#v038Sidebar,#v036BoosterSidebar,#v034Sidebar,
#v032Tools,#v034Tools,#v036Tools,#v037Tools,#v038Tools,
.v037-sidebar,.v038-sidebar,.v036-sidebar,.v034-sidebar{
  display:none!important;
}


/* ===== v0.50 hard fixes ===== */

/* Opening reveal: when revealed, show the real face directly.
   This bypasses the broken 3D flip state from older stacked CSS. */
.single-card-wrap.revealed-mode .card-flip-shell,
.card-flip-shell.v050-face-forced{
  transform:none!important;
}
.single-card-wrap.revealed-mode .card-back,
.card-flip-shell.v050-face-forced .card-back{
  display:none!important;
}
.single-card-wrap.revealed-mode .card-face,
.card-flip-shell.v050-face-forced .card-face{
  display:block!important;
  visibility:visible!important;
  opacity:1!important;
  transform:none!important;
  backface-visibility:visible!important;
  -webkit-backface-visibility:visible!important;
}
.single-card-wrap.revealed-mode .card-art,
.card-flip-shell.v050-face-forced .card-art{
  visibility:visible!important;
  opacity:1!important;
  background-size:cover!important;
  background-position:center!important;
}
.single-card-wrap.revealed-mode .card-ui,
.single-card-wrap.revealed-mode .card-bottom,
.card-flip-shell.v050-face-forced .card-ui,
.card-flip-shell.v050-face-forced .card-bottom{
  visibility:visible!important;
  opacity:1!important;
  z-index:30!important;
}

/* Role filters must win over album/sidebar renderers */
#v03SetSidebar{
  display:block!important;
  opacity:1!important;
  visibility:visible!important;
}
#v03SetSidebar .v03-sidebar-title{
  color:var(--void-gold,#d8b15f)!important;
}
#v03SetSidebar .v03-set-link{
  display:flex!important;
}

/* Keep wrong injected menus removed */
#v037BoosterSidebar,#v038Sidebar,#v036BoosterSidebar,#v034Sidebar,
#v032Tools,#v034Tools,#v036Tools,#v037Tools,#v038Tools,
.v037-sidebar,.v038-sidebar,.v036-sidebar,.v034-sidebar{
  display:none!important;
}


/* ===== VOID BOOSTER 1.0 REBUILD foundation fixes ===== */

.void-compat-hidden{display:none!important;}

.admin-compat-panels{
  display:grid;
  gap:18px;
  margin-top:18px;
}
.admin-modal-v9.hidden,
.admin-cards-modal.hidden,
.level-achievement-v63.hidden,
.collection-card-modal-v63.hidden{display:none!important;}

.admin-modal-v9,
.admin-cards-modal,
.collection-card-modal-v63,
.level-achievement-v63{
  position:fixed;
  inset:0;
  z-index:9999;
  display:grid;
  place-items:center;
  background:rgba(0,0,0,.72);
  padding:24px;
}
.admin-modal-card{
  width:min(960px,92vw);
  max-height:88vh;
  overflow:auto;
  border-radius:24px;
  border:1px solid rgba(255,255,255,.12);
  background:#100d18;
  padding:24px;
  box-shadow:0 30px 90px rgba(0,0,0,.55);
}
.admin-modal-wide{width:min(1180px,94vw);}
.admin-modal-backdrop{position:absolute;inset:0;}

.booster-assets-grid-v34{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
}
.booster-asset-card-v34{
  border:1px solid rgba(255,255,255,.10);
  border-radius:18px;
  padding:16px;
  background:rgba(255,255,255,.035);
}
.booster-pack-preview-v34,
.booster-back-preview-v9{
  min-height:180px;
  display:grid;
  place-items:center;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.10);
  background-size:cover;
  background-position:center;
  color:rgba(255,255,255,.45);
  margin:12px 0;
}

/* Ensure collection stats/top cards remain directly visible. */
#collectionStats{
  display:grid!important;
  opacity:1!important;
  visibility:visible!important;
}

/* Keep the good role filter sidebar, never the accidental booster duplicate. */
#v037BoosterSidebar,#v038Sidebar,#v036BoosterSidebar,#v034Sidebar,
#v032Tools,#v034Tools,#v036Tools,#v037Tools,#v038Tools,
.v037-sidebar,.v038-sidebar,.v036-sidebar,.v034-sidebar{
  display:none!important;
}
#v03SetSidebar{display:block!important;}

/* Opening face fix from v0.50: when revealed, show the card face instead of the broken 3D back. */
.single-card-wrap.revealed-mode .card-flip-shell,
.card-flip-shell.v050-face-forced{transform:none!important;}
.single-card-wrap.revealed-mode .card-back,
.card-flip-shell.v050-face-forced .card-back{display:none!important;}
.single-card-wrap.revealed-mode .card-face,
.card-flip-shell.v050-face-forced .card-face{
  display:block!important;
  visibility:visible!important;
  opacity:1!important;
  transform:none!important;
  backface-visibility:visible!important;
  -webkit-backface-visibility:visible!important;
}
.single-card-wrap.revealed-mode .card-art,
.card-flip-shell.v050-face-forced .card-art{
  visibility:visible!important;
  opacity:1!important;
  background-size:cover!important;
  background-position:center!important;
}

/* Custom backs: if admin injects a URL inline, use it cleanly and hide fallback text. */
.card-back[style*="url("],
.card-backface[style*="url("]{
  background-size:cover!important;
  background-position:center!important;
  background-repeat:no-repeat!important;
}
.card-back[style*="url("] .card-back-inner,
.card-backface[style*="url("] .card-back-inner{
  opacity:0!important;
}

@media(max-width:820px){
  .booster-assets-grid-v34{grid-template-columns:1fr;}
}
