/* =====================================================
   CARDS — design system
   Obsidienne · Or fondu · Prisme holographique
   ===================================================== */

:root {
  --bg: #0B0C10;
  --bg-2: #10121A;
  --panel: #141722;
  --panel-2: #1A1E2C;
  --surface: #14161F;      /* surface plate des tuiles/panneaux (fini les dégradés) */
  --surface-2: #181B26;    /* survol / surface légèrement relevée */
  --line: rgba(255, 255, 255, 0.10);
  --text: #F2F4F8;
  --dim: #8A93A8;
  --gold: #FFD60A;       /* jaune pétant (accent unique) */
  --gold-deep: #E6B800;
  --hot: #FF4D6D;
  --blue: #3FA9FF;
  --purple: #C24BFF;

  --font-display: "Manrope", sans-serif;
  --font-body: "Manrope", sans-serif;
  --font-mono: "Roboto Mono", monospace;
  --font-block: "Anton", "Manrope", sans-serif;  /* titre hero massif */

  --r-sm: 4px;
  --r-md: 6px;
  --r-lg: 10px;
}

/* ===================== MODE CLAIR ===================== */
html[data-theme="light"] {
  --bg: #FAF8F2; --bg-2: #FFFFFF;
  --panel: #FFFFFF; --panel-2: #F3F0E8;
  --surface: #FFFFFF; --surface-2: #F3F0E8;
  --line: rgba(0,0,0,0.11);
  --text: #16161A; --dim: #5E5E66;
  --gold: #FFD60A;          /* même jaune qu'en sombre */
  --gold-deep: #C9A300;     /* socle un peu plus foncé pour le bevel sur fond clair */
}
/* surfaces codées en dur à adapter en clair */
html[data-theme="light"] .topbar { background: rgba(255,255,255,0.82); }
html[data-theme="light"] .account-input,
html[data-theme="light"] .bet-input,
html[data-theme="light"] .ship-form input { background: rgba(0,0,0,0.04); color: var(--text); }
/* en mode clair : header et ticker live en clair (blanc), pas en noir */
html[data-theme="light"] .topbar { background: rgba(255,255,255,0.86); }
/* ticker uniforme aussi en clair : aucune teinte de fond, juste la mini-carte encadrée */
html[data-theme="light"] .drop-thumb { box-shadow: 0 0 0 1px rgba(0,0,0,0.14); }
html[data-theme="light"] .wallet-btn { background: var(--surface-2); }
html[data-theme="light"] .footer { color: var(--dim); }
/* jeux en clair : les boîtes/encarts sombres (cotes, stats) passent en clair (sinon texte sombre illisible) */
html[data-theme="light"] .game-mult-box { background: rgba(0,0,0,0.05); }
html[data-theme="light"] .card-stake-pick { background: rgba(0,0,0,0.04); }
/* en clair, les cartes se détachent mieux du fond crème */
html[data-theme="light"] .cardface { box-shadow: 0 12px 30px rgba(0,0,0,0.20); }

/* ===================== TRANSITION DE THÈME (révélation circulaire) ===================== */
::view-transition-old(root), ::view-transition-new(root) { animation: none; mix-blend-mode: normal; }
::view-transition-old(root) { z-index: 0; }
::view-transition-new(root) { z-index: 1; }
.theme-toggle .ic-moon { display: none; }
html[data-theme="light"] .theme-toggle .ic-sun { display: none; }
html[data-theme="light"] .theme-toggle .ic-moon { display: block; }

* { margin: 0; padding: 0; box-sizing: border-box; }

html { scroll-behavior: smooth; scrollbar-gutter: stable; } /* la place de la scrollbar est réservée : plus de décalage en changeant d'onglet */

body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-body);
  font-size: 15px;
  line-height: 1.6;
  overflow-x: hidden;
  min-height: 100vh;
}

body.no-scroll { overflow: hidden; }

::selection { background: var(--gold); color: #0B0C10; }

[hidden] { display: none !important; }

button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }
a { color: inherit; text-decoration: none; }
input { font-family: inherit; }

/* ===================== FOND ATMOSPHÉRIQUE ===================== */
.bg-atmo { position: fixed; inset: 0; z-index: -1; pointer-events: none; overflow: hidden; }

/* plus de quadrillage : place à l'ASCII animé (canvas) */
.bg-grid { display: none; }
.bg-ascii-canvas {
  position: absolute; inset: 0; width: 100%; height: 100%;
  mask-image: radial-gradient(ellipse 130% 100% at 50% 0%, black 0%, rgba(0,0,0,0.55) 60%, transparent 100%);
}

/* halos colorés retirés : fond uni + ASCII animé seulement */
.bg-glow { display: none; }
.bg-glow-old { position: absolute; border-radius: 50%; filter: blur(110px); opacity: 0.35; }
.bg-glow-1 {
  width: 700px; height: 500px; top: -220px; left: 8%;
  background: radial-gradient(circle, rgba(245,196,75,0.20), transparent 65%);
  animation: glowDrift 16s ease-in-out infinite alternate;
}
.bg-glow-2 {
  width: 600px; height: 500px; top: 30%; right: -180px;
  background: radial-gradient(circle, rgba(194,75,255,0.12), transparent 65%);
  animation: glowDrift 20s ease-in-out infinite alternate-reverse;
}
@keyframes glowDrift {
  from { transform: translate(0, 0) scale(1); }
  to   { transform: translate(60px, 40px) scale(1.15); }
}

.bg-noise {
  position: absolute; inset: 0; opacity: 0.05;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23n)'/%3E%3C/svg%3E");
}
/* en mode clair, les halos flous ressemblent à des ombres sales : on les coupe */
html[data-theme="light"] .bg-glow { display: none; }
html[data-theme="light"] .bg-noise { display: none; }

/* ===================== TOPBAR ===================== */
.topbar {
  position: sticky; top: 0; z-index: 100;
  display: flex; align-items: center; gap: 28px;
  padding: 14px 28px;
  background: rgba(11, 12, 16, 0.78);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  border-bottom: 1px solid var(--line);
}

.brand { display: flex; align-items: center; }
/* haut-gauche : le LOGO seul (monogramme), jamais le mot */
.brand-logo {
  width: 32px; height: 32px; display: block; border-radius: 9px;
  filter: drop-shadow(0 1px 5px rgba(0,0,0,0.35));
  transition: transform 0.18s ease;
}
.brand:hover .brand-logo { transform: rotate(-4deg) scale(1.05); }

/* ===== WORDMARK de marque (la typo « CARDS » + carré) — réutilisable ===== */
.wordmark {
  font-family: "Sora", var(--font-display), sans-serif;
  font-weight: 800; letter-spacing: -0.04em; color: var(--text);
  white-space: nowrap;
}
.wordmark::after {
  content: ""; display: inline-block;
  width: 0.34em; height: 0.34em; border-radius: 0.1em;
  background: #E8B23A; margin-left: 0.06em; vertical-align: baseline;
}

.mainnav { display: flex; gap: 22px; flex: 1; }
.mainnav a {
  position: relative;
  padding: 9px 2px;
  font-size: 13.5px; font-weight: 600; color: var(--dim);
  transition: color 0.2s;
}
.mainnav a::after {
  content: "";
  position: absolute; left: 0; right: 0; bottom: 1px;
  height: 2px; border-radius: 2px;
  background: var(--gold);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.25s cubic-bezier(0.2, 0.8, 0.3, 1);
}
.mainnav a:hover { color: var(--text); }
.mainnav a.active { color: var(--text); }
.mainnav a.active::after { transform: scaleX(1); }
.nav-count {
  font-family: var(--font-mono); font-size: 10px;
  background: rgba(245,196,75,0.15); color: var(--gold);
  border-radius: 6px; padding: 2px 7px; margin-left: 4px;
}

.topbar-right { display: flex; align-items: center; gap: 8px; }

.icon-btn {
  position: relative;
  display: grid; place-items: center;
  width: 36px; height: 36px; border-radius: 5px;
  color: var(--dim); border: 1px solid var(--line);
  transition: color 0.2s, border-color 0.2s;
}
.icon-btn:hover { color: var(--text); border-color: rgba(255,255,255,0.2); }

/* wallet : le solde avec des cartes en arrière-plan, porte du portefeuille */
.wallet-wrap { position: relative; }
/* le solde : pastille discrète avec cartes en déco (comme avant) */
.wallet-btn {
  position: relative; overflow: hidden;
  display: flex; align-items: center; gap: 6px;
  height: 32px; padding: 0 14px; border-radius: 8px;
  background: var(--surface);
  border: none;
  transition: background 0.2s;
}
.wallet-btn:hover { background: var(--surface-2); }
/* vraies mini-cartes en déco derrière le solde */
.wcard {
  position: absolute; width: 22px; height: 30px; border-radius: 3px;
  pointer-events: none; opacity: 0.7;
  background-size: cover; background-position: center;
  border: 1px solid rgba(255,255,255,0.25);
  box-shadow: 0 2px 6px rgba(0,0,0,0.4);
  transition: transform 0.25s;
}
.wcard-1 { right: -8px; top: -6px; transform: rotate(18deg); background-image: url(https://images.pokemontcg.io/base1/4.png); }
.wcard-2 { right: 4px; top: -13px; transform: rotate(34deg); background-image: url(https://images.pokemontcg.io/base1/2.png); }
.wallet-btn:hover .wcard-1 { transform: rotate(12deg) translateY(2px); }
.wallet-btn:hover .wcard-2 { transform: rotate(28deg) translateY(2px); }
.wallet-balance { display: flex; align-items: center; gap: 6px; position: relative; }
.wallet-cta {
  position: relative;
  font-family: var(--font-display); font-weight: 800; font-size: 12px;
  letter-spacing: 0.04em; color: var(--gold);
}
.coin-ico { display: grid; place-items: center; }
.balance-amount {
  font-family: var(--font-mono); font-weight: 700; font-size: 12.5px;
  color: var(--gold); letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
}
.wallet-btn.pulse-up { animation: pulseUp 0.5s ease; }
.wallet-btn.pulse-down { animation: pulseDown 0.5s ease; }
@keyframes pulseUp { 30% { transform: scale(1.07); border-color: #6BFF8F; box-shadow: 0 0 24px rgba(107,255,143,0.35); } }
@keyframes pulseDown { 30% { transform: scale(0.95); border-color: var(--hot); box-shadow: 0 0 24px rgba(255,77,109,0.3); } }
.wallet-btn.shake-pill { animation: pillShake 0.45s ease; }
@keyframes pillShake {
  20% { transform: translateX(-6px); } 40% { transform: translateX(5px); }
  60% { transform: translateX(-4px); } 80% { transform: translateX(3px); }
}

/* ===================== BOUTONS ===================== */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 11px 20px; border-radius: 8px;
  font-family: var(--font-display); font-weight: 700;
  font-size: 13.5px; letter-spacing: 0.01em;
  border: 1px solid transparent;
  transition: transform 0.12s, background 0.2s, border-color 0.2s, opacity 0.2s;
  user-select: none;
}
.btn b { font-family: var(--font-mono); font-weight: 700; font-size: 12px; }
.btn:active { transform: scale(0.96); }
.btn:disabled { opacity: 0.4; cursor: not-allowed; }

/* bouton primaire bevel 3D : socle plus foncé, s'enfonce au clic */
.btn-gold {
  background: var(--gold); color: #15130B;
  box-shadow: 0 5px 0 var(--gold-deep);
}
.btn-gold:hover:not(:disabled) { background: #FFE04D; transform: translateY(-1px); box-shadow: 0 6px 0 var(--gold-deep); }
.btn-gold:active:not(:disabled) { transform: translateY(4px); box-shadow: 0 1px 0 var(--gold-deep); }
.btn-hot { box-shadow: 0 5px 0 #C9304C; }
.btn-hot:hover:not(:disabled) { transform: translateY(-1px); box-shadow: 0 6px 0 #C9304C; }
.btn-hot:active:not(:disabled) { transform: translateY(4px); box-shadow: 0 1px 0 #C9304C; }

.btn-ghost {
  background: transparent;
  border-color: var(--line); color: var(--text);
}
.btn-ghost:hover:not(:disabled) { background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,0.22); }

.btn-hot {
  background: var(--hot);
  color: #fff;
}
.btn-hot:hover:not(:disabled) { background: #FF647F; transform: translateY(-1px); }

.btn-sm { padding: 9px 15px; font-size: 12.5px; border-radius: 7px; }
.btn-lg { padding: 15px 28px; font-size: 15px; border-radius: 9px; }
.btn-block { width: 100%; }

/* ===================== PRIX EN ANTON (dopamine) ===================== */
.cf-value, .chase-val, .balance-amount, .wallet-head-amount, .drop-val,
.tc-price, .recap-gain b, .coll-stat b, .crash-mult, .crashed,
.packcard-buy b, .pbuy b, #minesCashAmt, #crCashAmt, .hstat b, .band b {
  font-family: "Anton", "Archivo", sans-serif !important;
  letter-spacing: 0.02em; font-weight: 400;
}
.balance-amount { font-size: 16px; line-height: 1; }   /* solde en Anton, lisible */
.wallet-balance { gap: 4px; align-items: center; }
.drop-val { font-size: 12px; }

/* ===================== LOGO MONNAIE CR =====================
   Le « dollar » de CARDS : lettres CR en Anton + barre du dollar sur le C
   (symbole #g-cr). Taille relative au chiffre, centré sur sa hauteur
   (jamais posé en bas sur la ligne de base). */
.cr-ic {
  width: 0.7em; height: 0.7em; flex-shrink: 0;
  vertical-align: 0.012em;
  margin-left: 0.17em;
  opacity: 0.88;
}
.balance-cur { width: 12px; height: 12px; color: var(--gold); opacity: 0.95; margin-left: 0; }

/* ===================== DROPFEED ===================== */
.dropfeed {
  display: flex; align-items: stretch; gap: 0;
  border-bottom: 1px solid var(--line);
  background: color-mix(in srgb, var(--text) 4%, transparent);
  overflow: hidden; height: 38px;
}
.dropfeed-label {
  display: flex; align-items: center; gap: 7px;
  padding: 0 16px;
  font-family: var(--font-mono); font-size: 10px; font-weight: 700;
  letter-spacing: 0.18em; color: var(--hot);
  border-right: 1px solid var(--line);
  flex-shrink: 0;
}
.live-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--hot); box-shadow: 0 0 8px var(--hot);
  animation: liveBlink 1.4s ease infinite;
}
@keyframes liveBlink { 50% { opacity: 0.3; } }

/* marquee continu : fondu sur les bords, défilement linéaire, pause au survol */
.dropfeed-mask {
  flex: 1; overflow: hidden; display: flex; align-items: center;
  mask-image: linear-gradient(90deg, transparent, #000 5%, #000 94%, transparent);
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 5%, #000 94%, transparent);
}
.dropfeed-track {
  display: flex; align-items: center; width: max-content;
  animation: dropsScroll var(--drops-dur, 60s) linear infinite;
  will-change: transform;
}
.dropfeed:hover .dropfeed-track { animation-play-state: paused; }
@keyframes dropsScroll { to { transform: translateX(-50%); } }
.drops-copy { display: flex; align-items: center; gap: 38px; padding-right: 38px; }
.drop2 { display: inline-flex; align-items: center; gap: 8px; white-space: nowrap; font-size: 11.5px; }
.drop2-img { width: 18px; height: 25px; object-fit: cover; border-radius: 3px; opacity: 0.95; }
.drop2-who { color: var(--dim); font-size: 10px; font-family: var(--font-mono); }
.drop2-who::after { content: "·"; margin-left: 8px; opacity: 0.5; }
.drop2-name { font-weight: 600; color: var(--text); }
.drop2-val { font-family: var(--font-mono); font-size: 10.5px; font-weight: 700; }
@media (prefers-reduced-motion: reduce) { .dropfeed-track { animation: none; } }

/* ===================== LAYOUT / SECTIONS ===================== */
main { min-height: 70vh; }
/* transition d'onglet : simple fondu, aucun déplacement (fini le saut) */
.page-enter { animation: pageIn 0.32s ease; }
@keyframes pageIn { from { opacity: 0; } }

.section { max-width: 1240px; margin: 0 auto; padding: 56px 28px; }
.section-first { padding-top: 44px; }

.section-head { display: flex; align-items: baseline; gap: 18px; flex-wrap: wrap; margin-bottom: 28px; }
.section-head h2 {
  font-family: var(--font-display); font-size: clamp(22px, 3.4vw, 32px);
  font-weight: 800; letter-spacing: 0.02em;
}
.accent { color: var(--gold); }
.section-sub { color: var(--dim); font-size: 14px; flex-basis: 100%; }
/* tabbar de l'univers Packs : pleine ligne sous le titre, position stable
   quel que soit l'onglet (sinon margin-left:auto la fait sauter) */
.packs-tabs { flex-basis: 100%; margin-left: 0; width: fit-content; }
.section-link { margin-left: auto; color: var(--dim); font-size: 13px; font-weight: 600; transition: color 0.2s; }
.section-link:hover { color: var(--gold); }
.back-link { color: var(--dim); font-size: 13px; font-weight: 600; flex-basis: 100%; }
.back-link:hover { color: var(--gold); }
.game-head h2 { color: var(--accent-color, var(--text)); }

/* ===================== HERO ===================== */
.hero { position: relative; overflow: hidden; }
.hero-inner {
  max-width: 1240px; margin: 0 auto;
  padding: 72px 28px 56px;
  display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 40px;
  align-items: center;
}

.hero-eyebrow {
  font-family: var(--font-mono); font-size: 11px; font-weight: 700;
  letter-spacing: 0.3em; color: var(--gold);
  margin-bottom: 18px;
  animation: heroFade 0.7s 0.05s backwards;
}
.hero-title {
  font-family: var(--font-display); font-weight: 900;
  font-size: clamp(40px, 6.5vw, 78px);
  line-height: 1.02; letter-spacing: 0.01em;
}
.ht-line { display: block; animation: heroSlide 0.7s backwards cubic-bezier(0.2, 0.9, 0.3, 1); }
.ht-line:nth-child(1) { animation-delay: 0.10s; }
.ht-line:nth-child(3) { animation-delay: 0.34s; }
/* RÉVÈLE : jaune plein (sans fade) + ça bouge en continu */
.ht-gold {
  color: var(--gold);
  animation: heroSlide 0.7s 0.22s backwards cubic-bezier(0.2, 0.9, 0.3, 1), revBeat 2.6s 1.1s ease-in-out infinite;
}
@keyframes heroSlide { from { opacity: 0; transform: translateY(36px) skewY(2deg); } }
@keyframes revBeat { 0%, 100% { transform: translateY(0) rotate(0); } 45% { transform: translateY(-6px) rotate(-1.5deg); } }
@keyframes heroFade { from { opacity: 0; } }

.hero-sub {
  margin-top: 22px; max-width: 520px;
  color: var(--dim); font-size: 16px;
  animation: heroFade 0.7s 0.45s backwards;
}
.hero-sub b { color: var(--gold); font-weight: 700; }

.hero-cta { display: flex; gap: 14px; margin-top: 30px; flex-wrap: wrap; animation: heroFade 0.7s 0.55s backwards; }

.hero-stats { display: flex; gap: 34px; margin-top: 42px; animation: heroFade 0.7s 0.65s backwards; }
.hstat b { display: block; font-family: var(--font-display); font-size: 22px; font-weight: 800; color: var(--text); }
.hstat span { font-size: 12px; color: var(--dim); }

.hero-visual { position: relative; height: 460px; }
@keyframes orbitSpin { to { transform: rotate(360deg); } }

.hero-cards { position: absolute; inset: 0; }
.hero-card {
  position: absolute; width: clamp(160px, 16vw, 215px);
  animation: heroCardIn 0.9s backwards cubic-bezier(0.2, 0.9, 0.3, 1), cardFloat 5.5s 1s ease-in-out infinite alternate;
}
.hc-1 { left: 0; top: 12%; --base-rot: -10deg; animation-delay: 0.3s, 1s; z-index: 1; }
.hc-2 { left: 30%; top: 2%; --base-rot: 2deg; animation-delay: 0.45s, 1.6s; z-index: 3; }
.hc-3 { right: 2%; top: 24%; --base-rot: 11deg; animation-delay: 0.6s, 2.2s; z-index: 2; }
@keyframes heroCardIn { from { opacity: 0; transform: translateY(70px) rotate(var(--base-rot)) scale(0.85); } to { transform: translateY(0) rotate(var(--base-rot)); } }
@keyframes cardFloat { from { translate: 0 0; } to { translate: 0 -16px; } }
/* sur la home, on calme le glow/rainbow des cartes (balayage or, prisme mythique)
   pour qu'elles restent nettes — la révélation à l'ouverture garde tous ses effets */
.hero-card .cf-shine::before { display: none; }
.hero-card.rarity-legendary, .hero-card.rarity-mythic { box-shadow: 0 18px 50px rgba(0,0,0,0.5); }

/* ===================== CARTE (face) ===================== */
.cardface {
  position: relative;
  aspect-ratio: 5 / 7;
  width: 100%;
  border-radius: 7px;
  overflow: hidden;
  background: #0D0F16;
  transform: perspective(900px) rotateX(var(--tilt-x, 0deg)) rotateY(var(--tilt-y, 0deg));
  transition: transform 0.25s ease;
  box-shadow: 0 18px 50px rgba(0,0,0,0.55);
  isolation: isolate;
}

.cf-bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(120% 90% at 50% 0%, hsl(var(--card-hue, 40) 70% 22% / 0.85), transparent 60%),
    radial-gradient(100% 70% at 50% 110%, hsl(var(--card-hue, 40) 80% 14% / 0.9), transparent 65%),
    linear-gradient(180deg, #11141D, #0B0D13);
}
.cf-bg::after {
  content: "";
  position: absolute; inset: 0; opacity: 0.5;
  background-image:
    linear-gradient(hsl(var(--card-hue, 40) 60% 50% / 0.06) 1px, transparent 1px),
    linear-gradient(90deg, hsl(var(--card-hue, 40) 60% 50% / 0.06) 1px, transparent 1px);
  background-size: 14px 14px;
  mask-image: radial-gradient(ellipse at 50% 40%, black, transparent 75%);
}

.cf-frame {
  position: absolute; inset: 6px;
  border: 1.5px solid color-mix(in srgb, var(--rarity-color, #555) 55%, transparent);
  border-radius: 5px;
  pointer-events: none;
  z-index: 4;
}
.cf-frame::before, .cf-frame::after {
  content: ""; position: absolute; width: 14px; height: 14px;
  border-color: var(--rarity-color, #888); border-style: solid;
}
.cf-frame::before { top: -2px; left: -2px; border-width: 2.5px 0 0 2.5px; border-radius: 8px 0 0 0; }
.cf-frame::after { bottom: -2px; right: -2px; border-width: 0 2.5px 2.5px 0; border-radius: 0 0 8px 0; }

.cf-head {
  position: absolute; top: 13px; left: 16px; right: 16px;
  display: flex; justify-content: space-between; align-items: center;
  z-index: 5;
}
.cf-rarity {
  font-family: var(--font-mono); font-size: 8.5px; font-weight: 700;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--rarity-color);
}
.cf-num { font-family: var(--font-mono); font-size: 8.5px; color: var(--dim); }

.cf-art {
  position: absolute; inset: 18% 14% 26%;
  display: grid; place-items: center;
  z-index: 3;
}
.cf-art svg {
  width: 78%; height: 78%;
  color: var(--rarity-color);
  filter: drop-shadow(0 0 14px color-mix(in srgb, var(--rarity-color) 70%, transparent));
}

.cf-foot {
  position: absolute; left: 14px; right: 14px; bottom: 13px;
  display: flex; flex-direction: column; gap: 3px; align-items: center;
  z-index: 5;
}
.cf-name {
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(10px, 8cqw, 14px); text-align: center;
  letter-spacing: 0.04em; line-height: 1.2;
}
.cf-value {
  font-family: var(--font-mono); font-size: 10px; font-weight: 700;
  color: var(--gold);
  background: rgba(245,196,75,0.10);
  border: 1px solid rgba(245,196,75,0.25);
  padding: 2px 10px; border-radius: 6px;
  white-space: nowrap; /* le prix et le € restent sur une seule ligne */
}

/* holo : reflet qui suit le curseur */
.cf-holo {
  position: absolute; inset: 0; z-index: 2;
  opacity: var(--holo-o, 0);
  transition: opacity 0.4s;
  background: radial-gradient(circle at var(--holo-x, 50%) var(--holo-y, 50%),
    rgba(255,255,255,0.22), transparent 45%);
  mix-blend-mode: overlay;
}

.cf-shine { position: absolute; inset: 0; z-index: 6; pointer-events: none; }

/* — variations par rareté — */
.rarity-rare .cf-bg { filter: saturate(1.1); }

.rarity-epic .cf-holo {
  background:
    radial-gradient(circle at var(--holo-x, 50%) var(--holo-y, 50%), rgba(255,255,255,0.25), transparent 45%),
    linear-gradient(115deg, transparent 30%, rgba(194,75,255,0.16) 50%, transparent 75%);
}

.rarity-legendary .cf-shine::before {
  content: ""; position: absolute; inset: -60%;
  background: linear-gradient(115deg, transparent 42%, rgba(255,232,160,0.30) 50%, transparent 58%);
  animation: goldSweep 3.2s ease-in-out infinite;
}
@keyframes goldSweep { 0%, 25% { transform: translateX(-55%); } 70%, 100% { transform: translateX(55%); } }
.rarity-legendary { box-shadow: 0 18px 50px rgba(0,0,0,0.55), 0 0 30px rgba(245,196,75,0.18); }

/* mythique : balayage lumineux sobre (blanc rosé, UNE teinte — jamais de rainbow) */
.rarity-mythic .cf-shine::before {
  content: ""; position: absolute; inset: -60%;
  background: linear-gradient(115deg, transparent 42%, rgba(255,224,232,0.34) 50%, transparent 58%);
  animation: goldSweep 2.8s ease-in-out infinite;
}
.rarity-mythic {
  box-shadow: 0 18px 50px rgba(0,0,0,0.6), 0 0 36px rgba(255,77,109,0.28);
}
.rarity-mythic .cf-frame { border-color: rgba(255,255,255,0.35); }

/* ===================== CARTE AVEC PHOTO RÉELLE ===================== */
/* fond transparent : évite le liseré sombre sur les coins arrondis
   quand la carte est inclinée (artefact d'anticrénelage) */
.cardface.has-img {
  background: transparent;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}
.cf-img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  z-index: 1;
  user-select: none;
  -webkit-user-drag: none;
}
.cardface.has-img .cf-holo { z-index: 2; }
.cardface.has-img .cf-shine { z-index: 3; }
.cf-imgtag {
  position: absolute; top: 7px; left: 7px; z-index: 4;
  font-family: var(--font-mono); font-size: 8px; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--rarity-color);
  background: rgba(8, 9, 13, 0.82);
  border: 1px solid color-mix(in srgb, var(--rarity-color) 50%, transparent);
  padding: 3px 8px; border-radius: 6px;
  backdrop-filter: blur(4px);
}
.cf-imgfoot {
  position: absolute; left: 0; right: 0; bottom: 0; z-index: 4;
  display: flex; justify-content: center;
  padding: 22px 8px 8px;
  background: linear-gradient(transparent, rgba(5, 6, 9, 0.85));
}
.cardface.has-img .cf-value { background: rgba(8, 9, 13, 0.85); }

/* ===================== PACK 3D ===================== */
.pack3d {
  --foil-a: #2A2F3E; --foil-b: #171A24; --foil-edge: #3A4154;
  position: relative;
  width: 238px; aspect-ratio: 5 / 8.3;  /* élancé comme un vrai booster */
  transform: perspective(1100px) rotateX(var(--rx, 0deg)) rotateY(var(--ry, 0deg));
  transition: transform 0.2s ease-out;
  filter: drop-shadow(0 30px 50px rgba(0,0,0,0.6));
  user-select: none;
  -webkit-user-drag: none;
}

.theme-steel   { --foil-a: #39404F; --foil-b: #1B1F29; --foil-edge: #566078; --pack-accent: #9AA4B2; }
.theme-neon    { --foil-a: #15324A; --foil-b: #121627; --foil-edge: #2E6FB0; --pack-accent: #3FA9FF; }
.theme-obsidian{ --foil-a: #251636; --foil-b: #120D1C; --foil-edge: #5E2D8E; --pack-accent: #C24BFF; }
.theme-vault   { --foil-a: #3A2D10; --foil-b: #1C150A; --foil-edge: #A37B1E; --pack-accent: #F5C44B; }

.pack-foil {
  position: absolute; inset: 0;
  background:
    radial-gradient(140% 60% at 50% -6%, color-mix(in srgb, var(--pack-accent, #888) 30%, transparent), transparent 58%),
    linear-gradient(165deg, var(--foil-a), var(--foil-b) 72%);
}
/* satin métallisé : grande lumière diagonale, bombé central, bords qui plongent */
.pack-foil::before {
  content: ""; position: absolute; inset: 0;
  background:
    linear-gradient(115deg, transparent 28%, rgba(255,255,255,0.05) 45%, rgba(255,255,255,0.10) 50%, rgba(255,255,255,0.04) 56%, transparent 72%),
    radial-gradient(110% 50% at 50% 42%, rgba(255,255,255,0.06), transparent 62%),
    linear-gradient(90deg, rgba(0,0,0,0.52) 0%, transparent 9%, transparent 91%, rgba(0,0,0,0.52) 100%);
}
/* plis du sachet : quelques accidents posés à la main — AUCUNE répétition (le
   quadrillage régulier faisait faux/goofy) */
.pack-foil::after {
  content: ""; position: absolute; inset: 0; opacity: 0.9;
  background:
    linear-gradient(104deg, transparent 23.2%, rgba(255,255,255,0.09) 23.8%, rgba(0,0,0,0.17) 24.6%, transparent 25.6%) no-repeat,
    linear-gradient(97deg,  transparent 55.6%, rgba(255,255,255,0.07) 56.2%, rgba(0,0,0,0.14) 57%,  transparent 58%) no-repeat,
    linear-gradient(119deg, transparent 70.6%, rgba(255,255,255,0.06) 71.3%, rgba(0,0,0,0.12) 72.2%, transparent 73.4%) no-repeat,
    linear-gradient(84deg,  transparent 37.6%, rgba(0,0,0,0.13) 38.3%, rgba(255,255,255,0.055) 39.1%, transparent 40%) no-repeat,
    linear-gradient(108deg, transparent 87%,   rgba(255,255,255,0.05) 87.7%, rgba(0,0,0,0.10) 88.5%, transparent 89.6%) no-repeat,
    /* petits plis courts qui partent des soudures */
    linear-gradient(93deg, transparent 30%, rgba(255,255,255,0.10) 50%, transparent 70%) 12% 0 / 7% 9% no-repeat,
    linear-gradient(88deg, transparent 30%, rgba(255,255,255,0.08) 50%, transparent 70%) 39% 0 / 5% 7% no-repeat,
    linear-gradient(92deg, transparent 30%, rgba(255,255,255,0.09) 50%, transparent 70%) 68% 0 / 6% 8% no-repeat,
    linear-gradient(91deg, transparent 30%, rgba(255,255,255,0.07) 50%, transparent 70%) 88% 100% / 5% 8% no-repeat,
    linear-gradient(95deg, transparent 30%, rgba(255,255,255,0.08) 50%, transparent 70%) 23% 100% / 6% 8% no-repeat,
    linear-gradient(89deg, transparent 30%, rgba(255,255,255,0.06) 50%, transparent 70%) 55% 100% / 5% 6% no-repeat;
}

/* habillage personnalisé (admin / IA) : l'image couvre tout le sachet en 2 tranches
   continues (rabat 12,5% + corps 87,5%) ; la matière (satin, plis) repasse par-dessus
   via .pack-foil-over (fond vide → seuls ses pseudo-éléments s'affichent) */
.pack-wrap { position: absolute; inset: 0; background-repeat: no-repeat; }
.pack-wrap-top  { background-size: 100% 800%; background-position: 0 0; }
.pack-wrap-body { background-size: 100% 114.286%; background-position: 0 100%; }
.pack-foil-over { background: none; }

.pack-top {
  position: absolute; top: 0; left: 0; right: 0; height: 12.5%;
  overflow: hidden;
  z-index: 2;
  transform-origin: 35% 100%;
  /* déchirure réaliste : on PÈLE l'opercule — le rabat bascule vers l'arrière
     (perspective), se tord, et son ombre tombe sur le corps. Courbe quadratique
     (--tear-p2) : il résiste au début puis cède d'un coup. */
  transform:
    perspective(700px)
    rotateX(calc(var(--tear-p2, 0) * 32deg))
    rotate(calc(var(--tear-p2, 0) * -6deg))
    translateY(calc(var(--tear-p2, 0) * -4px))
    skewX(calc(var(--tear-p, 0) * -1.5deg));
  filter: drop-shadow(0 calc(var(--tear-p2, 0) * 11px) calc(var(--tear-p2, 0) * 8px) rgba(0,0,0,0.5));
  /* silhouette : bord supérieur serti en dents fines (fini le rectangle) */
  clip-path: polygon(0% 36%, 2% 14%, 4.5% 28%, 7% 10%, 9.5% 26%, 12% 8%, 15% 27%, 18% 11%, 21% 29%, 24% 9%, 27% 26%, 30% 12%, 33% 28%, 36% 8%, 39% 25%, 42% 11%, 45% 29%, 48% 9%, 51% 27%, 54% 12%, 57% 28%, 60% 8%, 63% 26%, 66% 11%, 69% 29%, 72% 9%, 75% 27%, 78% 12%, 81% 28%, 84% 8%, 87% 25%, 90% 11%, 93% 28%, 96% 10%, 98% 24%, 100% 36%, 100% 100%, 0% 100%);
}
/* soudure sertie du haut : les stries verticales de la machine à sceller */
.pack-top::after {
  content: ""; position: absolute; left: 0; right: 0; top: 0; height: 58%;
  z-index: 0;
  background:
    repeating-linear-gradient(90deg, rgba(0,0,0,0.30) 0 2px, transparent 2px 5px),
    linear-gradient(180deg, rgba(255,255,255,0.10), rgba(255,255,255,0.02) 70%, transparent);
  border-bottom: 1px solid rgba(255,255,255,0.07);
}
/* le bord de papier arraché du rabat : se délamine sur TOUTE la largeur à mesure
   que le rabat se soulève (pas une jauge qui avance), et s'envole avec lui */
.pack-top::before {
  content: ""; position: absolute; left: 0; bottom: 0; height: 5px;
  width: 100%;
  z-index: 3;
  background: #EFE7D4;
  opacity: min(calc(var(--tear-p, 0) * 2.2), 0.85);
  clip-path: polygon(0 0, 2% 70%, 5% 25%, 8% 90%, 11% 40%, 15% 100%, 18% 30%, 22% 80%, 25% 10%, 29% 95%, 33% 45%, 36% 85%, 40% 20%, 44% 100%, 47% 35%, 51% 75%, 55% 15%, 58% 90%, 62% 50%, 66% 100%, 69% 25%, 73% 80%, 77% 40%, 80% 95%, 84% 20%, 88% 70%, 91% 35%, 95% 100%, 98% 55%, 100% 85%, 100% 0);
}
.pack-notch {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
  width: 44%; height: 9px; border-radius: 6px; z-index: 1;
  background: rgba(0,0,0,0.45);
  box-shadow: inset 0 1.5px 3px rgba(0,0,0,0.8), 0 1px 0 rgba(255,255,255,0.08);
}
.pack-top.torn {
  animation: topFly 0.8s cubic-bezier(0.3, 0.6, 0.4, 1) forwards;
}
@keyframes topFly {
  20% { transform: translate(8px, -6px) rotate(3deg); }
  100% { transform: translate(-70px, -240px) rotate(-38deg); opacity: 0; }
}

/* la fente : l'interstice SOMBRE s'entrouvre sur TOUTE la largeur à mesure que
   le rabat se soulève — il s'élargit, il n'« avance » pas */
.tear-line {
  position: absolute; top: 12.5%; left: 0; right: 0; height: 9px; z-index: 3;
  margin-top: -2px;
  background: linear-gradient(180deg, rgba(4,5,9,0.96), rgba(4,5,9,0.55));
  opacity: min(calc(var(--tear-p, 0) * 2.4), 1);
  transform: scaleY(calc(0.22 + var(--tear-p2, 0) * 0.78));
  transform-origin: top;
  clip-path: polygon(0 30%, 2% 85%, 4% 15%, 7% 95%, 9% 45%, 12% 100%, 14% 25%, 17% 75%, 19% 5%, 22% 90%, 25% 50%, 27% 100%, 30% 20%, 33% 80%, 35% 40%, 38% 95%, 41% 10%, 44% 70%, 46% 35%, 49% 100%, 52% 15%, 55% 85%, 57% 55%, 60% 95%, 63% 25%, 66% 75%, 68% 5%, 71% 90%, 74% 45%, 76% 100%, 79% 30%, 82% 80%, 85% 10%, 88% 95%, 90% 50%, 93% 100%, 96% 20%, 98% 70%, 100% 40%, 100% 100%, 0 100%);
}
/* la lèvre de papier du corps accroche la lumière sous la fente */
.pack-body::before {
  content: ""; position: absolute; top: 0; left: 0; height: 3px; z-index: 3;
  width: 100%;
  opacity: min(calc(var(--tear-p, 0) * 2), 0.85);
  background: linear-gradient(180deg, rgba(255,248,222,0.5), transparent);
  pointer-events: none;
}

.pack-body {
  position: absolute; top: 12.5%; left: 0; right: 0; bottom: 0;
  overflow: hidden;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 10px;
  /* silhouette : côtés bombés (les cartes gonflent le sachet), bas serti en dents */
  clip-path: polygon(1% 0%, 99% 0%, 99.7% 5%, 100% 16%, 100% 78%, 99.7% 90%, 98.8% 96%, 97% 99%, 94% 96.8%, 91% 100%, 88% 96.6%, 85% 99.4%, 82% 96.9%, 79% 100%, 76% 96.7%, 73% 99.3%, 70% 96.8%, 67% 100%, 64% 96.6%, 61% 99.4%, 58% 96.9%, 55% 100%, 52% 96.7%, 49% 99.3%, 46% 96.8%, 43% 100%, 40% 96.6%, 37% 99.4%, 34% 96.9%, 31% 100%, 28% 96.7%, 25% 99.3%, 22% 96.8%, 19% 100%, 16% 96.6%, 13% 99.4%, 10% 96.9%, 7% 99.8%, 4% 97.2%, 3% 99%, 1.2% 96%, 0.3% 90%, 0% 78%, 0% 16%, 0.3% 5%);
}
/* soudure sertie du bas du sachet (le foil casse en plongeant dessous) */
.pack-body::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 5.5%;
  z-index: 1; pointer-events: none;
  background:
    repeating-linear-gradient(90deg, rgba(0,0,0,0.26) 0 2px, transparent 2px 5px),
    linear-gradient(180deg, rgba(0,0,0,0.34), transparent 45%),
    linear-gradient(0deg, rgba(255,255,255,0.06), transparent 80%);
  border-top: 1px solid rgba(0,0,0,0.3);
}

/* reflet spéculaire du foil : il SUIT la souris (--mx/--my posés par packopen) — le volume vivant */
.pack-sheen {
  position: absolute; inset: 0;
  background: radial-gradient(58% 46% at var(--mx, 50%) var(--my, 38%),
    rgba(255,255,255,0.16), rgba(255,255,255,0.045) 42%, transparent 68%);
}
/* en boutique (mini, pas de souris dessus) : balayage périodique d'origine */
.pack3d-mini .pack-sheen {
  inset: -40%;
  background: linear-gradient(115deg, transparent 44%, rgba(255,255,255,0.10) 50%, transparent 56%);
  animation: packSheen 4.5s ease-in-out infinite;
}
@keyframes packSheen { 0%, 30% { transform: translateX(-45%); } 75%, 100% { transform: translateX(45%); } }

/* la vitre du booster : fenêtre découpée dans le sachet, carte star visible derrière */
.pack-window {
  position: relative; z-index: 2;
  width: 64%; aspect-ratio: 5 / 7;
  border-radius: 9px;
  background: #05060A;
  border: 2px solid var(--foil-edge);
  box-shadow:
    inset 0 3px 14px rgba(0,0,0,0.85),
    inset 0 -2px 8px rgba(0,0,0,0.5),
    0 1px 0 rgba(255,255,255,0.07);
  overflow: hidden;
}
.pw-card {
  position: absolute; left: -4%; top: -3%; width: 108%;
  border-radius: 7px;
  transform: rotate(-2.4deg);
  box-shadow: 0 6px 16px rgba(0,0,0,0.6);
  user-select: none; -webkit-user-drag: none;
}
/* le reflet de la vitre (statique, discret — c'est du verre, pas du glow) */
.pw-glass {
  position: absolute; inset: 0; z-index: 2; pointer-events: none;
  background: linear-gradient(118deg,
    rgba(255,255,255,0.17) 6%, rgba(255,255,255,0.05) 22%, transparent 38%,
    transparent 60%, rgba(255,255,255,0.07) 78%, transparent 90%);
}
/* pendant la déchirure, la carte tremble dans le sachet (en léger contretemps) */
.pack3d.tearing .pw-card { animation: pwJiggle 0.11s infinite; }
@keyframes pwJiggle {
  30% { transform: rotate(calc(-2.4deg + var(--shake, 0) * 1.6deg)) translateY(calc(var(--shake, 0) * -2px)); }
  70% { transform: rotate(calc(-2.4deg - var(--shake, 0) * 1.4deg)) translateY(calc(var(--shake, 0) * 1.5px)); }
}
.pack-emblem {
  width: 38%; aspect-ratio: 1; position: relative; z-index: 2;
  color: var(--pack-accent, var(--gold));
  filter: drop-shadow(0 0 16px color-mix(in srgb, var(--pack-accent, var(--gold)) 60%, transparent));
}
.pack-emblem svg { width: 100%; height: 100%; }
.pack-title {
  font-family: var(--font-display); font-weight: 800;
  font-size: clamp(15px, 9cqw, 21px); letter-spacing: 0.06em;
  color: #fff; position: relative; z-index: 2;
  text-shadow: 0 2px 18px rgba(0,0,0,0.6);
}
.pack-count {
  font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.26em;
  color: var(--dim); position: relative; z-index: 2;
}

/* texte du sachet (le TITRE) personnalisable : templates de police + animations */
.pack-title span { display: inline-block; white-space: nowrap; max-width: 100%; }
.pb-gold span { font-family: "Anton", sans-serif; font-size: 23px; letter-spacing: .02em; text-transform: uppercase; background: linear-gradient(180deg,#FFEFB0,#EBBB4E 55%,#B8860B); -webkit-background-clip: text; background-clip: text; color: transparent; filter: drop-shadow(0 1px 1px rgba(0,0,0,.55)); }
.pb-fire span { font-family: "Bebas Neue", sans-serif; font-size: 30px; letter-spacing: .03em; background: linear-gradient(180deg,#FFD84A,#FF7A1A 52%,#E12C1A); -webkit-background-clip: text; background-clip: text; color: transparent; filter: drop-shadow(0 0 6px rgba(255,90,20,.5)); }
.pb-neon span { font-family: "Russo One", sans-serif; font-size: 20px; text-transform: uppercase; color: #B7F8FF; text-shadow: 0 0 4px #22D3EE, 0 0 10px #22D3EE; }
.pb-comic span { font-family: "Bangers", cursive; font-size: 30px; letter-spacing: .04em; color: #fff; -webkit-text-stroke: .1em #111; paint-order: stroke fill; text-shadow: .07em .07em 0 #111; }
.pb-script span { font-family: "Pacifico", cursive; font-size: 24px; background: linear-gradient(180deg,#FFEFB0,#E9B949); -webkit-background-clip: text; background-clip: text; color: transparent; filter: drop-shadow(0 1px 2px rgba(0,0,0,.5)); }
.pb-ribbon span { font-family: "Anton", sans-serif; font-size: 18px; letter-spacing: .04em; text-transform: uppercase; color: #1b1405; background: linear-gradient(180deg,#FFD96E,#E0A93B); padding: .28em .7em; border-radius: .25em; box-shadow: 0 .15em .35em rgba(0,0,0,.45); }
.pb-stamp span { font-family: "Bebas Neue", sans-serif; font-size: 21px; letter-spacing: .06em; text-transform: uppercase; color: #FF5470; border: .14em solid #FF5470; padding: .12em .45em; border-radius: .2em; }
.pb-clean span { font-family: "Manrope", sans-serif; font-weight: 800; font-size: 16px; letter-spacing: .18em; text-transform: uppercase; color: #fff; text-shadow: 0 1px 3px rgba(0,0,0,.6); }
.pb-anim.pb-pulse span { animation: pbPulse 1.4s ease-in-out infinite; }
@keyframes pbPulse { 50% { transform: scale(1.08); } }
.pb-anim.pb-float span { animation: pbFloat 2.2s ease-in-out infinite; }
@keyframes pbFloat { 50% { transform: translateY(-.35em); } }
.pb-anim.pb-blink span { animation: pbBlink 1s steps(1) infinite; }
@keyframes pbBlink { 0%,60% { opacity: 1; } 61%,100% { opacity: .35; } }
.pb-anim.pb-shine span { position: relative; overflow: hidden; }
.pb-anim.pb-shine span::after { content: ""; position: absolute; inset: 0; background: linear-gradient(110deg, transparent 42%, rgba(255,255,255,.8) 50%, transparent 58%); transform: translateX(-130%); animation: pbShine 2.4s ease-in-out infinite; }
@keyframes pbShine { 0% { transform: translateX(-130%); } 55%,100% { transform: translateX(130%); } }

/* au repos le pack flotte doucement, son ombre respire au sol */
.open-scene .pack3d:not(.tearing) { animation: packFloat 3.4s ease-in-out infinite; }
@keyframes packFloat { 50% { translate: 0 -8px; } }
.open-scene .pack-shadow { animation: shadowBreath 3.4s ease-in-out infinite; }
@keyframes shadowBreath { 50% { transform: translateX(-50%) scale(0.9); opacity: 0.72; } }

/* secousse pendant la déchirure */
.pack3d.tearing { animation: packTremble 0.09s infinite; }
@keyframes packTremble {
  25% { translate: calc(var(--shake, 0) * -5px) calc(var(--shake, 0) * 2px); }
  75% { translate: calc(var(--shake, 0) * 5px) calc(var(--shake, 0) * -2px); }
}

.pack3d.opened .pack-body { animation: bodyDrop 0.7s 0.15s cubic-bezier(0.5, 0, 0.8, 0.4) forwards; }
.pack3d.opened .tear-line { opacity: 0; }
@keyframes bodyDrop { to { transform: translateY(140px) rotate(6deg) scale(0.85); opacity: 0; } }

/* version mini (cartes boutique) */
.pack3d-mini { width: 100%; max-width: 210px; margin: 0 auto; pointer-events: none; filter: drop-shadow(0 18px 30px rgba(0,0,0,0.5)); }

/* ===================== GRILLE PACKS ===================== */
.packs-grid {
  display: grid; gap: 22px;
  grid-template-columns: repeat(auto-fit, minmax(290px, 1fr));
}
.packs-grid-4 { grid-template-columns: repeat(auto-fit, minmax(270px, 1fr)); }

.packcard {
  position: relative;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 28px 24px 24px;
  /* overflow visible : les cartes du booster sortent au survol */
  transition: transform 0.25s, border-color 0.25s, box-shadow 0.25s;
}
.packcard:hover { z-index: 6; }
.packcard::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(90% 50% at 50% 0%, color-mix(in srgb, var(--pack-accent, #888) 10%, transparent), transparent 70%);
  opacity: 0; transition: opacity 0.3s;
}
.packcard:hover { transform: translateY(-6px); border-color: color-mix(in srgb, var(--pack-accent, #888) 40%, transparent); box-shadow: 0 24px 50px rgba(0,0,0,0.45); }
.packcard:hover::before { opacity: 1; }
.packcard:hover .pack3d-mini { transform: perspective(1100px) rotateX(6deg) rotateY(-8deg) translateY(-6px); }

.packcard-visual { margin-bottom: 20px; position: relative; z-index: 1; }
.packcard-info { position: relative; z-index: 1; }
.packcard-info h3 { font-family: var(--font-display); font-size: 18px; font-weight: 800; letter-spacing: 0.04em; }
.packcard-tag { color: var(--dim); font-size: 13px; margin: 4px 0 14px; }

.packcard-odds { display: flex; flex-direction: column; gap: 5px; margin-bottom: 14px; }
.odds-row {
  display: flex; align-items: center; gap: 8px;
  font-size: 12px; color: var(--dim);
}
.odds-row b { margin-left: auto; font-family: var(--font-mono); font-size: 11px; color: var(--text); }
.odds-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }

.packcard-guarantee {
  font-size: 11.5px; font-weight: 600; color: var(--dim);
  margin-bottom: 16px;
}
.packcard-guarantee.dim { color: var(--dim); }

/* ===================== GRILLE JEUX ===================== */
.games-grid {
  display: grid; gap: 18px;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}
.gamecard {
  position: relative; overflow: hidden;
  display: flex; flex-direction: column;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  transition: transform 0.22s, border-color 0.22s;
}
.gamecard:hover { transform: translateY(-4px); border-color: color-mix(in srgb, var(--gold) 45%, transparent); }

/* tête de tuile : une vraie carte qui dépasse + le visuel animé du jeu, décalé en haut à droite */
.gc-viz {
  position: relative; overflow: hidden;
  height: 110px; display: flex; align-items: flex-start; justify-content: flex-end;
  padding: 22px 32px 0 0;
  background: radial-gradient(120% 120% at 30% 0, color-mix(in srgb, var(--gold) 14%, transparent), transparent 70%), var(--surface-2);
  border-bottom: 1px solid var(--line);
  color: var(--gold);
}
.gc-viz > :not(.gc-card) { filter: drop-shadow(0 6px 14px rgba(0,0,0,0.45)); }
.gc-card {
  position: absolute; left: 14px; bottom: -22px;
  width: 78px; height: 109px; object-fit: cover;
  border-radius: 7px; transform: rotate(-9deg);
  border: 1px solid rgba(255,255,255,0.18);
  box-shadow: 0 12px 26px rgba(0,0,0,0.5);
  transition: transform 0.3s;
}
.gamecard:hover .gc-card { transform: rotate(-6deg) translateY(-6px); }
.gc-body { padding: 16px 18px 18px; display: flex; flex-direction: column; gap: 5px; }
.gamecard-name { font-family: var(--font-display); font-weight: 800; font-size: 16px; }
.gamecard-desc { color: var(--dim); font-size: 12.5px; line-height: 1.5; flex: 1; }
.gamecard-go {
  font-family: var(--font-mono); font-size: 10.5px; font-weight: 700;
  letter-spacing: 0.16em; color: var(--gold); margin-top: 8px;
}

/* ---- visuels par jeu ---- */
.vz-mines { display: grid; grid-template-columns: repeat(3, 13px); gap: 6px; }
.vz-mines i { width: 13px; height: 13px; border-radius: 3px; background: color-mix(in srgb, var(--text) 15%, transparent); }
.vz-mines i.b { background: var(--hot); box-shadow: 0 0 8px color-mix(in srgb, var(--hot) 60%, transparent); }
.vz-mines i.g { background: var(--gold); }
.vz-coin {
  width: 44px; height: 44px; border-radius: 50%;
  background: radial-gradient(circle at 35% 30%, #fff3c0, var(--gold) 60%, var(--gold-deep));
  box-shadow: 0 0 14px color-mix(in srgb, var(--gold) 40%, transparent);
  animation: vzCoin 2.6s ease-in-out infinite;
}
@keyframes vzCoin { 50% { transform: rotateY(180deg); } }
.vz-wheel {
  width: 48px; height: 48px; border-radius: 50%;
  background: conic-gradient(var(--gold) 0 25%, #5b8cff 0 50%, #C24BFF 0 75%, var(--hot) 0);
  animation: vzWheel 4.5s linear infinite;
}
@keyframes vzWheel { to { transform: rotate(360deg); } }
.vz-crash { width: 62px; height: 44px; }
.vz-crash path { stroke: var(--gold); stroke-width: 3; fill: none; stroke-linecap: round; stroke-linejoin: round; stroke-dasharray: 130; stroke-dashoffset: 130; animation: vzCrash 2.4s ease infinite; }
@keyframes vzCrash { 25%, 100% { stroke-dashoffset: 0; } }

/* ===================== OVERLAY OUVERTURE ===================== */
.open-overlay {
  position: fixed; inset: 0; z-index: 900;
  background: rgba(7, 8, 11, 0.92);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  animation: overlayIn 0.35s ease;
}
@keyframes overlayIn { from { opacity: 0; } }

.open-overlay.mythic-zoom .open-stage { animation: mythicPunch 0.9s cubic-bezier(0.2, 0.8, 0.3, 1); }
@keyframes mythicPunch { 25% { transform: scale(1.05); } }

.open-vignette {
  position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(90% 80% at 50% 50%, transparent 50%, rgba(0,0,0,0.7));
}
/* couche de particules DERRIÈRE le paquet (le burst d'ouverture jaillit de derrière) */
.open-fx-back { position: absolute; inset: 0; z-index: 1; pointer-events: none; }

/* la zone scrollable : beaucoup de cartes → on peut descendre, SANS barre de
   défilement. Le décor et le bouton fermer restent fixes derrière/devant. */
.open-scroll {
  position: absolute; inset: 0; z-index: 2;
  display: flex;
  overflow-y: auto;
  overscroll-behavior: contain;
  scrollbar-width: none;
}
.open-scroll::-webkit-scrollbar { display: none; width: 0; }

/* margin:auto = centré quand ça tient à l'écran, scroll propre quand ça déborde */
.open-stage { position: relative; width: 100%; max-width: 1180px; padding: 24px 24px 52px; margin: auto; }

.open-close {
  position: absolute; top: 22px; right: 26px; z-index: 5;
  width: 42px; height: 42px; border-radius: 50%;
  border: 1px solid var(--line);
  color: var(--dim); font-size: 16px;
  background: rgba(255,255,255,0.04);
  transition: color 0.2s, border-color 0.2s, transform 0.2s;
}
.open-close:hover { color: #fff; border-color: rgba(255,255,255,0.3); transform: rotate(90deg); }

/* aurore : deux nappes de couleur floues qui respirent, puis se dégagent */
.god-rays {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  animation: raysIn 1.2s ease backwards;
  transition: opacity 1.4s ease;
}
.god-rays::before, .god-rays::after {
  content: "";
  position: absolute;
  width: 65vmax; height: 65vmax;
  border-radius: 50%;
  filter: blur(90px);
  mix-blend-mode: screen;
}
.god-rays::before {
  left: 50%; top: 55%;
  background: radial-gradient(circle, color-mix(in srgb, var(--ray-color, var(--gold)) 26%, transparent), transparent 65%);
  animation: auroraA 9s ease-in-out infinite alternate;
}
.god-rays::after {
  left: 18%; top: 18%;
  width: 45vmax; height: 45vmax;
  background: radial-gradient(circle, color-mix(in srgb, var(--ray-color, var(--gold)) 16%, transparent), transparent 65%);
  animation: auroraB 12s ease-in-out infinite alternate;
}
@keyframes auroraA {
  from { transform: translate(-60%, -55%) scale(1); }
  to   { transform: translate(-42%, -48%) scale(1.25); }
}
@keyframes auroraB {
  from { transform: translate(-30%, -30%) scale(1.15); }
  to   { transform: translate(-12%, -45%) scale(0.9); }
}
/* une fois les cartes arrivées, l'aurore se dégage */
.god-rays.calm { opacity: 0.22; }
@keyframes raysIn { from { opacity: 0; } }

/* scène pack */
.open-scene {
  display: flex; flex-direction: column; align-items: center; gap: 34px;
  padding: 30px 0;
}
.open-hint {
  position: relative;
  font-family: var(--font-mono); font-size: 11px; font-weight: 700;
  letter-spacing: 0.3em; text-transform: uppercase; color: var(--dim);
  padding-bottom: 10px;
  animation: hintBreath 2.6s ease infinite;
  transition: opacity 0.4s, transform 0.4s;
}
.open-hint::after {
  content: "";
  position: absolute; left: 50%; bottom: 0; height: 1px; width: 46px;
  transform: translateX(-50%);
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
}
@keyframes hintBreath { 50% { opacity: 0.55; } }
.open-hint.hint-hide { opacity: 0; transform: translateY(-10px); animation: none; }

.pack3d-wrap { position: relative; cursor: grab; touch-action: none; }
.pack3d-wrap:active { cursor: grabbing; }
.pack-shadow {
  position: absolute; left: 50%; bottom: -34px; transform: translateX(-50%);
  width: 70%; height: 26px; border-radius: 50%;
  background: radial-gradient(ellipse, rgba(0,0,0,0.65), transparent 70%);
}

.tear-bar {
  width: 240px; height: 5px; border-radius: 6px;
  background: rgba(255,255,255,0.08);
  overflow: hidden;
}
.tear-bar i {
  display: block; height: 100%; width: 0;
  border-radius: 6px;
  background: linear-gradient(90deg, var(--gold-deep), var(--gold), #FFF2C8);
  box-shadow: 0 0 12px rgba(245,196,75,0.8);
}

/* scène révélation */
.reveal-scene { display: flex; flex-direction: column; gap: 26px; align-items: center; }
.reveal-head {
  display: flex; align-items: baseline; gap: 22px;
  animation: pageIn 0.4s ease;
}
.reveal-pack-name {
  font-family: var(--font-mono); font-weight: 700; font-size: 11px;
  letter-spacing: 0.26em; text-transform: uppercase; color: var(--dim);
}
.reveal-all {
  font-family: var(--font-mono); font-weight: 700; font-size: 10.5px;
  letter-spacing: 0.24em; text-transform: uppercase;
  color: var(--dim); padding: 4px 0;
  border-bottom: 1px solid transparent;
  transition: color 0.2s, border-color 0.2s;
}
.reveal-all:hover { color: var(--gold); border-color: var(--gold); }

.reveal-row {
  display: flex; gap: clamp(10px, 2vw, 22px);
  justify-content: center; flex-wrap: wrap;
  perspective: 1400px;
}

.reveal-card {
  position: relative;
  z-index: 0; /* contexte d'empilement : les effets en z-index:-1 restent collés derrière CETTE carte */
  width: clamp(130px, 16.5vw, 195px);
  aspect-ratio: 5 / 7;
  cursor: pointer;
  /* l'arrivée est animée en JS : les cartes jaillissent du pack */
}

/* le meilleur tirage s'illumine au récap */
.reveal-card.best-pick { z-index: 3; }
.reveal-card.best-pick .cardface {
  outline: 3px solid var(--gold);
  outline-offset: 4px;
  animation: bestPulse 1.6s ease-in-out infinite;
}
@keyframes bestPulse {
  0%, 100% { box-shadow: 0 18px 50px rgba(0,0,0,0.55), 0 0 26px rgba(245,196,75,0.35); transform: scale(1); }
  50%      { box-shadow: 0 18px 50px rgba(0,0,0,0.55), 0 0 48px rgba(245,196,75,0.65); transform: scale(1.035); }
}
.reveal-card:not(.flipped):hover .rc-inner { transform: translateY(-10px) rotateY(0deg); }
.reveal-card:not(.flipped):hover .rc-back { box-shadow: 0 22px 50px rgba(0,0,0,0.6), 0 0 26px rgba(245,196,75,0.25); }

.rc-inner {
  position: absolute; inset: 0;
  transform-style: preserve-3d;
  transition: transform 0.65s cubic-bezier(0.3, 0.7, 0.25, 1.05);
}
.reveal-card.flipped .rc-inner { transform: rotateY(180deg); }

.rc-back, .rc-front {
  position: absolute; inset: 0;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  border-radius: 7px;
}
.rc-back {
  display: grid; place-items: center;
  background:
    radial-gradient(90% 70% at 50% 30%, rgba(245,196,75,0.08), transparent 60%),
    linear-gradient(160deg, #1B1F2C, #0E1018);
  border: 1px solid rgba(245,196,75,0.22);
  box-shadow: 0 16px 40px rgba(0,0,0,0.55);
  overflow: hidden;
  transition: box-shadow 0.3s;
}
.rc-back-pattern {
  position: absolute; inset: 0; opacity: 0.6;
  background:
    repeating-linear-gradient(45deg, rgba(245,196,75,0.05) 0 2px, transparent 2px 14px),
    repeating-linear-gradient(-45deg, rgba(245,196,75,0.05) 0 2px, transparent 2px 14px);
}
.rc-front { transform: rotateY(180deg); }

/* =====================================================
   RÉVÉLATION — esprit TCG holographique + anime kira-kira
   Tout est NET (zéro blur lourd). Trois couches :
   1. rc-ring  : flash de lumière franc derrière la carte au flip
   2. rc-sweep : reflet holo qui balaie la carte (la signature foil)
   3. rc-stars : étincelles 4 branches qui scintillent (kira-kira)
   Montée en intensité commune → mythique.
   ===================================================== */

/* 1. flash franc derrière la carte */
.rc-ring {
  position: absolute; inset: -8%;
  z-index: -1; pointer-events: none; opacity: 0;
  border-radius: 10px;
  background: radial-gradient(closest-side,
    #fff 0%,
    color-mix(in srgb, var(--ring-color, var(--gold)) 70%, white) 28%,
    color-mix(in srgb, var(--ring-color, var(--gold)) 45%, transparent) 56%,
    transparent 78%);
}
.reveal-card.revealed .rc-ring { animation: flashPop 0.55s cubic-bezier(0.2, 0.8, 0.3, 1); }
@keyframes flashPop {
  0%   { opacity: 0; transform: scale(0.55); }
  18%  { opacity: 0.95; }
  100% { opacity: 0; transform: scale(1.3); }
}
/* aura nette qui respire, collée au bord, sur les hautes raretés
   (sur le conteneur, pas sur .rc-front qui sert au revealPop) */
.reveal-card.revealed.rarity-legendary,
.reveal-card.revealed.rarity-mythic {
  animation: auraBreath 2.6s ease 0.6s infinite;
  border-radius: 8px;
}
@keyframes auraBreath {
  0%, 100% { box-shadow: 0 0 10px color-mix(in srgb, var(--ring-color, var(--gold)) 55%, transparent); }
  50%      { box-shadow: 0 0 24px var(--ring-color, var(--gold)), 0 0 46px color-mix(in srgb, var(--ring-color, var(--gold)) 45%, transparent); }
}

/* 2. reflet holographique qui balaie la carte (sur la carte, clippé) */
.rc-sweep {
  position: absolute; inset: 0; z-index: 3;
  border-radius: 7px; overflow: hidden;
  pointer-events: none; opacity: 0;
  mix-blend-mode: screen;
}
.rc-sweep::before {
  content: ""; position: absolute; inset: -60% -30%;
  background: linear-gradient(108deg,
    transparent 40%,
    rgba(255,255,255,0.55) 47%,
    rgba(255,255,255,0.95) 50%,
    rgba(255,255,255,0.55) 53%,
    transparent 60%);
  transform: translateX(-115%);
}
.reveal-card.revealed .rc-sweep { animation: sweepFade 0.85s ease 0.05s; }
.reveal-card.revealed .rc-sweep::before { animation: sweepMove 0.85s cubic-bezier(0.4, 0, 0.2, 1) 0.05s; }
@keyframes sweepFade { 0%, 100% { opacity: 0; } 18%, 78% { opacity: 1; } }
@keyframes sweepMove { 0% { transform: translateX(-115%); } 100% { transform: translateX(115%); } }
/* commune : pas de holo (une commune n'est pas brillante) */
.reveal-card.revealed.rarity-common .rc-sweep { display: none; }
/* épique et + : même balayage blanc sobre, juste un peu plus large.
   (le reflet « prismatique arc-en-ciel » multicolore a été retiré : ignoble) */
.reveal-card.revealed.rarity-epic .rc-sweep::before,
.reveal-card.revealed.rarity-legendary .rc-sweep::before,
.reveal-card.revealed.rarity-mythic .rc-sweep::before {
  background: linear-gradient(108deg,
    transparent 38%,
    rgba(255,255,255,0.5) 46%,
    rgba(255,255,255,0.95) 50%,
    rgba(255,255,255,0.5) 54%,
    transparent 62%);
}
/* légendaire / mythique : double balayage */
.reveal-card.revealed.rarity-legendary .rc-sweep,
.reveal-card.revealed.rarity-mythic .rc-sweep { animation: sweepFade 0.8s ease 0.05s, sweepFade 0.9s ease 0.7s; }
.reveal-card.revealed.rarity-legendary .rc-sweep::before,
.reveal-card.revealed.rarity-mythic .rc-sweep::before { animation: sweepMove 0.8s cubic-bezier(0.4,0,0.2,1) 0.05s, sweepMove 0.9s cubic-bezier(0.4,0,0.2,1) 0.7s; }

/* 3. étincelles kira-kira : étoiles 4 branches nettes qui scintillent */
.rc-stars { position: absolute; inset: -14%; z-index: 4; pointer-events: none; }
.rc-stars i {
  position: absolute;
  width: 16px; height: 16px; margin: -8px;
  background: #fff;
  clip-path: polygon(50% 0%, 59% 41%, 100% 50%, 59% 59%, 50% 100%, 41% 59%, 0% 50%, 41% 41%);
  filter: drop-shadow(0 0 4px var(--ring-color, var(--gold)));
  opacity: 0; transform: scale(0);
  will-change: transform, opacity;
}
.rc-stars i:nth-child(1) { left: 16%; top: 10%; }
.rc-stars i:nth-child(2) { left: 82%; top: 8%;  width: 12px; height: 12px; }
.rc-stars i:nth-child(3) { left: 50%; top: -2%; width: 20px; height: 20px; }
.rc-stars i:nth-child(4) { left: 96%; top: 42%; }
.rc-stars i:nth-child(5) { left: 88%; top: 88%; width: 13px; height: 13px; }
.rc-stars i:nth-child(6) { left: 50%; top: 100%; width: 18px; height: 18px; }
.rc-stars i:nth-child(7) { left: 10%; top: 86%; }
.rc-stars i:nth-child(8) { left: 2%;  top: 44%; width: 12px; height: 12px; }
.reveal-card.revealed .rc-stars i {
  animation: twinkle 0.9s ease-out both;
}
.rc-stars i:nth-child(1) { animation-delay: 0.10s; }
.rc-stars i:nth-child(2) { animation-delay: 0.22s; }
.rc-stars i:nth-child(3) { animation-delay: 0.05s; }
.rc-stars i:nth-child(4) { animation-delay: 0.28s; }
.rc-stars i:nth-child(5) { animation-delay: 0.16s; }
.rc-stars i:nth-child(6) { animation-delay: 0.34s; }
.rc-stars i:nth-child(7) { animation-delay: 0.20s; }
.rc-stars i:nth-child(8) { animation-delay: 0.12s; }
@keyframes twinkle {
  0%   { opacity: 0; transform: scale(0) rotate(-35deg); }
  45%  { opacity: 1; transform: scale(1.15) rotate(0deg); }
  100% { opacity: 0; transform: scale(0.2) rotate(28deg); }
}
/* commune : juste 3 petites étincelles discrètes */
.reveal-card.revealed.rarity-common .rc-stars i { filter: drop-shadow(0 0 3px rgba(255,255,255,0.6)); }
.reveal-card.revealed.rarity-common .rc-stars i:nth-child(n+4) { display: none; }
/* rare : 5 étincelles */
.reveal-card.revealed.rarity-rare .rc-stars i:nth-child(n+6) { display: none; }
/* légendaire / mythique : étincelles plus grosses + une 2e salve */
.reveal-card.revealed.rarity-legendary .rc-stars i,
.reveal-card.revealed.rarity-mythic .rc-stars i {
  animation: twinkle 0.9s ease-out both, twinkle 0.85s ease-out 0.7s both;
  filter: drop-shadow(0 0 6px var(--ring-color, var(--gold)));
}

/* pop selon rareté au flip */
.reveal-card.flipped.rarity-legendary .rc-front,
.reveal-card.flipped.rarity-mythic .rc-front { animation: revealPop 0.7s 0.32s; }
@keyframes revealPop { 30% { transform: rotateY(180deg) scale(1.12); } }

/* épique : petit pop énergique */
.reveal-card.pop { animation: cardPop 0.55s cubic-bezier(0.2, 1.4, 0.4, 1); z-index: 50; }
@keyframes cardPop { 0% { transform: scale(1); } 45% { transform: scale(1.16); } 100% { transform: scale(1); } }

/* légendaire / mythique : LA CARTE SE PRÉSENTE — elle grossit, monte au centre,
   se balance légèrement, puis revient. Tout le reste passe au second plan. */
.reveal-card.showcase {
  z-index: 100;
  animation: showcaseRise 1.15s cubic-bezier(0.18, 0.9, 0.25, 1);
}
.reveal-card.rarity-mythic.showcase { animation-duration: 1.5s; }
@keyframes showcaseRise {
  0%   { transform: scale(1) translateY(0) rotate(0); }
  18%  { transform: scale(1.55) translateY(-22px) rotate(-3deg); }
  30%  { transform: scale(1.5) translateY(-22px) rotate(2deg); }
  42%  { transform: scale(1.55) translateY(-24px) rotate(-1deg); }
  72%  { transform: scale(1.5) translateY(-22px) rotate(0); }
  100% { transform: scale(1) translateY(0) rotate(0); }
}
/* pendant la présentation, le fond se fonce en douceur pour isoler la carte
   (vignette pleine page, sans bord net / ligne noire) */
.reveal-card.showcase::after {
  content: ""; position: fixed; inset: 0; z-index: -1;
  background: radial-gradient(140% 140% at 50% 50%, transparent 28%, rgba(5,6,9,0.62) 100%);
  pointer-events: none;
  animation: showcaseDim 1.15s ease;
}
.reveal-card.rarity-mythic.showcase::after { animation-duration: 1.5s; }
@keyframes showcaseDim { 0%, 100% { opacity: 0; } 25%, 65% { opacity: 1; } }

/* ===================== ÉCRAN DE CONNEXION (porte obligatoire) ===================== */
.auth-panel {
  width: 100%; max-width: 400px;
  background: var(--surface); border: 1px solid var(--line);
  border-radius: 18px; padding: 32px 30px;
  display: flex; flex-direction: column;
  transform: translateY(16px) scale(0.98); transition: transform 0.35s cubic-bezier(0.2,0.9,0.3,1);
}
.gen-gate.in .auth-panel { transform: none; }
.auth-brand {
  display: flex; align-items: center; gap: 7px; margin-bottom: 18px;
}
.auth-logo-mark { width: 38px; height: 38px; display: block; border-radius: 11px;
  filter: drop-shadow(0 2px 7px rgba(0,0,0,0.3)); }
.auth-brand .wordmark { font-size: 27px; }
.auth-logo { color: var(--gold); }
.auth-panel h2 { font-family: var(--font-display); font-weight: 800; font-size: 24px; }
.auth-sub { color: var(--dim); font-size: 13px; line-height: 1.5; margin: 6px 0 18px; }
.auth-tabs {
  display: grid; grid-template-columns: 1fr 1fr; gap: 4px;
  background: rgba(255,255,255,0.03); border: 1px solid var(--line);
  border-radius: 10px; padding: 4px; margin-bottom: 18px;
}
.auth-tab {
  padding: 9px; border-radius: 7px; background: transparent;
  font-family: var(--font-display); font-weight: 700; font-size: 13px;
  color: var(--dim); cursor: pointer; transition: background 0.15s, color 0.15s;
}
.auth-tab.sel { background: rgba(245,196,75,0.14); color: var(--gold); }
.auth-panel .account-input { margin-bottom: 4px; }
.auth-err { color: var(--hot); font-size: 12.5px; min-height: 18px; margin: 6px 0 4px; }
.auth-go { width: 100%; margin-top: 8px; }

/* ===================== CARTE GENESIS — gate d'entrée ===================== */
.gen-gate {
  position: fixed; inset: 0; z-index: 990;
  display: grid; place-items: center; padding: 24px;
  background: radial-gradient(120% 90% at 50% 10%, rgba(245,196,75,0.08), transparent 60%), rgba(7,8,11,0.92);
  backdrop-filter: blur(10px);
  opacity: 0; transition: opacity 0.3s;
}
.gen-gate.in { opacity: 1; }
.gen-panel {
  display: grid; grid-template-columns: 300px 1fr; gap: 36px; align-items: center;
  max-width: 860px; width: 100%;
  background: var(--surface); border: 1px solid var(--line);
  border-radius: 20px; padding: 36px;
  transform: translateY(18px) scale(0.98); transition: transform 0.35s cubic-bezier(0.2,0.9,0.3,1);
}
.gen-gate.in .gen-panel { transform: none; }
.gen-left { display: grid; place-items: center; }

/* la carte d'accès — visuel premium */
.gen-card {
  position: relative; overflow: hidden;
  width: 260px; aspect-ratio: 1.585;
  border-radius: 16px; padding: 20px;
  background: linear-gradient(150deg, #2A2210, #15130B 55%, #0E0C07);
  border: 1px solid rgba(245,196,75,0.5);
  box-shadow: 0 24px 60px rgba(0,0,0,0.6), inset 0 0 30px rgba(245,196,75,0.06);
  display: flex; flex-direction: column; justify-content: space-between;
  animation: genFloat 5s ease-in-out infinite;
}
@keyframes genFloat { 50% { transform: translateY(-7px) rotate(-0.6deg); } }
.gen-card-sheen {
  position: absolute; top: 0; left: -60%; width: 45%; height: 100%;
  background: linear-gradient(100deg, transparent, rgba(255,236,180,0.22), transparent);
  transform: skewX(-18deg); animation: genSheen 4.5s ease-in-out infinite;
}
@keyframes genSheen { 0%, 65%, 100% { left: -60%; } 80% { left: 130%; } }
.gen-card-top { display: flex; align-items: center; justify-content: space-between; }
.gen-card-brand { font-family: var(--font-display); font-weight: 800; font-size: 15px; letter-spacing: 0.1em; color: var(--gold); }
.gen-card-chip { width: 36px; height: 26px; border-radius: 5px; background: linear-gradient(135deg, #F5D98A, #C99A1F); opacity: 0.9; }
.gen-card-mid { font-family: var(--font-display); font-weight: 800; font-size: 34px; letter-spacing: 0.12em;
  color: transparent; background: linear-gradient(100deg, #FFE9B0, var(--gold) 50%, #C99A1F); -webkit-background-clip: text; background-clip: text; }
.gen-card-bot { display: flex; align-items: flex-end; justify-content: space-between;
  font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.2em; color: rgba(245,196,75,0.7); }
.gen-card-id { color: rgba(255,255,255,0.4); }

.gen-right h2 { font-family: var(--font-display); font-weight: 800; font-size: 26px; line-height: 1.15; }
.gen-sub { color: var(--dim); font-size: 13.5px; line-height: 1.6; margin: 10px 0 20px; }
.gen-tiers { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 18px; }
.gen-tier {
  position: relative; text-align: left;
  display: flex; flex-direction: column; gap: 2px;
  padding: 14px; border-radius: 12px;
  background: rgba(255,255,255,0.02); border: 1.5px solid var(--line);
  cursor: pointer; transition: border-color 0.15s, background 0.15s, transform 0.15s;
}
.gen-tier:hover { transform: translateY(-2px); border-color: rgba(245,196,75,0.4); }
.gen-tier.sel { border-color: var(--gold); background: rgba(245,196,75,0.08); }
.gen-pop { position: absolute; top: -8px; right: 10px; font-family: var(--font-mono); font-size: 8px; font-weight: 800;
  letter-spacing: 0.1em; color: #15130B; background: var(--gold); border-radius: 4px; padding: 2px 6px; }
.gen-tier-name { font-family: var(--font-display); font-weight: 800; font-size: 14px; }
.gen-tier-cr { font-family: var(--font-mono); font-weight: 700; font-size: 18px; color: var(--gold); }
.gen-tier-cr i { font-style: normal; font-size: 10px; color: var(--dim); }
.gen-tier-price { font-family: var(--font-display); font-weight: 700; font-size: 13px; color: var(--text); }
.gen-tier-perk { font-size: 11px; color: var(--dim); margin-top: 2px; }
.gen-go { width: 100%; }
.gen-peek { display: block; width: 100%; margin-top: 10px; background: none; border: none;
  color: var(--dim); font-family: var(--font-body); font-weight: 600; font-size: 12.5px; cursor: pointer; }
.gen-peek:hover { color: var(--text); }
@media (max-width: 720px) {
  .gen-panel { grid-template-columns: 1fr; gap: 22px; padding: 24px; }
  .gen-left { order: -1; }
  .gen-card { width: 220px; }
  .gen-tiers { grid-template-columns: 1fr 1fr; }
}

/* ===================== RÉCAP D'OUVERTURE — pilule flottante ===================== */
.reveal-recap {
  position: relative;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  width: 100%; margin: 10px auto 0; padding: 16px 0 0;
  background: transparent; border: none;
  animation: recapIn 0.5s cubic-bezier(0.2, 0.9, 0.3, 1);
}
.reveal-recap::before {
  content: ""; position: absolute; top: 0; left: 50%; transform: translateX(-50%);
  width: 220px; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(245,196,75,0.4), transparent);
}
@keyframes recapIn { from { opacity: 0; transform: translateY(18px); } }

.recap-pill {
  display: flex; align-items: center; gap: 8px;
  background: var(--surface); border: 1px solid var(--line);
  border-radius: 999px; padding: 6px 6px 6px 18px;
}
.recap-gain { display: flex; flex-direction: column; line-height: 1; padding-right: 4px; }
.recap-gain b {
  display: inline-flex; align-items: center; gap: 1px;
  font-size: 24px; line-height: 1;  /* chiffre contenu dans la pilule, ne déborde plus */
  font-variant-numeric: tabular-nums;
}
.recap-gain b.pos { color: #6BFF8F; }
.recap-gain b.neg { color: var(--hot); }
.recap-gain b.tot { color: var(--gold); } /* cote totale neutre : jamais de rouge au récap */

/* ===== paliers de win (×1 / ×2 / ×5 / ×10) : le chiffre grossit avec le multiplicateur ===== */
.recap-pill-win {
  border-color: color-mix(in srgb, var(--gold) 55%, transparent);
  box-shadow: 0 0 34px color-mix(in srgb, var(--gold) 26%, transparent);
}
.recap-gain b.wt-1 { color: #6BFF8F; }
.recap-gain b.wt-2 { color: #6BFF8F; font-size: 28px; text-shadow: 0 0 18px rgba(107, 255, 143, 0.45); }
.recap-gain b.wt-3, .recap-gain b.wt-4 {
  font-size: 32px;
  background: linear-gradient(180deg, #FFF3B8, var(--gold) 55%, #FF9900);
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
  filter: drop-shadow(0 0 16px rgba(255, 214, 10, 0.5));
}
.recap-gain b.wt-3 .cr-ic, .recap-gain b.wt-4 .cr-ic { -webkit-text-fill-color: initial; }
.recap-gain b.wt-4 { font-size: 36px; animation: jackpotGlow 1.1s ease-in-out infinite; }
@keyframes jackpotGlow {
  0%, 100% { filter: drop-shadow(0 0 10px rgba(255, 214, 10, 0.4)); }
  50% { filter: drop-shadow(0 0 28px rgba(255, 214, 10, 0.9)); }
}
/* pose douce des petits tirages (sous ×2) */
.recap-gain b.settle { animation: winSettle 0.5s cubic-bezier(0.22, 1.3, 0.36, 1); }
@keyframes winSettle { 0% { transform: scale(1.18); } 100% { transform: scale(1); } }

/* petit chip ×N dans la pilule du récap */
.recap-multchip {
  font-style: normal; font-family: var(--font-mono); font-weight: 700; font-size: 9px;
  color: #15130B; background: var(--gold); border-radius: 999px; padding: 1px 7px;
  margin-left: 5px; vertical-align: 1px;
}

/* ===== LE CHIFFRE FAIT LE SHOW (pas de texte) — version SATISFAISANTE =====
   Tout passe par transform (zéro reflow : la pilule ne bouge pas d'un pixel).
   Pendant le roll : montée LENTE et douce en scale + respiration subtile + glow
   qui monte. À la pose : retombée élastique moelleuse + halo qui s'éteint
   doucement. Les durées sont synchronisées avec le comptage (packopen.js). */
.recap-gain b.roll-t2 { --grow: 1.16; --rolldur: 2.25s; }
.recap-gain b.roll-t3 { --grow: 1.3; --rolldur: 2.9s; }
.recap-gain b.roll-t4 { --grow: 1.45; --rolldur: 3.55s; }
.recap-gain b.rolling {
  animation:
    winGrow var(--rolldur, 2.2s) cubic-bezier(0.4, 0, 0.55, 1) forwards,
    winGlow 1.1s ease-in-out infinite alternate;
  transform-origin: 50% 60%;
}
@keyframes winGrow { from { transform: scale(1); } to { transform: scale(var(--grow, 1.25)); } }
@keyframes winGlow {
  from { filter: drop-shadow(0 0 5px rgba(255, 214, 10, 0.2)); }
  to { filter: drop-shadow(0 0 20px rgba(255, 214, 10, 0.6)); }
}
/* (pas d'animation sur le span intérieur : un transform sur un enfant casse
   le background-clip:text du parent dans Chromium → chiffres invisibles) */
/* la pose : redescend de la taille du roll en douceur, micro-rebond, halo qui s'éteint */
.recap-gain b.settle-big {
  transform-origin: 50% 60%;
  animation:
    winLand 0.85s cubic-bezier(0.22, 1.3, 0.36, 1) forwards,
    winAfterglow 1.4s ease-out forwards;
}
@keyframes winLand {
  0% { transform: scale(var(--grow, 1.3)); }
  62% { transform: scale(0.985); }
  100% { transform: scale(1); }
}
@keyframes winAfterglow {
  0% { filter: drop-shadow(0 0 26px rgba(255, 214, 10, 0.8)) brightness(1.3); }
  100% { filter: drop-shadow(0 0 8px rgba(255, 214, 10, 0.25)) brightness(1); }
}
/* petit suffixe « € » à côté du chiffre (le CR, lui, passe par l'icône .cr-ic) */
.cr-sfx {
  font-family: "Space Mono", monospace; font-weight: 700;
  font-size: 0.6em; opacity: 0.62; margin-left: 0.18em; letter-spacing: 0.02em;
}
.recap-gain b .cr-ic { opacity: 0.8; }
.recap-gain > span .cr-ic { width: 8px; height: 8px; }
.recap-gain > span {
  font-family: var(--font-display); font-weight: 600; font-size: 9.5px;
  letter-spacing: 0.06em; color: var(--dim);
}
.recap-gain i { font-style: normal; font-variant-numeric: tabular-nums; }
.recap-div { width: 1px; height: 30px; background: var(--line); margin: 0 2px; }

/* boutons ronds discrets : garder + recevoir */
.rp-ico {
  width: 38px; height: 38px; border-radius: 50%; flex-shrink: 0;
  background: rgba(255,255,255,0.05); border: 1px solid var(--line);
  color: var(--text); display: grid; place-items: center; cursor: pointer;
  transition: background 0.15s, border-color 0.15s, transform 0.15s;
}
.rp-ico:hover { background: rgba(255,255,255,0.12); border-color: rgba(255,255,255,0.25); transform: translateY(-3px); }
.rp-ico:active { transform: scale(0.94); }
.rp-ico:disabled { opacity: 0.4; cursor: not-allowed; }
.rp-ico .rico { width: 19px; height: 19px; }
/* vendre = bouton primaire doré (icône seule) */
.rp-ico-pri { background: var(--gold); color: #15130B; border-color: transparent; box-shadow: 0 6px 16px rgba(255,214,10,0.3); }
.rp-ico-pri:hover { background: #FFE761; border-color: transparent; }
/* animations continues des icônes du récap (pour qu'on les voie vivre) */
.ract-sell .ico-coins { animation: coinShine 3s ease-in-out infinite; }
@keyframes coinShine { 50% { filter: drop-shadow(0 0 5px rgba(0,0,0,0.3)); } }
.ract-sell:hover .ico-coins { animation: coinsBounce 0.5s ease; }
.ract-replay .ico-replay { animation: slowSpin 6s linear infinite; transform-box: fill-box; transform-origin: center; }
@keyframes slowSpin { to { transform: rotate(360deg); } }
.ract-replay:hover .ico-replay { animation: slowSpin 0.6s linear; }

/* boutons argent : vendre (or plein) + rejouer (flèche en cercle) */
.rp-sell, .rp-replay {
  height: 38px; padding: 0 16px; border-radius: 999px;
  display: flex; align-items: center; gap: 7px;
  font-family: var(--font-mono); font-weight: 700; font-size: 13px;
  cursor: pointer; border: 1px solid transparent;
  transition: background 0.15s, border-color 0.15s, transform 0.15s;
}
.rp-sell .rico, .rp-replay .rico { width: 17px; height: 17px; }
.rp-sell:active, .rp-replay:active { transform: scale(0.96); }
.rp-replay:disabled { opacity: 0.4; cursor: not-allowed; }

.rp-sell { background: var(--gold); color: #15130B; }
.rp-sell:hover { background: #FFD45E; }

.rp-replay {
  background: rgba(245,196,75,0.1); color: var(--gold);
  border-color: rgba(245,196,75,0.45);
  animation: replayBreath 2.6s ease infinite;
}
.rp-replay:hover:not(:disabled) { background: rgba(245,196,75,0.2); border-color: var(--gold); }
@keyframes replayBreath {
  0%, 100% { box-shadow: 0 0 0 rgba(245,196,75,0); }
  50%      { box-shadow: 0 0 16px rgba(245,196,75,0.22); }
}

/* ---- animations d'icônes au survol ---- */
/* garder : la flèche monte vers le sac (vers l'inventaire) */
.ico-bag .ic-up { transform-box: fill-box; transform-origin: center; transition: transform 0.3s cubic-bezier(0.3, 1.3, 0.4, 1); }
.rp-ico.ract-keep:hover .ico-bag .ic-up { transform: translateY(-3px); }
/* maison : flèche TOTALEMENT cachée au repos (display none), elle plonge
   dans la maison seulement au survol — plus rien ne traîne sur le toit */
.ico-home .ic-arrow { opacity: 0; transform: translateY(-7px); transition: opacity 0.22s, transform 0.4s cubic-bezier(0.3, 0.9, 0.3, 1); }
.rp-ico.ract-ship:not(:hover) .ico-home .ic-arrow { visibility: hidden; }
.rp-ico.ract-ship:hover .ico-home .ic-arrow { opacity: 1; transform: translateY(1px); visibility: visible; }
/* rejouer : la flèche circulaire fait un tour au survol */
.ico-replay { transition: transform 0.6s cubic-bezier(0.3, 0.8, 0.3, 1); transform-box: fill-box; transform-origin: center; }
.rp-replay:hover .ico-replay { transform: rotate(-360deg); }
/* tout vendre : les pièces rebondissent */
.rp-sell:hover .ico-coins { animation: coinsBounce 0.5s ease; }
@keyframes coinsBounce { 30% { transform: translateY(-3px); } 60% { transform: translateY(0); } }

@media (max-width: 480px) {
  .recap-pill { flex-wrap: wrap; justify-content: center; border-radius: 18px; padding: 12px 14px; }
}

/* infobulle au survol des actions du récap */
.recap-pill [data-tip] { position: relative; }
.recap-pill [data-tip]::after {
  content: attr(data-tip);
  position: absolute; bottom: calc(100% + 10px); left: 50%; transform: translateX(-50%) translateY(4px);
  white-space: nowrap;
  background: #05060A; color: var(--text);
  border: 1px solid var(--line); border-radius: 8px;
  padding: 7px 11px; font-family: var(--font-body); font-weight: 600; font-size: 11.5px;
  opacity: 0; pointer-events: none;
  transition: opacity 0.16s, transform 0.16s;
  box-shadow: 0 10px 26px rgba(0,0,0,0.5); z-index: 30;
}
.recap-pill [data-tip]::before {
  content: ""; position: absolute; bottom: calc(100% + 4px); left: 50%; transform: translateX(-50%);
  border: 5px solid transparent; border-top-color: var(--line);
  opacity: 0; pointer-events: none; transition: opacity 0.16s; z-index: 30;
}
.recap-pill [data-tip]:hover::after { opacity: 1; transform: translateX(-50%) translateY(0); }
.recap-pill [data-tip]:hover::before { opacity: 1; }

/* carte révélée : cliquable pour zoomer */
.reveal-card.zoomable { cursor: zoom-in; }

/* ===================== JEUX ===================== */
.game-layout {
  display: grid; grid-template-columns: 300px 1fr; gap: 22px;
  align-items: start;
}

.game-panel {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 22px;
  display: flex; flex-direction: column; gap: 18px;
  position: sticky; top: 86px;
}

.game-board {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 28px;
  min-height: 480px;
}
.game-board-center { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 26px; }

.bet-control { display: flex; flex-direction: column; gap: 8px; }
.bet-label {
  font-family: var(--font-mono); font-size: 10px; font-weight: 700;
  letter-spacing: 0.22em; color: var(--dim);
}
.bet-row { display: flex; gap: 6px; }
.bet-input {
  flex: 1; min-width: 0;
  background: rgba(0,0,0,0.35);
  border: 1px solid var(--line);
  border-radius: 5px;
  color: var(--gold);
  font-family: var(--font-mono); font-weight: 700; font-size: 14px;
  padding: 10px 12px;
  outline: none;
  transition: border-color 0.2s;
}
.bet-input:focus { border-color: rgba(245,196,75,0.5); }
.bet-input:disabled { opacity: 0.5; }
/* mise en CR (Mines, Wheel) */
.cr-bet { display: flex; align-items: center; gap: 8px; }
.cr-bet .bet-input { flex: 1; }
.cr-bet-unit { font-family: var(--font-mono); font-weight: 700; color: var(--gold); font-size: 13px; }
.cr-bet-quick { display: flex; gap: 6px; margin-top: 8px; }
.cr-bet-quick button {
  flex: 1; padding: 8px 0; border-radius: 7px;
  background: color-mix(in srgb, var(--text) 5%, transparent);
  border: 1px solid var(--line);
  font-family: var(--font-mono); font-weight: 700; font-size: 11px;
  color: var(--dim); cursor: pointer; transition: color 0.15s, border-color 0.15s;
}
.cr-bet-quick button:hover { color: var(--gold); border-color: color-mix(in srgb, var(--gold) 45%, transparent); }

/* ===================== TABLE D'ÉCHANGES ===================== */
.trade-gate {
  max-width: 680px; margin: 20px auto; text-align: center;
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg);
  padding: 44px 32px;
}
.tg-kicker { font-family: var(--font-mono); font-size: 11px; font-weight: 700; letter-spacing: 0.24em; color: var(--gold); }
.trade-gate h1 { font-family: var(--font-display); font-weight: 900; font-size: clamp(30px, 5vw, 46px); margin: 12px 0 14px; }
.tg-lead { color: var(--dim); font-size: 15px; line-height: 1.6; max-width: 520px; margin: 0 auto 26px; }
.tg-perks { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 28px; }
.tg-perk { background: var(--surface-2); border: 1px solid var(--line); border-radius: 10px; padding: 16px 10px; }
.tg-perk b { display: block; font-family: var(--font-display); font-weight: 900; font-size: 20px; color: var(--gold); }
.tg-perk span { font-size: 11px; color: var(--dim); line-height: 1.35; }
.tg-note { margin-top: 16px; font-size: 12px; color: var(--dim); }

.trade-tabs { margin-bottom: 22px; }
.trade-sub { color: var(--dim); font-size: 13.5px; margin-bottom: 18px; max-width: 720px; line-height: 1.55; }
.trade-sell-head { display: flex; align-items: center; gap: 18px; justify-content: space-between; flex-wrap: wrap; margin-bottom: 20px; }
.trade-sell-head .trade-sub { margin-bottom: 0; flex: 1; min-width: 240px; }
.trade-h3 { font-family: var(--font-display); font-weight: 800; font-size: 16px; margin: 26px 0 14px; }
.trade-empty { color: var(--dim); font-size: 13.5px; padding: 24px; text-align: center; background: var(--surface); border: 1px dashed var(--line); border-radius: 10px; }

.trade-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(168px, 1fr)); gap: 18px; }
.trade-card { background: var(--surface); border: 1px solid var(--line); border-radius: 12px; padding: 12px; display: flex; flex-direction: column; gap: 12px; transition: transform 0.2s, border-color 0.2s; }
.trade-card:hover { transform: translateY(-3px); border-color: color-mix(in srgb, var(--gold) 35%, transparent); }
.trade-card.tc-sold { opacity: 0.72; }
.tc-face { pointer-events: none; position: relative; }
.tc-face .cardface { box-shadow: 0 10px 26px rgba(0,0,0,0.45); }
.ts-count {
  position: absolute; top: 8px; right: 8px; z-index: 4;
  font-family: var(--font-mono); font-weight: 800; font-size: 11px;
  background: var(--gold); color: #15130B; border-radius: 999px; padding: 2px 8px;
  box-shadow: 0 2px 7px rgba(255,214,10,0.45);
}
.ts-locked { font-family: var(--font-mono); font-size: 11px; color: var(--dim); flex-shrink: 0; }

/* offres du marché : badge type + carte en attente */
.tc-kind { position: absolute; top: 7px; left: 7px; z-index: 4; font-family: var(--font-mono); font-size: 8px; font-weight: 700; letter-spacing: 0.05em; padding: 3px 7px; border-radius: 6px; }
.tc-site { background: rgba(91,140,255,0.9); color: #fff; }
.tc-perso { background: rgba(255,122,60,0.92); color: #fff; }
.tc-or { color: var(--dim); font-weight: 400; }
.tc-pending { opacity: 0.72; }
.tc-pendlabel { font-family: var(--font-mono); font-size: 11px; color: var(--gold); flex-shrink: 0; }

/* modale faire une offre */
.offer-body { display: flex; gap: 20px; align-items: flex-start; }
.offer-card { width: 140px; flex-shrink: 0; pointer-events: none; }
.offer-form { flex: 1; display: flex; flex-direction: column; gap: 7px; }
.offer-name { font-family: var(--font-display); font-weight: 800; font-size: 18px; }
.offer-seller { font-size: 12px; color: var(--dim); }
.offer-ask { font-size: 12.5px; color: var(--gold); font-family: var(--font-mono); margin-bottom: 6px; }
.offer-cur { display: flex; gap: 6px; margin-bottom: 4px; }
.oc-opt { flex: 1; padding: 8px 0; border-radius: 8px; background: color-mix(in srgb, var(--text) 5%, transparent); border: 1px solid var(--line); color: var(--dim); font-family: var(--font-mono); font-weight: 700; font-size: 11px; cursor: pointer; transition: all 0.15s; }
.oc-opt.sel { background: var(--gold); color: #15130B; border-color: transparent; }
.offer-actions { display: flex; gap: 10px; margin-top: 12px; }
.offer-actions .btn { flex: 1; }
@media (max-width: 520px) { .offer-body { flex-direction: column; align-items: center; } }

/* catégories de l'onglet Acheter (cartes du site / collection perso) */
.buy-cats { display: flex; gap: 8px; margin-bottom: 16px; flex-wrap: wrap; }
.buy-cat { padding: 9px 16px; border-radius: 999px; background: color-mix(in srgb, var(--text) 5%, transparent); border: 1px solid var(--line); color: var(--dim); font-family: var(--font-display); font-weight: 700; font-size: 13px; cursor: pointer; transition: color 0.15s, background 0.15s, border-color 0.15s; }
.buy-cat.sel { background: var(--gold); color: #15130B; border-color: transparent; }
.buy-cat:not(.sel):hover { color: var(--text); }
.tc-swapbadge { background: rgba(107,255,143,0.92); color: #06210F; }

/* modale échange : leur carte ⇄ la tienne (centré, clair) */
.swap-head { display: flex; align-items: center; justify-content: center; gap: 22px; margin-bottom: 16px; flex-wrap: wrap; }
.swap-col { display: flex; flex-direction: column; align-items: center; gap: 9px; width: 108px; }
.swap-mini { width: 100px; pointer-events: none; }
.swap-cap { font-size: 11.5px; color: var(--dim); text-align: center; line-height: 1.45; }
.swap-cap b { color: var(--text); }
.swap-qmark { width: 100px; aspect-ratio: 5 / 7; border-radius: 7px; border: 2px dashed var(--line); display: grid; place-items: center; font-family: var(--font-display); font-weight: 900; font-size: 38px; color: var(--dim); background: color-mix(in srgb, var(--text) 3%, transparent); }
.swap-arrow { font-size: 28px; color: var(--gold); font-weight: 700; }

/* ===================== PACKS INFLUENCEURS ===================== */
.infl-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(238px, 1fr)); gap: 20px; }
.infl-card {
  position: relative; overflow: hidden;
  background: var(--surface); border: 1px solid var(--line); border-radius: 16px; padding: 16px;
  display: flex; flex-direction: column; gap: 14px;
  transition: transform 0.2s, border-color 0.2s;
}
.infl-card::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--accent); }
.infl-card:hover { transform: translateY(-4px); border-color: color-mix(in srgb, var(--accent) 50%, transparent); }
.infl-head { display: flex; align-items: center; gap: 10px; }
.infl-av { width: 38px; height: 38px; border-radius: 50%; flex-shrink: 0; display: grid; place-items: center; color: #fff; font-family: var(--font-display); font-weight: 800; font-size: 13px; box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent) 45%, transparent); }
.infl-id { min-width: 0; }
.infl-id b { display: flex; align-items: center; gap: 5px; font-size: 14px; }
.infl-check { flex-shrink: 0; }
.infl-id span { font-size: 10px; color: var(--dim); font-family: var(--font-mono); letter-spacing: 0.03em; }
.infl-visual { position: relative; }
.infl-tag { position: absolute; bottom: 8px; left: 50%; transform: translateX(-50%); font-family: var(--font-display); font-weight: 800; font-size: 12px; background: rgba(0,0,0,0.62); color: #fff; padding: 3px 11px; border-radius: 999px; white-space: nowrap; backdrop-filter: blur(4px); }
.infl-pool { display: flex; gap: 5px; align-items: center; }
.infl-stats { display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: 11px; color: var(--dim); }

/* ===================== CARTE CARDS (recharge brandée, premium) =====================
   Tailles en cqw (% de la largeur de LA CARTE, pas de l'écran) : rendu identique
   en vignette admin 60px comme en grande carte — fini les textes qui débordent.
   Paliers visuels via --cfc-a : Starter (argent) / Avancée (bleu) / Premium
   (violet) / Élite (or) / Custom (émeraude). */
.cardface.cf-cards {
  overflow: hidden; isolation: isolate;
  container-type: inline-size;
  --cfc-a: var(--gold);
  background:
    radial-gradient(130% 75% at 50% -18%, color-mix(in srgb, var(--cfc-a) 26%, transparent), transparent 55%),
    radial-gradient(150% 90% at 50% 135%, color-mix(in srgb, var(--cfc-a) 12%, transparent), transparent 58%),
    linear-gradient(168deg, color-mix(in srgb, var(--cfc-a) 8%, #161310) 0%, #0a0907 58%, color-mix(in srgb, var(--cfc-a) 5%, #0d0c0a) 100%);
  border: 1px solid color-mix(in srgb, var(--cfc-a) 45%, transparent);
  box-shadow: 0 16px 40px rgba(0,0,0,0.55), 0 0 26px color-mix(in srgb, var(--cfc-a) 22%, transparent);
}
.cf-cards.cfc-t0 { --cfc-a: #AEB8C4; }
.cf-cards.cfc-t1 { --cfc-a: #3FA9FF; }
.cf-cards.cfc-t2 { --cfc-a: #C24BFF; }
.cf-cards.cfc-t3 { --cfc-a: #F5C44B; }
.cf-cards.cfc-custom { --cfc-a: #3DD68C; }
/* le monogramme C en FILIGRANE, qui déborde bas-droite — la signature de la maison */
.cf-cards::before {
  content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background: linear-gradient(150deg, color-mix(in srgb, var(--cfc-a) 70%, #fff) 0%, var(--cfc-a) 70%);
  opacity: 0.1;
  -webkit-mask: url("../assets/logo-glyph.svg") no-repeat calc(100% + 32cqw) calc(100% + 30cqw) / 105cqw auto;
  mask: url("../assets/logo-glyph.svg") no-repeat calc(100% + 32cqw) calc(100% + 30cqw) / 105cqw auto;
}
/* éclairage : matière du palier + grande lumière diagonale + vignettage */
.cf-cards::after {
  content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background:
    var(--cfc-tex, linear-gradient(transparent, transparent)),
    linear-gradient(118deg, transparent 28%, rgba(255,255,255,0.045) 44%, rgba(255,255,255,0.085) 50%, rgba(255,255,255,0.03) 57%, transparent 72%),
    radial-gradient(140% 105% at 50% 42%, transparent 55%, rgba(0,0,0,0.42) 100%);
}
/* matière par palier — large, profonde, jamais criarde */
.cfc-t0 { --cfc-tex: linear-gradient(100deg, transparent 18%, rgba(220,228,236,0.05) 38%, rgba(220,228,236,0.1) 50%, rgba(220,228,236,0.04) 62%, transparent 82%); }
.cfc-t1 { --cfc-tex: radial-gradient(120% 75% at 50% 128%, rgba(63,169,255,0.18), rgba(63,169,255,0.05) 45%, transparent 68%); }
.cfc-t2 {
  --cfc-tex:
    radial-gradient(1cqw 1cqw at 24% 22%, rgba(255,255,255,0.5), transparent 60%),
    radial-gradient(0.7cqw 0.7cqw at 73% 13%, rgba(255,255,255,0.4), transparent 60%),
    radial-gradient(0.8cqw 0.8cqw at 86% 58%, rgba(255,255,255,0.3), transparent 60%),
    radial-gradient(0.6cqw 0.6cqw at 38% 70%, rgba(255,255,255,0.28), transparent 60%),
    radial-gradient(70% 48% at 74% 22%, rgba(194,75,255,0.18), transparent 70%);
}
.cfc-t3 {
  --cfc-tex:
    repeating-conic-gradient(from -8deg at 50% 30%, rgba(245,196,75,0.07) 0deg 9deg, transparent 9deg 24deg),
    radial-gradient(90% 60% at 50% 30%, rgba(245,196,75,0.1), transparent 68%);
}
.cfc-custom {
  --cfc-tex:
    conic-gradient(from 45deg at 72% 30%, rgba(61,214,140,0.1) 0 22%, transparent 22% 100%),
    radial-gradient(110% 80% at 18% 110%, rgba(61,214,140,0.12), transparent 60%);
}
/* une cover (IA/import) remplace filigrane + matière */
.cf-cards.has-skin::before, .cf-cards.has-skin::after { display: none; }
.cfc-inner {
  position: absolute; inset: 3.4cqw; z-index: 2;
  border: 1.5px solid color-mix(in srgb, var(--cfc-a) 55%, transparent);
  border-radius: 3cqw; padding: 4.5cqw 5cqw 4cqw;
  display: grid; grid-template-rows: auto 1fr auto auto; gap: 2cqw;
}
.cfc-head { display: flex; align-items: center; justify-content: space-between; }
/* le logo officiel, intégré en signature de la carte */
.cfc-mark { width: 11cqw; height: 11cqw; border-radius: 2.8cqw; flex-shrink: 0; }
.cfc-tag {
  font-family: var(--font-mono); font-size: 3.4cqw; font-weight: 700; letter-spacing: 0.18em;
  color: color-mix(in srgb, var(--cfc-a) 85%, #fff);
  border: 1px solid color-mix(in srgb, var(--cfc-a) 45%, transparent);
  padding: 1cqw 2.6cqw; border-radius: 2cqw;
}
.cfc-logo { display: grid; place-items: center; min-height: 0; }
/* le wordmark OFFICIEL (BRANDING.md) : Sora 800 + carré or mat #E8B23A */
.cfc-word {
  font-family: "Sora", var(--font-display), sans-serif;
  font-weight: 800; letter-spacing: -0.04em;
  font-size: 15cqw; color: #fff;
  text-shadow: 0 2px 14px rgba(0,0,0,0.45);
}
.cfc-word::after {
  content: ""; display: inline-block;
  width: 0.34em; height: 0.34em; border-radius: 0.1em;
  background: #E8B23A; margin-left: 0.07em; vertical-align: baseline;
}
/* cover personnalisée (habillage admin : saisons, événements…) sous le logo et le montant */
.cf-cards .cfc-bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; }
.cf-cards .cfc-shade {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background: linear-gradient(180deg, rgba(8,7,4,0.32), rgba(8,7,4,0.06) 38%, rgba(8,7,4,0.6) 84%);
}
.cf-cards.has-skin .cfc-inner { border-color: color-mix(in srgb, var(--cfc-a) 70%, transparent); }
.cf-cards.has-skin .cfc-word { text-shadow: 0 2px 18px rgba(0,0,0,0.8); }
.cf-cards.has-skin .cfc-amount,
.cf-cards.has-skin .cfc-tag,
.cf-cards.has-skin .cfc-foot { text-shadow: 0 1px 10px rgba(0,0,0,0.85); }

/* ===================== CARTE PERSO (physique déclarée) ===================== */
.cfp-badge {
  position: absolute; top: 7px; left: 7px; z-index: 6;
  font-family: var(--font-mono); font-size: 8px; font-weight: 700; letter-spacing: 0.1em;
  background: rgba(255,122,60,0.95); color: #fff; padding: 3px 7px; border-radius: 6px;
}
.cf-perso-blank { background: linear-gradient(160deg, #1a1d27, #0e1015); }
.cf-perso-blank .cf-frame { position: absolute; inset: 6px; border: 1.5px solid color-mix(in srgb, var(--rarity-color) 55%, transparent); border-radius: 5px; pointer-events: none; }
.cf-perso-blank .cfp-center { position: absolute; inset: 30px 12px 34px; display: grid; place-items: center; z-index: 2; }
.cf-perso-blank .cfp-name { font-family: var(--font-display); font-weight: 800; font-size: 15px; text-align: center; line-height: 1.25; }
.cf-perso-blank .cf-foot { position: absolute; left: 0; right: 0; bottom: 12px; text-align: center; z-index: 2; }
.cf-perso-blank .cf-value { font-family: var(--font-mono); font-weight: 700; color: var(--gold); font-size: 13px; }
.cc-persotag { font-family: var(--font-mono); font-size: 9px; font-weight: 700; color: #FF7A3C !important; display: grid; place-items: center; letter-spacing: 0.08em; }

/* beau bouton « Ajouter mes cartes » */
.add-perso-btn {
  display: inline-flex; align-items: center; gap: 9px; cursor: pointer;
  padding: 10px 16px 10px 11px; border-radius: 11px;
  background: color-mix(in srgb, var(--gold) 12%, transparent);
  border: 1.5px dashed color-mix(in srgb, var(--gold) 55%, transparent);
  color: var(--gold); font-family: var(--font-display); font-weight: 800; font-size: 13.5px;
  transition: background 0.2s, border-color 0.2s, transform 0.15s, box-shadow 0.2s;
}
.add-perso-btn .apb-ico {
  display: grid; place-items: center; width: 28px; height: 28px; border-radius: 8px;
  background: var(--gold); color: #15130B; flex-shrink: 0; transition: transform 0.2s;
}
.add-perso-btn:hover {
  background: color-mix(in srgb, var(--gold) 20%, transparent);
  border-color: var(--gold); border-style: solid;
  transform: translateY(-2px); box-shadow: 0 8px 20px color-mix(in srgb, var(--gold) 28%, transparent);
}
.add-perso-btn:hover .apb-ico { transform: rotate(-8deg) scale(1.06); }
.add-perso-btn:active { transform: translateY(0); }

/* formulaire d'ajout d'une carte perso */
.perso-form { display: flex; gap: 22px; align-items: flex-start; }
.perso-preview { width: 150px; flex-shrink: 0; pointer-events: none; }
.perso-fields { flex: 1; display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.perso-fields .bet-label { margin-top: 6px; }
.perso-rar { display: flex; gap: 8px; }
.pr-opt { width: 26px; height: 26px; border-radius: 50%; border: 2px solid color-mix(in srgb, var(--c) 55%, transparent); background: color-mix(in srgb, var(--c) 22%, transparent); cursor: pointer; transition: transform 0.15s; }
.pr-opt:hover { transform: scale(1.12); }
.pr-opt.sel { background: var(--c); box-shadow: 0 0 0 2px var(--surface), 0 0 0 4px var(--c); }
.perso-file { padding: 9px 12px; font-size: 12px; color: var(--dim); cursor: pointer; }
#pfAdd { margin-top: 12px; }
@media (max-width: 520px) { .perso-form { flex-direction: column; align-items: center; } }
.cfc-amount { text-align: center; font-family: var(--font-display); font-weight: 900; font-size: 14cqw; line-height: 1; color: #fff; }
.cfc-amount span { font-size: 0.4em; font-family: var(--font-mono); color: var(--cfc-a, var(--gold)); letter-spacing: 0.1em; margin-left: 0.15em; }
.cfc-foot { text-align: center; font-family: var(--font-mono); font-size: 3.1cqw; font-weight: 700; letter-spacing: 0.16em; color: rgba(255,255,255,0.42); white-space: nowrap; overflow: hidden; }
.cfc-foil {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background: linear-gradient(115deg, transparent 34%, rgba(255,214,10,0.28) 47%, rgba(120,200,255,0.2) 53%, transparent 66%);
  background-size: 250% 250%; animation: cfcSweep 4.6s linear infinite; mix-blend-mode: screen;
}
@keyframes cfcSweep { from { background-position: 170% 0; } to { background-position: -70% 0; } }

/* ===================== PAGE RECHARGE ===================== */
.recharge-intro { color: var(--dim); font-size: 15px; line-height: 1.6; max-width: 640px; margin-bottom: 30px; }
.recharge-intro b { color: var(--text); }
.recharge-page-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(205px, 1fr)); gap: 22px; align-items: stretch; }
/* boutons calés en bas → toutes les tuiles alignées, sans gap au milieu */
.rcp-item .btn { margin-top: auto; }
/* tuile CUSTOM : le montant se règle SUR la carte */
.rcp-custom { border-color: rgba(61,214,140,0.35); }
.rcp-custom:hover { border-color: rgba(61,214,140,0.65); }
.rcp-badge-cust { background: #3DD68C; }
.rcp-cust-stage { position: relative; width: 100%; max-width: 200px; }
.rcp-cust-stage .cfc-amount { cursor: text; }
/* +/− posés sur la carte, alignés avec le montant */
.rcp-step {
  appearance: none; cursor: pointer; position: absolute; z-index: 5;
  top: 76%; transform: translateY(-50%);
  width: 30px; height: 30px; border-radius: 50%;
  background: #10231B; border: 1px solid rgba(61,214,140,0.55); color: #3DD68C;
  font-size: 17px; font-weight: 800; line-height: 1;
  box-shadow: 0 4px 12px rgba(0,0,0,0.5);
  transition: background 0.15s, border-color 0.15s, transform 0.15s;
}
.rcp-sminus { left: -13px; }
.rcp-splus { right: -13px; }
.rcp-step:hover { background: #173527; border-color: #3DD68C; transform: translateY(-50%) scale(1.1); }
.rcp-step:active { transform: translateY(calc(-50% + 1px)); }
/* saisie libre par-dessus le chiffre de la carte */
.rcp-cust-edit {
  position: absolute; z-index: 6;
  left: 18%; right: 18%; top: 69%; height: 14%;
  background: rgba(5, 14, 10, 0.92); border: 1px solid rgba(61,214,140,0.6); border-radius: 8px;
  outline: none; text-align: center; color: #fff;
  font-family: var(--font-display); font-size: 19px; font-weight: 800;
  appearance: textfield; -moz-appearance: textfield;
}
.rcp-cust-edit::-webkit-outer-spin-button, .rcp-cust-edit::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.rcp-item {
  position: relative; display: flex; flex-direction: column; align-items: center; gap: 16px;
  background: var(--surface); border: 1px solid var(--line); border-radius: 16px; padding: 22px 18px;
  transition: transform 0.2s, border-color 0.2s;
}
.rcp-item:hover { transform: translateY(-5px); border-color: color-mix(in srgb, var(--gold) 45%, transparent); }
.rcp-item.rcp-hot { border-color: color-mix(in srgb, var(--gold) 55%, transparent); box-shadow: 0 0 30px color-mix(in srgb, var(--gold) 14%, transparent); }
.rcp-badge {
  position: absolute; top: -11px; left: 50%; transform: translateX(-50%);
  font-family: var(--font-mono); font-size: 10px; font-weight: 700; letter-spacing: 0.06em;
  background: var(--gold); color: #15130B; padding: 3px 12px; border-radius: 999px; white-space: nowrap;
}
.rcp-card { width: 100%; max-width: 200px; }
.rcp-card .cardface { transition: transform 0.3s; }
.rcp-item:hover .rcp-card .cardface { transform: translateY(-4px) rotate(-1.5deg); }
.rcp-buy { width: 100%; }
.recharge-foot { margin-top: 26px; font-size: 12.5px; color: var(--dim); }

/* étape de confirmation (modale, après le choix d'une carte) — célébration :
   obtenir sa carte doit ressembler à une victoire, pas à un reçu. */
.modal.modal-recharge {
  width: min(700px, calc(100vw - 40px));
  position: relative; overflow: hidden;
  border-color: color-mix(in srgb, var(--gold) 35%, var(--line));
  box-shadow: 0 40px 90px rgba(0,0,0,0.65), 0 0 90px color-mix(in srgb, var(--gold) 16%, transparent);
}
.modal-recharge::before { /* halo doré qui baigne le côté carte */
  content: ""; position: absolute; left: -18%; top: -30%; width: 75%; height: 150%;
  background: radial-gradient(ellipse at 38% 50%, color-mix(in srgb, var(--gold) 13%, transparent), transparent 65%);
  pointer-events: none;
}
.modal-recharge .modal-head { position: relative; }
.modal-recharge .modal-head h3 {
  font-family: var(--font-mono); font-size: 11px; font-weight: 700;
  letter-spacing: 0.22em; text-transform: uppercase; color: var(--gold);
}
.modal-recharge .modal-head h3::before { content: "✦ "; }

.recharge-confirm { display: flex; gap: 30px; align-items: center; position: relative; padding: 10px 0 2px; }

/* scène : rayons tournants + halo respirant + étincelles autour de la carte */
.rc-stage { position: relative; width: 200px; flex-shrink: 0; display: grid; place-items: center; }
.rc-rays {
  position: absolute; width: 330px; height: 330px; border-radius: 50%;
  background: repeating-conic-gradient(from 0deg, color-mix(in srgb, var(--gold) 20%, transparent) 0deg 9deg, transparent 9deg 30deg);
  -webkit-mask: radial-gradient(circle, #000 0%, transparent 68%);
  mask: radial-gradient(circle, #000 0%, transparent 68%);
  animation: rcRays 18s linear infinite; pointer-events: none;
}
.rc-glow {
  position: absolute; width: 240px; height: 240px; border-radius: 50%;
  background: radial-gradient(circle, color-mix(in srgb, var(--gold) 28%, transparent), transparent 70%);
  animation: rcBreath 2.6s ease-in-out infinite; pointer-events: none;
}
@keyframes rcRays { to { transform: rotate(360deg); } }
@keyframes rcBreath { 0%, 100% { opacity: 0.6; transform: scale(0.95); } 50% { opacity: 1; transform: scale(1.06); } }

.rc-bigcard {
  width: 172px; position: relative; z-index: 1;
  animation: rcPop 0.7s cubic-bezier(0.18, 1.4, 0.35, 1) both, rcFloat 4.5s ease-in-out 0.7s infinite;
  filter: drop-shadow(0 18px 34px rgba(0,0,0,0.5)) drop-shadow(0 0 26px color-mix(in srgb, var(--gold) 32%, transparent));
}
@keyframes rcPop { from { opacity: 0; transform: translateY(46px) rotate(-10deg) scale(0.55); } }
@keyframes rcFloat { 0%, 100% { transform: translateY(0) rotate(-1.5deg); } 50% { transform: translateY(-9px) rotate(1.5deg); } }

.rc-spark {
  position: absolute; width: 5px; height: 5px; border-radius: 50%; z-index: 2;
  background: var(--gold); box-shadow: 0 0 9px 1px var(--gold);
  animation: rcTwinkle 2.2s ease-in-out infinite; pointer-events: none;
}
.rc-spark.s1 { top: 9%; left: 15%; }
.rc-spark.s2 { top: 4%; right: 22%; animation-delay: 0.4s; width: 3px; height: 3px; }
.rc-spark.s3 { top: 40%; left: 2%; animation-delay: 0.9s; width: 4px; height: 4px; }
.rc-spark.s4 { bottom: 13%; left: 11%; animation-delay: 1.3s; }
.rc-spark.s5 { bottom: 6%; right: 15%; animation-delay: 0.6s; width: 4px; height: 4px; }
.rc-spark.s6 { top: 54%; right: 2%; animation-delay: 1.7s; }
.rc-spark.s7 { top: 18%; right: 5%; animation-delay: 1.1s; width: 3px; height: 3px; }
@keyframes rcTwinkle { 0%, 100% { opacity: 0; transform: scale(0.4); } 50% { opacity: 1; transform: scale(1.3); } }

.rc-confirm-txt { flex: 1; min-width: 0; position: relative; }
.rc-kicker {
  display: inline-flex; white-space: nowrap; margin-bottom: 10px; padding: 4px 11px; border-radius: 999px;
  font-family: var(--font-mono); font-size: 9.5px; font-weight: 700; letter-spacing: 0.15em; color: var(--gold);
  border: 1px solid color-mix(in srgb, var(--gold) 45%, transparent);
  background: color-mix(in srgb, var(--gold) 10%, transparent);
}
.rc-title { display: block; font-family: var(--font-display); font-weight: 900; font-size: 26px; line-height: 1.08; margin-bottom: 4px; }
.rc-value {
  display: flex; align-items: baseline; gap: 7px; margin-bottom: 10px;
  font-family: var(--font-display); font-weight: 900; font-size: 48px; line-height: 1;
  background: linear-gradient(180deg, #FFF3B8, var(--gold) 55%, #D99E00);
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
  filter: drop-shadow(0 2px 16px color-mix(in srgb, var(--gold) 38%, transparent));
}
.rc-value i { font-style: normal; font-family: var(--font-mono); font-size: 15px; letter-spacing: 0.14em; }
.rc-confirm-txt p { color: var(--dim); font-size: 13px; line-height: 1.55; margin-bottom: 16px; }

.rc-confirm-actions { display: flex; flex-direction: column; gap: 9px; }
.rc-confirm-actions .btn { width: 100%; }
.rc-cash { position: relative; overflow: hidden; padding: 15px 18px; font-size: 15px; animation: rcPulse 2s ease-in-out infinite; }
.rc-cash::after { /* reflet qui balaie le bouton : impossible de le rater */
  content: ""; position: absolute; top: 0; bottom: 0; width: 46%; left: -60%;
  background: linear-gradient(105deg, transparent, rgba(255,255,255,0.55), transparent);
  transform: skewX(-18deg); animation: rcSheen 2.4s ease-in-out infinite;
}
@keyframes rcPulse { 0%, 100% { box-shadow: 0 0 0 0 color-mix(in srgb, var(--gold) 55%, transparent); } 50% { box-shadow: 0 0 0 10px transparent; } }
@keyframes rcSheen { 0%, 55% { left: -60%; } 90%, 100% { left: 120%; } }
.rc-note {
  display: block; margin-top: 12px; text-align: center;
  font-family: var(--font-mono); font-size: 9.5px; font-weight: 700; letter-spacing: 0.1em; color: var(--dim);
}

/* wallet : bouton recharge ISO avec « Ouvrir un pack » (bevel standard) + icône */
.wallet-recharge { margin: 8px 0 14px; display: inline-flex; align-items: center; justify-content: center; gap: 9px; }
.wallet-recharge svg { width: 17px; height: 17px; }
@media (max-width: 760px) { .recharge-page-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) {
  .recharge-confirm { flex-direction: column; text-align: center; gap: 18px; }
  .rc-stage { width: 160px; }
  .rc-bigcard { width: 140px; }
  .rc-value { justify-content: center; font-size: 40px; }
}
.tc-foot { display: flex; align-items: center; gap: 8px; }
.tc-meta { flex: 1; min-width: 0; }
.tc-meta b { display: block; font-size: 13px; font-weight: 700; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.tc-meta span { font-size: 11px; color: var(--dim); }
.tc-buy { flex-shrink: 0; }
/* infos tuile marché : nom (jusqu'à 2 lignes, plus de troncature « C... ») + vendeur + prix, bouton pleine largeur dessous */
.tc-info { display: flex; flex-direction: column; gap: 2px; }
.tc-name {
  font-family: var(--font-display); font-weight: 800; font-size: 14px; line-height: 1.22;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.tc-sub { font-size: 11.5px; color: var(--dim); }
.tc-price { font-family: var(--font-mono); font-weight: 700; font-size: 12.5px; color: var(--gold); }
.tc-pendlabel { font-family: var(--font-mono); font-size: 11px; color: var(--gold); text-align: center; padding: 6px 0; }
.tl-net { font-family: var(--font-mono); font-weight: 700; font-size: 13px; color: #3BD17A; flex-shrink: 0; }

/* mise en vente : étape prix */
.sell-price { display: flex; gap: 20px; align-items: flex-start; }
.sell-price .sp-card { width: 150px; flex-shrink: 0; pointer-events: none; }
.sp-form { flex: 1; display: flex; flex-direction: column; gap: 8px; }
.sp-name { font-family: var(--font-display); font-weight: 800; font-size: 18px; }
.sp-cote { font-size: 12px; color: var(--dim); margin-bottom: 6px; }
.sp-net { font-size: 12.5px; color: #3BD17A; min-height: 18px; }
.sp-actions { display: flex; gap: 10px; margin-top: 10px; }
.sp-actions .btn { flex: 1; }
@media (max-width: 560px) {
  .tg-perks { grid-template-columns: repeat(2, 1fr); }
  .sell-price { flex-direction: column; align-items: center; }
}
.bet-mod {
  padding: 0 12px; border-radius: 5px;
  background: rgba(255,255,255,0.05);
  border: 1px solid var(--line);
  font-family: var(--font-mono); font-size: 11px; font-weight: 700;
  color: var(--dim);
  transition: color 0.2s, background 0.2s;
}
.bet-mod:hover { color: var(--text); background: rgba(255,255,255,0.1); }

.game-mult-box {
  background: rgba(0,0,0,0.25);
  border: 1px solid var(--line);
  border-radius: 7px;
  padding: 14px 16px;
  display: flex; flex-direction: column; gap: 8px;
}
.gm-row { display: flex; justify-content: space-between; font-size: 12.5px; color: var(--dim); }
.gm-row b { font-family: var(--font-mono); color: var(--text); font-size: 12px; }

/* --- Mines --- */
.mines-select { display: flex; gap: 6px; }
.mines-opt {
  flex: 1; padding: 9px 0; border-radius: 5px;
  background: rgba(255,255,255,0.05);
  border: 1px solid var(--line);
  font-family: var(--font-mono); font-weight: 700; font-size: 12px;
  color: var(--dim);
  transition: all 0.2s;
}
.mines-opt:hover { color: var(--text); }
.mines-opt.sel { background: rgba(63,169,255,0.15); border-color: rgba(63,169,255,0.5); color: var(--blue); }

.mines-grid {
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 10px;
  max-width: 480px; margin: 0 auto;
}
.mine-tile {
  aspect-ratio: 1;
  border-radius: 7px;
  background: linear-gradient(160deg, #222738, #181C29);
  border: 1px solid rgba(255,255,255,0.09);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.06), 0 4px 10px rgba(0,0,0,0.3);
  display: grid; place-items: center;
  transition: transform 0.15s, border-color 0.2s, background 0.2s;
}
.mine-tile:not(:disabled):not(.open):hover { transform: translateY(-3px); border-color: rgba(63,169,255,0.5); }
.mine-tile:disabled { cursor: default; }
.mine-tile.is-gem {
  background: linear-gradient(160deg, rgba(63,169,255,0.22), rgba(63,169,255,0.08));
  border-color: rgba(63,169,255,0.55);
  animation: gemPop 0.4s cubic-bezier(0.2, 0.9, 0.3, 1.4);
}
@keyframes gemPop { from { transform: scale(0.6); } 60% { transform: scale(1.1); } }
.mine-tile.is-mine {
  background: linear-gradient(160deg, rgba(255,77,109,0.25), rgba(255,77,109,0.08));
  border-color: rgba(255,77,109,0.55);
}
.mine-tile.is-mine.hit { animation: mineHit 0.5s; }
@keyframes mineHit { 20% { transform: scale(1.25); background: #FF4D6D; } }
.mine-tile.is-mine.shown { opacity: 0.65; }

/* --- Coinflip --- */
.coin-scene { position: relative; padding: 30px 0 50px; }
.coin {
  position: relative;
  width: clamp(150px, 22vw, 210px); aspect-ratio: 1;
  transform-style: preserve-3d;
}
.coin-scene:has(.coin.in-air) { animation: coinJump 2.2s cubic-bezier(0.4, 0, 0.6, 1); }
@keyframes coinJump {
  0% { translate: 0 0; }
  40% { translate: 0 -90px; }
  75% { translate: 0 0; }
  85% { translate: 0 -14px; }
  100% { translate: 0 0; }
}
.coin-face {
  position: absolute; inset: 0;
  border-radius: 50%;
  display: grid; place-items: center;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  border: 6px solid;
}
.coin-face svg { width: 46%; height: 46%; }
.coin-heads {
  background: radial-gradient(circle at 35% 30%, #FFE9A8, var(--gold) 55%, #B8860B);
  border-color: #8F6914;
  color: #5C430A;
  box-shadow: inset 0 0 30px rgba(0,0,0,0.2), 0 0 40px rgba(245,196,75,0.35);
}
.coin-tails {
  background: radial-gradient(circle at 35% 30%, #C9D8EE, #8FA8CC 55%, #4A6285);
  border-color: #3A4E6B;
  color: #1E2C42;
  transform: rotateX(180deg);
  box-shadow: inset 0 0 30px rgba(0,0,0,0.25), 0 0 40px rgba(143,168,204,0.3);
}
.coin-shadow {
  position: absolute; left: 50%; bottom: 8px; transform: translateX(-50%);
  width: 60%; height: 18px; border-radius: 50%;
  background: radial-gradient(ellipse, rgba(0,0,0,0.6), transparent 70%);
}

.cf-choice { display: flex; gap: 8px; }
.cf-side {
  flex: 1;
  display: flex; align-items: center; justify-content: center; gap: 7px;
  padding: 11px 0; border-radius: 6px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--line);
  font-family: var(--font-mono); font-size: 10px; font-weight: 700;
  letter-spacing: 0.08em; color: var(--dim);
  transition: all 0.2s;
}
.cf-side svg { color: currentColor; }
.cf-side:hover { color: var(--text); }
.cf-side.sel { background: rgba(245,196,75,0.12); border-color: rgba(245,196,75,0.5); color: var(--gold); }

.cf-result {
  font-family: var(--font-display); font-weight: 800; font-size: 26px;
  min-height: 40px;
}
.cf-result.win { color: #6BFF8F; animation: gemPop 0.5s; }
.cf-result.lose { color: var(--hot); animation: gemPop 0.5s; }

/* --- Wheel --- */
.wheel-scene { position: relative; width: min(420px, 76vw); }
.wheel-svg { width: 100%; display: block; filter: drop-shadow(0 16px 38px rgba(0,0,0,0.5)); }
.wheel-pointer {
  position: absolute; top: -6px; left: 50%; transform: translateX(-50%);
  width: 0; height: 0; z-index: 2;
  border-left: 13px solid transparent;
  border-right: 13px solid transparent;
  border-top: 22px solid var(--gold);
  filter: drop-shadow(0 3px 8px rgba(245,196,75,0.6));
}

/* --- Crash --- */
.crash-scene {
  position: relative;
  height: 440px;
  border-radius: 4px;
  background: rgba(0,0,0,0.3);
  border: 1px solid var(--line);
  overflow: hidden;
}
#crashCanvas { position: absolute; inset: 0; width: 100%; height: 100%; }
.crash-mult {
  position: absolute; top: 22px; left: 28px;
  font-family: var(--font-display); font-weight: 900;
  font-size: clamp(34px, 5vw, 54px);
  color: var(--gold);
  text-shadow: 0 0 30px rgba(245,196,75,0.4);
  font-variant-numeric: tabular-nums;
}
.crash-mult.crashed { color: var(--hot); text-shadow: 0 0 30px rgba(255,77,109,0.5); animation: gemPop 0.4s; }
.crash-history { display: flex; flex-wrap: wrap; gap: 6px; }
.crash-chip {
  font-family: var(--font-mono); font-size: 10px; font-weight: 700;
  padding: 3px 9px; border-radius: 6px;
  background: rgba(255,77,109,0.12); color: var(--hot);
  border: 1px solid rgba(255,77,109,0.25);
}
.crash-chip.hi { background: rgba(107,255,143,0.10); color: #6BFF8F; border-color: rgba(107,255,143,0.25); }
.crash-chip.cashed { outline: 1px dashed rgba(245,196,75,0.5); }

/* ===================== COLLECTION ===================== */
.coll-bar {
  display: flex; align-items: center; gap: 30px; flex-wrap: wrap;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 20px 26px;
  margin-bottom: 28px;
}
.coll-stat span { display: block; font-size: 11px; color: var(--dim); letter-spacing: 0.08em; text-transform: uppercase; }
.coll-stat b { font-family: var(--font-display); font-size: 18px; font-weight: 800; }
.gold-text { color: var(--gold); }
.coll-bar .btn { margin-left: auto; }

.coll-grid {
  display: grid; gap: 20px;
  grid-template-columns: repeat(auto-fill, minmax(185px, 1fr));
}
.coll-item { display: flex; flex-direction: column; gap: 10px; position: relative; }
.coll-card-wrap { position: relative; }
.coll-count {
  position: absolute; top: -8px; right: -8px; z-index: 6;
  font-family: var(--font-mono); font-size: 11px; font-weight: 700;
  background: var(--gold); color: #1A1205;
  border-radius: 6px; padding: 3px 9px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.4);
}
.coll-sell { width: 100%; }

.empty-state {
  text-align: center; padding: 70px 20px;
  display: flex; flex-direction: column; align-items: center; gap: 18px;
  color: var(--dim);
}
.empty-icon { font-size: 70px; line-height: 1; opacity: 0.5; }

/* ===================== MODAL ===================== */
.modal-backdrop {
  position: fixed; inset: 0; z-index: 980;
  background: rgba(7, 8, 11, 0.75);
  backdrop-filter: blur(8px);
  display: grid; place-items: center;
  animation: overlayIn 0.25s ease;
}
.modal {
  width: min(460px, calc(100vw - 40px));
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 26px;
  animation: modalIn 0.35s cubic-bezier(0.2, 0.9, 0.3, 1.2);
  box-shadow: 0 40px 90px rgba(0,0,0,0.6);
}
@keyframes modalIn { from { opacity: 0; transform: translateY(26px) scale(0.94); } }
.modal-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 6px; }
.modal-head h3 { font-family: var(--font-display); font-size: 18px; font-weight: 800; }
.modal-sub { color: var(--dim); font-size: 13px; margin-bottom: 20px; }

.deposit-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.deposit-opt {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  padding: 20px 12px; border-radius: 4px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--line);
  transition: all 0.2s;
}
.deposit-opt:hover { border-color: rgba(245,196,75,0.5); background: rgba(245,196,75,0.07); transform: translateY(-2px); }
.deposit-opt.dep-hot { border-color: rgba(245,196,75,0.4); background: rgba(245,196,75,0.06); }
.dep-amt { font-family: var(--font-display); font-weight: 800; font-size: 19px; color: var(--gold); }
.dep-tag { font-size: 11px; color: var(--dim); }

/* ===================== FX GLOBAUX ===================== */
#fxCanvas {
  position: fixed; inset: 0; z-index: 950;
  pointer-events: none;
}

.screen-flash {
  position: fixed; inset: 0; z-index: 940;
  pointer-events: none;
  animation: flashOut 0.7s ease-out forwards;
}
@keyframes flashOut { from { opacity: 1; } to { opacity: 0; } }

.float-gain {
  position: fixed; z-index: 995;
  transform: translate(-50%, 0);
  font-family: var(--font-display); font-weight: 800; font-size: 22px;
  pointer-events: none;
  text-shadow: 0 2px 18px rgba(0,0,0,0.7);
  animation: floatUp 1.4s ease-out forwards;
}
@keyframes floatUp {
  from { opacity: 0; transform: translate(-50%, 10px) scale(0.8); }
  20% { opacity: 1; transform: translate(-50%, -8px) scale(1.1); }
  to { opacity: 0; transform: translate(-50%, -70px) scale(1); }
}

.shake-sm { animation: bodyShakeSm 0.45s; }
.shake-lg { animation: bodyShakeLg 0.55s; }
@keyframes bodyShakeSm {
  20% { transform: translate(-5px, 3px); } 40% { transform: translate(5px, -3px); }
  60% { transform: translate(-3px, 2px); } 80% { transform: translate(3px, -1px); }
}
@keyframes bodyShakeLg {
  15% { transform: translate(-11px, 6px) rotate(-0.4deg); } 30% { transform: translate(10px, -6px) rotate(0.4deg); }
  45% { transform: translate(-8px, 4px); } 60% { transform: translate(7px, -4px); }
  75% { transform: translate(-4px, 2px); } 90% { transform: translate(3px, -1px); }
}

/* ===================== BADGE LIVE / QTY / MODE / PICKER ===================== */
.live-badge {
  display: flex; align-items: center; gap: 7px;
  font-family: var(--font-mono); font-size: 9.5px; font-weight: 700;
  letter-spacing: 0.16em;
  color: #6BFF8F;
  border: 1px solid rgba(107,255,143,0.35);
  background: rgba(107,255,143,0.07);
  padding: 7px 12px; border-radius: 6px;
}
.live-badge-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: #6BFF8F; box-shadow: 0 0 8px #6BFF8F;
  animation: liveBlink 1.6s ease infinite;
}

/* jauge ×N : une réglette segmentée, l'option choisie glisse en doré */
.qty-select {
  position: relative;
  display: flex; gap: 4px; margin-bottom: 12px;
  background: color-mix(in srgb, var(--text) 5%, transparent);
  border: 1px solid var(--line); border-radius: 10px; padding: 4px;
}
/* la pastille dorée qui glisse vers l'option choisie */
.qty-slider {
  position: absolute; left: 0; top: 0; z-index: 0;
  border-radius: 7px; background: var(--gold); box-shadow: 0 3px 0 var(--gold-deep);
  pointer-events: none;
  transition: transform 0.34s cubic-bezier(0.34, 1.3, 0.5, 1), width 0.34s cubic-bezier(0.34, 1.3, 0.5, 1), height 0.2s;
}
.qty-opt {
  position: relative; z-index: 1;
  flex: 1; padding: 8px 0; border-radius: 7px;
  background: transparent;
  border: none;
  font-family: var(--font-mono); font-size: 12px; font-weight: 700;
  color: var(--dim);
  transition: color 0.2s;
}
.qty-opt:hover { color: var(--text); }
.qty-opt.sel { color: #15130B; } /* le fond doré est fourni par le slider qui glisse */

.mode-toggle { display: flex; gap: 6px; margin-bottom: 4px; }
.mode-opt {
  flex: 1; padding: 9px 0; border-radius: 5px;
  background: rgba(255,255,255,0.05);
  border: 1px solid var(--line);
  font-family: var(--font-mono); font-size: 10.5px; font-weight: 700;
  color: var(--dim);
  transition: all 0.2s;
}
.mode-opt:hover { color: var(--text); }
.mode-opt.sel { background: rgba(245,196,75,0.12); border-color: rgba(245,196,75,0.5); color: var(--gold); }

.card-stake-pick {
  width: 100%;
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px; border-radius: 5px;
  background: rgba(0,0,0,0.35);
  border: 1px dashed rgba(245,196,75,0.35);
  color: var(--dim); font-size: 12.5px; font-weight: 600;
  transition: border-color 0.2s, color 0.2s;
  text-align: left;
}
.card-stake-pick:hover { border-color: var(--gold); color: var(--text); }
.card-stake-pick img { width: 30px; height: 42px; object-fit: cover; border-radius: 4px; }
.pick-dot { width: 12px; height: 12px; border-radius: 50%; flex-shrink: 0; }
.pick-name { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--text); }
.pick-val { font-family: var(--font-mono); font-size: 11px; color: var(--gold); }

.modal-wide { width: min(720px, calc(100vw - 40px)); max-height: 82vh; display: flex; flex-direction: column; }
.picker-grid {
  display: grid; gap: 14px;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  overflow-y: auto; padding: 4px;
}
.picker-item {
  display: flex; flex-direction: column; gap: 6px;
  border-radius: 6px; padding: 6px;
  border: 1px solid transparent;
  transition: border-color 0.2s, transform 0.15s, background 0.2s;
}
.picker-item:hover { border-color: rgba(245,196,75,0.5); background: rgba(245,196,75,0.06); transform: translateY(-3px); }
.picker-card { pointer-events: none; }
.picker-card .cardface { box-shadow: 0 8px 22px rgba(0,0,0,0.4); }
.picker-val { font-family: var(--font-mono); font-size: 11px; font-weight: 700; color: var(--gold); }

/* ===================== VOL VERS LE SAC ===================== */
.fly-card {
  position: fixed; z-index: 996;
  border-radius: 5px;
  background: linear-gradient(160deg, #2A2417, #15110A);
  box-shadow: 0 14px 34px rgba(0,0,0,0.55), 0 0 18px rgba(245,196,75,0.3);
  pointer-events: none;
  object-fit: cover;
}
/* pièces qui volent vers le solde (vente → CR en haut à droite) */
.fly-coin {
  position: fixed; z-index: 996; width: 22px; height: 22px; border-radius: 50%;
  background: radial-gradient(circle at 35% 30%, #fff3c0, var(--gold) 58%, var(--gold-deep));
  box-shadow: 0 2px 9px rgba(255,214,10,0.55), inset 0 1px 0 rgba(255,255,255,0.6);
  pointer-events: none;
}
.wallet-btn.wallet-pulse { animation: walletPulse 0.5s cubic-bezier(0.2, 0.9, 0.3, 1.4); }
@keyframes walletPulse { 35% { transform: scale(1.13); } 70% { transform: scale(0.97); } }

.mainnav a.bag-receive, .inv-btn.bag-receive { animation: bagBounce 0.45s cubic-bezier(0.2, 0.9, 0.3, 1.4); color: var(--gold); }
.inv-btn.bag-receive .acc-count { background: var(--gold); color: #0B0C10; }
@keyframes bagBounce { 35% { transform: scale(1.18) rotate(-3deg); } 70% { transform: scale(0.95); } }
.mainnav a.bag-receive .nav-count { background: var(--gold); color: #1A1205; }

/* multi-packs : badge + piles derrière le pack */
.pack-qty-badge {
  position: absolute; top: -16px; right: -16px; z-index: 5;
  font-family: var(--font-display); font-weight: 700; font-size: 17px;
  background: linear-gradient(160deg, #FFE08A, var(--gold));
  color: #1A1205;
  padding: 6px 13px; border-radius: 6px;
  box-shadow: 0 6px 18px rgba(245,196,75,0.4);
}
/* multi : une vraie PILE de boosters derrière le pack principal (fan) */
.pack-pile { position: absolute; inset: 0; z-index: 0; }
.pile-item { position: absolute; inset: 0; display: grid; place-items: center; }
.pile-item .pack3d { animation: none !important; filter: drop-shadow(0 16px 26px rgba(0,0,0,0.5)); }
.pack3d-wrap > .pack3d { z-index: 1; } /* le pack principal devant la pile */

/* beaucoup de cartes (multi-packs) → plus petites */
.reveal-row.cards-many .reveal-card { width: clamp(92px, 10.5vw, 130px); }

.cf-versus {
  display: flex; align-items: center; gap: 10px;
  font-size: 13.5px; color: var(--dim); flex-wrap: wrap; justify-content: center;
}
.cf-versus b { color: var(--text); }
.cf-versus span { font-family: var(--font-display); font-weight: 700; color: var(--hot); }
.cf-versus i { font-size: 11.5px; }

.recap-note {
  text-align: center; margin-top: 12px;
  font-size: 11px; color: var(--dim);
}

.drop-thumb { width: 20px; height: 28px; object-fit: cover; border-radius: 3px; }

/* ===================== SQUELETTE DE CHARGEMENT (cartes) ===================== */
/* tant que l'image Pokémon n'est pas chargée, un shimmer en forme de carte
   (plus stylé que les icônes de fallback). Disparaît dès que l'image arrive. */
.cf-img, .peek-card, .gc-card, .drop-thumb, .mkt-thumb, .pkimg, .pk-feat img, .pk-mini img, .picker-card .cf-img {
  background-image: linear-gradient(100deg, #181b26 16%, #2a2f3f 42%, #181b26 68%);
  background-size: 220% 100%;
  animation: cardSkeleton 1.25s ease-in-out infinite;
}
html[data-theme="light"] .cf-img,
html[data-theme="light"] .peek-card,
html[data-theme="light"] .gc-card,
html[data-theme="light"] .mkt-thumb,
html[data-theme="light"] .pkimg,
html[data-theme="light"] .pk-feat img,
html[data-theme="light"] .pk-mini img {
  background-image: linear-gradient(100deg, #e7e3d9 16%, #f6f3ec 42%, #e7e3d9 68%);
}
img.img-loaded { animation: none !important; background-image: none !important; }
@keyframes cardSkeleton { 0% { background-position: 135% 0; } 100% { background-position: -135% 0; } }
@media (prefers-reduced-motion: reduce) { .cf-img, .peek-card, .gc-card, .drop-thumb, .mkt-thumb, .pkimg { animation: none; } }

/* carte entière en squelette (pendant le chargement du vrai pool) */
.cardface.cf-skeleton {
  background-image: linear-gradient(100deg, #14171f 16%, #21262f 42%, #14171f 68%);
  background-size: 220% 100%; animation: cardSkeleton 1.25s ease-in-out infinite;
  box-shadow: 0 18px 50px rgba(0,0,0,0.45);
}
html[data-theme="light"] .cardface.cf-skeleton { background-image: linear-gradient(100deg, #e7e3d9 16%, #f6f3ec 42%, #e7e3d9 68%); box-shadow: 0 12px 30px rgba(0,0,0,0.18); }
/* squelette de drop dans le ticker */
.drop-skel-thumb, .drop-skel-bar {
  display: block; background-image: linear-gradient(100deg, #1b1e29 20%, #2a2f3d 45%, #1b1e29 70%);
  background-size: 220% 100%; animation: cardSkeleton 1.25s ease-in-out infinite;
}
.drop-skel-thumb { width: 20px; height: 28px; border-radius: 4px; }
.drop-skel-bar { width: 66px; height: 10px; border-radius: 99px; }
html[data-theme="light"] .drop-skel-thumb, html[data-theme="light"] .drop-skel-bar { background-image: linear-gradient(100deg, #ddd9cf 20%, #f1eee6 45%, #ddd9cf 70%); }

/* ===================== ICÔNES INLINE ===================== */
.bicon { width: 15px; height: 15px; flex-shrink: 0; }
.bicon use { color: inherit; }
.hicon { width: 26px; height: 26px; vertical-align: -3px; }
.gamecard-icon svg { display: block; }

/* ===================== PACK : ART RÉEL + CHASE ===================== */
.pack-art {
  position: relative; z-index: 2;
  width: 52%;
  transform: rotate(-3deg);
  border-radius: 4px;
  box-shadow: 0 10px 26px rgba(0,0,0,0.55), 0 0 18px color-mix(in srgb, var(--pack-accent, var(--gold)) 35%, transparent);
  outline: 2px solid color-mix(in srgb, var(--pack-accent, var(--gold)) 55%, transparent);
  outline-offset: 2px;
  margin: 2px 0 4px;
}
.pack-art img {
  display: block; width: 100%; border-radius: 4px;
  user-select: none; -webkit-user-drag: none;
}

.packcard-chase {
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 10px;
  font-size: 12.5px;
}
.chase-label {
  font-family: var(--font-mono); font-size: 8.5px; font-weight: 700;
  letter-spacing: 0.18em;
  color: var(--gold);
  border: 1px solid rgba(245,196,75,0.4);
  background: rgba(245,196,75,0.08);
  padding: 2px 7px; border-radius: 6px;
}
.packcard-chase b { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
/* le chiffre du Chase : or sur fond sombre, flat — jamais de texte noir sur jaune */
.chase-val {
  margin-left: auto; flex-shrink: 0;
  font-size: 14px; line-height: 1;
  color: var(--gold);
}

.rotation-chip {
  display: flex; align-items: center; gap: 8px;
  font-family: var(--font-mono); font-size: 10.5px; font-weight: 700;
  letter-spacing: 0.12em; color: var(--dim);
  border: 1px solid var(--line);
  background: transparent;
  padding: 8px 14px; border-radius: 6px;
  margin-left: auto;
}
.rotation-chip b { color: var(--gold); font-variant-numeric: tabular-nums; }
.rotation-chip .bicon { animation: orbitSpin 6s linear infinite; }

/* ===================== LIVRAISONS ===================== */
.orders-list { display: flex; flex-direction: column; gap: 18px; }

.order-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 20px 24px;
}
.order-card.done { opacity: 0.75; }
.order-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 14px; }
.order-id { font-family: var(--font-mono); font-size: 12px; font-weight: 700; color: var(--dim); letter-spacing: 0.08em; }
.order-status {
  font-family: var(--font-mono); font-size: 10px; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  padding: 5px 12px; border-radius: 6px;
}
.order-status.queue    { color: var(--dim); border: 1px solid var(--line); }
.order-status.buying   { color: var(--blue); border: 1px solid rgba(63,169,255,0.4); background: rgba(63,169,255,0.08); }
.order-status.bought   { color: var(--purple); border: 1px solid rgba(194,75,255,0.4); background: rgba(194,75,255,0.08); }
.order-status.shipped  { color: var(--gold); border: 1px solid rgba(245,196,75,0.4); background: rgba(245,196,75,0.08); }
.order-status.delivered{ color: #6BFF8F; border: 1px solid rgba(107,255,143,0.4); background: rgba(107,255,143,0.08); }
.order-status.cancelled{ color: var(--hot); border: 1px solid rgba(255,77,109,0.4); background: rgba(255,77,109,0.08); }
.order-card.cancelled .order-body { opacity: 0.6; }
.order-live {
  font-family: var(--font-mono); font-size: 9px; font-weight: 800;
  letter-spacing: 0.12em; color: #6BFF8F;
  border: 1px solid rgba(107,255,143,0.4); border-radius: 4px;
  padding: 3px 7px; margin-left: auto; margin-right: 8px;
}

.order-body { display: flex; gap: 18px; align-items: center; flex-wrap: wrap; margin-bottom: 16px; }
.order-meta { display: flex; flex-direction: column; gap: 3px; font-size: 12.5px; color: var(--dim); }
.order-meta b { color: var(--text); }
.order-tracking { font-family: var(--font-mono); letter-spacing: 0.06em; }

.ship-items { display: flex; align-items: center; gap: 6px; }
.ship-thumb {
  width: 38px; height: 53px; object-fit: cover; border-radius: 4px;
  border: 1px solid var(--line);
  box-shadow: 0 4px 10px rgba(0,0,0,0.4);
}
.ship-thumb-txt {
  display: grid; place-items: center;
  background: var(--panel-2);
  font-family: var(--font-mono); font-size: 11px; font-weight: 700; color: var(--dim);
}
.ship-more { font-family: var(--font-mono); font-size: 11px; color: var(--dim); margin-left: 4px; }

.order-timeline { display: flex; align-items: center; gap: 0; margin-bottom: 14px; flex-wrap: wrap; }
.tl-step { display: flex; flex-direction: column; align-items: center; gap: 6px; min-width: 76px; }
.tl-dot {
  width: 18px; height: 18px; border-radius: 50%;
  border: 2px solid var(--line);
  background: var(--panel);
  display: grid; place-items: center;
  color: #0B0C10;
}
.tl-step.past .tl-dot { background: #6BFF8F; border-color: #6BFF8F; }
.tl-step.now .tl-dot { border-color: var(--gold); background: rgba(245,196,75,0.2); animation: liveBlink 1.4s ease infinite; }
.tl-label { font-size: 9.5px; color: var(--dim); text-align: center; max-width: 86px; line-height: 1.3; }
.tl-step.now .tl-label { color: var(--gold); font-weight: 700; }
.tl-bar { flex: 1; height: 2px; background: var(--line); min-width: 14px; margin: 0 2px 22px; }
.tl-bar.past { background: #6BFF8F; }

.order-agent {
  font-size: 12.5px; color: var(--dim);
  background: rgba(0,0,0,0.25);
  border: 1px solid var(--line);
  border-radius: 5px;
  padding: 10px 14px;
}
.order-agent-tag {
  font-family: var(--font-mono); font-size: 9px; font-weight: 700;
  letter-spacing: 0.18em; color: var(--gold);
  margin-right: 8px;
}

/* modal livraison */
.ship-sum {
  display: flex; justify-content: space-between; gap: 12px; flex-wrap: wrap;
  font-size: 12.5px; color: var(--dim);
  margin: 12px 0 16px;
}
.ship-sum b { color: var(--gold); }
.ship-addr {
  display: flex; justify-content: space-between; align-items: center; gap: 14px;
  background: rgba(0,0,0,0.25);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 14px 16px;
  font-size: 13px; line-height: 1.5;
  margin-bottom: 16px;
}
.ship-form { display: flex; flex-direction: column; gap: 10px; margin-bottom: 16px; }
.ship-form-row { display: grid; grid-template-columns: 1fr 2fr; gap: 10px; }
.ship-form input {
  background: rgba(0,0,0,0.35);
  border: 1px solid var(--line);
  border-radius: 5px;
  color: var(--text);
  font-size: 13.5px;
  padding: 11px 13px;
  outline: none;
  width: 100%;
  transition: border-color 0.2s;
}
.ship-form input:focus { border-color: rgba(245,196,75,0.5); }

.coll-actions { display: flex; gap: 8px; }
.coll-actions .coll-sell { flex: 1; }

/* ===================== SCÈNE BOUTIQUE : CARTES QUI DÉPASSENT DU PACK ===================== */
.packcard-scene {
  position: relative;
  height: 316px; /* contient toute la hauteur du booster : il ne chevauche plus l'entête (ROTATION DANS…) */
  margin-bottom: 18px;
  /* overflow visible : au survol, les cartes sortent de la carte de vente */
}
.ps-sky {
  position: absolute; inset: -12px;
  overflow: hidden;
  /* halo fondu, aucun bord visible derrière les cartes */
  background: radial-gradient(75% 85% at 50% 72%, rgba(60, 105, 160, 0.45) 0%, rgba(36, 64, 102, 0.22) 45%, transparent 72%);
  mask-image: radial-gradient(80% 90% at 50% 65%, black 40%, transparent 78%);
  -webkit-mask-image: radial-gradient(80% 90% at 50% 65%, black 40%, transparent 78%);
}
.ps-cloud {
  position: absolute;
  border-radius: 50%;
  filter: blur(13px);
  background: radial-gradient(ellipse at 45% 60%, rgba(255,255,255,0.6), rgba(255,255,255,0) 70%);
  animation: psDrift linear infinite;
  pointer-events: none;
}
.psc1 { width: 170px; height: 56px; top: 16px; animation-duration: 30s; }
.psc2 { width: 110px; height: 38px; top: 70px; opacity: 0.55; animation-duration: 44s; animation-delay: -20s; }
.psc3 { width: 220px; height: 70px; top: 38px; opacity: 0.3; animation-duration: 58s; animation-delay: -35s; }
@keyframes psDrift {
  from { transform: translateX(-240px); }
  to   { transform: translateX(440px); }
}

/* le booster du pack, DEVANT : les trois cartes dépassent derrière lui */
.ps-booster {
  position: absolute; left: 50%; bottom: 4px;
  width: 184px;
  transform: translateX(-50%);
  z-index: 3; /* devant les cartes qui dépassent derrière */
  pointer-events: none;
  animation: peekBob 4.5s ease-in-out infinite alternate;
  animation-delay: -0.7s; /* léger décalage avec les cartes : parallaxe */
}
.ps-booster .pack3d-mini {
  max-width: none;
  filter: drop-shadow(0 14px 24px rgba(0,0,0,0.55));
  transition: transform 0.4s cubic-bezier(0.2, 0.8, 0.3, 1);
}
/* au survol : le booster MONTE franchement avec les cartes, se redresse et se penche */
.packcard:hover .ps-booster .pack3d-mini {
  transform: perspective(1100px) rotateX(7deg) rotateY(-7deg) translateY(-30px) scale(1.04);
}

.ps-peek {
  position: absolute; left: 50%; bottom: 26%;
  transform: translateX(-50%);
  width: 1px;
  animation: peekBob 4.5s ease-in-out infinite alternate;
}
@keyframes peekBob { from { translate: 0 0; } to { translate: 0 -6px; } }
.peek-card {
  position: absolute; bottom: 0; left: 50%;
  width: 136px;
  border-radius: 4px;
  box-shadow: 0 12px 30px rgba(0, 10, 25, 0.55);
  transform-origin: 50% 100%;
  transition: transform 0.4s cubic-bezier(0.2, 0.8, 0.3, 1);
  user-select: none; -webkit-user-drag: none;
}
/* au repos : deux GROSSES cartes bien enfoncées derrière le booster — seul leur bord
   incliné dépasse (pas de carte centrale : la star du pack se voit déjà dans la vitre) */
.peek-card.pk1 { transform: translateX(-88%) rotate(-12deg); transition-delay: 0.04s; }
.peek-card.pk3 { transform: translateX(-12%) rotate(12deg); transition-delay: 0.08s; }
/* au survol : elles glissent de derrière le booster, sans envahir la vignette */
.packcard:hover .peek-card.pk1 { transform: translateX(-108%) rotate(-20deg) translateY(-22%); }
.packcard:hover .peek-card.pk3 { transform: translateX(8%) rotate(20deg) translateY(-22%); }
/* home (packs à la une) : cartes plus grandes ; la boutique officielle garde la taille normale */
.packs-grid:not(.packs-grid-4) .packcard-scene { height: 392px; }
.packs-grid:not(.packs-grid-4) .peek-card { width: 168px; }
.packs-grid:not(.packs-grid-4) .ps-booster { width: 228px; bottom: 6px; }

.ps-sleeve {
  position: absolute; left: 50%; bottom: 0;
  transform: translateX(-50%);
  width: 66%; height: 88px;
  border-radius: 6px 6px 0 0;
  overflow: hidden;
  border: 1px solid var(--foil-edge, var(--line));
  border-bottom: none;
  z-index: 3;
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 1px;
  box-shadow: 0 -12px 32px rgba(0, 8, 20, 0.45);
}
/* design propre à chaque pack : motif + emblème, zéro texte */
.ps-pattern { position: absolute; inset: 0; opacity: 0.5; }
.pat-1 .ps-pattern {
  background: repeating-linear-gradient(115deg,
    color-mix(in srgb, var(--pack-accent, #888) 14%, transparent) 0 3px, transparent 3px 14px);
}
.pat-2 .ps-pattern {
  background-image: radial-gradient(color-mix(in srgb, var(--pack-accent, #888) 22%, transparent) 1.5px, transparent 1.5px);
  background-size: 14px 14px;
}
.pat-3 .ps-pattern {
  background: repeating-conic-gradient(from 0deg at 50% 130%,
    color-mix(in srgb, var(--pack-accent, #888) 14%, transparent) 0deg 7deg, transparent 7deg 22deg);
}
.pat-4 .ps-pattern {
  background:
    repeating-linear-gradient(45deg, color-mix(in srgb, var(--pack-accent, #888) 10%, transparent) 0 2px, transparent 2px 12px),
    repeating-linear-gradient(-45deg, color-mix(in srgb, var(--pack-accent, #888) 10%, transparent) 0 2px, transparent 2px 12px);
}
.ps-emblem {
  position: relative; z-index: 2;
  width: 34px; height: 34px;
  color: var(--pack-accent, var(--gold));
  filter: drop-shadow(0 0 12px color-mix(in srgb, var(--pack-accent, var(--gold)) 55%, transparent));
}

/* odds compactes sur une ligne */
.odds-line {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  margin-bottom: 8px;
}
.ol-item {
  display: flex; align-items: center; gap: 5px;
  font-family: var(--font-mono); font-size: 10px; font-weight: 500;
  color: var(--dim);
}
.ol-item i { width: 7px; height: 7px; border-radius: 50%; display: block; }

/* titre du pack + petit « ? » des cotes juste à côté du nom */
.packcard-title { display: flex; align-items: center; gap: 9px; }
.packcard-title h3 { margin: 0; }
.pack-odds {
  position: relative; display: inline-grid; place-items: center;
  width: 18px; height: 18px; border-radius: 50%; flex-shrink: 0;
  background: var(--gold); color: #15130B; cursor: help; outline: none;
}
.po-q { font-family: var(--font-display); font-weight: 800; font-size: 11px; line-height: 1; }
/* au survol, la pastille « ? » se hisse au-dessus des cartes du pack (et des voisines) */
.pack-odds:hover, .pack-odds:focus { z-index: 200; }
.pack-odds-tip {
  position: absolute; bottom: calc(100% + 10px); left: 50%; transform: translate(-50%, 6px); z-index: 300;
  width: 220px; padding: 12px 14px;
  background: #05060A; border: 1px solid var(--line); border-radius: 10px;
  box-shadow: 0 16px 36px rgba(0,0,0,0.55);
  opacity: 0; pointer-events: none;
  transition: opacity 0.16s, transform 0.16s;
}
.pack-odds:hover .pack-odds-tip, .pack-odds:focus .pack-odds-tip { opacity: 1; transform: translate(-50%, 0); }
/* pastille « ? » d'entête de section : l'explication n'apparaît qu'au survol */
.head-help { align-self: center; }
.head-help-tip {
  bottom: auto; top: calc(100% + 10px);
  transform: translate(-50%, -6px);
  width: 290px;
  color: var(--dim); font-size: 13px; line-height: 1.55;
}
.pack-odds:hover .head-help-tip, .pack-odds:focus .head-help-tip { transform: translate(-50%, 0); }
/* la carte dont le tooltip est ouvert passe devant les autres */
.packcard:has(.pack-odds:hover), .packcard:has(.pack-odds:focus) { z-index: 200; }
/* sécurité : le contenu du pack (scène/cartes/visuel) ne doit pas recouvrir le tooltip ouvert */
.packcard:has(.pack-odds:hover) .packcard-scene, .packcard:has(.pack-odds:focus) .packcard-scene,
.packcard:has(.pack-odds:hover) .packcard-visual, .packcard:has(.pack-odds:focus) .packcard-visual { z-index: 0; }
.po-title { display: block; font-family: var(--font-display); font-weight: 800; font-size: 12px; margin-bottom: 8px; }
.po-row { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--dim); padding: 3px 0; }
.po-row i { width: 9px; height: 9px; border-radius: 50%; }
.po-row b { margin-left: auto; font-family: var(--font-mono); color: var(--text); font-weight: 700; }
.po-note { display: block; margin-top: 8px; padding-top: 8px; border-top: 1px solid var(--line); font-size: 11px; color: var(--dim); font-style: italic; }
.po-note.ok { color: #6BFF8F; font-style: normal; }

/* onglets collection */
/* onglets épurés : soulignement, pas de boîte */
.tabbar {
  display: flex; gap: 26px; flex-wrap: wrap;
  margin-left: auto;
  border-bottom: 1px solid var(--line);
}
.tab {
  position: relative;
  padding: 0 0 12px;
  font-family: var(--font-display);
  font-size: 14px; font-weight: 700; color: var(--dim);
  transition: color 0.2s;
}
.tab::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -1px; height: 2px;
  background: var(--gold); transform: scaleX(0); transform-origin: left;
  transition: transform 0.22s ease;
}
.tab:hover { color: var(--text); }
.tab.sel { color: var(--text); }
.tab.sel::after { transform: scaleX(1); }

/* nuages derrière les cartes du hero */
.hero-clouds { position: absolute; inset: -10% -5%; pointer-events: none; }
.hcl {
  position: absolute;
  border-radius: 50%;
  filter: blur(22px);
  background: radial-gradient(ellipse at 45% 60%, rgba(180, 210, 255, 0.16), rgba(180, 210, 255, 0) 70%);
  animation: psDrift linear infinite;
}
.hcl1 { width: 300px; height: 100px; top: 8%; animation-duration: 48s; }
.hcl2 { width: 200px; height: 70px; top: 42%; animation-duration: 62s; animation-delay: -25s; opacity: 0.8; }
.hcl3 { width: 360px; height: 120px; top: 64%; animation-duration: 78s; animation-delay: -50s; opacity: 0.6; }
.hcl4 { width: 150px; height: 52px; top: 24%; animation-duration: 38s; animation-delay: -12s; opacity: 0.7; }

.packcard-promo {
  position: absolute; top: -10px; right: 14px; z-index: 7;
  transform: rotate(3deg);
  font-family: var(--font-display); font-weight: 800; font-size: 11px;
  letter-spacing: 0.06em;
  background: linear-gradient(160deg, #FF7A92, var(--hot));
  color: #fff;
  padding: 6px 14px;
  border-radius: 5px;
  box-shadow: 0 6px 18px rgba(255,77,109,0.4);
}

/* badge informatif : pack encore en anglais (français à venir) — plat, discret */
.packcard-lang {
  position: absolute; top: -10px; left: 14px; z-index: 7;
  font-family: var(--font-display); font-weight: 800; font-size: 10.5px;
  letter-spacing: 0.07em;
  background: var(--surface-2, #16171d); color: var(--dim);
  border: 1px solid var(--line);
  padding: 6px 12px; border-radius: 5px;
}

/* bouton d'achat : le bevel or 3D validé, SEULEMENT le prix — gros chiffre Anton
   + logo CR ; le prix sort de sa case au survol, le socle s'enfonce au clic */
.packcard-buy {
  display: flex; align-items: center; justify-content: center; gap: 9px;
  width: 100%; padding: 11px 16px; border-radius: 8px;
  background: var(--gold); color: #15130B;
  box-shadow: 0 5px 0 var(--gold-deep);
  font-family: var(--font-display); font-weight: 700;
  cursor: pointer; user-select: none;
  transition: transform 0.12s, background 0.2s, box-shadow 0.12s, opacity 0.2s;
}
.packcard-buy b { font-size: 21px; line-height: 1; }
.packcard-buy .cr-ic { opacity: 0.95; }
.packcard-buy:hover:not(:disabled) { background: #FFE04D; transform: translateY(-1px); box-shadow: 0 6px 0 var(--gold-deep); }
.packcard-buy:active:not(:disabled) { transform: translateY(4px); box-shadow: 0 1px 0 var(--gold-deep); }
.packcard-buy:disabled { opacity: 0.4; cursor: not-allowed; }
.packcard-buy s { opacity: 0.55; font-weight: 600; font-size: 11.5px; font-family: var(--font-mono); }
.packcard-buy .pb-qty {
  font-style: normal; font-family: var(--font-mono); font-weight: 700; font-size: 11px;
  opacity: 0.65;
}

/* ===================== POP DES CHIFFRES =====================
   Les montants sortent de leur case au survol — petit rebond élastique.
   (inline-flex : aligne aussi proprement le logo CR sur les chiffres) */
.packcard-buy b, .btn b, .chase-val, .balance-amount, .wallet-head-amount,
.coll-stat b, .drop-val, .tc-price, .pick-val, .picker-val, .sp-val,
.recap-gain b, .cf-value {
  display: inline-flex; align-items: center;
  transition: transform 0.22s cubic-bezier(0.3, 1.9, 0.4, 1);
  transform-origin: center;
}
.packcard-buy:hover:not(:disabled) b { transform: scale(1.18) rotate(-1.5deg); }
.btn-gold:hover:not(:disabled) b, .btn-hot:hover:not(:disabled) b { transform: scale(1.16) rotate(-1.2deg); }
.packcard-chase:hover .chase-val { transform: scale(1.22) rotate(-2deg); }
.wallet-btn:hover .balance-amount { transform: scale(1.14); }
.drop-item:hover .drop-val { transform: scale(1.25); }
.coll-stat:hover b { transform: scale(1.12); }
.trade-card:hover .tc-price { transform: scale(1.16); }
/* PAS de zoom au survol sur le chiffre du récap : il a sa propre chorégraphie
   (roll → pose) et un transform au hover la casserait (double zoom) */
.pick-btn:hover .pick-val, .picker-item:hover .picker-val, .sp-card:hover .sp-val { transform: scale(1.2); }
.reveal-card.flipped:hover .cf-value, .hero-card:hover .cf-value { transform: scale(1.2); }

/* solde en euros */
/* solde : chiffre Anton + petit « cr » doré à côté */
.balance-cur { font-family: "Space Mono", monospace; font-weight: 700; font-size: 10px; color: var(--gold); opacity: 0.7; }

/* toolbar catalogue */
.cat-toolbar {
  display: flex; flex-direction: column; gap: 16px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 20px 24px;
  margin-bottom: 22px;
}
.cat-global { display: flex; align-items: center; gap: 18px; }
.cat-global-text b { display: block; font-family: var(--font-display); font-size: 15px; }
.cat-global-text span { font-size: 12px; color: var(--dim); }
.cat-progress { flex: 1; max-width: none; height: 8px; }
.cat-global-pct { font-family: var(--font-mono); font-weight: 700; font-size: 15px; color: var(--gold); }
.cat-controls { display: flex; gap: 12px; flex-wrap: wrap; }
.cat-search-wrap {
  flex: 1; min-width: 220px;
  display: flex; align-items: center; gap: 10px;
  background: rgba(0,0,0,0.35);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 0 14px;
  color: var(--dim);
  transition: border-color 0.2s;
}
.cat-search-wrap:focus-within { border-color: rgba(245,196,75,0.5); }
.cat-search {
  flex: 1; background: none; border: none; outline: none;
  color: var(--text); font-size: 13.5px; padding: 12px 0;
}
.cat-filters { display: flex; gap: 6px; }
.cat-f {
  padding: 10px 16px; border-radius: 6px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--line);
  font-size: 12.5px; font-weight: 600; color: var(--dim);
  transition: all 0.2s;
}
.cat-f:hover { color: var(--text); }
.cat-f.sel { background: rgba(245,196,75,0.13); border-color: rgba(245,196,75,0.45); color: var(--gold); }

.set-block.open .set-summary { cursor: default; }
.set-summary .btn { margin-left: 14px; }

/* toggle réglages */
.settings-block { display: flex; flex-direction: column; gap: 10px; margin: 4px 0 16px; }
.settings-row {
  display: flex; justify-content: space-between; align-items: center;
  background: rgba(0,0,0,0.25);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 12px 16px;
  font-size: 13.5px;
}
.setting-toggle {
  display: flex; align-items: center; gap: 9px;
  font-family: var(--font-mono); font-size: 11px; font-weight: 700;
  color: var(--dim);
}
.setting-toggle i {
  width: 34px; height: 19px; border-radius: 6px;
  background: rgba(255,255,255,0.12);
  position: relative;
  transition: background 0.2s;
}
.setting-toggle i::after {
  content: ""; position: absolute; top: 2.5px; left: 3px;
  width: 14px; height: 14px; border-radius: 50%;
  background: #fff;
  transition: transform 0.22s cubic-bezier(0.2, 0.8, 0.3, 1.2);
}
.setting-toggle.on { color: var(--gold); }
.setting-toggle.on i { background: var(--gold); }
.setting-toggle.on i::after { transform: translateX(14px); }

/* ===================== COMPTE ===================== */
.account-row { display: flex; flex-direction: column; gap: 8px; margin-bottom: 16px; }
.account-input {
  background: rgba(0,0,0,0.35);
  border: 1px solid var(--line);
  border-radius: 5px;
  color: var(--text);
  font-family: var(--font-display); font-weight: 700; font-size: 15px;
  padding: 11px 13px;
  outline: none;
}
.account-input:focus { border-color: rgba(245,196,75,0.5); }
.account-stats {
  display: grid; grid-template-columns: 1fr 1fr; gap: 14px;
  margin-bottom: 16px;
}
.modal .btn-block { margin-top: 4px; }
.modal .recap-note { margin-top: 12px; }

/* ===================== DÉTAIL PACK ===================== */
.pack-detail-link {
  display: block; width: 100%;
  text-align: left;
  font-size: 12px; font-weight: 600;
  color: var(--gold);
  padding: 4px 0 12px;
  transition: opacity 0.2s;
}
.pack-detail-link:hover { opacity: 0.75; }

.pd-body { overflow-y: auto; display: flex; flex-direction: column; gap: 20px; padding-right: 4px; }
.pd-section { display: flex; flex-direction: column; gap: 10px; }
.pd-head { display: flex; align-items: center; gap: 9px; font-size: 13px; }
.pd-head .pd-odds { font-family: var(--font-mono); font-size: 10.5px; color: var(--dim); }
.pd-head i { margin-left: auto; font-size: 11px; color: var(--dim); font-style: normal; }
.pd-grid {
  display: grid; gap: 8px;
  grid-template-columns: repeat(auto-fill, minmax(72px, 1fr));
}
.pd-card {
  position: relative; border-radius: 6px; overflow: hidden;
  display: flex; flex-direction: column;
}
.pd-card img { width: 100%; display: block; border-radius: 6px; }
.pd-card span {
  position: absolute; bottom: 4px; left: 50%; transform: translateX(-50%);
  font-family: var(--font-mono); font-size: 8.5px; font-weight: 700;
  background: rgba(8,9,13,0.85); color: var(--gold);
  padding: 1px 6px; border-radius: 6px; white-space: nowrap;
}
.pd-card-txt {
  aspect-ratio: 5/7; background: var(--panel-2); border: 1px solid var(--line);
  align-items: center; justify-content: center; gap: 6px; padding: 6px; text-align: center;
}
.pd-card-txt b { font-size: 10px; }
.pd-more {
  aspect-ratio: 5/7; border-radius: 6px;
  border: 1px dashed var(--line);
  display: grid; place-items: center;
  font-family: var(--font-mono); font-size: 11px; color: var(--dim);
  text-align: center; line-height: 1.4;
}

/* ===================== CATALOGUE (SETS) ===================== */
.sets-list { display: flex; flex-direction: column; gap: 16px; }

.set-block {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  overflow: hidden;
}
.set-summary {
  display: flex; align-items: center; gap: 18px;
  padding: 18px 22px;
  cursor: pointer; list-style: none;
  transition: background 0.2s;
}
.set-summary::-webkit-details-marker { display: none; }
.set-summary:hover { background: rgba(255,255,255,0.02); }
.set-cover {
  width: 52px; height: 72px; object-fit: cover; border-radius: 6px;
  box-shadow: 0 6px 16px rgba(0,0,0,0.45);
}
.set-info { flex: 1; display: flex; flex-direction: column; gap: 5px; }
.set-info b { font-family: var(--font-display); font-size: 16px; }
.set-info > span { font-size: 12px; color: var(--dim); }
.set-progress {
  height: 5px; border-radius: 6px; max-width: 320px;
  background: rgba(255,255,255,0.07); overflow: hidden;
}
.set-progress i {
  display: block; height: 100%;
  background: linear-gradient(90deg, var(--gold-deep), var(--gold));
  border-radius: 6px;
}
.set-pct {
  font-family: var(--font-mono); font-size: 12px; font-weight: 700; color: var(--dim);
  display: flex; align-items: center; gap: 6px;
}
.set-pct.done { color: #6BFF8F; }

.set-actions { padding: 0 22px 14px; }
.set-missing-note { font-size: 12.5px; color: var(--dim); }

.set-grid {
  display: grid; gap: 10px;
  grid-template-columns: repeat(auto-fill, minmax(86px, 1fr));
  padding: 4px 22px 22px;
}
.set-card { position: relative; border-radius: 6px; }
.set-card img { width: 100%; display: block; border-radius: 6px; }
.set-card span {
  position: absolute; bottom: 5px; left: 50%; transform: translateX(-50%);
  font-family: var(--font-mono); font-size: 8.5px; font-weight: 700;
  background: rgba(8,9,13,0.85); color: var(--gold);
  padding: 1px 6px; border-radius: 6px; white-space: nowrap;
}
.set-card.missing img { filter: grayscale(1) brightness(0.45); }
.set-card.missing span { color: var(--dim); }
.set-card-count {
  position: absolute; top: -6px; right: -6px;
  font-family: var(--font-mono); font-size: 10px; font-weight: 700;
  background: var(--gold); color: #1A1205;
  border-radius: 6px; padding: 2px 7px;
  box-shadow: 0 3px 10px rgba(0,0,0,0.4);
}

/* ===================== WHEEL : CARTE GAGNÉE ===================== */
.wheel-won { width: clamp(120px, 14vw, 165px); animation: gemPop 0.5s cubic-bezier(0.2, 0.9, 0.3, 1.4); }

/* ===================== COLLECTION : OVERLAY / SÉLECTION / LOCK ===================== */
.coll-card-wrap { position: relative; }

.cc-overlay {
  position: absolute; left: 6px; right: 6px; bottom: 6px; z-index: 7;
  display: flex; gap: 4px; align-items: center;
  padding: 6px 5px;
  border-radius: 5px;
  background: rgba(8, 10, 15, 0.82);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,0.1);
  opacity: 0; transform: translateY(8px);
  transition: opacity 0.22s, transform 0.22s;
  pointer-events: none;
}
.coll-card-wrap:hover .cc-overlay { opacity: 1; transform: none; pointer-events: auto; }

.cc-act {
  display: flex; align-items: center; justify-content: center; gap: 4px;
  height: 30px; min-width: 30px; padding: 0; width: 30px;
  border-radius: 4px;
  background: rgba(255,255,255,0.07);
  color: var(--dim);
  white-space: nowrap; flex-shrink: 0;
  transition: background 0.18s, color 0.18s, transform 0.15s;
}
.cc-act svg { width: 15px; height: 15px; }
.cc-act:hover { background: rgba(255,255,255,0.14); color: var(--text); transform: translateY(-1px); }
.cc-act.on { background: rgba(245,196,75,0.2); color: var(--gold); }
.cc-act:disabled { opacity: 0.35; cursor: not-allowed; }
.cc-sellbtn {
  background: var(--gold);
  color: #15130B; font-weight: 700;
  width: auto; padding: 0 11px; margin-left: auto; /* compact, calé à droite */
}
.cc-sellbtn b { font-family: var(--font-mono); font-size: 11px; }
.cc-sellbtn:hover:not(:disabled) { background: #FFD45E; color: #15130B; }

.cc-select {
  position: absolute; top: 8px; left: 8px; z-index: 8;
  width: 24px; height: 24px; border-radius: 4px;
  border: 1.5px solid rgba(255,255,255,0.4);
  background: rgba(8, 10, 15, 0.6);
  color: transparent;
  display: grid; place-items: center;
  opacity: 0;
  transition: all 0.18s;
}
.coll-card-wrap:hover .cc-select, .coll-item.selected .cc-select { opacity: 1; }
.cc-select:hover { border-color: var(--gold); }
.coll-item.selected .cc-select { background: var(--gold); border-color: var(--gold); color: #1A1205; }
.coll-item.selected .cardface { outline: 2.5px solid var(--gold); outline-offset: 3px; }

.cc-lockbadge {
  position: absolute; top: 8px; right: 8px; z-index: 8;
  width: 24px; height: 24px; border-radius: 4px;
  display: grid; place-items: center;
  background: rgba(245,196,75,0.92);
  color: #1A1205;
  box-shadow: 0 3px 10px rgba(0,0,0,0.4);
}
.coll-item.locked .cardface { box-shadow: 0 18px 50px rgba(0,0,0,0.55), 0 0 0 1.5px rgba(245,196,75,0.4); }

.sel-bar {
  position: sticky; bottom: 18px; z-index: 50;
  display: flex; align-items: center; gap: 16px; justify-content: center;
  margin-top: 22px;
  padding: 12px 22px;
  border-radius: 4px;
  background: rgba(18, 21, 32, 0.94);
  border: 1px solid rgba(245,196,75,0.35);
  backdrop-filter: blur(12px);
  box-shadow: 0 18px 44px rgba(0,0,0,0.5);
  animation: toastIn 0.3s ease;
}
.sel-bar.hide { display: none; }
.sel-bar > span { font-size: 13.5px; color: var(--dim); }
.sel-bar > span b { color: var(--gold); font-family: var(--font-display); }

/* ===================== ZOOM CARTE ===================== */
.zoom-backdrop {
  position: fixed; inset: 0; z-index: 985;
  background: rgba(5, 6, 10, 0.92);
  backdrop-filter: blur(14px);
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 18px;
  cursor: zoom-out;
  perspective: 1600px;          /* scène 3D : la carte a de la profondeur */
  animation: overlayIn 0.25s ease;
}
.zoom-stage { position: relative; transform-style: preserve-3d; will-change: transform; }
/* vraie carte recto/verso : deux faces dos à dos, chacune masquée de l'autre côté */
.zoom-card {
  position: relative; transform-style: preserve-3d; will-change: transform; cursor: grab;
  width: min(82vw, calc(74vh * 63 / 88)); aspect-ratio: 63 / 88;
  --d: 4px;  /* épaisseur de la carte (fine) */
  --r: 13px; /* rayon des coins arrondis */
}
.zoom-card.grabbing { cursor: grabbing; }
.zoom-face {
  position: absolute; inset: 0; border-radius: var(--r); overflow: hidden;
  backface-visibility: hidden; -webkit-backface-visibility: hidden;
  box-shadow: 0 30px 70px rgba(0,0,0,0.55);
}
.zoom-front { transform: translateZ(calc(var(--d) / 2)); }
.zoom-back { transform: rotateY(180deg) translateZ(calc(var(--d) / 2)); }
/* épaisseur : fines tranches arrondies (même rayon) empilées entre recto et verso →
   bord arrondi sur toute la tranche, pas de trou noir aux coins. (générées en JS) */
.zoom-slab {
  position: absolute; inset: 1.5px; border-radius: calc(var(--r) - 1.5px);
  background: linear-gradient(135deg, #efece3, #d6d3c9);
}
/* border-radius DIRECTEMENT sur l'image/reflet : en contexte 3D le overflow:hidden
   du parent est souvent ignoré → sans ça, les coins de la carte restent carrés. */
.zoom-img { display: block; width: 100%; height: 100%; object-fit: cover; pointer-events: none; border-radius: var(--r); }
.zoom-gloss {
  position: absolute; inset: 0; pointer-events: none; border-radius: var(--r);
  background: radial-gradient(42% 34% at 50% 38%, rgba(255,255,255,0.4), rgba(255,255,255,0) 70%);
  mix-blend-mode: overlay;
}
.zoom-cardface { position: absolute; inset: 0; }
.zoom-caption {
  position: relative;
  font-family: var(--font-mono); font-weight: 700; font-size: 11.5px;
  letter-spacing: 0.08em;
  color: var(--gold);
  background: rgba(16, 19, 29, 0.92);
  border: 1px solid rgba(245,196,75,0.25);
  padding: 8px 16px; border-radius: 6px;
}
.zoom-hint { position: relative; font-size: 11px; color: var(--dim); letter-spacing: 0.03em; }

/* ===================== TOUTES LES COLLECTIONS ===================== */
.allsets-head { margin: 26px 0 16px; }
.allsets-head h3 { font-family: var(--font-display); font-size: 21px; font-weight: 800; }
.allsets-grid {
  display: grid; gap: 14px;
  grid-template-columns: repeat(auto-fill, minmax(225px, 1fr));
  margin-bottom: 14px;
}
.allset-tile {
  position: relative;
  display: flex; flex-direction: column; gap: 12px;
  padding: 16px 16px 15px;
  border-radius: 4px;
  background: var(--surface);
  border: 1px solid var(--line);
  transition: transform 0.2s, border-color 0.2s, box-shadow 0.2s;
}
.allset-tile:hover { transform: translateY(-3px); border-color: rgba(255,255,255,0.2); box-shadow: 0 14px 32px rgba(0,0,0,0.4); }
.allset-tile.dispo { border-color: rgba(245,196,75,0.4); box-shadow: 0 0 0 1px rgba(245,196,75,0.15); }
.allset-logo {
  height: 56px; width: 100%;
  object-fit: contain;
  padding: 8px 10px;
  border-radius: 5px;
  background: radial-gradient(80% 100% at 50% 50%, rgba(255,255,255,0.10), rgba(255,255,255,0.03));
}
.allset-tile:not(.dispo) .allset-logo { filter: grayscale(0.7) opacity(0.75); }
.allset-noname { font-family: var(--font-display); font-size: 15px; }
.allset-meta b { display: block; font-size: 13.5px; font-weight: 700; padding-right: 70px; }
.allset-meta span { font-size: 11px; color: var(--dim); }
.allset-status {
  position: absolute; top: 12px; right: 12px;
  font-family: var(--font-mono); font-size: 8.5px; font-weight: 700; letter-spacing: 0.14em;
  padding: 4px 9px; border-radius: 6px;
  background: rgba(10, 12, 17, 0.85);
  border: 1px solid var(--line); color: var(--dim);
}
.allset-tile.dispo .allset-status {
  color: #6BFF8F; border-color: rgba(107,255,143,0.4); background: rgba(107,255,143,0.1);
}

/* compteur de value en révélation multi-packs */
.reveal-total {
  font-family: var(--font-display); font-size: 19px; font-weight: 800;
  color: var(--gold); font-variant-numeric: tabular-nums;
}
.reveal-total b { color: var(--dim); font-size: 12px; font-family: var(--font-mono); font-weight: 700; margin-right: 4px; }
.reveal-total.bump { animation: gemPop 0.35s; }

.set-card { cursor: zoom-in; }

/* ===================== PAGES JEUX & PROFIL ===================== */
.games-hero { text-align: center; margin: 18px 0 36px; }
.games-hero h2 {
  font-family: var(--font-display); font-weight: 800;
  font-size: clamp(26px, 4vw, 38px);
}
.games-hero p { color: var(--dim); font-size: 14.5px; max-width: 480px; margin: 8px auto 0; }

.game-topbar {
  display: flex; align-items: center; gap: 16px;
  padding-bottom: 20px; margin-bottom: 24px;
  border-bottom: 1px solid var(--line);
}
.game-back {
  display: grid; place-items: center;
  width: 38px; height: 38px; border-radius: 6px;
  border: 1px solid var(--line);
  color: var(--dim);
  transition: color 0.2s, border-color 0.2s, transform 0.2s;
}
.game-back:hover { color: var(--text); border-color: rgba(255,255,255,0.25); transform: translateX(-2px); }
.gc-chip-sm { width: 42px; height: 42px; border-radius: 6px; margin-bottom: 0; }
.gc-chip-sm svg { width: 21px; height: 21px; }
.game-titles h2 { font-family: var(--font-display); font-weight: 800; font-size: 21px; line-height: 1.2; }
.game-titles p { color: var(--dim); font-size: 12.5px; max-width: 640px; }

.section-narrow { max-width: 920px; }
.profile-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 18px;
  margin-bottom: 22px;
}
.profile-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 22px 24px;
  display: flex; flex-direction: column; gap: 10px;
}
.profile-card h3 {
  font-family: var(--font-display); font-weight: 800; font-size: 15px;
  margin-bottom: 4px;
}
.profile-card .ship-form { margin-bottom: 0; }
.profile-actions { display: flex; gap: 12px; flex-wrap: wrap; }
.cloud-status {
  font-family: var(--font-mono); font-size: 12px;
  display: flex; align-items: center; gap: 8px;
}
.cloud-status.on { color: var(--gold); }
.cloud-status.on::before {
  content: ""; width: 8px; height: 8px; border-radius: 50%;
  background: var(--gold); box-shadow: 0 0 8px rgba(245,196,75,0.7);
}
.cloud-hint { font-size: 12px; color: var(--dim); line-height: 1.5; }
/* avatar du joueur : la porte de l'inventaire, tout en haut à droite */
.acc-wrap { position: relative; }
.avatar-btn { position: relative; display: block; width: 32px; height: 32px; }
.avatar-face {
  display: flex; align-items: center; justify-content: center;
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--gold);
  color: #15130B;
  font-family: var(--font-display); font-weight: 800; font-size: 11px;
  letter-spacing: 0.02em;
  transition: transform 0.15s;
}
.avatar-btn:hover .avatar-face { transform: scale(1.06); }
/* avatar lambda quand personne n'est connecté : neutre, initiales grisées */
.avatar-btn.guest .avatar-face,
.avatar-face.guest {
  background: #262A36; color: var(--dim);
  border: 1px solid var(--line);
}
.avatar-btn.active .avatar-face { outline: 2px solid rgba(245,196,75,0.6); outline-offset: 2px; }
.avatar-btn.online::after {
  content: ""; position: absolute; bottom: -1px; left: -1px;
  width: 9px; height: 9px; border-radius: 50%;
  background: #4BE88A; box-shadow: 0 0 7px rgba(75,232,138,0.8);
  border: 2px solid var(--bg);
}
.acc-count {
  position: absolute; top: -6px; right: -8px;
  min-width: 17px; height: 17px; padding: 0 4px;
  border-radius: 9px; background: var(--gold); color: #15130B;
  border: 2px solid var(--bg);
  font-family: var(--font-mono); font-size: 9.5px; font-weight: 800;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 2px 7px rgba(255,214,10,0.45);
}

/* la petite fenêtre du compte */
.acc-menu {
  position: absolute; top: calc(100% + 10px); right: 0; z-index: 200;
  min-width: 250px; padding: 6px;
  background: var(--panel-2);
  border: 1px solid var(--line); border-radius: 8px;
  box-shadow: 0 24px 50px rgba(0,0,0,0.6);
  display: flex; flex-direction: column; gap: 2px;
}
.acc-head {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 12px 12px;
  border-bottom: 1px solid var(--line); margin-bottom: 4px;
}
.acc-head .avatar-face { width: 34px; height: 34px; font-size: 12px; flex-shrink: 0; }
.acc-id { display: flex; flex-direction: column; min-width: 0; }
.acc-id b { font-family: var(--font-display); font-size: 14px; }
.acc-id span { font-size: 11px; color: var(--dim); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.acc-menu a, .acc-logout {
  padding: 9px 12px; border-radius: 4px; text-align: left;
  font-size: 13px; font-weight: 600; color: var(--dim);
  transition: background 0.15s, color 0.15s;
}
.acc-menu a:hover { background: rgba(255,255,255,0.06); color: var(--text); }
.acc-logout { color: var(--hot); margin-top: 4px; border-radius: 0 0 4px 4px; }
.acc-logout:hover { background: rgba(255,77,109,0.08); }

/* bouton inventaire (header) : le sac à dos du joueur */
/* icônes header épurées : pas de contour, juste l'icône (comme la nav) */
.inv-btn {
  position: relative;
  display: grid; place-items: center;
  width: 34px; height: 34px;
  border: none; background: transparent; color: var(--dim);
  transition: color 0.2s, transform 0.2s;
}
.inv-btn:hover, .inv-btn.active { color: var(--gold); }
/* sac à dos très vivant : le rabat se soulève au survol, s'ouvre en grand au clic */
.inv-btn .bag-flap { transform-box: fill-box; transform-origin: center bottom; transition: transform 0.28s cubic-bezier(0.3, 1.5, 0.5, 1); }
.inv-btn:hover { transform: translateY(-1px); }
.inv-btn:hover .bag-flap { transform: translateY(-1.5px) rotate(-18deg); }
.inv-btn.opening { animation: bagPop 0.55s cubic-bezier(0.3, 1.4, 0.5, 1); }
.inv-btn.opening .bag-flap { animation: flapOpen 0.6s cubic-bezier(0.3, 1.5, 0.5, 1); }
@keyframes bagPop { 30% { transform: scale(1.2) rotate(-5deg); } 60% { transform: scale(0.95); } 100% { transform: scale(1); } }
@keyframes flapOpen { 0% { transform: rotate(0); } 45% { transform: translateY(-3px) rotate(-46deg); } 100% { transform: rotate(0); } }
.inv-btn .acc-count { top: -6px; right: -6px; }
.bag-flap {
  transform-box: fill-box; transform-origin: center bottom;
  transition: transform 0.22s cubic-bezier(0.3, 1.5, 0.5, 1);
}
/* réception de cartes : le sac s'illumine et son rabat se soulève */
.inv-btn.bag-open {
  color: var(--gold);
  border-color: rgba(245,196,75,0.6);
  box-shadow: 0 0 16px rgba(245,196,75,0.35), inset 0 0 8px rgba(245,196,75,0.12);
}
.inv-btn.bag-open .bag-flap { transform: translateY(-3px) rotate(-16deg); }

/* panneaux du header (wallet + notifications) : même langage */
.head-panel {
  position: absolute; top: calc(100% + 10px); right: 0; z-index: 200;
  width: 330px; max-width: calc(100vw - 24px); padding: 6px;
  background: var(--panel-2);
  border: 1px solid var(--line); border-radius: 8px;
  box-shadow: 0 24px 50px rgba(0,0,0,0.6);
  animation: panelIn 0.18s cubic-bezier(0.2, 0.9, 0.3, 1.2);
}
@keyframes panelIn { from { opacity: 0; transform: translateY(-6px) scale(0.98); } }

/* ---- wallet ---- */
.wallet-head {
  position: relative; overflow: hidden;
  padding: 18px 16px; margin-bottom: 6px; border-radius: 5px;
  background: linear-gradient(120deg, rgba(245,196,75,0.14), rgba(245,196,75,0.03) 70%);
  border: 1px solid rgba(245,196,75,0.25);
}
.wallet-head .wcard { opacity: 0.7; }
.wallet-head .wcard-1 { width: 40px; height: 56px; right: 6px; top: -10px; }
.wallet-head .wcard-2 { width: 40px; height: 56px; right: 34px; top: -22px; }
.wallet-head-label { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.2em; color: var(--dim); }
.wallet-head-amount { font-family: var(--font-mono); font-weight: 700; font-size: 26px; color: var(--gold); font-variant-numeric: tabular-nums; }
.wallet-sub { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.15em; color: var(--dim); padding: 10px 12px 6px; }
.wallet-methods { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; padding: 0 6px; }
.wallet-method {
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  padding: 12px 6px; border-radius: 5px;
  background: rgba(255,255,255,0.03); border: 1px solid var(--line);
  font-size: 11px; font-weight: 700; color: var(--text);
  transition: border-color 0.15s, background 0.15s;
}
.wallet-method:hover { border-color: rgba(245,196,75,0.5); background: rgba(245,196,75,0.07); }
.wallet-method svg { color: var(--gold); }
.wallet-withdraw { display: flex; gap: 6px; padding: 0 6px; align-items: stretch; }
.wallet-withdraw .account-input { flex: 1; margin: 0; }
.wallet-tx { max-height: 240px; overflow-y: auto; display: flex; flex-direction: column; }
/* scrollbar maison (fine, dorée) au lieu de celle du navigateur */
.wallet-tx, .notif-list, .picker-grid, .pd-body { scrollbar-width: thin; scrollbar-color: color-mix(in srgb, var(--gold) 45%, transparent) transparent; }
.wallet-tx::-webkit-scrollbar, .notif-list::-webkit-scrollbar, .picker-grid::-webkit-scrollbar, .pd-body::-webkit-scrollbar { width: 9px; }
.wallet-tx::-webkit-scrollbar-track, .notif-list::-webkit-scrollbar-track, .picker-grid::-webkit-scrollbar-track, .pd-body::-webkit-scrollbar-track { background: transparent; }
.wallet-tx::-webkit-scrollbar-thumb, .notif-list::-webkit-scrollbar-thumb, .picker-grid::-webkit-scrollbar-thumb, .pd-body::-webkit-scrollbar-thumb {
  background: color-mix(in srgb, var(--gold) 40%, transparent); border-radius: 99px;
  border: 2.5px solid transparent; background-clip: padding-box;
}
.wallet-tx::-webkit-scrollbar-thumb:hover, .notif-list::-webkit-scrollbar-thumb:hover, .picker-grid::-webkit-scrollbar-thumb:hover, .pd-body::-webkit-scrollbar-thumb:hover {
  background: color-mix(in srgb, var(--gold) 65%, transparent); background-clip: padding-box;
}
.wtx {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 12px; border-radius: 4px; font-size: 12px;
}
.wtx:hover { background: rgba(255,255,255,0.03); }
.wtx-label { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.wtx-time { font-family: var(--font-mono); font-size: 10px; color: var(--dim); }
.wtx-amt { font-family: var(--font-mono); font-weight: 700; font-size: 12px; font-variant-numeric: tabular-nums; }
.wtx-amt.in { color: #4BE88A; }
.wtx-amt.out { color: var(--hot); }
.wallet-empty { padding: 14px 12px; font-size: 12px; color: var(--dim); text-align: center; }

/* ---- notifications ---- */
.notif-wrap { position: relative; }
.notif-btn {
  position: relative;
  display: grid; place-items: center;
  width: 34px; height: 34px;
  color: var(--dim); border: none; background: transparent;
  transition: color 0.2s, transform 0.2s;
}
.notif-btn:hover { color: var(--gold); transform: translateY(-1px); }
/* la cloche sonne quand il y a du non-lu */
.notif-btn.has-unread svg { transform-box: fill-box; transform-origin: top center; animation: bellRing 2.6s ease-in-out infinite; }
@keyframes bellRing { 0%, 70%, 100% { transform: rotate(0); } 76% { transform: rotate(14deg); } 82% { transform: rotate(-11deg); } 88% { transform: rotate(7deg); } 94% { transform: rotate(-4deg); } }
.notif-btn svg { width: 15px; height: 15px; }
.notif-count {
  position: absolute; top: -6px; right: -7px;
  min-width: 15px; height: 15px; padding: 0 3px;
  border-radius: 4px; background: var(--hot); color: #fff;
  font-family: var(--font-mono); font-size: 9px; font-weight: 800;
  display: flex; align-items: center; justify-content: center;
  animation: notifPulse 2s ease infinite;
}
@keyframes notifPulse { 50% { box-shadow: 0 0 0 4px rgba(255,77,109,0.25); } }
.notif-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 12px; border-bottom: 1px solid var(--line); margin-bottom: 4px;
}
.notif-head b { font-family: var(--font-display); font-size: 14px; }
.notif-head span { font-family: var(--font-mono); font-size: 10px; color: var(--dim); letter-spacing: 0.1em; }
.notif-list { max-height: 380px; overflow-y: auto; display: flex; flex-direction: column; gap: 2px; }
.notif-item {
  display: flex; gap: 12px; padding: 12px; border-radius: 5px;
  animation: notifItemIn 0.3s cubic-bezier(0.2, 0.9, 0.3, 1.1) backwards;
}
.notif-item:nth-child(1) { animation-delay: 0.03s; }
.notif-item:nth-child(2) { animation-delay: 0.08s; }
.notif-item:nth-child(3) { animation-delay: 0.13s; }
.notif-item:nth-child(4) { animation-delay: 0.18s; }
@keyframes notifItemIn { from { opacity: 0; transform: translateX(10px); } }
.notif-item:hover { background: rgba(255,255,255,0.03); }
.notif-item.unread { background: rgba(245,196,75,0.05); box-shadow: inset 2px 0 0 var(--gold); }
.notif-tag {
  font-family: var(--font-mono); font-size: 8.5px; font-weight: 800;
  letter-spacing: 0.1em; border-radius: 3px; padding: 2px 5px;
  margin-right: 7px; vertical-align: 1px;
}
.notif-tag.tag-news { color: var(--blue); background: rgba(63,169,255,0.12); }
.notif-tag.tag-promo { color: var(--hot); background: rgba(255,77,109,0.12); }
.notif-tag.tag-bonus { color: var(--gold); background: rgba(245,196,75,0.14); }
.notif-kind {
  flex-shrink: 0; display: grid; place-items: center;
  width: 34px; height: 34px; border-radius: 5px;
  background: rgba(245,196,75,0.1); color: var(--gold);
}
.notif-body { min-width: 0; }
.notif-title { font-weight: 700; font-size: 13px; }
.notif-text { font-size: 12px; color: var(--dim); line-height: 1.45; margin-top: 2px; }
.notif-cards { display: flex; gap: 6px; margin-top: 8px; }
.notif-cards img {
  width: 40px; height: 56px; object-fit: cover; border-radius: 3px;
  border: 1px solid var(--line);
  transition: transform 0.18s;
}
.notif-cards img:hover { transform: translateY(-3px) scale(1.06); }
.notif-time { font-family: var(--font-mono); font-size: 10px; color: var(--dim); margin-top: 6px; }
.notif-empty { padding: 22px 12px; font-size: 12px; color: var(--dim); text-align: center; }
/* héro identité (page Mon compte) */
.id-hero {
  display: flex; align-items: center; gap: 24px;
  padding: 26px 28px; margin-bottom: 18px;
  background: var(--surface);
  border: 1px solid var(--line); border-radius: var(--r-lg);
}
.avatar-xl {
  width: 84px; height: 84px; font-size: 26px;
  cursor: pointer; flex-shrink: 0;
}
.avatar-xl:hover { box-shadow: 0 4px 22px rgba(245,196,75,0.5); }
.avatar-face img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; display: block; }
.id-info { min-width: 0; }
.id-info h2 { font-family: var(--font-display); font-weight: 800; font-size: 26px; line-height: 1.2; }
.id-mail { color: var(--dim); font-size: 13px; margin-top: 2px; overflow: hidden; text-overflow: ellipsis; }
.id-status { font-family: var(--font-mono); font-size: 11px; color: var(--dim); margin-top: 4px; }
.id-status.on { color: #4BE88A; }
.id-actions { display: flex; gap: 8px; margin-top: 14px; flex-wrap: wrap; }
.login-card { margin-bottom: 18px; }
.login-card .ship-form-row { display: flex; gap: 10px; }
.login-card .ship-form-row + .ship-form-row { margin-top: 10px; }
.login-card .account-input { flex: 1; }
@media (max-width: 560px) {
  .id-hero { flex-direction: column; text-align: center; }
  .id-actions { justify-content: center; }
  .login-card .ship-form-row { flex-direction: column; }
}

.mkt-badge {
  font-family: var(--font-mono); font-size: 9px; font-weight: 800;
  letter-spacing: 0.08em; color: #0B0C10;
  background: var(--gold);
  border-radius: 4px; padding: 2px 5px; margin-left: 4px;
  vertical-align: 1px;
}

/* ===================== MARCHÉ COMMUNAUTAIRE ===================== */
.mkt-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(290px, 1fr));
  gap: 18px;
}
.mkt-tile {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 20px;
  display: flex; flex-direction: column; gap: 14px;
  transition: transform 0.25s, border-color 0.25s;
}
.mkt-tile:hover { transform: translateY(-4px); border-color: rgba(245,196,75,0.35); }
.mkt-visual { padding: 6px 0; }
.mkt-visual .pack3d-mini { max-width: 150px; }
.mkt-info { display: flex; flex-direction: column; gap: 8px; }
.mkt-name { font-family: var(--font-display); font-weight: 800; font-size: 16px; }
.mkt-seller { font-size: 12px; color: var(--dim); }
.mkt-seller b { color: var(--gold); }
.mkt-pool { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.mkt-thumb {
  width: 34px; height: 47px; object-fit: cover; border-radius: 4px;
  border: 1px solid var(--line); background: #15171F;
  display: inline-flex; align-items: center; justify-content: center;
}
.mkt-thumb-glyph svg { width: 20px; height: 20px; opacity: 0.8; }
.mkt-more { font-family: var(--font-mono); font-size: 11px; color: var(--dim); }
.mkt-stats {
  display: flex; gap: 12px; flex-wrap: wrap;
  font-family: var(--font-mono); font-size: 11px; color: var(--dim);
}
.mkt-stock { color: var(--gold); }
.mkt-note { font-size: 12px; color: var(--dim); margin-top: 18px; line-height: 1.6; max-width: 720px; }
.mkt-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  gap: 14px; flex-wrap: wrap; margin-bottom: 18px;
}
.mkt-count { font-family: var(--font-mono); font-size: 12px; color: var(--dim); }
.mkt-subhead { font-family: var(--font-display); font-weight: 800; font-size: 15px; margin: 22px 0 10px; }

/* vendre : sélecteur de cartes */
.sell-layout { display: grid; grid-template-columns: 1fr 330px; gap: 18px; align-items: start; }
.sell-picker {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(72px, 1fr));
  gap: 8px;
}
.sp-card {
  position: relative; padding: 4px; border-radius: 4px;
  background: var(--panel); border: 2px solid var(--line);
  cursor: pointer; display: flex; flex-direction: column; align-items: center; gap: 2px;
  transition: border-color 0.15s, transform 0.15s;
}
.sp-card:hover { transform: translateY(-2px); }
.sp-card .mkt-thumb { width: 100%; height: auto; aspect-ratio: 63/88; }
.sp-card.sel { border-color: var(--gold); box-shadow: 0 0 12px rgba(245,196,75,0.25); }
.sp-card.sel::after {
  content: "✓"; position: absolute; top: 2px; right: 4px;
  color: #0B0C10; background: var(--gold); border-radius: 50%;
  width: 16px; height: 16px; font-size: 11px; font-weight: 800;
  display: flex; align-items: center; justify-content: center;
}
.sp-val { font-family: var(--font-mono); font-size: 10px; color: var(--dim); }
.sell-form { position: sticky; top: 86px; }

/* listes ventes / achats */
.mkt-list { display: flex; flex-direction: column; gap: 10px; }
.mkt-order {
  display: flex; align-items: center; gap: 14px; flex-wrap: wrap;
  background: var(--surface);
  border: 1px solid var(--line); border-radius: var(--r-lg);
  padding: 14px 18px;
}
.mkt-order-main { flex: 1; min-width: 220px; display: flex; flex-direction: column; gap: 5px; font-size: 13px; }
.mkt-order-main > span { color: var(--dim); font-size: 12px; }
.mkt-addr { font-family: var(--font-mono); font-size: 11px; color: var(--dim); }
.mkt-status {
  font-family: var(--font-mono); font-size: 11px; padding: 5px 10px;
  border-radius: 6px; border: 1px solid var(--line); color: var(--dim); white-space: nowrap;
}
.mkt-status.st-escrow { color: #E8B34B; border-color: rgba(232,179,75,0.4); }
.mkt-status.st-shipped { color: #3FA9FF; border-color: rgba(63,169,255,0.4); }
.mkt-status.st-received, .mkt-status.st-live { color: #4BE88A; border-color: rgba(75,232,138,0.4); }
.mkt-status.st-paid, .mkt-status.st-soldout, .mkt-status.st-closed { opacity: 0.7; }

.payout-banner {
  display: flex; align-items: center; justify-content: space-between; gap: 14px; flex-wrap: wrap;
  background: linear-gradient(120deg, rgba(245,196,75,0.14), rgba(245,196,75,0.04));
  border: 1px solid rgba(245,196,75,0.4); border-radius: var(--r-lg);
  padding: 16px 20px; margin-bottom: 18px; font-size: 14px;
}
.payout-banner b { color: var(--gold); }

@media (max-width: 860px) {
  .sell-layout { grid-template-columns: 1fr; }
  .sell-form { position: static; }
}
@media (max-width: 760px) { .profile-grid { grid-template-columns: 1fr; } }

/* ===================== CANVAS D'OUVERTURE (warp/poussières) ===================== */
.open-bg {
  position: absolute; inset: 0;
  pointer-events: none;
  opacity: 0.85;
}

/* dos de carte officiel */
.rc-back { padding: 0; }
.rc-back-img {
  width: 100%; height: 100%;
  object-fit: cover;
  border-radius: 6px;
  user-select: none; -webkit-user-drag: none;
}

/* ===================== CATALOGUE : LIGNES DE COLLECTIONS DÉPLIABLES ===================== */
.setrows { display: flex; flex-direction: column; gap: 10px; }

.setrow {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 4px;
  overflow: hidden;
  transition: border-color 0.2s;
}
.setrow.dispo { border-color: rgba(245,196,75,0.32); }
.setrow.open { border-color: rgba(255,255,255,0.18); }
.setrow.dispo.open { border-color: rgba(245,196,75,0.5); }

.setrow-head {
  display: flex; align-items: center; gap: 16px;
  width: 100%;
  padding: 13px 18px;
  text-align: left;
  transition: background 0.18s;
}
.setrow-head:hover { background: rgba(255,255,255,0.025); }

.setrow-logo {
  width: 96px; height: 42px;
  object-fit: contain;
  flex-shrink: 0;
  padding: 3px 6px;
  border-radius: 4px;
  background: radial-gradient(80% 100% at 50% 50%, rgba(255,255,255,0.09), rgba(255,255,255,0.02));
}
.setrow:not(.dispo) .setrow-logo { filter: grayscale(0.65) opacity(0.8); }
.setrow-nologo {
  display: grid; place-items: center;
  font-family: var(--font-display); font-weight: 800; font-size: 15px;
  color: var(--dim);
}
.setrow-info { flex: 1; min-width: 0; }
.setrow-info b { display: block; font-size: 14px; font-weight: 700; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.setrow-info span { font-size: 11px; color: var(--dim); }

.setrow-progress {
  display: flex; align-items: center; gap: 9px;
  flex-shrink: 0;
}
.setrow-progress span { font-family: var(--font-mono); font-size: 10.5px; color: var(--dim); }
.setrow-progress .set-progress { width: 110px; }

.allset-status.ok { color: #6BFF8F; border-color: rgba(107,255,143,0.4); background: rgba(107,255,143,0.1); }
.setrow .allset-status { position: static; flex-shrink: 0; }

.setrow-chev { color: var(--dim); flex-shrink: 0; transition: transform 0.25s; }
.setrow.open .setrow-chev { transform: rotate(180deg); }

.setrow-body {
  border-top: 1px solid var(--line);
  padding: 16px 18px 20px;
  animation: pageIn 0.3s ease;
}
.setrow-body .set-grid { padding: 0; }
.setrow-body .set-actions { padding: 0 0 14px; }
.setrow-loading {
  padding: 24px 0; text-align: center;
  color: var(--dim); font-size: 13px;
}

.cat-sort {
  background: rgba(0,0,0,0.35);
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--text);
  font-family: var(--font-body); font-size: 12.5px; font-weight: 600;
  padding: 0 14px;
  outline: none;
  cursor: pointer;
}
.cat-sort:focus { border-color: rgba(245,196,75,0.5); }
.cat-sort option { background: var(--panel); }

/* ===================== TOASTS ===================== */
.toasts {
  position: fixed; top: 74px; right: 22px; z-index: 990;
  display: flex; flex-direction: column; gap: 10px;
  pointer-events: none;
}
.toast {
  padding: 13px 20px; border-radius: 7px;
  background: rgba(20, 23, 34, 0.92);
  border: 1px solid var(--line);
  backdrop-filter: blur(10px);
  font-size: 13.5px; font-weight: 600;
  box-shadow: 0 14px 36px rgba(0,0,0,0.5);
  animation: toastIn 0.4s cubic-bezier(0.2, 0.9, 0.3, 1.2);
  max-width: 330px;
}
@keyframes toastIn { from { opacity: 0; transform: translateX(40px); } }
.toast.out { opacity: 0; transform: translateX(40px); transition: all 0.5s; }
.toast-ok { border-color: rgba(107,255,143,0.3); }
.toast-error { border-color: rgba(255,77,109,0.4); }

/* ===================== FOOTER ===================== */
.footer { border-top: 1px solid var(--line); margin-top: 60px; }
.footer-inner {
  max-width: 1240px; margin: 0 auto; padding: 26px 28px;
  display: flex; align-items: center; gap: 20px; flex-wrap: wrap;
}
.footer-brand { font-family: var(--font-display); font-weight: 800; font-size: 14px; letter-spacing: 0.1em; }
.footer-tm { color: var(--dim); font-size: 10px; }
.footer-note { color: var(--dim); font-size: 12px; flex: 1; }
.footer-18 {
  font-family: var(--font-mono); font-size: 11px; font-weight: 700;
  border: 1.5px solid var(--hot); color: var(--hot);
  border-radius: 50%; width: 34px; height: 34px;
  display: grid; place-items: center;
}
.footer-links {
  max-width: 1240px; margin: 0 auto; padding: 0 28px 24px;
  display: flex; gap: 8px 22px; flex-wrap: wrap;
}
.footer-links a { color: var(--dim); font-size: 12px; text-decoration: none; }
.footer-links a:hover { color: var(--text); text-decoration: underline; }

/* ===================== ROUE QUOTIDIENNE + BOOSTERS GRATUITS ===================== */
.daily-sec { padding-top: 0; padding-bottom: 0; margin-top: -16px; }
.daily-banner {
  display: flex; align-items: center; gap: 16px;
  background: linear-gradient(90deg, rgba(214,179,106,0.1), var(--surface) 55%);
  border: 1px solid rgba(214,179,106,0.32); border-radius: 14px;
  padding: 14px 20px; position: relative;
  animation: dailyPulse 3s ease-in-out infinite;
}
@keyframes dailyPulse {
  0%, 100% { box-shadow: 0 0 0 rgba(245,196,75,0); }
  50% { box-shadow: 0 0 24px rgba(245,196,75,0.12); }
}
.daily-banner:hover { border-color: rgba(214,179,106,0.5); }
/* médaillon animé : mini-roue qui tourne, halo doré qui pulse, étincelles */
.daily-ico {
  position: relative; width: 50px; height: 50px; flex-shrink: 0;
  display: grid; place-items: center;
}
.dico-glow {
  position: absolute; inset: -8px; border-radius: 50%; z-index: 0;
  background: radial-gradient(circle, rgba(245,196,75,0.55), transparent 68%);
  filter: blur(5px); animation: dicoGlow 2.4s ease-in-out infinite;
}
@keyframes dicoGlow { 0%, 100% { opacity: 0.5; transform: scale(0.92); } 50% { opacity: 1; transform: scale(1.08); } }
.dico-wheel {
  position: absolute; inset: 3px; border-radius: 50%; z-index: 1;
  background: conic-gradient(from 0deg, #F5C44B 0deg 45deg, #3FA9FF 45deg 90deg, #C24BFF 90deg 135deg, #AEB8C4 135deg 180deg, #F5C44B 180deg 225deg, #3FA9FF 225deg 270deg, #C24BFF 270deg 315deg, #AEB8C4 315deg 360deg);
  box-shadow: inset 0 0 0 2px rgba(12,13,18,0.9), inset 0 0 14px rgba(0,0,0,0.55), 0 4px 12px rgba(0,0,0,0.5);
  animation: dicoSpin 9s linear infinite;
}
@keyframes dicoSpin { to { transform: rotate(360deg); } }
.dico-hub {
  position: absolute; z-index: 3; width: 20px; height: 20px; border-radius: 50%;
  background: #0C0D12; display: grid; place-items: center;
  box-shadow: 0 0 0 2px rgba(245,196,75,0.55), 0 2px 6px rgba(0,0,0,0.6);
}
.dico-hub svg { width: 13px; height: 13px; border-radius: 4px; }
.dico-pin {
  position: absolute; z-index: 4; top: -3px; left: 50%; transform: translateX(-50%);
  width: 0; height: 0; border-left: 5px solid transparent; border-right: 5px solid transparent;
  border-top: 8px solid var(--gold); filter: drop-shadow(0 1px 2px rgba(0,0,0,0.6));
}
.dico-spark {
  position: absolute; z-index: 5; width: 3px; height: 3px; border-radius: 50%;
  background: #fff; box-shadow: 0 0 6px 1px rgba(255,235,170,0.9);
  opacity: 0; animation: dicoSpark 2.6s ease-in-out infinite;
}
.dico-spark.sp1 { top: 2px; right: 4px; animation-delay: 0s; }
.dico-spark.sp2 { bottom: 5px; left: 2px; animation-delay: 0.9s; }
.dico-spark.sp3 { top: 12px; right: -2px; animation-delay: 1.7s; }
@keyframes dicoSpark { 0%, 100% { opacity: 0; transform: scale(0.4); } 45% { opacity: 1; transform: scale(1.2); } }
/* au survol de la bannière : la roue s'emballe, le halo flambe */
.daily-banner:hover .dico-wheel { animation-duration: 1.6s; }
.daily-banner:hover .dico-glow { animation-duration: 1.1s; }
@media (prefers-reduced-motion: reduce) {
  .dico-wheel, .dico-glow, .dico-spark { animation: none; }
  .dico-glow { opacity: 0.7; }
}
.daily-txt { flex: 1; min-width: 0; }
.daily-txt b { display: block; font-family: var(--font-display); font-size: 15px; letter-spacing: 0.04em; }
.daily-unl { font-style: normal; font-family: var(--font-mono); font-size: 9px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: #15130B; background: var(--gold); padding: 2px 7px; border-radius: 8px; margin-left: 8px; vertical-align: 2px; }
.daily-txt span { font-size: 12.5px; color: var(--dim); }
.daily-banner #dailyCd { font-family: var(--font-mono); }
/* modale roue */
.wheel-back {
  position: fixed; inset: 0; z-index: 700;
  background: rgba(4,5,9,0.72); backdrop-filter: blur(4px);
  display: grid; place-items: center; padding: 20px;
}
.wheel-modal {
  position: relative; width: min(440px, 94vw);
  background: #0E1016; border: 1px solid var(--line); border-radius: 18px;
  padding: 24px 24px 26px; text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: 12px;
  animation: drawerIn 0.25s cubic-bezier(0.2, 0.8, 0.3, 1);
}
.wheel-modal-case { width: min(760px, 96vw); }
.wheel-modal h3 { margin: 0; font-family: var(--font-display); font-size: 21px; letter-spacing: 0.04em; }
.wheel-sub { margin: 0; font-size: 12.5px; color: var(--dim); max-width: 420px; }
.wheel-close {
  position: absolute; top: 12px; right: 12px;
  appearance: none; cursor: pointer; width: 30px; height: 30px; border-radius: 50%;
  background: rgba(255,255,255,0.05); border: 1px solid var(--line); color: var(--dim);
}
/* ===== bande horizontale « case opening » ===== */
.case {
  position: relative; width: 100%; margin: 8px 0 4px;
  border-radius: 14px; overflow: hidden;
  background: radial-gradient(120% 100% at 50% 0%, rgba(214,179,106,0.07), transparent 70%), #0A0B0F;
  border: 1px solid var(--line);
  box-shadow: inset 0 0 40px rgba(0,0,0,0.6);
}
.case-view { overflow: hidden; padding: 18px 0; }
.case-reel { display: flex; gap: 14px; width: max-content; padding-left: 0; will-change: transform; }
.case-cell {
  --acc: var(--pack-accent, #9AA4B2);
  flex: 0 0 132px; width: 132px;
  display: flex; flex-direction: column; align-items: center; gap: 9px;
  padding: 12px 10px; border-radius: 11px;
  background: linear-gradient(180deg, color-mix(in srgb, var(--acc) 11%, #111319), #0C0D12);
  border: 1px solid color-mix(in srgb, var(--acc) 22%, var(--line));
}
.case-cell-pack { width: 86px; }
.case-cell-pack .pack3d-mini { max-width: 86px; pointer-events: none; }
/* à cette taille, le titre/compteur internes du booster débordent (clamp min 15px et
   polices de bannière custom en taille fixe) → on les masque ; le nom est sous la cellule */
.case-cell-pack .pack-title, .case-cell-pack .pack-count,
.dwon-pack .pack-title, .dwon-pack .pack-count { display: none; }
.case-cell-name {
  font-family: var(--font-mono); font-size: 9.5px; font-weight: 700; letter-spacing: 0.04em;
  color: color-mix(in srgb, var(--acc) 75%, #fff);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 100%;
}
.case-cell.win {
  border-color: var(--gold);
  box-shadow: 0 0 0 1px var(--gold), 0 0 34px color-mix(in srgb, var(--gold) 45%, transparent);
  transform: scale(1.04);
  transition: transform 0.3s, box-shadow 0.3s;
}
/* marqueur central + fondus latéraux */
.case-marker {
  position: absolute; top: 0; bottom: 0; left: 50%; transform: translateX(-50%); z-index: 4;
  width: 3px; background: linear-gradient(180deg, var(--gold), color-mix(in srgb, var(--gold) 40%, transparent));
  box-shadow: 0 0 14px color-mix(in srgb, var(--gold) 70%, transparent);
}
.case-marker::before, .case-marker::after {
  content: ""; position: absolute; left: 50%; transform: translateX(-50%);
  border-left: 7px solid transparent; border-right: 7px solid transparent;
}
.case-marker::before { top: -1px; border-top: 9px solid var(--gold); }
.case-marker::after { bottom: -1px; border-bottom: 9px solid var(--gold); }
.case-fade { position: absolute; top: 0; bottom: 0; width: 90px; z-index: 3; pointer-events: none; }
.case-fade-l { left: 0; background: linear-gradient(90deg, #0A0B0F, transparent); }
.case-fade-r { right: 0; background: linear-gradient(270deg, #0A0B0F, transparent); }
.wheel-spin { min-width: 220px; }
/* écran « gagné » : la bande s'efface, le prix s'affiche en HORIZONTAL (visuel à gauche, infos à droite) */
.wheel-won-mode .case { max-height: 0; opacity: 0; margin: 0; border-width: 0; transition: max-height 0.5s, opacity 0.4s, margin 0.5s; overflow: hidden; }
.wheel-won-mode .wheel-sub { display: none; }
.wheel-result { width: 100%; }
.dwon {
  display: flex; flex-direction: row; align-items: center; gap: 22px; text-align: left;
  max-width: 460px; margin: 0 auto; padding: 4px;
  animation: drawerIn 0.4s cubic-bezier(0.2, 0.8, 0.3, 1);
}
.dwon-pack { width: 120px; flex-shrink: 0; animation: wonFloat 3s ease-in-out infinite; }
.dwon-pack .pack3d-mini { max-width: 120px; filter: drop-shadow(0 16px 28px rgba(0,0,0,0.55)); }
@keyframes wonFloat { 50% { transform: translateY(-7px); } }
.dwon-txt { flex: 1 1 auto; min-width: 0; display: flex; flex-direction: column; gap: 4px; }
.dwon-kicker {
  font-family: var(--font-mono); font-size: 10px; font-weight: 700; letter-spacing: 0.2em; color: var(--gold);
}
.dwon-name { font-family: var(--font-display); font-size: 21px; letter-spacing: 0.03em; line-height: 1.1; }
.dwon-sub { font-size: 12.5px; color: var(--dim); margin-bottom: 12px; }
.dwon-acts { display: flex; flex-direction: column; gap: 8px; align-items: stretch; }
.dwon-acts .btn { width: 100%; }
@media (max-width: 480px) {
  .dwon { flex-direction: column; text-align: center; gap: 12px; }
  .dwon-txt { align-items: center; }
}
/* étagère des boosters gagnés (collection) */
.bshelf {
  background: linear-gradient(90deg, rgba(214,179,106,0.07), var(--surface) 60%);
  border: 1px solid rgba(214,179,106,0.32); border-radius: 14px;
  padding: 16px 20px; margin-bottom: 24px;
}
.bshelf-head { display: flex; align-items: baseline; gap: 12px; margin-bottom: 14px; flex-wrap: wrap; }
.bshelf-head b { font-family: var(--font-display); font-size: 15px; letter-spacing: 0.04em; }
.bshelf-head span { font-size: 12px; color: var(--dim); }
.bshelf-row { display: flex; gap: 18px; flex-wrap: wrap; }
.bshelf-item { display: flex; flex-direction: column; align-items: center; gap: 10px; }
.bshelf-pack { width: 92px; }
.bshelf-pack .pack3d-mini { max-width: 92px; filter: drop-shadow(0 10px 18px rgba(0,0,0,0.5)); }
.bshelf-ghost {
  width: 92px; aspect-ratio: 5 / 8.3; border-radius: 8px;
  border: 1px dashed var(--line); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 4px;
  background: rgba(255,255,255,0.03); padding: 8px; text-align: center;
}
.bshelf-ghost b { font-size: 10.5px; font-family: var(--font-display); }
.bshelf-ghost span { font-size: 8.5px; color: var(--dim); font-family: var(--font-mono); }

/* ===================== PAGES LÉGALES ===================== */
.legal-layout { display: grid; grid-template-columns: 210px 1fr; gap: 34px; align-items: start; }
@media (max-width: 820px) { .legal-layout { grid-template-columns: 1fr; } }
.legal-nav { display: flex; flex-direction: column; gap: 4px; position: sticky; top: 86px; }
@media (max-width: 820px) { .legal-nav { flex-direction: row; flex-wrap: wrap; position: static; } }
.legal-nav a {
  color: var(--dim); text-decoration: none; font-size: 13.5px; font-weight: 600;
  padding: 9px 14px; border-radius: 9px; border: 1px solid transparent;
}
.legal-nav a:hover { color: var(--text); background: rgba(255,255,255,0.03); }
.legal-nav a.on { color: var(--gold); background: rgba(214,179,106,0.08); border-color: rgba(214,179,106,0.3); }
.legal-doc { max-width: 760px; }
.legal-doc h2 { font-family: var(--font-display); font-size: 26px; margin: 0 0 4px; }
.legal-updated { color: var(--dim); font-size: 12px; font-family: var(--font-mono); margin: 0 0 22px; }
.legal-doc h3 { font-size: 15.5px; margin: 26px 0 8px; }
.legal-doc p, .legal-doc li { font-size: 13.5px; line-height: 1.75; color: color-mix(in srgb, var(--text) 86%, var(--dim)); }
.legal-doc p { margin: 0 0 10px; }
.legal-doc ul { margin: 0 0 12px; padding-left: 22px; display: flex; flex-direction: column; gap: 5px; }
.legal-doc a { color: var(--gold); }
.legal-doc b { color: var(--text); }
.legal-key {
  background: rgba(214,179,106,0.06); border: 1px solid rgba(214,179,106,0.3);
  border-radius: 12px; padding: 16px 20px; margin: 0 0 8px;
}
.legal-key > b { display: block; color: var(--gold); font-size: 13px; letter-spacing: 0.05em; text-transform: uppercase; margin-bottom: 8px; }
.legal-key ul { margin: 0; }
.legal-todo { background: rgba(255,159,69,0.08); border: 1px solid rgba(255,159,69,0.35); border-radius: 9px; padding: 10px 14px; font-size: 12.5px; }
.legal-foot-note {
  margin-top: 34px; padding-top: 16px; border-top: 1px solid var(--line);
  font-size: 12px !important; color: var(--dim) !important;
}

/* ===================== RESPONSIVE ===================== */
@media (max-width: 1020px) {
  .hero-inner { grid-template-columns: 1fr; }
  .hero-visual { height: 380px; max-width: 560px; margin: 0 auto; width: 100%; }
  .game-layout { grid-template-columns: 1fr; }
  .game-panel { position: static; }
}

@media (max-width: 720px) {
  .topbar { padding: 12px 16px; gap: 12px; flex-wrap: wrap; }
  .mainnav { order: 3; flex-basis: 100%; overflow-x: auto; }
  .mainnav a { white-space: nowrap; }
  .topbar-right { margin-left: auto; }
  .section { padding: 38px 18px; }
  .hero-inner { padding: 44px 18px 36px; }
  .hero-stats { gap: 22px; }
  .coll-bar .btn { margin-left: 0; flex-basis: 100%; }
  .dropfeed { height: 40px; }
  .reveal-row { gap: 8px; }
  .reveal-card { width: clamp(96px, 27vw, 140px); }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}

/* ============ ADMIN — boutique officielle ============ */
.adm { max-width: 1080px; }
.adm-bar { position: sticky; top: 8px; z-index: 20; display: flex; align-items: center; justify-content: space-between; gap: 16px;
  background: var(--surface); border: 1px solid var(--line); border-radius: 10px; padding: 14px 18px; margin-bottom: 18px; }
.adm-bar-l h2 { margin: 0; }
.adm-bar-l .section-sub { margin: 3px 0 0; }
.adm-bar-r { display: flex; align-items: center; gap: 14px; flex-shrink: 0; }
.adm-count { font-size: 13px; color: var(--dim); font-weight: 600; white-space: nowrap; }
.adm-fronly { display: flex; align-items: center; justify-content: space-between; gap: 16px;
  background: var(--surface); border: 1px solid var(--line); border-radius: 10px; padding: 13px 18px; margin-bottom: 18px; }
.adm-fronly-txt b { display: block; font-size: 14px; }
.adm-fronly-txt span { font-size: 12.5px; color: var(--dim); }
.adm-fronly .adm-toggle { flex-shrink: 0; }
/* ---- onglets de l'admin ---- */
.adm-tabs { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 22px; border-bottom: 1px solid var(--line); padding-bottom: 0; }
.adm-tab {
  appearance: none; background: none; border: none; cursor: pointer;
  padding: 10px 16px 12px; font: inherit; font-size: 13.5px; font-weight: 700; color: var(--dim);
  border-bottom: 2px solid transparent; margin-bottom: -1px;
  display: inline-flex; align-items: center; gap: 7px;
  transition: color 0.15s;
}
.adm-tab:hover { color: var(--text); }
.adm-tab.on { color: var(--gold); border-bottom-color: var(--gold); }
.adm-tab i { font-style: normal; font-size: 11px; font-family: var(--font-mono); background: rgba(255,255,255,0.07); border-radius: 9px; padding: 1px 7px; color: var(--dim); }
.adm-tab.on i { background: rgba(214,179,106,0.15); color: var(--gold); }
/* ---- dashboard ---- */
/* KPIs : 2 lignes FIXES — 4 cartes € puis 6 cartes CR compactes */
.adm-kpis { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin-bottom: 10px; }
.adm-kpis-cr { grid-template-columns: repeat(6, 1fr); margin-bottom: 16px; }
@media (max-width: 900px) { .adm-kpis { grid-template-columns: repeat(2, 1fr); } .adm-kpis-cr { grid-template-columns: repeat(3, 1fr); } }
.adm-kpi {
  background: var(--surface); border: 1px solid var(--line); border-radius: 10px;
  padding: 11px 14px; display: flex; flex-direction: column; gap: 2px; min-width: 0;
}
.adm-kpi b { font-size: 20px; font-family: var(--font-display); letter-spacing: 0.02em; display: flex; align-items: center; gap: 7px; white-space: nowrap; overflow: hidden; }
.adm-kpi span { font-size: 11px; color: var(--dim); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.adm-kpi i { font-style: normal; font-size: 10.5px; color: var(--dim); opacity: 0.85; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.adm-kpi.kpi-gold b { color: var(--gold); }
.adm-kpi.kpi-live { border-color: rgba(61,214,140,0.35); }
.adm-dash-cols { display: grid; grid-template-columns: 1.5fr 1fr; gap: 12px; margin-bottom: 12px; }
.adm-dash-cols-3 { grid-template-columns: 1.2fr 1fr 0.8fr; }
@media (max-width: 980px) { .adm-dash-cols, .adm-dash-cols-3 { grid-template-columns: 1fr; } }
/* graphe d'activité (SVG fait main) */
.adm-chart { width: 100%; height: auto; display: block; }
.ac-grid { stroke: rgba(255,255,255,0.07); stroke-width: 1; }
.ac-axis { fill: var(--dim); font-size: 9.5px; font-family: var(--font-mono); }
.ac-area { fill: rgba(245,196,75,0.13); }
.ac-line-spent { fill: none; stroke: #F5C44B; stroke-width: 2.2; stroke-linejoin: round; stroke-linecap: round; }
.ac-line-dep { fill: none; stroke: #3DD68C; stroke-width: 1.8; stroke-dasharray: 5 4; stroke-linejoin: round; stroke-linecap: round; }
.ac-dot { fill: #F5C44B; }
.ac-dot:hover { r: 4; }
.adm-legend { display: flex; gap: 16px; flex-wrap: wrap; margin-top: 8px; font-size: 12px; color: var(--dim); }
.adm-legend span { display: inline-flex; align-items: center; gap: 6px; }
.adm-legend i { width: 10px; height: 10px; border-radius: 3px; display: inline-block; }
.adm-legend b { color: var(--text); font-family: var(--font-mono); }
.adm-legend-col { flex-direction: column; gap: 7px; margin-top: 0; }
/* donut répartition */
.adm-donut-wrap { display: flex; gap: 18px; align-items: center; }
.adm-donut { width: 140px; height: 140px; flex-shrink: 0; }
.ad-big { fill: var(--text); font-size: 21px; font-family: var(--font-display); }
.ad-sub { fill: var(--dim); font-size: 9.5px; }
/* barres de revenu sous les noms de packs */
.adm-tp-name { position: relative; padding-bottom: 6px; }
.adm-tp-bar { position: absolute; left: 0; bottom: 0; height: 3px; border-radius: 2px; background: linear-gradient(90deg, var(--gold), rgba(245,196,75,0.35)); }
/* flux live des transactions */
.adm-feed-box { margin-bottom: 12px; }
.adm-feed { display: flex; flex-direction: column; gap: 2px; max-height: 330px; overflow-y: auto; }
.adm-feed-it { display: grid; grid-template-columns: 140px 120px 1fr 130px 78px; gap: 9px; align-items: center; padding: 6px 8px; font-size: 12.5px; border-radius: 6px; }
.adm-feed-amt { display: flex; flex-direction: column; align-items: flex-end; gap: 1px; }
/* montant € (CA si dépôt, coût si retrait de cartes) */
.adm-eur { font-family: var(--font-mono); font-size: 11px; font-weight: 700; }
.adm-eur.pos { color: #3DD68C; }
.adm-eur.neg { color: #FF6B6B; }
/* chip type de transaction — texte volontairement discret dans une petite pastille */
.adm-type {
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 8.5px; font-weight: 700; letter-spacing: 0.05em; text-transform: uppercase;
  color: var(--tc, #9AA4B2); background: color-mix(in srgb, var(--tc, #9AA4B2) 12%, transparent);
  border: 1px solid color-mix(in srgb, var(--tc, #9AA4B2) 30%, transparent);
  border-radius: 9px; padding: 2px 7px; line-height: 1.45;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 100%;
}
.adm-type-none { opacity: 0.4; }
/* icône inline (remplace les émojis) */
.aico { width: 13px; height: 13px; flex-shrink: 0; vertical-align: -2px; }
.adm-pp-badge .aico, .adm-pmail-toggle .aico { width: 12px; height: 12px; }
/* outils joueurs : recherche + filtres */
.adm-pl-tools { display: flex; gap: 12px; flex-wrap: wrap; align-items: center; padding: 12px 18px 4px; }
.adm-search {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(0,0,0,0.25); border: 1px solid var(--line); border-radius: 18px;
  padding: 7px 13px; color: var(--dim); min-width: 230px;
}
.adm-search:focus-within { border-color: rgba(214,179,106,0.5); }
.adm-search input { background: none; border: none; outline: none; font: inherit; font-size: 12.5px; color: var(--text); width: 100%; }
.adm-pl-filters { display: flex; gap: 7px; flex-wrap: wrap; }
.adm-pl-filters .adm-aud { display: inline-flex; align-items: center; gap: 6px; }
/* commandes d'un joueur */
.adm-ord-list { display: flex; flex-direction: column; gap: 4px; max-height: 180px; overflow-y: auto; }
.adm-ord { display: grid; grid-template-columns: 70px 1fr 60px 74px 86px; gap: 8px; align-items: center; font-size: 11.5px; padding: 4px 6px; border-radius: 6px; }
.adm-ord:nth-child(odd) { background: rgba(255,255,255,0.025); }
.adm-ord-id { font-family: var(--font-mono); font-size: 10.5px; color: var(--dim); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.adm-ord-n { color: var(--dim); white-space: nowrap; }
.adm-ord b { text-align: right; font-family: var(--font-mono); font-size: 11px; }
.adm-ord-when { color: var(--dim); font-family: var(--font-mono); font-size: 10px; text-align: right; }
/* email perso depuis la fiche */
.adm-pmail-toggle {
  appearance: none; cursor: pointer; font: inherit; font-size: 11px; font-weight: 700;
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--gold); background: rgba(214,179,106,0.1); border: 1px solid rgba(214,179,106,0.45);
  border-radius: 14px; padding: 4px 12px; margin-left: auto;
}
.adm-pmail-toggle:hover { background: rgba(214,179,106,0.18); }
.adm-pmail { display: flex; flex-direction: column; gap: 8px; margin: 2px 0 10px; padding: 12px; background: rgba(214,179,106,0.05); border: 1px solid rgba(214,179,106,0.25); border-radius: 8px; }
.adm-pmail-to { margin: 0; font-size: 11.5px; color: var(--dim); }
.adm-pmail-to b { color: var(--text); }
.adm-pp-cols-3 { grid-template-columns: 1.1fr 1fr 1fr; }
@media (max-width: 980px) { .adm-pp-cols-3 { grid-template-columns: 1fr; } }
/* ---- PANNEAU JOUEUR (drawer) ---- */
.adm-drawer-wrap { position: fixed; inset: 0; z-index: 800; }
.adm-drawer-back { position: absolute; inset: 0; background: rgba(4,5,9,0.6); backdrop-filter: blur(2px); }
.adm-drawer {
  position: absolute; top: 0; right: 0; bottom: 0;
  width: min(580px, 94vw);
  background: #0E1016; border-left: 1px solid var(--line);
  box-shadow: -30px 0 70px rgba(0,0,0,0.55);
  display: flex; flex-direction: column;
  animation: drawerIn 0.28s cubic-bezier(0.2, 0.8, 0.3, 1);
}
@keyframes drawerIn { from { transform: translateX(60px); opacity: 0; } to { transform: none; opacity: 1; } }
.adm-dr-head {
  display: flex; align-items: center; gap: 12px;
  padding: 15px 18px; border-bottom: 1px solid var(--line);
  background: linear-gradient(180deg, rgba(214,179,106,0.06), transparent);
}
.adm-dr-avatar {
  width: 42px; height: 42px; border-radius: 50%; flex-shrink: 0;
  display: grid; place-items: center;
  font-family: var(--font-display); font-size: 19px; color: #15130B;
  background: linear-gradient(135deg, #F5C44B, #C89B3C);
}
.adm-dr-id { min-width: 0; flex: 1; }
.adm-dr-id b { display: flex; align-items: center; gap: 7px; font-size: 15px; }
.adm-dr-id span { display: block; font-size: 11.5px; color: var(--dim); font-family: var(--font-mono); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.adm-dr-close {
  appearance: none; cursor: pointer; background: rgba(255,255,255,0.05);
  border: 1px solid var(--line); border-radius: 50%;
  width: 32px; height: 32px; display: grid; place-items: center; color: var(--dim); flex-shrink: 0;
}
.adm-dr-close:hover { color: var(--text); border-color: rgba(255,255,255,0.3); }
.adm-dr-close .aico { width: 14px; height: 14px; }
.adm-dr-scroll { overflow-y: auto; padding: 14px 18px 22px; display: flex; flex-direction: column; gap: 13px; }
.adm-dr-sec h5, .adm-dr-scroll .adm-pp-box h5 { margin: 0 0 8px; font-size: 11px; color: var(--dim); text-transform: uppercase; letter-spacing: 0.05em; font-weight: 700; display: flex; align-items: center; gap: 6px; }
.adm-dr-n { font-family: var(--font-mono); font-size: 10px; background: rgba(255,255,255,0.07); border-radius: 9px; padding: 1px 7px; }
.adm-dr-scroll .adm-pp-eur { margin-bottom: 0; }
.adm-dr-scroll .adm-pmail { margin: 0; }
.adm-dr-scroll .adm-ev-list { max-height: 280px; }
.adm-dr-scroll .adm-ev { grid-template-columns: 104px 92px 1fr 86px 74px; }
.adm-dr-scroll .adm-ev-bal { display: none; }
/* commandes : carte par commande avec PIPELINE visuel */
.adm-ordf-row { display: flex; gap: 7px; flex-wrap: wrap; margin-bottom: 9px; }
.adm-ord2-list { display: flex; flex-direction: column; gap: 8px; max-height: 320px; overflow-y: auto; }
.adm-ord2 { background: rgba(255,255,255,0.025); border: 1px solid var(--line); border-radius: 8px; padding: 9px 12px; }
.adm-ord2-top { display: flex; align-items: center; gap: 10px; }
.adm-ord2-id { font-family: var(--font-mono); font-size: 11.5px; }
.adm-ord2-when { font-family: var(--font-mono); font-size: 10px; color: var(--dim); }
.adm-ord2-val { margin-left: auto; font-family: var(--font-mono); font-size: 12px; }
.adm-ord2-pipe { display: flex; align-items: center; margin: 9px 2px 7px; }
.adm-ord2-pipe i {
  width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0;
  background: rgba(255,255,255,0.1); border: 1px solid rgba(255,255,255,0.15);
}
.adm-ord2-pipe i.on { background: var(--tc); border-color: var(--tc); box-shadow: 0 0 6px color-mix(in srgb, var(--tc) 60%, transparent); }
.adm-ord2-pipe em { flex: 1; height: 2px; background: rgba(255,255,255,0.08); }
.adm-ord2-pipe em.on { background: rgba(255,255,255,0.3); }
.adm-ord2-items { font-size: 11px; color: var(--dim); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.adm-feed-it:nth-child(odd) { background: rgba(255,255,255,0.025); }
.adm-feed-who { font-weight: 700; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.adm-feed-label { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; color: var(--dim); }
.adm-feed-it b { text-align: right; font-family: var(--font-mono); }
.adm-feed-when { color: var(--dim); font-size: 11px; text-align: right; font-family: var(--font-mono); }
.adm-kpi.kpi-pos b { color: #3DD68C; }
.adm-kpi.kpi-neg b { color: #FF6B6B; }
/* rangée ARGENT RÉEL (€) : mise en avant */
.adm-kpis-eur .adm-kpi { border-color: rgba(63,169,255,0.3); background: linear-gradient(180deg, rgba(63,169,255,0.07), var(--surface)); }
.adm-kpis-eur .adm-kpi b { color: #9CCFFF; }
.adm-kpis-eur .adm-kpi.kpi-pos b { color: #3DD68C; }
.adm-kpis-eur .adm-kpi.kpi-neg b { color: #FF6B6B; }
.ac-line-eur { fill: none; stroke: #3FA9FF; stroke-width: 1.8; stroke-linejoin: round; stroke-linecap: round; }
/* fiche joueur déroulée */
.adm-pp { padding: 10px 0 4px; }
.adm-pp-eur { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; margin-bottom: 10px; }
.adm-pp-chip { font-size: 11px; color: var(--dim); background: rgba(255,255,255,0.05); border: 1px solid var(--line); border-radius: 14px; padding: 4px 11px; }
.adm-pp-chip b { color: var(--text); font-family: var(--font-mono); }
.adm-pp-chip i { font-style: normal; opacity: 0.8; }
.adm-pp-badge { font-size: 11px; font-weight: 800; border-radius: 14px; padding: 4px 12px; letter-spacing: 0.03em; font-family: var(--font-mono); }
.adm-pp-badge.pos { background: rgba(61,214,140,0.14); color: #3DD68C; border: 1px solid rgba(61,214,140,0.4); }
.adm-pp-badge.neg { background: rgba(255,107,107,0.13); color: #FF6B6B; border: 1px solid rgba(255,107,107,0.4); }
.adm-pp-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 10px; }
@media (max-width: 800px) { .adm-pp-cols { grid-template-columns: 1fr; } }
.adm-pp-box { background: rgba(255,255,255,0.025); border: 1px solid var(--line); border-radius: 8px; padding: 10px 12px; }
.adm-pp-box h5 { margin: 0 0 8px; font-size: 11.5px; color: var(--dim); text-transform: uppercase; letter-spacing: 0.05em; font-weight: 700; }
.adm-spark { width: 100%; height: 64px; display: block; }
.sp-line { fill: none; stroke: var(--gold); stroke-width: 2; stroke-linejoin: round; stroke-linecap: round; }
.sp-area { fill: rgba(245,196,75,0.1); }
.sp-dot { fill: var(--gold); }
.adm-tb-list { display: flex; flex-direction: column; gap: 7px; }
.adm-tb { display: grid; grid-template-columns: 120px 1fr 80px; gap: 9px; align-items: center; font-size: 12px; }
.adm-tb span { color: var(--dim); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.adm-tb em { display: block; height: 9px; border-radius: 5px; min-width: 4px; }
.adm-tb b { text-align: right; font-family: var(--font-mono); font-size: 11.5px; }
@media (max-width: 700px) { .adm-feed-it { grid-template-columns: 110px 1fr 110px; } .adm-feed-when, .adm-feed-it .adm-type { display: none; } .adm-donut-wrap { flex-direction: column; } }
/* ---- module Emails ---- */
.adm-mail { background: var(--surface); border: 1px solid var(--line); border-radius: 10px; padding: 16px 18px; margin-bottom: 18px; display: flex; flex-direction: column; gap: 11px; }
.adm-mail-aud { display: flex; gap: 8px; flex-wrap: wrap; }
.adm-aud {
  appearance: none; cursor: pointer; font: inherit; font-size: 12px; font-weight: 700;
  color: var(--dim); background: rgba(255,255,255,0.04); border: 1px solid var(--line);
  border-radius: 16px; padding: 6px 14px; transition: color 0.15s, border-color 0.15s, background 0.15s;
}
.adm-aud:hover { color: var(--text); }
.adm-aud.on { color: var(--gold); border-color: rgba(214,179,106,0.55); background: rgba(214,179,106,0.1); }
.adm-mail-count { margin: 0; font-size: 12.5px; color: var(--dim); }
.adm-mail-count b { color: var(--text); }
.adm-mail-subj, .adm-mail-body {
  width: 100%; font: inherit; font-size: 13.5px; color: var(--text);
  background: rgba(0,0,0,0.25); border: 1px solid var(--line); border-radius: 8px; padding: 10px 13px;
}
.adm-mail-subj:focus, .adm-mail-body:focus { outline: none; border-color: rgba(214,179,106,0.5); }
.adm-mail-body { resize: vertical; line-height: 1.6; }
.adm-mail-actions { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }

/* ----- Mail Marketing : éditeur 2 colonnes + galerie de designs + aperçu ----- */
.adm-mail2 { display: grid; grid-template-columns: minmax(0,1fr) 400px; gap: 18px; align-items: start; margin-bottom: 18px; }
.mail-col { min-width: 0; }
.mail-edit { background: var(--surface); border: 1px solid var(--line); border-radius: 10px; padding: 16px 18px; display: flex; flex-direction: column; gap: 8px; }
.mail-lab { font-size: 10.5px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--dim); margin: 6px 0 -2px; }
.mail-designs { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 8px; }
.mail-design {
  appearance: none; cursor: pointer; font: inherit; text-align: left;
  background: rgba(0,0,0,0.25); border: 1px solid var(--line); border-radius: 9px; padding: 9px 11px;
  display: flex; flex-direction: column; gap: 2px; transition: border-color 0.15s, background 0.15s, transform 0.1s;
}
.mail-design:hover { border-color: rgba(214,179,106,0.5); }
.mail-design:active { transform: translateY(1px); }
.mail-design.on { border-color: var(--gold); background: rgba(214,179,106,0.12); }
.mail-design b { font-size: 13px; color: var(--text); }
.mail-design span { font-size: 10.5px; line-height: 1.3; color: var(--dim); }
.mail-ai { display: flex; gap: 8px; align-items: center; }
.mail-ai input { flex: 1; }
.mail-ai .btn { white-space: nowrap; }
.mail-row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.mail-f { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.mail-prev { position: sticky; top: 14px; background: var(--surface); border: 1px solid var(--line); border-radius: 10px; padding: 12px; }
.mail-prev-head { display: flex; align-items: center; justify-content: space-between; font-size: 11px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--dim); margin: 2px 4px 10px; }
.mail-prev-head i { font-style: normal; font-size: 10.5px; color: var(--gold); text-transform: none; letter-spacing: 0; }
#mailPreview { width: 100%; height: 600px; border: 1px solid var(--line); border-radius: 8px; background: #0B0C10; display: block; }
@media (max-width: 920px) {
  .adm-mail2 { grid-template-columns: 1fr; }
  .mail-prev { position: static; }
  #mailPreview { height: 520px; }
}
.adm-dash-box { background: var(--surface); border: 1px solid var(--line); border-radius: 10px; padding: 14px 16px; }
.adm-dash-box h4 { margin: 0 0 10px; font-size: 13.5px; }
.adm-dash-box h4 span { font-weight: 500; font-size: 11.5px; color: var(--dim); margin-left: 6px; }
.adm-tp-list { display: flex; flex-direction: column; gap: 4px; }
.adm-tp { display: grid; grid-template-columns: 26px 1fr 70px 100px; gap: 10px; align-items: center; font-size: 13px; padding: 6px 8px; border-radius: 6px; }
.adm-tp:nth-child(odd) { background: rgba(255,255,255,0.025); }
.adm-tp-rank { font-family: var(--font-mono); color: var(--gold); font-weight: 700; }
.adm-tp-name { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.adm-tp-n { color: var(--dim); font-size: 12px; text-align: right; }
.adm-tp b { text-align: right; font-family: var(--font-mono); }
.adm-ol-list { display: flex; flex-wrap: wrap; gap: 8px; }
.adm-ol { display: inline-flex; align-items: center; gap: 6px; font-size: 11.5px; background: rgba(255,255,255,0.05); border: 1px solid var(--line); border-radius: 14px; padding: 4px 11px; }
.adm-dash-note { margin: 14px 2px 0; font-size: 12px; color: var(--dim); }
/* pastille présence */
.adm-dot, u.adm-dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; background: rgba(255,255,255,0.18); flex-shrink: 0; text-decoration: none; }
.adm-dot.on { background: #3DD68C; box-shadow: 0 0 7px rgba(61,214,140,0.8); }
.adm-pl-num { display: inline-flex; align-items: center; gap: 7px; }
/* ---- section Joueurs & dépenses ---- */
.adm-players { background: var(--surface); border: 1px solid var(--line); border-radius: 10px; padding: 6px 0 4px; margin-bottom: 18px; overflow-x: auto; }
.adm-pl-empty { padding: 16px 18px; font-size: 13px; color: var(--dim); margin: 0; }
.adm-pl-tot { display: flex; gap: 22px; flex-wrap: wrap; padding: 10px 18px 12px; font-size: 13px; color: var(--dim); border-bottom: 1px solid var(--line); }
.adm-pl-tot b { color: var(--text); }
.adm-pl-row { display: grid; grid-template-columns: 64px minmax(150px, 1.5fr) 95px 95px 95px 85px 56px 56px 130px; gap: 10px; align-items: center; padding: 9px 18px; font-size: 13px; min-width: 940px; }
.adm-pl-head { color: var(--dim); font-size: 11px; text-transform: uppercase; letter-spacing: 0.06em; border-bottom: 1px solid var(--line); }
.adm-pl-line { cursor: pointer; border-bottom: 1px solid color-mix(in srgb, var(--line) 50%, transparent); }
.adm-pl-line:hover { background: rgba(255,255,255,0.03); }
.adm-pl-line.open { background: rgba(214,179,106,0.07); }
.adm-pl-num { font-family: var(--font-mono); color: var(--gold); font-weight: 700; }
.adm-pl-who { overflow: hidden; }
.adm-pl-who b { display: block; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.adm-pl-who i { display: block; font-style: normal; font-size: 11.5px; color: var(--dim); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.adm-pl-when { font-size: 12px; color: var(--dim); font-family: var(--font-mono); }
.adm-players .pos { color: #3DD68C; }
.adm-players .neg { color: #FF6B6B; }
/* journal déroulé d'un joueur */
.adm-pl-detail { padding: 4px 18px 12px; border-bottom: 1px solid var(--line); min-width: 880px; }
.adm-ev-list { max-height: 320px; overflow-y: auto; display: flex; flex-direction: column; gap: 2px; }
.adm-ev { display: grid; grid-template-columns: 118px 112px 1fr 95px 85px 95px; gap: 9px; align-items: center; padding: 5px 8px; font-size: 12.5px; border-radius: 6px; }
.adm-ev-eur { text-align: right; }
.adm-ev:nth-child(odd) { background: rgba(255,255,255,0.025); }
.adm-ev-when { color: var(--dim); font-family: var(--font-mono); font-size: 11.5px; }
.adm-ev-label { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.adm-ev b { text-align: right; font-family: var(--font-mono); }
.adm-ev-bal { color: var(--dim); font-size: 11.5px; text-align: right; font-family: var(--font-mono); }
/* composeur IA (haut de l'admin) */
.adm-ai { background: linear-gradient(180deg, rgba(214,179,106,0.09), rgba(214,179,106,0.02)); border: 1px solid rgba(214,179,106,0.38); border-radius: 12px; padding: 15px 18px; margin-bottom: 14px; }
.adm-ai-head b { display: flex; align-items: center; gap: 8px; font-size: 14px; color: var(--gold); }
.adm-ai-head span { display: block; font-size: 12.5px; color: var(--dim); margin-top: 4px; }
.adm-ai-row { display: flex; gap: 12px; align-items: stretch; margin-top: 12px; }
.adm-ai-input { flex: 1; resize: vertical; min-height: 48px; background: var(--bg); border: 1px solid var(--line); border-radius: 9px; padding: 10px 12px; color: var(--text); font: inherit; font-size: 13.5px; line-height: 1.45; }
.adm-ai-input:focus { outline: none; border-color: var(--gold); }
.adm-ai-go { flex-shrink: 0; padding: 12px 22px !important; white-space: nowrap; }
.adm-ai-go:disabled { opacity: 0.6; cursor: wait; }

/* têtes de section numérotées : la page se lit en 3 blocs clairs */
.adm-sec { display: flex; align-items: flex-start; gap: 12px; margin: 34px 0 14px; }
.adm-sec-n {
  width: 28px; height: 28px; flex-shrink: 0; display: grid; place-items: center; border-radius: 50%;
  background: var(--gold); color: #15130B; font-family: var(--font-display); font-weight: 900; font-size: 14px;
}
.adm-sec-t h3 { font-family: var(--font-display); font-size: 17px; font-weight: 800; line-height: 1.3; }
.adm-sec-t span { display: block; font-size: 12.5px; color: var(--dim); margin-top: 2px; max-width: 780px; }

/* zone « Ajouter un pack » : IA et pack vierge au même endroit, en fin de liste */
.adm-create {
  background: linear-gradient(180deg, rgba(214,179,106,0.09), rgba(214,179,106,0.02));
  border: 1.5px dashed rgba(214,179,106,0.45); border-radius: 12px; padding: 15px 18px; margin-top: 14px;
}
.adm-create-head b { display: flex; align-items: center; gap: 8px; font-size: 14px; color: var(--gold); }
.adm-create-head span { display: block; font-size: 12.5px; color: var(--dim); margin-top: 4px; }
.adm-create-btns { display: flex; flex-direction: column; gap: 8px; flex-shrink: 0; }
.adm-create .adm-add { width: auto; margin: 0; padding: 10px 18px; flex: 1; }

/* champs étiquetés + pastilles d'étape dans l'éditeur de pack */
.adm-field { display: flex; flex-direction: column; gap: 4px; }
.adm-field > span { font-family: var(--font-mono); font-size: 9px; font-weight: 700; letter-spacing: 0.09em; color: var(--dim); }
.adm-step {
  display: inline-grid; place-items: center; width: 17px; height: 17px; border-radius: 50%; margin-right: 3px;
  background: color-mix(in srgb, var(--gold) 16%, transparent); border: 1px solid color-mix(in srgb, var(--gold) 50%, transparent);
  color: var(--gold); font-style: normal; font-size: 10px; vertical-align: -3px;
}
.adm-save.dirty { animation: admPulse 1.5s ease-in-out infinite; }
@keyframes admPulse { 0%,100%{ box-shadow: 0 0 0 0 rgba(255,214,10,0); } 50%{ box-shadow: 0 0 0 4px rgba(255,214,10,.18); } }

.adm-list { display: flex; flex-direction: column; gap: 14px; }
/* ===== ADMIN : éditeur de pack (refonte en blocs clairs) ===== */
.adm-pack { display: flex; flex-direction: column; gap: 14px; background: var(--surface); border: 1px solid var(--line); border-radius: 14px; padding: 16px 18px; transition: opacity .2s, border-color .2s; }
.adm-pack.off { opacity: .55; }
.adm-pack.on { border-color: rgba(255,214,10,.32); }
.adm-pack input, .adm-pack select { background: var(--bg); border: 1px solid var(--line); border-radius: 8px; padding: 9px 11px; color: var(--text); font: inherit; font-size: 14px; }
.adm-pack input:focus, .adm-pack select:focus { outline: none; border-color: var(--gold); }

/* en-tête : nom/accroche + actions (pleine largeur) */
.adm-ptop { display: flex; align-items: flex-start; gap: 14px; }
.adm-id { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 8px; }
.adm-id input { width: 100%; }
.adm-id .adm-name { font-weight: 800; font-size: 16px; }
.adm-ptop .adm-toggle { flex-shrink: 0; }
.adm-savepack { flex-shrink: 0; padding: 10px 18px !important; font-size: 13px; }

/* corps : 2 colonnes — booster + design à gauche, gestion à droite */
.adm-cols { display: grid; grid-template-columns: 236px 1fr; gap: 18px; align-items: stretch; }
.adm-left { display: flex; flex-direction: column; gap: 14px; }
.adm-booster { flex: 1; min-height: 300px; display: grid; place-items: center; background: radial-gradient(120% 90% at 50% 0%, rgba(255,255,255,.04), transparent), var(--bg); border: 1px solid var(--line); border-radius: 12px; overflow: hidden; padding: 10px; }
.adm-booster .pack3d { transform: scale(.92); transform-origin: center; flex-shrink: 0; }
.adm-pv-empty { color: var(--dim); font-size: 11px; }
.adm-design { background: var(--bg); border: 1px solid var(--line); border-radius: 10px; padding: 13px 14px; display: flex; flex-direction: column; gap: 10px; }
.adm-right { display: flex; flex-direction: column; gap: 12px; min-width: 0; }
.adm-block { background: var(--bg); border: 1px solid var(--line); border-radius: 10px; padding: 13px 14px; display: flex; flex-direction: column; gap: 10px; }
.adm-bh { font-size: 11px; text-transform: uppercase; letter-spacing: .07em; color: var(--gold); font-weight: 800; }
.adm-bsub { font-size: 12px; color: var(--dim); }
.adm-bsub b { color: var(--text); }
.adm-cards-btn { width: 100%; padding: 12px; background: var(--surface); border: 1px solid var(--line); border-radius: 8px; color: var(--text); font-weight: 700; font-size: 13.5px; cursor: pointer; transition: all .15s; }
.adm-cards-btn:hover { border-color: var(--gold); color: var(--gold); }
.adm-priceline { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.adm-seg { display: inline-flex; background: var(--surface); border: 1px solid var(--line); border-radius: 8px; overflow: hidden; flex-shrink: 0; }
.adm-pm { padding: 8px 13px; background: none; border: none; color: var(--dim); font-weight: 700; font-size: 12.5px; cursor: pointer; }
.adm-pm.sel { background: var(--gold); color: #0B0C10; }
.adm-price-wrap { display: inline-flex; align-items: center; gap: 6px; }
.adm-price-wrap.hidden { display: none; }
.adm-price-wrap input { width: 96px; }
.adm-price-wrap span { font-size: 12px; color: var(--dim); font-weight: 700; }
.adm-margin { font-size: 14px; color: var(--text); line-height: 1.4; }
.adm-margin b { font-weight: 800; }
.adm-m.ok { color: #6BFF8F; } .adm-m.warn { color: var(--gold); } .adm-m.bad { color: #FF4D6D; }
.adm-m-na { color: var(--dim); font-style: italic; }
.adm-promo-line { display: flex; align-items: center; gap: 8px; font-size: 12.5px; color: var(--dim); }
.adm-promo-line input { width: 64px; }

.adm-lbl { font-size: 11px; text-transform: uppercase; letter-spacing: .06em; color: var(--dim); font-weight: 700; }
.adm-ncards { width: 64px; }
/* bande d'aperçu des meilleures cartes du pack */
.adm-cstrip { display: flex; gap: 6px; }
.adm-cmini { width: 46px; aspect-ratio: 63/88; border-radius: 5px; overflow: hidden; border: 1px solid var(--line); background: #0b0c10; flex-shrink: 0; }
.adm-cmini img { width: 100%; height: 100%; object-fit: cover; display: block; }
.adm-cstrip-empty { font-size: 12px; color: var(--dim); font-style: italic; }
.adm-count-badge { font-size: 11px; font-weight: 700; color: var(--dim); background: var(--surface); border: 1px solid var(--line); border-radius: 20px; padding: 1px 8px; margin-left: 6px; letter-spacing: 0; text-transform: none; }
/* ligne réglages : nb cartes + équilibrer + marge */
.adm-rrow { display: flex; align-items: center; flex-wrap: wrap; gap: 10px; }
.adm-lbl-inline { display: inline-flex; align-items: center; gap: 8px; font-size: 12px; color: var(--dim); white-space: nowrap; }

/* bandeau marketing : texte + templates de police + animation (dans Design du sachet) */
.adm-banner { display: flex; flex-direction: column; gap: 9px; padding-top: 11px; border-top: 1px solid var(--line); }
.adm-bn-lbl { font-size: 11px; text-transform: uppercase; letter-spacing: .06em; color: var(--dim); font-weight: 700; }
.adm-bn-text { width: 100%; }
.adm-bn-tpls { display: grid; grid-template-columns: repeat(4, 1fr); gap: 5px; }
.adm-bn-tpl { padding: 9px 4px; background: var(--bg); border: 1px solid var(--line); border-radius: 7px; color: var(--text); cursor: pointer; transition: all .15s; overflow: hidden; display: grid; place-items: center; }
.adm-bn-tpl span { font-size: 13px; line-height: 1; }
.adm-bn-tpl:hover { border-color: var(--dim); }
.adm-bn-tpl.sel { border-color: var(--gold); box-shadow: 0 0 0 1px var(--gold) inset; }
.adm-bn-tpl[data-tpl="gold"] span { font-family: "Anton", sans-serif; color: #E9B949; }
.adm-bn-tpl[data-tpl="fire"] span { font-family: "Bebas Neue", sans-serif; color: #FF7A1A; font-size: 15px; }
.adm-bn-tpl[data-tpl="neon"] span { font-family: "Russo One", sans-serif; color: #7FE9F5; }
.adm-bn-tpl[data-tpl="comic"] span { font-family: "Bangers", cursive; color: #fff; font-size: 15px; letter-spacing: .03em; }
.adm-bn-tpl[data-tpl="script"] span { font-family: "Pacifico", cursive; color: #E9B949; }
.adm-bn-tpl[data-tpl="ribbon"] span { font-family: "Anton", sans-serif; color: #E0A93B; }
.adm-bn-tpl[data-tpl="stamp"] span { font-family: "Bebas Neue", sans-serif; color: #FF5470; font-size: 15px; }
.adm-bn-tpl[data-tpl="clean"] span { font-family: "Manrope", sans-serif; font-weight: 800; color: #fff; font-size: 11px; letter-spacing: .1em; }
.adm-bn-anim { display: inline-flex; align-items: center; gap: 8px; font-size: 12px; color: var(--dim); }
.adm-bn-asel { flex: 1; }

/* pied : déplacer / supprimer */
.adm-foot { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.adm-move { display: flex; gap: 6px; }
.adm-move button { padding: 7px 13px; background: var(--bg); border: 1px solid var(--line); border-radius: 8px; color: var(--dim); cursor: pointer; font-size: 12px; }
.adm-move button:disabled { opacity: .35; cursor: default; }
.adm-move button:not(:disabled):hover { color: var(--text); border-color: var(--dim); }
.adm-del { padding: 8px 14px; background: none; border: 1px solid var(--line); border-radius: 8px; color: var(--dim); font-size: 12px; font-weight: 600; cursor: pointer; transition: all .15s; }
.adm-del:hover { color: #FF4D6D; border-color: #FF4D6D; }
@media (max-width: 820px) { .adm-cols { grid-template-columns: 1fr; } .adm-booster { min-height: 220px; } }

/* répartition des tirages — barre segmentée éditable (poignées draggables) */
.adm-dist { margin: 2px 0 2px; }
.adm-dist-bar { position: relative; display: flex; width: 100%; height: 24px; border-radius: 7px; background: var(--bg); box-shadow: inset 0 0 0 1px var(--line); }
.adm-dist-seg { position: relative; height: 100%; min-width: 0; transition: width .04s linear; }
.adm-dist-seg:first-child { border-radius: 7px 0 0 7px; }
.adm-dist-seg:last-child { border-radius: 0 7px 7px 0; }
.adm-dist-seg.zero { min-width: 0; }
.adm-dist-handle { position: absolute; top: -4px; right: -6px; width: 12px; height: calc(100% + 8px); cursor: ew-resize; z-index: 3; touch-action: none; display: grid; place-items: center; }
.adm-dist-handle::before { content: ""; width: 3px; height: 100%; border-radius: 3px; background: #fff; box-shadow: 0 0 0 1px rgba(0,0,0,0.4), 0 1px 4px rgba(0,0,0,0.5); }
.adm-dist-handle:hover::before { background: var(--gold); }
.adm-dist-leg { display: flex; flex-wrap: wrap; gap: 4px 12px; margin-top: 8px; font-size: 11.5px; color: var(--dim); }
.adm-dist-li { display: inline-flex; align-items: center; gap: 5px; }
.adm-dist-li i { width: 9px; height: 9px; border-radius: 3px; flex-shrink: 0; }
.adm-dist-li b { color: var(--text); font-variant-numeric: tabular-nums; }
.adm-dist-reset { margin-top: 8px; background: none; border: 1px solid var(--line); border-radius: 7px; padding: 5px 10px; color: var(--dim); font-size: 11.5px; font-weight: 600; cursor: pointer; }
.adm-dist-reset:hover { color: var(--gold); border-color: var(--gold); }
.adm-dist-reset.hidden { display: none; }
/* générosité (préréglages) */
.adm-tiers { display: grid; grid-template-columns: repeat(4, 1fr); gap: 6px; }
.adm-tier { display: flex; flex-direction: column; align-items: center; gap: 2px; padding: 7px 4px; background: var(--bg); border: 1px solid var(--line); border-radius: 8px; color: var(--dim);
  cursor: pointer; transition: all .15s; text-align: center; }
.adm-tier b { font-size: 12px; font-weight: 800; }
.adm-tier span { font-size: 9.5px; line-height: 1.1; font-weight: 600; opacity: 0.78; }
.adm-tier:hover { color: var(--text); border-color: var(--dim); }
.adm-tier.sel { background: var(--gold); border-color: var(--gold); color: #0B0C10; }
.adm-tier.sel span { opacity: 0.82; }
.adm-ncards { max-width: 110px; }
/* bloc « éco » : équilibrer la répartition selon prix + nb de cartes */
.adm-eco { display: flex; align-items: center; flex-wrap: wrap; gap: 10px; margin-top: 8px; }
.adm-balance { flex-shrink: 0; background: rgba(214,179,106,0.12); border: 1px solid rgba(214,179,106,0.5); border-radius: 8px; padding: 8px 13px; color: var(--gold); font-weight: 700; font-size: 12.5px; cursor: pointer; transition: all .15s; }
.adm-balance:hover { background: rgba(214,179,106,0.22); }
.adm-eco-m { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; color: var(--dim); white-space: nowrap; }
.adm-eco-m input { width: 56px !important; }

/* habillage (wrap) du sachet : import / IA / retrait */
.adm-hint { font-weight: 500; letter-spacing: 0; text-transform: none; color: var(--dim); opacity: 0.8; margin-left: 6px; }
.adm-wrap { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.adm-wrap-thumb { width: 38px; aspect-ratio: 5 / 8.3; object-fit: cover; border-radius: 5px; border: 1px solid var(--line); }
.adm-wrap-none { font-family: var(--font-mono); font-size: 10px; color: var(--dim); }
.adm-wrap-btns { display: flex; gap: 6px; flex-wrap: wrap; }
.adm-wbtn {
  padding: 7px 11px; border-radius: 7px; cursor: pointer;
  font-family: var(--font-display); font-size: 11.5px; font-weight: 700;
  background: transparent; border: 1px solid var(--line); color: var(--text);
  transition: border-color 0.15s, color 0.15s;
}
.adm-wbtn:hover { border-color: var(--gold); color: var(--gold); }
.adm-ai-prompt { width: 100%; resize: vertical; margin: 10px 0 6px; }
.adm-ai-actions { display: flex; align-items: center; gap: 12px; }
.adm-ai-status { font-size: 12px; color: var(--dim); }
.adm-ai-preview { margin-top: 14px; display: flex; align-items: flex-start; gap: 16px; }
.adm-ai-pv { width: 150px; flex-shrink: 0; }
.adm-ai-side { flex: 1; display: flex; flex-direction: column; gap: 10px; align-items: flex-start; min-width: 0; }
/* la direction artistique tirée au sort : l'admin voit ce que le dé a donné */
.adm-ai-dir { font-size: 12px; color: var(--dim); line-height: 1.5; }
/* toggle « Mode délire » : direction artistique aléatoire à chaque rendu */
.adm-wild { display: flex; align-items: baseline; gap: 8px; margin-bottom: 12px; cursor: pointer; flex-wrap: wrap; }
.adm-wild input { accent-color: var(--gold); cursor: pointer; }
.adm-wild b { font-size: 13px; color: var(--text); white-space: nowrap; }
.adm-wild:has(input:checked) b { color: var(--gold); }

/* ---- covers des cartes CARDS (recharge) : section admin + modale IA saisons ---- */
/* ---- éditeur des offres de recharge ---- */
.adm-offers { display: grid; grid-template-columns: repeat(auto-fill, minmax(290px, 1fr)); gap: 12px; margin-bottom: 18px; }
.adm-offer {
  display: flex; gap: 13px; align-items: flex-start;
  background: var(--surface); border: 1px solid var(--line); border-radius: 10px; padding: 13px;
}
.adm-offer-card { width: 84px; flex-shrink: 0; pointer-events: none; }
.adm-offer-fields { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 7px; }
.adm-offer-fields label {
  display: flex; flex-direction: column; gap: 3px;
  font-family: var(--font-mono); font-size: 8.5px; font-weight: 700; letter-spacing: 0.08em; color: var(--dim);
}
.adm-offer-fields input {
  font: inherit; font-size: 13px; color: var(--text);
  background: rgba(0,0,0,0.25); border: 1px solid var(--line); border-radius: 7px; padding: 6px 9px; width: 100%;
}
.adm-offer-fields input:focus { outline: none; border-color: rgba(214,179,106,0.5); }
.adm-offer-foot { display: flex; align-items: center; gap: 8px; }
.adm-offer-hot {
  appearance: none; cursor: pointer; font-family: var(--font-mono); font-size: 8.5px; font-weight: 700; letter-spacing: 0.06em;
  color: var(--dim); background: rgba(255,255,255,0.04); border: 1px solid var(--line); border-radius: 10px; padding: 3px 9px;
}
.adm-offer-hot.on { color: #15130B; background: var(--gold); border-color: var(--gold); }
.adm-offer-bonus { font-size: 10.5px; color: var(--dim); flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.adm-offer-del {
  appearance: none; cursor: pointer; width: 24px; height: 24px; border-radius: 50%;
  background: rgba(255,107,107,0.1); border: 1px solid rgba(255,107,107,0.35); color: #FF6B6B;
  font-size: 14px; line-height: 1; flex-shrink: 0;
}
.adm-offer-del:hover { background: rgba(255,107,107,0.22); }
.adm-offer-custom { border-color: rgba(61,214,140,0.35); background: linear-gradient(180deg, rgba(61,214,140,0.05), var(--surface)); }
.adm-offer-fixed b { font-size: 12.5px; color: #3DD68C; letter-spacing: 0.04em; }
.adm-offer-fixed span { font-size: 11.5px; color: var(--dim); line-height: 1.55; }
.adm-offer-add { align-self: center; justify-self: start; }
.adm-skins {
  background: linear-gradient(180deg, rgba(214,179,106,0.07), rgba(214,179,106,0.015));
  border: 1px solid rgba(214,179,106,0.3); border-radius: 12px; padding: 15px 18px; margin-bottom: 14px;
}
.adm-skins-txt b { display: flex; align-items: center; gap: 8px; font-size: 14px; color: var(--gold); }
.adm-skins-txt span { display: block; font-size: 12.5px; color: var(--dim); margin-top: 4px; max-width: 760px; }
.adm-skins-row { display: flex; gap: 14px; align-items: stretch; margin-top: 14px; flex-wrap: wrap; }
.adm-skin {
  display: flex; flex-direction: column; align-items: center; gap: 7px;
  background: var(--bg); border: 1.5px solid var(--line); border-radius: 12px; padding: 10px 12px;
  cursor: pointer; transition: border-color 0.18s, transform 0.15s, box-shadow 0.18s;
}
.adm-skin:hover { transform: translateY(-2px); border-color: color-mix(in srgb, var(--gold) 45%, transparent); }
.adm-skin.sel { border-color: var(--gold); box-shadow: 0 0 0 1px var(--gold), 0 8px 22px color-mix(in srgb, var(--gold) 20%, transparent); }
.adm-skin-card { width: 96px; pointer-events: none; }
.adm-skin-lbl { font-family: var(--font-mono); font-size: 10px; font-weight: 700; letter-spacing: 0.05em; color: var(--dim); }
.adm-skin.sel .adm-skin-lbl { color: var(--gold); }
.adm-skin-all { justify-content: center; min-width: 96px; text-align: center; color: var(--dim); font-family: var(--font-display); font-weight: 800; font-size: 12.5px; line-height: 1.3; }
.adm-skin-all .adm-skin-allico { font-size: 22px; color: var(--gold); }
.adm-skin-all.sel { color: var(--text); }
.adm-skins-acts { display: flex; align-items: center; gap: 9px; margin-top: 14px; flex-wrap: wrap; }
.adm-skins-target { font-size: 12.5px; color: var(--dim); margin-right: 4px; }
.adm-skins-target b { color: var(--gold); }
.adm-seasons { display: flex; gap: 7px; flex-wrap: wrap; margin-top: 12px; }
.adm-season {
  padding: 6px 12px; border-radius: 999px; cursor: pointer;
  background: var(--bg); border: 1px solid var(--line); color: var(--text);
  font-family: var(--font-display); font-weight: 700; font-size: 12.5px;
  transition: border-color 0.15s, background 0.15s, transform 0.12s;
}
.adm-season:hover { border-color: var(--gold); transform: translateY(-1px); }
.adm-season.sel { background: color-mix(in srgb, var(--gold) 16%, transparent); border-color: var(--gold); color: var(--gold); }
.adm-skin-pvrow { display: flex; gap: 10px; flex-wrap: wrap; flex: 1; }
.adm-skin-pv { width: 104px; }

.adm-toggle { display: flex; align-items: center; gap: 8px; padding: 9px 12px; background: var(--bg); border: 1px solid var(--line);
  border-radius: 99px; color: var(--dim); font-size: 11.5px; font-weight: 800; letter-spacing: .03em; cursor: pointer; transition: all .18s; }
.adm-knob { width: 30px; height: 18px; border-radius: 99px; background: var(--line); position: relative; flex-shrink: 0; transition: background .18s; }
.adm-knob::after { content: ""; position: absolute; top: 2px; left: 2px; width: 14px; height: 14px; border-radius: 50%; background: var(--dim); transition: transform .18s, background .18s; }
.adm-toggle.on { background: rgba(255,214,10,.12); border-color: var(--gold); color: var(--gold); }
.adm-toggle.on .adm-knob { background: var(--gold); }
.adm-toggle.on .adm-knob::after { transform: translateX(12px); background: #0B0C10; }

.adm-add { width: 100%; margin-top: 14px; padding: 18px; background: none; border: 1.5px dashed var(--line); border-radius: 12px;
  color: var(--dim); font-size: 14px; font-weight: 700; cursor: pointer; transition: all .18s; }
.adm-add:hover { border-color: var(--gold); color: var(--gold); }

.acc-admin { color: var(--gold) !important; font-weight: 700; }

/* admin : sélecteur de cartes d'un pack (inclure / exclure) */
.cardpick-back { position: fixed; inset: 0; z-index: 1100; background: rgba(5,6,10,0.85); backdrop-filter: blur(10px); display: grid; place-items: center; padding: 18px; }
.cardpick { width: min(1080px, 96vw); height: 90vh; display: flex; flex-direction: column; background: var(--surface); border: 1px solid var(--line); border-radius: 14px; overflow: hidden; }
/* médiathèque (habillages enregistrés en IndexedDB) */
.assetlib { width: min(920px, 96vw); height: 84vh; }
.assetlib-grid { flex: 1; overflow-y: auto; padding: 16px; display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 14px; align-content: start; }
.al-item { display: flex; flex-direction: column; gap: 7px; background: var(--bg); border: 1px solid var(--line); border-radius: 10px; padding: 8px; }
.al-thumb { aspect-ratio: 5 / 8.3; border-radius: 7px; overflow: hidden; background: #0b0c10; border: 1px solid var(--line); }
.al-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.al-name { width: 100%; background: var(--surface); border: 1px solid var(--line); border-radius: 6px; padding: 5px 7px; color: var(--text); font: inherit; font-size: 11.5px; }
.al-name:focus { outline: none; border-color: var(--gold); }
.al-acts { display: flex; gap: 6px; }
.al-use { flex: 1; padding: 6px; background: var(--gold); border: none; border-radius: 6px; color: #0B0C10; font-weight: 800; font-size: 11.5px; cursor: pointer; }
.al-use:hover { filter: brightness(1.05); }
.al-del { width: 30px; flex-shrink: 0; background: var(--surface); border: 1px solid var(--line); border-radius: 6px; color: var(--dim); cursor: pointer; }
.al-del:hover { color: #FF4D6D; border-color: #FF4D6D; }
.cardpick-head { display: flex; align-items: center; gap: 12px; padding: 13px 16px; border-bottom: 1px solid var(--line); flex-wrap: wrap; }
.cardpick-title { font-size: 14px; flex-shrink: 0; font-weight: 800; }
.cardpick-src { flex-shrink: 0; background: var(--bg); border: 1px solid var(--line); border-radius: 8px; padding: 8px 10px; color: var(--text); font: inherit; font-size: 13px; font-weight: 600; cursor: pointer; max-width: 220px; }
.cardpick-src:focus { outline: none; border-color: var(--gold); }
.cardpick-search { flex: 1; min-width: 150px; background: var(--bg); border: 1px solid var(--line); border-radius: 8px; padding: 8px 11px; color: var(--text); font: inherit; font-size: 13px; }
.cardpick-search:focus { outline: none; border-color: var(--gold); }
.cardpick-count { font-size: 12px; color: var(--dim); font-weight: 600; white-space: nowrap; }
.cardpick-mini { padding: 7px 11px; background: var(--bg); border: 1px solid var(--line); border-radius: 8px; color: var(--dim); font-size: 12px; font-weight: 600; cursor: pointer; }
.cardpick-mini:hover { color: var(--text); border-color: var(--dim); }
.cardpick-save { padding: 8px 16px !important; }
.cardpick-x { background: none; border: none; color: var(--dim); font-size: 17px; cursor: pointer; padding: 4px 8px; }
.cardpick-x:hover { color: var(--text); }
/* grille virtualisée : le conteneur scrolle, .cp-view est le spacer, les tuiles sont
   positionnées en absolu (left/top) — seules les visibles existent dans le DOM. */
.cardpick-grid { position: relative; flex: 1; overflow-y: auto; overflow-x: hidden; padding: 0; background: var(--bg); }
.cardpick-grid::-webkit-scrollbar { width: 10px; }
.cardpick-grid::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.12); border-radius: 8px; border: 3px solid transparent; background-clip: padding-box; }
.cp-view { position: relative; width: 100%; }
.cp-card { position: absolute; top: 0; left: 0; border-radius: 10px; overflow: hidden; cursor: pointer; border: 2px solid transparent; background: #0b0c10; box-shadow: 0 2px 6px rgba(0,0,0,0.45); transition: transform .14s ease, box-shadow .15s, opacity .15s, filter .15s; will-change: transform; }
.cp-card img { width: 100%; height: 100%; object-fit: cover; display: block; }
.cp-card.in { border-color: rgba(214,179,106,0.85); }
.cp-card.out { opacity: 0.3; filter: grayscale(0.85); }
.cp-card:hover { transform: translateY(-5px) scale(1.05); box-shadow: 0 12px 30px rgba(0,0,0,0.6); z-index: 6; }
.cp-val { position: absolute; bottom: 0; left: 0; right: 0; font-family: var(--font-block,"Anton"); font-size: 13px; letter-spacing: .01em; color: #fff; background: linear-gradient(0deg, rgba(0,0,0,0.9), rgba(0,0,0,0.55) 55%, transparent); text-align: center; padding: 14px 4px 5px; pointer-events: none; }
.cp-tick { position: absolute; top: 6px; right: 6px; width: 20px; height: 20px; border-radius: 50%; background: var(--gold); color: #0B0C10; display: grid; place-items: center; box-shadow: 0 1px 4px rgba(0,0,0,0.5); pointer-events: none; }
.cp-card.out .cp-tick { display: none; }
.cp-card.out::after { content: ""; position: absolute; inset: 0; background: rgba(255,77,109,0.12); }
.cardpick-empty { position: absolute; inset: 0; display: grid; place-items: center; text-align: center; color: var(--dim); padding: 40px; }

/* admin : générateur de sélection (prix de vente + marge → propose les cartes) */
.cpg { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; padding: 12px 16px; border-bottom: 1px solid var(--line); background: var(--bg); }
.cpg-lbl { font-family: var(--font-display); font-weight: 800; font-size: 11.5px; letter-spacing: .05em; color: var(--gold); text-transform: uppercase; }
.cpg-field { font-size: 12.5px; color: var(--dim); display: inline-flex; align-items: center; gap: 6px; }
.cpg-field input { width: 72px; background: var(--surface); border: 1px solid var(--line); border-radius: 7px; padding: 6px 8px; color: var(--text); font: inherit; font-size: 13px; }
.cpg-field input:focus { outline: none; border-color: var(--gold); }
.cpg-go { padding: 7px 14px !important; font-size: 12.5px; }
.cpg-readout { font-size: 12.5px; color: var(--dim); margin-left: auto; }
.cpg-m.ok { color: #6BFF8F; } .cpg-m.warn { color: var(--gold); } .cpg-m.bad { color: #FF4D6D; }

@media (max-width: 760px) {
  .adm-pack { grid-template-columns: 1fr; }
  .adm-pv { border-right: none; border-bottom: 1px solid var(--line); padding: 0 0 12px; }
  .adm-side { border-left: none; padding-left: 0; flex-direction: row; flex-wrap: wrap; align-items: center; }
  .adm-side .adm-toggle { flex: 1; }
}
