/* ═══════════════════════════════════════════════════════════════
   DIAMOND PULLS v2 — styles.css
   Stadium-night dark theme. Bebas Neue + Nunito.
   ═══════════════════════════════════════════════════════════════ */

/* ── Type Scale ─────────────────────────────────────────────── */
:root {
  --text-xs:   clamp(0.75rem,  0.7rem  + 0.25vw, 0.875rem);
  --text-sm:   clamp(0.875rem, 0.8rem  + 0.35vw, 1rem);
  --text-base: clamp(1rem,     0.95rem + 0.25vw, 1.125rem);
  --text-lg:   clamp(1.125rem, 1rem    + 0.75vw, 1.5rem);
  --text-xl:   clamp(1.5rem,   1.2rem  + 1.25vw, 2.25rem);
  --text-2xl:  clamp(2rem,     1.2rem  + 2.5vw,  3.5rem);
  --text-hero: clamp(4rem,     1rem    + 9vw,     10rem);
}

/* ── Spacing ────────────────────────────────────────────────── */
:root {
  --sp-1: 0.25rem; --sp-2: 0.5rem; --sp-3: 0.75rem;
  --sp-4: 1rem;    --sp-5: 1.25rem; --sp-6: 1.5rem;
  --sp-8: 2rem;    --sp-10: 2.5rem; --sp-12: 3rem;
  --sp-16: 4rem;   --sp-20: 5rem;
}

/* ── Color Palette: Stadium Night ───────────────────────────── */
:root {
  /* Deep stadium backgrounds */
  --bg-void:      #050810;
  --bg-deep:      #080d1a;
  --bg-surface:   #0e1528;
  --bg-elevated:  #141e35;
  --bg-card:      #111826;
  --bg-card-high: #18243a;

  /* Field green */
  --green-deep:   #0d3320;
  --green-mid:    #145c38;
  --green-bright: #1a8048;
  --green-glow:   rgba(26, 128, 72, 0.35);

  /* Text */
  --txt-primary:  #e8edf5;
  --txt-secondary:#8a96b0;
  --txt-muted:    #4a5470;
  --txt-white:    #ffffff;

  /* Rarity palette — each distinct, vivid */
  --common:       #6b7a99;
  --common-glow:  rgba(107, 122, 153, 0.2);
  --rare:         #2563eb;
  --rare-light:   #60a5fa;
  --rare-glow:    rgba(37, 99, 235, 0.3);
  --epic:         #7c3aed;
  --epic-light:   #c084fc;
  --epic-glow:    rgba(124, 58, 237, 0.4);
  --legendary:    #d97706;
  --legendary-lt: #fbbf24;
  --legendary-glow: rgba(217, 119, 6, 0.5);

  /* Accent - stadium gold */
  --accent:       #f59e0b;
  --accent-glow:  rgba(245, 158, 11, 0.4);

  /* UI */
  --border:       rgba(255,255,255,0.07);
  --border-mid:   rgba(255,255,255,0.12);
  --radius-sm:    6px;
  --radius-md:    12px;
  --radius-lg:    18px;
  --radius-xl:    24px;
  --radius-card:  20px;

  /* Fonts */
  --font-display: 'Bebas Neue', 'Arial Black', sans-serif;
  --font-body:    'Nunito', 'Helvetica Neue', sans-serif;

  /* Motion */
  --ease-out:    cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in:     cubic-bezier(0.4, 0, 1, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
  --t-fast:  180ms;
  --t-mid:   300ms;
  --t-slow:  500ms;

  /* Safe areas */
  --safe-t: env(safe-area-inset-top,    0px);
  --safe-b: env(safe-area-inset-bottom, 0px);
  --safe-l: env(safe-area-inset-left,   0px);
  --safe-r: env(safe-area-inset-right,  0px);
}

/* ── Base Reset ─────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html {
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  scroll-behavior: smooth;
  touch-action: manipulation;
  height: 100%;
}
body {
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--txt-primary);
  background: var(--bg-void);
  min-height: 100dvh;
  overflow-x: hidden;
  overscroll-behavior: none;
  position: relative;
}
img, svg { display: block; max-width: 100%; }
button  { cursor: pointer; border: none; background: none; font: inherit; color: inherit; -webkit-tap-highlight-color: transparent; }
select  { font: inherit; color: inherit; cursor: pointer; }
input   { font: inherit; }
.hidden { display: none !important; }


/* ══════════════════════════════════════════════════════════════
   STADIUM CANVAS (background layer)
══════════════════════════════════════════════════════════════ */
#stadium-canvas, #confetti-canvas {
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 0;
}
#stadium-canvas { z-index: 0; }
#confetti-canvas { z-index: 900; }


/* ══════════════════════════════════════════════════════════════
   SCREEN SYSTEM
══════════════════════════════════════════════════════════════ */
.screen {
  position: fixed;
  inset: 0;
  display: flex;
  flex-direction: column;
  pointer-events: none;
  opacity: 0;
  transition: opacity 350ms var(--ease-out);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  z-index: 10;
}
.screen.active {
  pointer-events: auto;
  opacity: 1;
}
.screen.exiting {
  opacity: 0;
  transition: opacity 220ms var(--ease-in);
  pointer-events: none;
}


/* ══════════════════════════════════════════════════════════════
   STADIUM LIGHTS
══════════════════════════════════════════════════════════════ */
.stadium-lights {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: 320px;
  pointer-events: none;
  z-index: 1;
  overflow: hidden;
}
.light-beam {
  position: absolute;
  top: -60px;
  width: 3px;
  height: 320px;
  background: linear-gradient(180deg, rgba(255,240,180,0.12) 0%, transparent 100%);
  transform-origin: top center;
}
.lb-1 { left: 10%; transform: rotate(-18deg); animation: beam-sway 8s ease-in-out infinite; }
.lb-2 { left: 28%; transform: rotate(-8deg);  animation: beam-sway 10s ease-in-out infinite 1s; }
.lb-3 { right: 28%; transform: rotate(8deg);  animation: beam-sway 9s ease-in-out infinite 0.5s; }
.lb-4 { right: 10%; transform: rotate(18deg); animation: beam-sway 11s ease-in-out infinite 2s; }
@keyframes beam-sway {
  0%, 100% { opacity: 0.6; transform: rotate(var(--r, -10deg)) scaleX(1); }
  50%       { opacity: 1;   transform: rotate(calc(var(--r, -10deg) + 4deg)) scaleX(1.5); }
}
.lb-1 { --r: -18deg; }
.lb-2 { --r: -8deg; }
.lb-3 { --r: 8deg; }
.lb-4 { --r: 18deg; }


/* ══════════════════════════════════════════════════════════════
   SCOREBOARD HEADER
══════════════════════════════════════════════════════════════ */
.scoreboard-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 50;
  padding-top: var(--safe-t);
  background: linear-gradient(180deg, rgba(5,8,16,0.95) 0%, transparent 100%);
}
.scoreboard-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--sp-3) var(--sp-6);
  max-width: 900px;
  margin: 0 auto;
}
.score-segment {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  min-width: 48px;
}
.score-label {
  font-family: var(--font-display);
  font-size: 9px;
  letter-spacing: 3px;
  color: var(--txt-muted);
}
.score-val {
  font-family: var(--font-display);
  font-size: 22px;
  letter-spacing: 2px;
  color: var(--accent);
  line-height: 1;
}
.scoreboard-logo {
  flex: 1;
  display: flex;
  justify-content: center;
}
.logo-svg {
  height: 48px;
  width: auto;
  color: var(--txt-primary);
}


/* ══════════════════════════════════════════════════════════════
   HERO SCREEN
══════════════════════════════════════════════════════════════ */
#screen-hero {
  justify-content: center;
  align-items: center;
  min-height: 100dvh;
  padding: calc(80px + var(--safe-t)) var(--sp-6) calc(var(--sp-8) + var(--safe-b));
}

/* Field grass effect at bottom */
.grass-overlay {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  height: 140px;
  background: linear-gradient(0deg,
    rgba(13, 51, 32, 0.7) 0%,
    rgba(13, 51, 32, 0.4) 40%,
    transparent 100%
  );
  pointer-events: none;
  z-index: 1;
}

.hero-stage {
  position: relative;
  z-index: 5;
  display: flex;
  justify-content: center;
  width: 100%;
}

.hero-center {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--sp-6);
  max-width: 640px;
  width: 100%;
}

.hero-eyebrow {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--txt-secondary);
  letter-spacing: 0.5px;
}

.hero-headline {
  display: flex;
  flex-direction: column;
  align-items: center;
  line-height: 0.88;
  user-select: none;
}
.hl-line {
  display: block;
  font-family: var(--font-display);
  letter-spacing: 4px;
  color: var(--txt-white);
  text-shadow:
    0 0 40px rgba(245,158,11,0.2),
    0 2px 0 rgba(0,0,0,0.5);
}
.hl-1 {
  font-size: clamp(5rem, 18vw, 11rem);
  background: linear-gradient(160deg, #fff 30%, #c8d0e8 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.hl-2 {
  font-size: clamp(3rem, 12vw, 8rem);
  background: linear-gradient(160deg, var(--accent) 0%, #fbbf24 50%, var(--accent) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: headline-glow 3s ease-in-out infinite;
}
@keyframes headline-glow {
  0%, 100% { filter: brightness(1); }
  50%       { filter: brightness(1.15); }
}

.hero-sub {
  font-size: var(--text-base);
  color: var(--txt-secondary);
  max-width: 360px;
  line-height: 1.5;
}


/* ── Pack Chooser ────────────────────────────────────────────── */
.pack-chooser {
  display: flex;
  gap: var(--sp-4);
  width: 100%;
  justify-content: center;
}

.pack-tile {
  flex: 1;
  max-width: 180px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-4) var(--sp-3);
  background: var(--bg-surface);
  border: 2px solid var(--border);
  border-radius: var(--radius-lg);
  transition:
    border-color var(--t-mid) var(--ease-out),
    background var(--t-mid) var(--ease-out),
    transform var(--t-mid) var(--ease-spring),
    box-shadow var(--t-mid) var(--ease-out);
  user-select: none;
  -webkit-tap-highlight-color: transparent;
}
.pack-tile:hover { transform: translateY(-3px); }
.pack-tile.selected {
  border-color: var(--accent);
  background: rgba(245,158,11,0.08);
  box-shadow: 0 0 24px rgba(245,158,11,0.18), 0 4px 20px rgba(0,0,0,0.4);
}
.pack-tile.selected .pack-tile-name { color: var(--accent); }

.pack-tile-art {
  height: 80px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* 3D pack shape */
.pack-wrapper { perspective: 200px; }
.pack-3d {
  width: 52px;
  height: 72px;
  position: relative;
  transform-style: preserve-3d;
  animation: pack-float 4s ease-in-out infinite;
}
.pack-tile.selected .pack-3d { animation: pack-float-selected 3s ease-in-out infinite; }
@keyframes pack-float {
  0%,100% { transform: rotateY(-10deg) rotateX(5deg) translateY(0); }
  50%      { transform: rotateY(10deg) rotateX(-3deg) translateY(-4px); }
}
@keyframes pack-float-selected {
  0%,100% { transform: rotateY(-12deg) rotateX(5deg) translateY(0); }
  50%      { transform: rotateY(12deg) rotateX(-5deg) translateY(-6px); }
}

.pack-face {
  position: absolute;
  border-radius: 6px;
}
.pack-front {
  width: 52px; height: 72px;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 4px;
  border: 1.5px solid rgba(255,255,255,0.15);
  transform: translateZ(5px);
  background: linear-gradient(145deg, #1a2540 0%, #0d1525 100%);
}
.pack-art-standard .pack-front { background: linear-gradient(145deg, #1e2d4a, #0e1a2e); border-color: rgba(59,130,246,0.4); }
.pack-art-premium  .pack-front { background: linear-gradient(145deg, #231a40, #120f26); border-color: rgba(124,58,237,0.5); }
.pack-art-legendary .pack-front { background: linear-gradient(145deg, #3d2a0a, #1e1204); border-color: rgba(245,158,11,0.6); }

.pack-back {
  width: 52px; height: 72px;
  background: rgba(0,0,0,0.6);
  transform: translateZ(-5px);
  border-radius: 6px;
}
.pack-side {
  width: 10px; height: 72px;
  right: -5px; top: 0;
  background: rgba(255,255,255,0.05);
  transform: rotateY(90deg) translateZ(26px);
}
.pack-emoji  { font-size: 24px; line-height: 1; }
.pack-face-name {
  font-family: var(--font-display);
  font-size: 9px;
  letter-spacing: 2px;
  color: rgba(255,255,255,0.6);
}

.pack-tile-info { text-align: center; }
.pack-tile-name {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  letter-spacing: 1px;
  color: var(--txt-primary);
  transition: color var(--t-fast);
}
.pack-tile-cards {
  font-size: var(--text-xs);
  color: var(--txt-muted);
  margin-top: var(--sp-1);
}
.pack-tile-guarantee {
  font-size: var(--text-xs);
  color: var(--accent);
  font-weight: 700;
  margin-top: var(--sp-1);
}
.pack-tile.selected .pack-art-premium  { filter: drop-shadow(0 0 12px rgba(124,58,237,0.5)); }
.pack-tile.selected .pack-art-legendary { filter: drop-shadow(0 0 16px rgba(245,158,11,0.6)); }


/* ── CTA Buttons ─────────────────────────────────────────────── */
.rip-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-4) var(--sp-10);
  background: linear-gradient(135deg, var(--accent), #d97706);
  color: #000;
  font-family: var(--font-display);
  font-size: var(--text-xl);
  letter-spacing: 2px;
  border-radius: var(--radius-xl);
  box-shadow: 0 6px 32px rgba(245,158,11,0.35), 0 2px 0 rgba(0,0,0,0.3) inset;
  transition:
    transform var(--t-mid) var(--ease-spring),
    box-shadow var(--t-mid) var(--ease-out),
    filter var(--t-mid);
  white-space: nowrap;
}
.rip-btn:hover {
  transform: translateY(-3px) scale(1.02);
  box-shadow: 0 10px 44px rgba(245,158,11,0.5), 0 2px 0 rgba(0,0,0,0.3) inset;
  filter: brightness(1.05);
}
.rip-btn:active {
  transform: scale(0.97);
  box-shadow: 0 3px 16px rgba(245,158,11,0.25);
}
.rip-btn-icon { width: 22px; height: 22px; stroke-width: 3; }

.reveal-next-btn { padding: var(--sp-4) var(--sp-8); font-size: var(--text-lg); }

.ghost-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-3) var(--sp-5);
  background: rgba(255,255,255,0.06);
  border: 1.5px solid var(--border-mid);
  border-radius: var(--radius-lg);
  color: var(--txt-secondary);
  font-size: var(--text-sm);
  font-weight: 700;
  transition:
    color var(--t-fast),
    background var(--t-fast),
    border-color var(--t-fast),
    transform var(--t-mid) var(--ease-spring);
}
.ghost-btn:hover {
  color: var(--txt-primary);
  background: rgba(255,255,255,0.1);
  border-color: rgba(255,255,255,0.22);
  transform: translateY(-1px);
}
.ghost-btn:active { transform: scale(0.97); }

.hero-nav-row {
  display: flex;
  gap: var(--sp-3);
  flex-wrap: wrap;
  justify-content: center;
}

.nav-badge {
  background: var(--accent);
  color: #000;
  font-size: 10px;
  font-weight: 800;
  min-width: 20px;
  height: 20px;
  border-radius: 10px;
  padding: 0 5px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* Floating mini card ticker — only visible on hero screen */
.card-ticker {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  height: 48px;
  overflow: hidden;
  pointer-events: none;
  z-index: 2;
  opacity: 0;
  transition: opacity 0.4s ease;
  mask-image: linear-gradient(90deg, transparent, black 10%, black 90%, transparent);
  -webkit-mask-image: linear-gradient(90deg, transparent, black 10%, black 90%, transparent);
}
#screen-hero.active .card-ticker {
  opacity: 0.4;
}
.ticker-inner {
  display: flex;
  gap: var(--sp-6);
  white-space: nowrap;
  animation: ticker-scroll 30s linear infinite;
  padding: var(--sp-3) 0;
}
@keyframes ticker-scroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
.ticker-item {
  font-family: var(--font-display);
  font-size: 13px;
  letter-spacing: 2px;
  color: var(--txt-muted);
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}
.ticker-item-rarity { color: var(--accent); }


/* ══════════════════════════════════════════════════════════════
   PACK OPENING SCREEN
══════════════════════════════════════════════════════════════ */
#screen-opening {
  justify-content: center;
  align-items: center;
  min-height: 100dvh;
  padding: calc(var(--sp-12) + var(--safe-t)) var(--sp-5) calc(var(--sp-8) + var(--safe-b));
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

.open-phase {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-6);
  width: 100%;
  max-width: 500px;
}
.open-phase.hidden { display: none; }

.phase-eyebrow {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  letter-spacing: 4px;
  color: var(--txt-secondary);
}


/* ── Mega Pack ───────────────────────────────────────────────── */
.mega-pack {
  position: relative;
  cursor: pointer;
  outline: none;
  -webkit-tap-highlight-color: transparent;
  transition: transform var(--t-mid) var(--ease-spring);
}
.mega-pack:hover .mega-pack-body  { transform: translateY(-8px) scale(1.03); }
.mega-pack:focus-visible .mega-pack-body { outline: 3px solid var(--accent); outline-offset: 8px; }

.mega-pack-body {
  width: 220px;
  height: 320px;
  border-radius: 20px;
  position: relative;
  overflow: hidden;
  background: linear-gradient(160deg, #1a2540 0%, #0a1020 60%, #050810 100%);
  border: 2px solid rgba(245,158,11,0.3);
  box-shadow:
    0 20px 60px rgba(0,0,0,0.7),
    0 0 0 1px rgba(255,255,255,0.04) inset,
    0 0 80px rgba(245,158,11,0.08);
  transition: transform 0.4s var(--ease-spring), box-shadow 0.4s var(--ease-out);
  animation: mega-breathe 4s ease-in-out infinite;
}
@keyframes mega-breathe {
  0%,100% { box-shadow: 0 20px 60px rgba(0,0,0,0.7), 0 0 0 1px rgba(255,255,255,0.04) inset, 0 0 60px rgba(245,158,11,0.08); }
  50%      { box-shadow: 0 24px 80px rgba(0,0,0,0.7), 0 0 0 1px rgba(255,255,255,0.04) inset, 0 0 100px rgba(245,158,11,0.18); }
}

/* Holographic foil texture */
.mega-foil {
  position: absolute;
  inset: 0;
  background:
    repeating-linear-gradient(
      -45deg,
      transparent,
      transparent 6px,
      rgba(255,255,255,0.015) 6px,
      rgba(255,255,255,0.015) 7px
    );
}
.mega-shine {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    135deg,
    transparent 20%,
    rgba(255,255,255,0.06) 42%,
    rgba(255,255,255,0.16) 50%,
    rgba(255,255,255,0.06) 58%,
    transparent 80%
  );
  animation: shine-sweep 2.2s ease-in-out infinite;
}
@keyframes shine-sweep {
  0%   { transform: translateX(-180%) translateY(-80%); }
  60%  { transform: translateX(180%) translateY(80%); }
  100% { transform: translateX(180%) translateY(80%); }
}

.mega-pack-logo {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -60%);
  font-size: 72px;
  filter: drop-shadow(0 4px 20px rgba(245,158,11,0.4));
  animation: logo-pulse 3s ease-in-out infinite;
}
@keyframes logo-pulse {
  0%,100% { filter: drop-shadow(0 4px 20px rgba(245,158,11,0.4)); transform: translate(-50%, -60%) scale(1); }
  50%      { filter: drop-shadow(0 4px 40px rgba(245,158,11,0.7)); transform: translate(-50%, -60%) scale(1.06); }
}

.mega-pack-name {
  position: absolute;
  bottom: 60px;
  left: 0; right: 0;
  text-align: center;
  font-family: var(--font-display);
  font-size: 28px;
  letter-spacing: 5px;
  color: var(--accent);
  text-shadow: 0 0 20px rgba(245,158,11,0.5);
}
.mega-pack-year {
  position: absolute;
  bottom: 40px;
  left: 0; right: 0;
  text-align: center;
  font-size: 10px;
  letter-spacing: 3px;
  color: rgba(255,255,255,0.3);
  font-weight: 700;
}
.mega-notch-top {
  position: absolute;
  top: 0; right: 28px;
  width: 22px; height: 10px;
  background: rgba(245,158,11,0.5);
  border-radius: 0 0 10px 10px;
}
.mega-stripe {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 10px;
  background: linear-gradient(90deg, var(--legendary), #fbbf24, var(--legendary));
  background-size: 200% 100%;
  animation: gold-flow 2s linear infinite;
}
@keyframes gold-flow {
  0%   { background-position: 0% 0%; }
  100% { background-position: 200% 0%; }
}

/* Pack rarity variants */
#mega-pack[data-rarity="premium"] .mega-pack-body {
  background: linear-gradient(160deg, #1e1040 0%, #0d0820 100%);
  border-color: rgba(124,58,237,0.4);
  box-shadow: 0 20px 60px rgba(0,0,0,0.7), 0 0 80px rgba(124,58,237,0.12);
}
#mega-pack[data-rarity="premium"] .mega-pack-name { color: var(--epic-light); text-shadow: 0 0 20px rgba(124,58,237,0.5); }
#mega-pack[data-rarity="legendary"] .mega-pack-body {
  background: linear-gradient(160deg, #3d2508 0%, #1a0d02 100%);
  border-color: rgba(245,158,11,0.6);
  box-shadow: 0 20px 80px rgba(0,0,0,0.7), 0 0 120px rgba(245,158,11,0.25);
}

/* Tear animation */
.mega-pack.tearing .mega-pack-body {
  animation: mega-tear 0.7s var(--ease-in) forwards;
}
@keyframes mega-tear {
  0%   { transform: scale(1) rotate(0deg); filter: brightness(1); }
  15%  { transform: scale(1.08) rotate(-4deg); filter: brightness(1.4); }
  35%  { transform: scale(1.08) rotate(4deg); filter: brightness(1.6); }
  60%  { transform: scale(0.85) rotate(-6deg); opacity: 0.7; filter: brightness(0.8); }
  100% { transform: scale(0) rotate(20deg); opacity: 0; }
}

.tap-instruction {
  font-size: var(--text-base);
  color: var(--txt-secondary);
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}
.tap-pulse {
  color: var(--accent);
  animation: bounce-down 1.2s ease-in-out infinite;
  display: inline-block;
}
@keyframes bounce-down {
  0%,100% { transform: translateY(0); opacity: 0.6; }
  50%      { transform: translateY(5px); opacity: 1; }
}


/* ── Card Reveal ─────────────────────────────────────────────── */
.reveal-progress { text-align: center; }
.reveal-counter {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  letter-spacing: 2px;
  color: var(--txt-secondary);
}
.reveal-pip-row {
  display: flex;
  gap: var(--sp-2);
  justify-content: center;
  margin-top: var(--sp-2);
}
.pip {
  width: 12px; height: 12px;
  border-radius: 50%;
  background: rgba(255,255,255,0.12);
  transition: all var(--t-mid) var(--ease-out);
}
.pip.active {
  background: var(--accent);
  transform: scale(1.5);
  box-shadow: 0 0 8px var(--accent-glow);
}
.pip.done { background: rgba(255,255,255,0.35); }

/* 3D Flip Scene */
.flip-scene {
  perspective: 1000px;
  width: 300px;
  height: 460px;
  flex-shrink: 0;
}
.flip-card {
  width: 100%;
  height: 100%;
  position: relative;
  transform-style: preserve-3d;
  transition: transform 0.75s cubic-bezier(0.34, 1.1, 0.64, 1);
}
.flip-card.flipped { transform: rotateY(180deg); }
.flip-face {
  position: absolute;
  inset: 0;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  border-radius: var(--radius-card);
  overflow: hidden;
}
.flip-back { transform: rotateY(0deg); }
.flip-front { transform: rotateY(180deg); }

/* Card back design */
.card-back-design {
  width: 100%;
  height: 100%;
  background: linear-gradient(145deg, #141e38, #0a1020);
  border: 2px solid rgba(245,158,11,0.25);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--sp-3);
}
.card-back-pattern {
  position: absolute;
  inset: 0;
  background:
    repeating-linear-gradient(
      45deg,
      transparent,
      transparent 12px,
      rgba(255,255,255,0.02) 12px,
      rgba(255,255,255,0.02) 13px
    );
}
.card-back-logo {
  font-size: 64px;
  position: relative;
  z-index: 1;
  filter: drop-shadow(0 0 24px rgba(245,158,11,0.4));
  animation: logo-pulse 3s ease-in-out infinite;
}
.card-back-text {
  font-family: var(--font-display);
  font-size: 12px;
  letter-spacing: 4px;
  color: rgba(255,255,255,0.3);
  position: relative;
  z-index: 1;
}

/* Reveal CTA */
.reveal-cta-row {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-2);
}
.swipe-hint {
  font-size: var(--text-xs);
  color: var(--txt-muted);
  font-weight: 600;
}


/* ══════════════════════════════════════════════════════════════
   THE CARD — Full design
══════════════════════════════════════════════════════════════ */
.card {
  width: 300px;
  border-radius: var(--radius-card);
  background: var(--bg-card);
  position: relative;
  overflow: hidden;
  flex-shrink: 0;
  transition: transform var(--t-mid) var(--ease-spring), box-shadow var(--t-mid) var(--ease-out);
}

/* Rarity top stripe */
.card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 5px;
  z-index: 5;
  border-radius: 20px 20px 0 0;
}
.card[data-rarity="common"]::before   { background: var(--common); }
.card[data-rarity="rare"]::before     { background: linear-gradient(90deg, var(--rare), var(--rare-light)); }
.card[data-rarity="epic"]::before     { background: linear-gradient(90deg, var(--epic), var(--epic-light)); }
.card[data-rarity="legendary"]::before {
  background: linear-gradient(90deg, var(--legendary), #fbbf24, var(--legendary));
  background-size: 200%;
  animation: gold-flow 2s linear infinite;
}

/* Rarity border & glow */
.card[data-rarity="common"]   { border: 1.5px solid rgba(107,122,153,0.3); }
.card[data-rarity="rare"]     { border: 2px solid rgba(37,99,235,0.55); box-shadow: 0 0 40px rgba(37,99,235,0.2), 0 8px 32px rgba(0,0,0,0.6); }
.card[data-rarity="epic"]     { border: 2px solid rgba(124,58,237,0.6);  box-shadow: 0 0 50px rgba(124,58,237,0.25), 0 8px 32px rgba(0,0,0,0.6); }
.card[data-rarity="legendary"] {
  border: 2.5px solid rgba(245,158,11,0.7);
  box-shadow: 0 0 80px rgba(245,158,11,0.35), 0 8px 40px rgba(0,0,0,0.7);
  animation: legend-pulse 2s ease-in-out infinite;
}
@keyframes legend-pulse {
  0%,100% { box-shadow: 0 0 60px rgba(245,158,11,0.3), 0 8px 40px rgba(0,0,0,0.7); }
  50%      { box-shadow: 0 0 120px rgba(245,158,11,0.55), 0 12px 50px rgba(0,0,0,0.7); }
}

/* Team gradient band */
.card-team-band {
  position: absolute;
  top: 5px; left: 0; right: 0;
  height: 200px;
  z-index: 0;
  opacity: 0.22;
}

/* Card shimmer overlay */
.card-shimmer {
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
  background: linear-gradient(
    125deg,
    transparent 20%,
    rgba(255,255,255,0.03) 40%,
    rgba(255,255,255,0.1) 50%,
    rgba(255,255,255,0.03) 60%,
    transparent 80%
  );
  animation: card-shimmer 5s ease-in-out infinite;
}
@keyframes card-shimmer {
  0%,100% { transform: translateX(-120%) translateY(-80%); }
  50%      { transform: translateX(120%) translateY(80%); }
}
.card[data-rarity="legendary"] .card-shimmer {
  background: linear-gradient(
    125deg,
    transparent 20%,
    rgba(245,158,11,0.05) 40%,
    rgba(245,158,11,0.18) 50%,
    rgba(245,158,11,0.05) 60%,
    transparent 80%
  );
}

/* Card header */
.card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 14px 6px;
  position: relative;
  z-index: 4;
}
.card-team-pos {
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 2px;
  color: var(--txt-muted);
  text-transform: uppercase;
}
.card[data-rarity="legendary"] .card-team-pos { color: rgba(245,158,11,0.6); }

.card-rarity-label {
  font-family: var(--font-display);
  font-size: 11px;
  letter-spacing: 1.5px;
  padding: 3px 9px;
  border-radius: 8px;
}
.card[data-rarity="common"]   .card-rarity-label { background: rgba(107,122,153,0.2); color: var(--common); }
.card[data-rarity="rare"]     .card-rarity-label { background: rgba(37,99,235,0.2); color: var(--rare-light); }
.card[data-rarity="epic"]     .card-rarity-label { background: rgba(124,58,237,0.2); color: var(--epic-light); }
.card[data-rarity="legendary"].card-rarity-label { background: rgba(245,158,11,0.2); color: var(--legendary-lt); }

/* Photo area */
.card-photo-area {
  position: relative;
  height: 195px;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  overflow: hidden;
  z-index: 2;
}
.card-photo-area::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 70px;
  background: linear-gradient(to top, var(--bg-card), transparent);
  z-index: 2;
}
.card-player-photo {
  height: 185px;
  width: auto;
  object-fit: contain;
  object-position: center bottom;
  filter: drop-shadow(0 8px 20px rgba(0,0,0,0.7));
  transition: transform var(--t-mid) var(--ease-out);
  position: relative;
  z-index: 1;
}
.card:hover .card-player-photo { transform: scale(1.05) translateY(-5px); }
.card-initials {
  width: 100px; height: 100px;
  border-radius: 50%;
  background: rgba(255,255,255,0.04);
  border: 2px solid rgba(255,255,255,0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: 36px;
  color: var(--txt-muted);
  margin-bottom: 20px;
  position: relative;
  z-index: 1;
}

/* Card body */
.card-body {
  padding: 10px 16px 8px;
  text-align: center;
  position: relative;
  z-index: 4;
}
.card-player-name {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  letter-spacing: 1px;
  line-height: 1.05;
  color: var(--txt-white);
}
.card[data-rarity="legendary"] .card-player-name {
  background: linear-gradient(135deg, #fde68a, #f59e0b, #fbbf24);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.card-position-badge {
  display: inline-block;
  margin-top: 4px;
  padding: 2px 10px;
  border-radius: 20px;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 2px;
  text-transform: uppercase;
}
.card[data-rarity="common"]   .card-position-badge { background: rgba(107,122,153,0.15); color: var(--common); }
.card[data-rarity="rare"]     .card-position-badge { background: rgba(37,99,235,0.15); color: var(--rare-light); }
.card[data-rarity="epic"]     .card-position-badge { background: rgba(124,58,237,0.15); color: var(--epic-light); }
.card[data-rarity="legendary"].card-position-badge { background: rgba(245,158,11,0.15); color: var(--legendary-lt); }

/* Descriptor */
.card-descriptor {
  margin-top: 7px;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  padding: 3px 12px;
  border-radius: 10px;
  display: inline-block;
}
.card[data-rarity="common"]   .card-descriptor { background: rgba(107,122,153,0.12); color: var(--common); }
.card[data-rarity="rare"]     .card-descriptor { background: rgba(37,99,235,0.12); color: var(--rare-light); }
.card[data-rarity="epic"]     .card-descriptor { background: rgba(124,58,237,0.12); color: var(--epic-light); }
.card[data-rarity="legendary"].card-descriptor { background: rgba(245,158,11,0.12); color: var(--legendary-lt); }

/* Stats row */
.card-stats {
  display: flex;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid rgba(255,255,255,0.07);
}
.card-stat {
  flex: 1;
  text-align: center;
  padding: 0 4px;
  position: relative;
}
.card-stat + .card-stat::before {
  content: '';
  position: absolute;
  left: 0; top: 15%; bottom: 15%;
  width: 1px;
  background: rgba(255,255,255,0.07);
}
.stat-val {
  font-family: var(--font-display);
  font-size: 20px;
  letter-spacing: 1px;
  line-height: 1;
  color: var(--txt-white);
  font-variant-numeric: tabular-nums;
}
.card[data-rarity="legendary"] .stat-val { color: var(--legendary-lt); }
.card[data-rarity="epic"]      .stat-val { color: var(--epic-light); }
.card[data-rarity="rare"]      .stat-val { color: var(--rare-light); }
.stat-label {
  font-size: 8px;
  font-weight: 800;
  letter-spacing: 1.5px;
  color: var(--txt-muted);
  text-transform: uppercase;
  margin-top: 3px;
}

/* Fun fact */
.card-fun-fact {
  font-size: 9px;
  color: var(--txt-muted);
  font-style: italic;
  text-align: center;
  padding: 6px 14px 0;
  line-height: 1.4;
  position: relative;
  z-index: 4;
}
.card[data-rarity="legendary"] .card-fun-fact { color: rgba(245,158,11,0.5); }

/* Card footer */
.card-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 7px 14px 12px;
  position: relative;
  z-index: 4;
}
.card-series { font-size: 8px; color: var(--txt-muted); font-weight: 600; letter-spacing: 1px; }
.card-serial { font-size: 8px; color: var(--txt-muted); font-variant-numeric: tabular-nums; }

/* ── Mini card ───────────────────────────────────────────────── */
.card.mini {
  width: 150px;
  cursor: pointer;
  transition: transform var(--t-mid) var(--ease-spring), box-shadow var(--t-mid) var(--ease-out);
}
.card.mini:hover   { transform: translateY(-6px) scale(1.02); }
.card.mini:active  { transform: scale(0.97); }
.card.mini .card-photo-area     { height: 100px; }
.card.mini .card-player-photo   { height: 95px; }
.card.mini .card-initials       { width: 55px; height: 55px; font-size: 22px; margin-bottom: 10px; }
.card.mini .card-photo-area::after { height: 35px; }
.card.mini .card-header         { padding: 9px 10px 4px; }
.card.mini .card-team-pos       { font-size: 7px; }
.card.mini .card-rarity-label   { font-size: 8px; padding: 2px 6px; }
.card.mini .card-body           { padding: 6px 10px 4px; }
.card.mini .card-player-name    { font-size: var(--text-sm); }
.card.mini .card-position-badge { font-size: 7px; }
.card.mini .card-descriptor     { display: none; }
.card.mini .card-stats          { margin-top: 7px; padding-top: 7px; }
.card.mini .stat-val            { font-size: 14px; }
.card.mini .stat-label          { font-size: 6px; }
.card.mini .card-fun-fact       { display: none; }
.card.mini .card-footer         { padding: 4px 10px 8px; }
.card.mini .card-series,
.card.mini .card-serial         { font-size: 7px; }


/* ══════════════════════════════════════════════════════════════
   PACK SUMMARY
══════════════════════════════════════════════════════════════ */
.summary-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-5);
  max-width: 800px;
  width: 100%;
}
.summary-headline {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  letter-spacing: 2px;
  text-align: center;
}
.summary-sub {
  font-size: var(--text-base);
  color: var(--txt-secondary);
  font-weight: 700;
}
.summary-cards {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--sp-4);
  padding: var(--sp-2) 0;
}
.summary-actions {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-3);
}


/* ══════════════════════════════════════════════════════════════
   INNER PAGES (Collection / Stats)
══════════════════════════════════════════════════════════════ */
.inner-page {
  max-width: 1100px;
  margin: 0 auto;
  padding: calc(80px + var(--safe-t)) var(--sp-6) calc(var(--sp-12) + var(--safe-b));
  width: 100%;
}
.inner-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: var(--sp-6);
}
.inner-title {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  letter-spacing: 2px;
}
.inner-sub { font-size: var(--text-sm); color: var(--txt-secondary); margin-top: var(--sp-1); }

.back-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-4);
  background: rgba(255,255,255,0.06);
  border: 1.5px solid var(--border-mid);
  border-radius: var(--radius-md);
  color: var(--txt-secondary);
  font-size: var(--text-sm);
  font-weight: 700;
  transition: all var(--t-fast);
}
.back-btn:hover { color: var(--txt-primary); background: rgba(255,255,255,0.1); }

/* Toolbar */
.toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--sp-4);
  margin-bottom: var(--sp-6);
}
.filter-pills { display: flex; gap: var(--sp-2); flex-wrap: wrap; }
.pill {
  padding: var(--sp-2) var(--sp-4);
  font-size: var(--text-xs);
  font-weight: 800;
  border: 1.5px solid var(--border-mid);
  border-radius: var(--radius-full, 9999px);
  background: transparent;
  color: var(--txt-secondary);
  transition: all var(--t-fast);
  letter-spacing: 0.5px;
}
.pill:hover  { border-color: rgba(255,255,255,0.25); color: var(--txt-primary); }
.pill.active { background: var(--accent); color: #000; border-color: var(--accent); }
.pill-legendary.active { background: var(--legendary-lt); border-color: var(--legendary-lt); }
.pill-epic.active      { background: var(--epic-light); color: #fff; border-color: var(--epic-light); }
.pill-rare.active      { background: var(--rare-light); color: #fff; border-color: var(--rare-light); }

.sort-select {
  padding: var(--sp-2) var(--sp-5) var(--sp-2) var(--sp-3);
  font-size: var(--text-xs);
  font-weight: 700;
  border: 1.5px solid var(--border-mid);
  border-radius: var(--radius-md);
  background: var(--bg-surface);
  color: var(--txt-primary);
  -webkit-appearance: none;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238a96b0' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  padding-right: 30px;
}

/* Card grid */
.card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: var(--sp-4);
}

.empty-state { text-align: center; padding: var(--sp-20) var(--sp-6); }
.empty-icon  { font-size: 56px; margin-bottom: var(--sp-4); }
.empty-msg   { color: var(--txt-muted); margin-bottom: var(--sp-6); font-size: var(--text-base); }


/* ── Stats KPIs ──────────────────────────────────────────────── */
.stats-kpis {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-4);
  margin-bottom: var(--sp-8);
}
.kpi-card {
  background: var(--bg-surface);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--sp-5) var(--sp-4);
  text-align: center;
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
}
.kpi-card:hover  { border-color: rgba(245,158,11,0.3); box-shadow: 0 0 20px rgba(245,158,11,0.08); }
.kpi-gold { border-color: rgba(245,158,11,0.2); }
.kpi-icon { font-size: 28px; margin-bottom: var(--sp-2); }
.kpi-val  {
  font-family: var(--font-display);
  font-size: clamp(2rem, 6vw, 3rem);
  letter-spacing: 1px;
  color: var(--accent);
  line-height: 1;
}
.kpi-label {
  font-size: var(--text-xs);
  color: var(--txt-muted);
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-top: var(--sp-2);
}

.stats-section { margin-bottom: var(--sp-8); }
.stats-section-title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  letter-spacing: 2px;
  color: var(--txt-secondary);
  margin-bottom: var(--sp-5);
}

/* Rarity bars */
.rarity-bars { display: flex; flex-direction: column; gap: var(--sp-4); }
.rbar-row    { display: flex; align-items: center; gap: var(--sp-4); }
.rbar-label  { width: 76px; font-size: var(--text-xs); font-weight: 800; text-align: right; flex-shrink: 0; }
.rbar-track  { flex: 1; height: 28px; background: rgba(255,255,255,0.04); border-radius: 14px; overflow: hidden; }
.rbar-fill   { height: 100%; border-radius: 14px; transition: width 1.2s cubic-bezier(0.34, 1.2, 0.64, 1); min-width: 4px; }
.rbar-fill.common    { background: var(--common); }
.rbar-fill.rare      { background: linear-gradient(90deg, var(--rare), var(--rare-light)); }
.rbar-fill.epic      { background: linear-gradient(90deg, var(--epic), var(--epic-light)); }
.rbar-fill.legendary { background: linear-gradient(90deg, var(--legendary), var(--legendary-lt)); }
.rbar-count  { font-size: var(--text-sm); font-weight: 800; min-width: 28px; text-align: right; }

.best-grid { display: flex; flex-wrap: wrap; gap: var(--sp-4); }


/* ══════════════════════════════════════════════════════════════
   MODAL
══════════════════════════════════════════════════════════════ */
.modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 500;
  background: rgba(0,0,0,0.9);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: var(--sp-4);
  padding: calc(var(--sp-6) + var(--safe-t)) var(--sp-5) calc(var(--sp-6) + var(--safe-b));
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  animation: fade-in 0.2s var(--ease-out);
}
@keyframes fade-in { from { opacity: 0; } to { opacity: 1; } }
.modal-box {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-4);
  max-width: 340px;
  width: 100%;
}
.modal-close-btn {
  position: absolute;
  top: -48px; right: 0;
  width: 36px; height: 36px;
  border-radius: 50%;
  background: rgba(255,255,255,0.1);
  border: 1px solid var(--border-mid);
  color: var(--txt-primary);
  font-size: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background var(--t-fast);
}
.modal-close-btn:hover { background: rgba(255,255,255,0.2); }
.modal-tap-hint { font-size: var(--text-xs); color: var(--txt-muted); }


/* ══════════════════════════════════════════════════════════════
   RARITY REVEAL OVERLAY
══════════════════════════════════════════════════════════════ */
.reveal-overlay {
  position: fixed;
  inset: 0;
  z-index: 800;
  pointer-events: none;
  display: flex;
  align-items: center;
  justify-content: center;
  animation: rev-overlay 1.4s var(--ease-out) forwards;
}
.reveal-overlay.legendary-reveal {
  background: radial-gradient(ellipse at center, rgba(245,158,11,0.5) 0%, transparent 65%);
}
.reveal-overlay.epic-reveal {
  background: radial-gradient(ellipse at center, rgba(124,58,237,0.4) 0%, transparent 60%);
}
.reveal-overlay.rare-reveal {
  background: radial-gradient(ellipse at center, rgba(37,99,235,0.3) 0%, transparent 55%);
}
@keyframes rev-overlay {
  0%   { opacity: 0; transform: scale(0.5); }
  30%  { opacity: 1; }
  100% { opacity: 0; transform: scale(2.5); }
}

.reveal-overlay-text {
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 8vw, 6rem);
  letter-spacing: clamp(2px, 1.5vw, 8px);
  color: #fff;
  text-align: center;
  padding: 0 16px;
  max-width: 100vw;
  box-sizing: border-box;
  text-shadow: 0 0 40px rgba(245,158,11,0.8);
  animation: rev-text 1.4s var(--ease-spring) forwards;
}
@keyframes rev-text {
  0%   { opacity: 0; transform: scale(0.4) translateY(40px); }
  40%  { opacity: 1; transform: scale(1.02) translateY(-6px); }
  70%  { transform: scale(0.99) translateY(0); }
  100% { opacity: 0; transform: scale(0.96) translateY(-20px); }
}


/* ══════════════════════════════════════════════════════════════
   LOADING
══════════════════════════════════════════════════════════════ */
.loading-veil {
  position: fixed;
  inset: 0;
  z-index: 1000;
  background: rgba(5,8,16,0.95);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--sp-4);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
}
.loading-ball { font-size: 56px; animation: load-spin 0.9s linear infinite; }
@keyframes load-spin { to { transform: rotate(360deg); } }
.loading-msg { font-family: var(--font-display); font-size: var(--text-xl); letter-spacing: 3px; color: var(--txt-primary); }
.loading-sub { font-size: var(--text-sm); color: var(--txt-muted); }


/* ══════════════════════════════════════════════════════════════
   TOAST
══════════════════════════════════════════════════════════════ */
.toast {
  position: fixed;
  bottom: calc(var(--sp-6) + var(--safe-b));
  left: 50%;
  transform: translateX(-50%);
  background: var(--bg-elevated);
  border: 1.5px solid var(--border-mid);
  border-radius: var(--radius-lg);
  padding: var(--sp-3) var(--sp-6);
  font-size: var(--text-sm);
  font-weight: 700;
  color: var(--txt-primary);
  box-shadow: 0 8px 32px rgba(0,0,0,0.6);
  z-index: 700;
  max-width: calc(100vw - 40px);
  text-align: center;
  animation: toast-in 0.3s var(--ease-out);
}
@keyframes toast-in {
  from { opacity: 0; transform: translateX(-50%) translateY(16px); }
  to   { opacity: 1; transform: translateX(-50%) translateY(0); }
}

/* ── Screen shake ────────────────────────────────────────────── */
.shake {
  animation: screen-shake 0.45s var(--ease-out) both;
}
@keyframes screen-shake {
  0%,100% { transform: translate(0); }
  15%     { transform: translate(-4px, 2px); }
  30%     { transform: translate(5px, -3px); }
  45%     { transform: translate(-4px, 1px); }
  60%     { transform: translate(4px, -2px); }
  75%     { transform: translate(-2px, 1px); }
  90%     { transform: translate(2px, 0); }
}

/* Particles */
.particle {
  position: fixed;
  border-radius: 50%;
  pointer-events: none;
  z-index: 850;
  animation: pfx 1.6s var(--ease-in) forwards;
}
@keyframes pfx {
  0%   { opacity: 1; transform: translate(0,0) scale(1); }
  100% { opacity: 0; transform: translate(var(--dx), var(--dy)) scale(0); }
}


/* ══════════════════════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════════════════════ */
@media (max-width: 520px) {
  /* Hero pack chooser: horizontal scroll */
  .pack-chooser {
    gap: var(--sp-3);
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    justify-content: flex-start;
    padding-bottom: var(--sp-2);
    max-width: 100%;
    scrollbar-width: none;
  }
  .pack-chooser::-webkit-scrollbar { display: none; }
  .pack-tile { min-width: 140px; max-width: 140px; scroll-snap-align: center; flex-shrink: 0; }

  .hero-nav-row { flex-direction: column; align-items: stretch; }
  .hero-nav-row .ghost-btn { justify-content: center; }

  /* Reveal */
  .flip-scene { width: 280px; height: 430px; }
  .card { width: 280px; }

  /* Inner pages */
  .inner-page { padding-left: var(--sp-4); padding-right: var(--sp-4); }
  .toolbar { flex-direction: column; align-items: flex-start; }
  .stats-kpis { grid-template-columns: repeat(2,1fr); gap: var(--sp-3); }
}

@media (min-width: 640px) {
  .stats-kpis { grid-template-columns: repeat(4,1fr); }
}

@media (max-height: 600px) and (orientation: landscape) {
  .hl-1 { font-size: clamp(3rem, 12vw, 6rem); }
  .hl-2 { font-size: clamp(2rem, 8vw, 4rem); }
  .hero-center { gap: var(--sp-4); }
  .flip-scene { width: 220px; height: 340px; }
  .card { width: 220px; }
  .card-photo-area { height: 140px; }
  .card-player-photo { height: 130px; }
}
