/* ==========================================================================
   Gopnik NFT Marketplace — v2 (Iteration 1)
   All styles scoped under `.mpv2-*` to coexist with `.mp-*` legacy styles.
   Depends on nft_tokens_v2.css for design tokens.
   ========================================================================== */

/* Cross-surface cosmetic polish (Arena, Activity, Explore, Notif Prefs,
   Fusion, Master Book).  Imported from the base v2 stylesheet so every
   template that already loads ``nft_marketplace_v2.css`` picks up the
   lifts automatically — no per-template wiring, no v1 leakage. */
@import url('nft_marketplace_v2_polish.css');

.mpv2 {
  --mpv2-layout-max: 1440px;
  color: var(--mpv2-text);
  font-family: var(--mpv2-font-body);
  background:
    radial-gradient(80% 60% at 50% -10%, rgba(139,92,246,0.20), transparent 70%),
    radial-gradient(40% 30% at 90% 10%, rgba(34,211,238,0.14), transparent 70%),
    radial-gradient(50% 40% at 10% 40%, rgba(244,114,182,0.10), transparent 70%),
    var(--mpv2-bg-deep);
  min-height: 100vh;
  position: relative;
  overflow-x: hidden;
}

.mpv2 * { box-sizing: border-box; }
.mpv2 a { color: inherit; text-decoration: none; }

/* ── Shell / layout ─────────────────────────────────────────────────────── */
.mpv2-shell      { max-width: var(--mpv2-layout-max); margin: 0 auto; padding: 0 24px; }
.mpv2-layout     { display: grid; grid-template-columns: 260px 1fr; gap: 28px; padding: 20px 24px 72px; max-width: var(--mpv2-layout-max); margin: 0 auto; }
@media (max-width: 1024px) { .mpv2-layout { grid-template-columns: 1fr; } .mpv2-sidebar { display: none; } }

/* ── Sticky nav ─────────────────────────────────────────────────────────── */
/*
 * The sticky nav + blurred backdrop combo is gorgeous but notoriously
 * flickery: Chrome/Safari re-paint the frosted strip whenever an element
 * below it invalidates a compositor layer (SSE frame floaters on Arena,
 * activity polling on Activity, etc).  Promoting the nav to its own layer
 * with `transform: translateZ(0)` + `will-change` keeps the blur bake
 * stable and eliminates the "top banner sometimes flickers" bug reported
 * against the Arena page.  `contain: paint` prevents any accidental
 * cross-layer redraws from repainting the whole bar.
 */
.mpv2-nav {
  position: sticky; top: 0; z-index: 80;
  backdrop-filter: blur(22px) saturate(130%);
  -webkit-backdrop-filter: blur(22px) saturate(130%);
  background: rgba(5, 5, 16, 0.72);
  border-bottom: 1px solid var(--mpv2-border);
  transform: translateZ(0);
  will-change: backdrop-filter;
  contain: paint;
}
.mpv2-nav-inner { max-width: var(--mpv2-layout-max); margin: 0 auto; display: flex; align-items: center; gap: 24px; padding: 14px 24px; }
.mpv2-logo { display: flex; align-items: center; gap: 10px; font-family: var(--mpv2-font-disp); font-weight: 800; letter-spacing: 0.02em; }
.mpv2-logo-mark {
  width: 32px; height: 32px; border-radius: 10px;
  background: var(--mpv2-grad-title);
  box-shadow: 0 0 18px rgba(139,92,246,0.55);
  display: grid; place-items: center; font-weight: 900; color: #fff;
}
.mpv2-nav-tabs { display: flex; gap: 4px; flex: 1; }
.mpv2-nav-tab {
  padding: 8px 14px; border-radius: 10px; color: var(--mpv2-text-dim);
  font-size: 0.85rem; font-weight: 600; cursor: pointer;
  transition: background var(--mpv2-dur-fast), color var(--mpv2-dur-fast);
}
.mpv2-nav-tab:hover { color: var(--mpv2-text); background: rgba(139,92,246,0.08); }
.mpv2-nav-tab.is-active { color: var(--mpv2-text); background: rgba(139,92,246,0.14); box-shadow: inset 0 0 0 1px var(--mpv2-border); }
.mpv2-search {
  display: flex; align-items: center; gap: 8px; padding: 8px 12px;
  background: rgba(15,18,55,0.65); border: 1px solid var(--mpv2-border);
  border-radius: 10px; min-width: 260px; color: var(--mpv2-text-dim); font-size: 0.85rem;
}
.mpv2-search kbd {
  margin-left: auto; font-family: var(--mpv2-font-mono); font-size: 0.7rem;
  background: rgba(139,92,246,0.18); color: var(--mpv2-text);
  padding: 2px 6px; border-radius: 4px;
}
.mpv2-wallet-chip {
  display: flex; align-items: center; gap: 8px; padding: 6px 12px 6px 6px;
  background: rgba(139,92,246,0.12); border: 1px solid var(--mpv2-border-hi);
  border-radius: 999px; font-size: 0.78rem; font-weight: 600;
}
.mpv2-wallet-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--mpv2-green); box-shadow: 0 0 8px var(--mpv2-green); }

/* ── Cinematic Hero ─────────────────────────────────────────────────────── */
.mpv2-hero {
  position: relative; height: 520px; overflow: hidden;
  border-bottom: 1px solid var(--mpv2-border);
}
.mpv2-hero-bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 50% 60% at 50% 50%, rgba(139,92,246,0.35), transparent 70%),
    radial-gradient(ellipse 30% 40% at 20% 80%, rgba(34,211,238,0.25), transparent 70%),
    radial-gradient(ellipse 40% 50% at 80% 20%, rgba(244,114,182,0.20), transparent 70%);
}
.mpv2-hero-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(139,92,246,0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(139,92,246,0.06) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(ellipse 70% 50% at 50% 50%, #000 30%, transparent 80%);
}
.mpv2-hero-particles { position: absolute; inset: 0; pointer-events: none; }
.mpv2-hero-particles span {
  position: absolute; width: 3px; height: 3px; border-radius: 50%;
  background: rgba(255, 255, 255, 0.85); box-shadow: 0 0 8px rgba(139,92,246,0.8);
  animation: mpv2-particle-drift linear infinite;
}
.mpv2-hero-inner {
  position: relative; z-index: 2; max-width: var(--mpv2-layout-max);
  margin: 0 auto; padding: 60px 24px;
  display: grid; grid-template-columns: 1fr 520px; gap: 48px; align-items: center;
}
@media (max-width: 1024px) { .mpv2-hero-inner { grid-template-columns: 1fr; } .mpv2-hero { height: auto; padding-bottom: 40px; } }

.mpv2-hero-kicker {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 14px; border-radius: 999px;
  background: rgba(139,92,246,0.14); border: 1px solid var(--mpv2-border-hi);
  font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--mpv2-text-dim); font-weight: 700;
}
.mpv2-hero-kicker .mpv2-pulse {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--mpv2-green); box-shadow: 0 0 6px var(--mpv2-green);
  animation: mpv2-heartbeat 1.4s infinite;
}
.mpv2-hero h1 {
  font-family: var(--mpv2-font-disp); font-weight: 900; letter-spacing: -0.02em;
  font-size: clamp(2.4rem, 5vw, 4.4rem); line-height: 1.02; margin: 20px 0 16px;
  background: var(--mpv2-grad-title); -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
  background-size: 200% 100%; animation: mpv2-grad-shift 10s ease-in-out infinite;
}
.mpv2-hero-sub { color: var(--mpv2-text-dim); font-size: 1.05rem; max-width: 520px; line-height: 1.6; }
.mpv2-hero-actions { display: flex; gap: 12px; margin-top: 28px; flex-wrap: wrap; }
.mpv2-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 20px; border-radius: 12px; font-weight: 700; font-size: 0.88rem;
  border: 1px solid var(--mpv2-border); background: var(--mpv2-bg-panel);
  color: var(--mpv2-text); cursor: pointer; transition: all var(--mpv2-dur-fast) var(--mpv2-ease-out);
}
.mpv2-btn:hover { border-color: var(--mpv2-border-hi); transform: translateY(-1px); }
.mpv2-btn-primary {
  background: linear-gradient(135deg, #8b5cf6, #22d3ee); border-color: transparent;
  box-shadow: 0 8px 24px rgba(139,92,246,0.35);
}
.mpv2-btn-primary:hover { transform: translateY(-2px); box-shadow: 0 12px 32px rgba(139,92,246,0.5); }

/* Hero right — orbiting trait stage */
.mpv2-hero-stage {
  position: relative; aspect-ratio: 1; width: 100%;
  max-width: 520px; min-height: 420px; margin: 0 auto;
}
.mpv2-hero-silhouette {
  position: absolute; inset: 22%; border-radius: 50%;
  background: radial-gradient(circle, rgba(139,92,246,0.6) 0%, rgba(34,211,238,0.3) 50%, transparent 70%);
  box-shadow: 0 0 80px rgba(139,92,246,0.6), inset 0 0 40px rgba(34,211,238,0.4);
  animation: mpv2-silhouette-float 4s ease-in-out infinite;
  pointer-events: none;
}
.mpv2-hero-silhouette::after {
  content: ''; position: absolute; inset: 10%; border-radius: 50%;
  background: radial-gradient(circle at 40% 35%, rgba(255,255,255,0.9), rgba(167,139,250,0.4) 40%, transparent 70%);
  filter: blur(1px);
}
.mpv2-hero-orbit {
  position: absolute; inset: 8%; border: 1px dashed rgba(139,92,246,0.25);
  border-radius: 50%;
  animation: mpv2-orbit-rotate 40s linear infinite;
  pointer-events: none;
}
.mpv2-hero-orbit.is-reverse {
  animation-direction: reverse; animation-duration: 56s; inset: 20%;
  border-color: rgba(34,211,238,0.18);
}
/* Trait chips: positioned on a hexagonal ring, float gently in place */
.mpv2-trait-chip {
  position: absolute; display: flex; align-items: center; gap: 6px;
  padding: 8px 12px; border-radius: 10px;
  background: var(--mpv2-bg-panel-hi); border: 1px solid var(--mpv2-border-hi);
  font-size: 0.75rem; font-weight: 700; white-space: nowrap;
  box-shadow: 0 8px 24px rgba(0,0,0,0.45);
  animation: mpv2-chip-float 6s ease-in-out infinite;
  will-change: transform;
}
.mpv2-trait-chip .mpv2-trait-val { color: var(--mpv2-green); font-family: var(--mpv2-font-mono); }
/* 6 slots evenly spaced around the silhouette, offsets expressed via CSS vars
   so the float keyframes can reuse them without clobbering placement. */
.mpv2-trait-chip[data-slot="1"] { --y: 2%;    --x: 50%; top: var(--y); left: var(--x); transform: translate(-50%, 0); animation-delay: -0.0s; }
.mpv2-trait-chip[data-slot="2"] { --y: 20%;   --x: 92%; top: var(--y); left: var(--x); transform: translate(-50%, 0); animation-delay: -1.0s; }
.mpv2-trait-chip[data-slot="3"] { --y: 72%;   --x: 92%; top: var(--y); left: var(--x); transform: translate(-50%, 0); animation-delay: -2.0s; }
.mpv2-trait-chip[data-slot="4"] { --y: 92%;   --x: 50%; top: var(--y); left: var(--x); transform: translate(-50%, 0); animation-delay: -3.0s; }
.mpv2-trait-chip[data-slot="5"] { --y: 72%;   --x: 8%;  top: var(--y); left: var(--x); transform: translate(-50%, 0); animation-delay: -4.0s; }
.mpv2-trait-chip[data-slot="6"] { --y: 20%;   --x: 8%;  top: var(--y); left: var(--x); transform: translate(-50%, 0); animation-delay: -5.0s; }

/* ── Stats strip ───────────────────────────────────────────────────────── */
.mpv2-stats {
  max-width: var(--mpv2-layout-max); margin: -40px auto 0; padding: 0 24px;
  position: relative; z-index: 5;
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 14px;
}
@media (max-width: 1024px) { .mpv2-stats { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 640px)  { .mpv2-stats { grid-template-columns: repeat(2, 1fr); } }
.mpv2-stat {
  padding: 16px 18px; border-radius: var(--mpv2-radius-md);
  background: var(--mpv2-bg-panel); border: 1px solid var(--mpv2-border);
  backdrop-filter: blur(16px); position: relative; overflow: hidden;
}
.mpv2-stat-label { font-size: 0.68rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--mpv2-text-faint); font-weight: 700; }
.mpv2-stat-val   { font-size: 1.5rem; font-weight: 900; font-family: var(--mpv2-font-disp); margin-top: 4px; }
.mpv2-stat-delta { font-size: 0.72rem; font-weight: 700; margin-top: 4px; }
.mpv2-stat-delta.is-up   { color: var(--mpv2-green); }
.mpv2-stat-delta.is-down { color: var(--mpv2-red); }
.mpv2-stat-spark { position: absolute; right: 10px; bottom: 10px; opacity: 0.6; }

/* ── Sidebar / filters ─────────────────────────────────────────────────── */
.mpv2-sidebar { display: flex; flex-direction: column; gap: 18px; position: sticky; top: 72px; align-self: start; }
.mpv2-panel {
  background: var(--mpv2-bg-panel); border: 1px solid var(--mpv2-border);
  border-radius: var(--mpv2-radius-lg); padding: 16px;
}
.mpv2-panel h3 { font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--mpv2-text-dim); font-weight: 800; margin: 0 0 12px; }
.mpv2-nav-list { display: flex; flex-direction: column; gap: 2px; }
.mpv2-nav-item {
  display: flex; align-items: center; gap: 10px; padding: 10px 12px;
  border-radius: 10px; font-size: 0.85rem; font-weight: 600; color: var(--mpv2-text-dim);
  cursor: pointer; transition: background var(--mpv2-dur-fast), color var(--mpv2-dur-fast);
}
.mpv2-nav-item:hover { color: var(--mpv2-text); background: rgba(139,92,246,0.08); }
.mpv2-nav-item.is-active { color: var(--mpv2-text); background: rgba(139,92,246,0.16); }
.mpv2-nav-item .mpv2-nav-count { margin-left: auto; font-size: 0.72rem; color: var(--mpv2-text-faint); }

.mpv2-chip-row { display: flex; flex-wrap: wrap; gap: 6px; }
.mpv2-chip {
  padding: 6px 10px; border-radius: 8px; font-size: 0.72rem; font-weight: 700;
  background: rgba(139,92,246,0.08); border: 1px solid var(--mpv2-border);
  color: var(--mpv2-text-dim); cursor: pointer;
  transition: all var(--mpv2-dur-fast) var(--mpv2-ease-out);
}
.mpv2-chip:hover { color: var(--mpv2-text); border-color: var(--mpv2-border-hi); }
.mpv2-chip.is-active { background: rgba(139,92,246,0.22); color: var(--mpv2-text); border-color: var(--mpv2-border-hi); }
.mpv2-chip[data-rarity="common"].is-active    { background: rgba(100,116,139,0.25); border-color: var(--mpv2-rarity-common); color: #fff; }
.mpv2-chip[data-rarity="rare"].is-active      { background: rgba(56,189,248,0.20); border-color: var(--mpv2-rarity-rare); color: #fff; }
.mpv2-chip[data-rarity="epic"].is-active      { background: rgba(168,85,247,0.22); border-color: var(--mpv2-rarity-epic); color: #fff; }
.mpv2-chip[data-rarity="legendary"].is-active { background: rgba(245,158,11,0.22); border-color: var(--mpv2-rarity-legendary); color: #fff; }
.mpv2-chip[data-rarity="mythic"].is-active    { background: rgba(244,114,182,0.22); border-color: var(--mpv2-rarity-mythic); color: #fff; }

/* 1fr | 12px | 1fr — grid prevents flex inputs from stealing each other's min-content width
   and keeps the dash centred without overlap in narrow filter rails. */
.mpv2-range-row {
  display: grid; grid-template-columns: 1fr 12px 1fr; align-items: center;
  gap: 8px; font-size: 0.78rem; color: var(--mpv2-text-dim);
}
.mpv2-range-row > span { text-align: center; opacity: 0.6; }
.mpv2-range-row input[type="number"] {
  width: 100%; min-width: 0; padding: 8px 10px; border-radius: 8px;
  background: rgba(15,18,55,0.65); border: 1px solid var(--mpv2-border);
  color: var(--mpv2-text); font-size: 0.78rem; font-family: var(--mpv2-font-mono);
  box-sizing: border-box;
}
/* Suppress the native spinner that ate into input width on WebKit */
.mpv2-range-row input[type="number"]::-webkit-outer-spin-button,
.mpv2-range-row input[type="number"]::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.mpv2-range-row input[type="number"] { -moz-appearance: textfield; }
.mpv2-range-row input[type="number"]:focus { outline: none; border-color: var(--mpv2-border-hi); box-shadow: 0 0 0 3px rgba(139,92,246,0.12); }

.mpv2-toggle { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 8px 0; font-size: 0.82rem; color: var(--mpv2-text-dim); }
.mpv2-toggle-switch { position: relative; width: 36px; height: 20px; background: rgba(100,116,139,0.35); border-radius: 999px; cursor: pointer; transition: background var(--mpv2-dur-fast); }
.mpv2-toggle-switch::after { content: ''; position: absolute; top: 2px; left: 2px; width: 16px; height: 16px; border-radius: 50%; background: #fff; transition: transform var(--mpv2-dur-fast) var(--mpv2-ease-spring); }
.mpv2-toggle.is-on .mpv2-toggle-switch { background: var(--mpv2-purple); }
.mpv2-toggle.is-on .mpv2-toggle-switch::after { transform: translateX(16px); }

/* ── Tabs + view toggles ───────────────────────────────────────────────── */
.mpv2-tabs { display: flex; align-items: center; gap: 4px; padding: 6px; background: var(--mpv2-bg-panel); border: 1px solid var(--mpv2-border); border-radius: 12px; overflow-x: auto; }
.mpv2-tab { padding: 8px 14px; border-radius: 8px; font-size: 0.82rem; font-weight: 700; color: var(--mpv2-text-dim); cursor: pointer; white-space: nowrap; transition: all var(--mpv2-dur-fast); }
.mpv2-tab:hover { color: var(--mpv2-text); }
.mpv2-tab.is-active { color: var(--mpv2-text); background: linear-gradient(135deg, rgba(139,92,246,0.25), rgba(34,211,238,0.15)); box-shadow: inset 0 0 0 1px var(--mpv2-border-hi); }
.mpv2-toolbar { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; flex-wrap: wrap; }
.mpv2-toolbar-spacer { flex: 1; }
.mpv2-view-toggle { display: flex; background: var(--mpv2-bg-panel); border: 1px solid var(--mpv2-border); border-radius: 10px; padding: 4px; }
.mpv2-view-toggle button { padding: 6px 10px; border: 0; background: transparent; color: var(--mpv2-text-dim); border-radius: 6px; font-size: 0.78rem; font-weight: 700; cursor: pointer; }
.mpv2-view-toggle button.is-active { color: var(--mpv2-text); background: rgba(139,92,246,0.22); }

/* ── Card grid + rarity treatments ─────────────────────────────────────── */
.mpv2-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(252px, 1fr)); gap: 18px; }

.mpv2-card {
  position: relative; border-radius: var(--mpv2-radius-lg); overflow: hidden;
  background: var(--mpv2-bg-panel); border: 1px solid var(--mpv2-border);
  transition: transform var(--mpv2-dur-med) var(--mpv2-ease-out),
              box-shadow var(--mpv2-dur-med) var(--mpv2-ease-out),
              border-color var(--mpv2-dur-med);
  animation: mpv2-card-enter var(--mpv2-dur-slow) var(--mpv2-ease-out) both;
  will-change: transform;
}
.mpv2-card:hover { transform: translateY(-4px); box-shadow: var(--mpv2-shadow-hover); border-color: var(--mpv2-border-hi); }

.mpv2-card-media {
  position: relative; aspect-ratio: 1; overflow: hidden;
  background: linear-gradient(135deg, #1a1540, #0e1028);
}
.mpv2-card-img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--mpv2-dur-slow) var(--mpv2-ease-out); }
.mpv2-card:hover .mpv2-card-img { transform: scale(1.06); }
.mpv2-card-badges { position: absolute; top: 10px; left: 10px; right: 10px; display: flex; justify-content: space-between; gap: 8px; pointer-events: none; }
.mpv2-rarity-badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 4px 10px; border-radius: 999px;
  font-size: 0.66rem; font-weight: 900; letter-spacing: 0.08em; text-transform: uppercase;
  background: rgba(5,5,16,0.72); backdrop-filter: blur(8px);
  pointer-events: auto;
}
.mpv2-fav {
  pointer-events: auto; width: 32px; height: 32px; display: grid; place-items: center;
  border-radius: 50%; background: rgba(5,5,16,0.72); backdrop-filter: blur(8px);
  color: var(--mpv2-text-dim); cursor: pointer; border: 0; transition: all var(--mpv2-dur-fast);
}
.mpv2-fav:hover { color: var(--mpv2-pink); transform: scale(1.1); }
.mpv2-fav.is-faved { color: var(--mpv2-pink); animation: mpv2-heart-pulse 420ms var(--mpv2-ease-spring); }

.mpv2-card-body { padding: 14px 16px 16px; }
.mpv2-card-title { display: flex; align-items: center; justify-content: space-between; gap: 8px; font-size: 0.95rem; font-weight: 800; font-family: var(--mpv2-font-disp); margin: 0 0 4px; }
.mpv2-card-sub   { display: flex; align-items: center; gap: 6px; color: var(--mpv2-text-dim); font-size: 0.78rem; }
.mpv2-card-sub .mpv2-verified { color: var(--mpv2-cyan); }
.mpv2-card-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 6px; margin: 12px 0 10px; }
.mpv2-card-stat { padding: 6px 4px; border-radius: 8px; background: rgba(15,18,55,0.5); text-align: center; }
.mpv2-card-stat-lbl { font-size: 0.62rem; color: var(--mpv2-text-faint); text-transform: uppercase; letter-spacing: 0.08em; font-weight: 700; }
.mpv2-card-stat-val { font-size: 0.9rem; font-weight: 800; font-family: var(--mpv2-font-mono); color: var(--mpv2-text); margin-top: 2px; }
.mpv2-card-price-row { display: flex; align-items: flex-end; justify-content: space-between; gap: 8px; }
.mpv2-card-price-lbl { font-size: 0.66rem; color: var(--mpv2-text-faint); text-transform: uppercase; letter-spacing: 0.08em; font-weight: 700; }
.mpv2-card-price-val { font-size: 1.05rem; font-weight: 900; color: var(--mpv2-text); font-family: var(--mpv2-font-mono); }
.mpv2-card-price-val .mpv2-ccy { color: var(--mpv2-text-dim); font-weight: 700; font-size: 0.78rem; margin-left: 3px; }
.mpv2-card-last { text-align: right; font-size: 0.7rem; color: var(--mpv2-text-dim); }
.mpv2-card-last.is-up   { color: var(--mpv2-green); }
.mpv2-card-last.is-down { color: var(--mpv2-red); }

/* Rarity frames */
.mpv2-card[data-rarity="common"]    { border-color: rgba(100,116,139,0.35); }
.mpv2-card[data-rarity="common"]    .mpv2-rarity-badge { color: var(--mpv2-rarity-common); }
.mpv2-card[data-rarity="rare"]      { border-color: rgba(56,189,248,0.45); box-shadow: inset 0 0 24px rgba(56,189,248,0.08); }
.mpv2-card[data-rarity="rare"]      .mpv2-rarity-badge { color: var(--mpv2-rarity-rare); }
.mpv2-card[data-rarity="rare"]:hover{ box-shadow: 0 16px 48px rgba(56,189,248,0.25), 0 0 0 1px rgba(56,189,248,0.55); }
.mpv2-card[data-rarity="epic"]      { border-color: transparent; padding: 2px; background: var(--mpv2-grad-epic); animation: mpv2-border-spin 6s linear infinite; }
.mpv2-card[data-rarity="epic"] > *  { background: var(--mpv2-bg-panel); border-radius: calc(var(--mpv2-radius-lg) - 2px); }
.mpv2-card[data-rarity="epic"] .mpv2-card-media { margin-bottom: 0; }
.mpv2-card[data-rarity="epic"]      .mpv2-rarity-badge { color: var(--mpv2-rarity-epic); }
.mpv2-card[data-rarity="legendary"] { border-color: transparent; padding: 2.5px; background: var(--mpv2-grad-legendary); animation: mpv2-border-spin 4s linear infinite; position: relative; }
.mpv2-card[data-rarity="legendary"] > * { background: var(--mpv2-bg-panel); border-radius: calc(var(--mpv2-radius-lg) - 2.5px); }
.mpv2-card[data-rarity="legendary"] .mpv2-rarity-badge { color: var(--mpv2-rarity-legendary); }
.mpv2-card[data-rarity="legendary"]::after {
  content: '\f521'; font-family: 'Font Awesome 6 Free'; font-weight: 900;
  position: absolute; top: 18px; right: 18px; z-index: 3;
  color: var(--mpv2-rarity-legendary); font-size: 0.9rem; opacity: 0.4;
  text-shadow: 0 0 10px var(--mpv2-rarity-legendary); pointer-events: none;
}
.mpv2-card[data-rarity="mythic"]    { border-color: transparent; padding: 3px; background: var(--mpv2-grad-mythic); animation: mpv2-border-spin 7s linear infinite; position: relative; }
.mpv2-card[data-rarity="mythic"] > *{ background: var(--mpv2-bg-panel); border-radius: calc(var(--mpv2-radius-lg) - 3px); }
.mpv2-card[data-rarity="mythic"]    .mpv2-rarity-badge { color: var(--mpv2-rarity-mythic); }
.mpv2-card[data-rarity="mythic"] .mpv2-fleck {
  position: absolute; width: 4px; height: 4px; border-radius: 50%;
  background: #fff; box-shadow: 0 0 8px var(--mpv2-rarity-mythic);
  animation: mpv2-fleck-drift 6s ease-in-out infinite; pointer-events: none; z-index: 4;
}
.mpv2-card[data-rarity="mythic"] .mpv2-fleck:nth-child(1) { top: 12%; left: 20%; animation-delay: 0s;   }
.mpv2-card[data-rarity="mythic"] .mpv2-fleck:nth-child(2) { top: 70%; left: 80%; animation-delay: 2s;   }
.mpv2-card[data-rarity="mythic"] .mpv2-fleck:nth-child(3) { top: 40%; left: 50%; animation-delay: 4s;   }

/* Stagger entrance */
.mpv2-card:nth-child(1) { animation-delay: 0ms; }
.mpv2-card:nth-child(2) { animation-delay: 60ms; }
.mpv2-card:nth-child(3) { animation-delay: 120ms; }
.mpv2-card:nth-child(4) { animation-delay: 180ms; }
.mpv2-card:nth-child(5) { animation-delay: 240ms; }
.mpv2-card:nth-child(6) { animation-delay: 300ms; }
.mpv2-card:nth-child(7) { animation-delay: 360ms; }
.mpv2-card:nth-child(8) { animation-delay: 420ms; }

/* ── Section headers ───────────────────────────────────────────────────── */
.mpv2-section { margin-top: 48px; }
.mpv2-section-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 16px; margin-bottom: 20px; flex-wrap: wrap; }
.mpv2-section-title { font-family: var(--mpv2-font-disp); font-weight: 900; font-size: 1.75rem; letter-spacing: -0.02em; margin: 0; }
.mpv2-section-sub   { color: var(--mpv2-text-dim); font-size: 0.88rem; margin-top: 4px; }
.mpv2-section-link  { color: var(--mpv2-cyan); font-size: 0.82rem; font-weight: 700; display: inline-flex; align-items: center; gap: 6px; }
.mpv2-section-link:hover { color: var(--mpv2-text); }

/* ── Fusion Lab teaser ─────────────────────────────────────────────────── */
.mpv2-fusion {
  background: linear-gradient(135deg, rgba(139,92,246,0.10), rgba(34,211,238,0.06));
  border: 1px solid var(--mpv2-border); border-radius: var(--mpv2-radius-xl);
  padding: 32px; position: relative; overflow: hidden;
  display: grid; grid-template-columns: 1.1fr 1fr; gap: 32px; align-items: center;
}
@media (max-width: 900px) { .mpv2-fusion { grid-template-columns: 1fr; } }
.mpv2-fusion-copy h3 { font-family: var(--mpv2-font-disp); font-size: 2rem; font-weight: 900; margin: 12px 0; letter-spacing: -0.02em; }
.mpv2-fusion-copy p  { color: var(--mpv2-text-dim); line-height: 1.6; margin: 0 0 20px; }
.mpv2-fusion-list    { display: flex; flex-direction: column; gap: 8px; margin-bottom: 20px; }
.mpv2-fusion-list-item { display: flex; align-items: center; gap: 10px; font-size: 0.88rem; color: var(--mpv2-text); }
.mpv2-fusion-list-item i { width: 22px; height: 22px; display: grid; place-items: center; border-radius: 6px; background: rgba(139,92,246,0.22); color: var(--mpv2-purple); font-size: 0.72rem; }

.mpv2-fusion-stage { position: relative; aspect-ratio: 1; max-width: 420px; margin: 0 auto; width: 100%; }
.mpv2-fusion-core {
  position: absolute; inset: 32%; border-radius: 50%;
  background: radial-gradient(circle, rgba(139,92,246,0.8) 0%, rgba(34,211,238,0.5) 50%, transparent 70%);
  box-shadow: 0 0 60px rgba(139,92,246,0.65), inset 0 0 30px rgba(34,211,238,0.5);
  animation: mpv2-silhouette-float 4s ease-in-out infinite;
}
.mpv2-fusion-ring {
  position: absolute; inset: 0; border: 1px dashed rgba(139,92,246,0.3); border-radius: 50%;
  animation: mpv2-orbit-rotate 20s linear infinite;
}
.mpv2-fusion-ring.is-inner { inset: 15%; animation-duration: 14s; animation-direction: reverse; border-style: dotted; border-color: rgba(34,211,238,0.3); }
.mpv2-fusion-slot {
  position: absolute; width: 56px; height: 56px; border-radius: 14px;
  background: var(--mpv2-bg-panel-hi); border: 1.5px solid var(--mpv2-border);
  display: grid; place-items: center; font-size: 1rem;
  box-shadow: 0 8px 24px rgba(0,0,0,0.45);
}
.mpv2-fusion-slot.is-empty { border-style: dashed; color: var(--mpv2-text-faint); }
.mpv2-fusion-slot.is-filled { border-color: var(--mpv2-border-hi); color: var(--mpv2-text); }
.mpv2-fusion-slot[data-slot="1"] { top: -8px; left: 50%; transform: translateX(-50%); }
.mpv2-fusion-slot[data-slot="2"] { top: 22%; right: -8px; }
.mpv2-fusion-slot[data-slot="3"] { bottom: 22%; right: -8px; }
.mpv2-fusion-slot[data-slot="4"] { bottom: -8px; left: 50%; transform: translateX(-50%); }
.mpv2-fusion-slot[data-slot="5"] { bottom: 22%; left: -8px; }
.mpv2-fusion-slot[data-slot="6"] { top: 22%; left: -8px; }
.mpv2-fusion-slot.is-filled[data-type="attack"]  { color: var(--mpv2-red); }
.mpv2-fusion-slot.is-filled[data-type="defense"] { color: var(--mpv2-cyan); }
.mpv2-fusion-slot.is-filled[data-type="speed"]   { color: var(--mpv2-amber); }

/* ── Live arena telemetry ──────────────────────────────────────────────── */
.mpv2-live { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
@media (max-width: 1024px) { .mpv2-live { grid-template-columns: 1fr; } }
.mpv2-battle {
  padding: 18px; border-radius: var(--mpv2-radius-lg);
  background: var(--mpv2-bg-panel); border: 1px solid var(--mpv2-border);
  position: relative; overflow: hidden;
}
.mpv2-battle::before {
  content: ''; position: absolute; top: 0; left: -100%; width: 100%; height: 2px;
  background: linear-gradient(90deg, transparent, var(--mpv2-red), transparent);
  animation: mpv2-battle-sweep 3s linear infinite;
}
.mpv2-battle-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; font-size: 0.72rem; }
.mpv2-live-tag {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 3px 10px; border-radius: 999px; font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase;
  background: rgba(239,68,68,0.16); color: var(--mpv2-red); border: 1px solid rgba(239,68,68,0.4);
}
.mpv2-live-tag .mpv2-live-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--mpv2-red); box-shadow: 0 0 6px var(--mpv2-red); animation: mpv2-heartbeat 1.2s infinite; }
.mpv2-battle-turn { color: var(--mpv2-text-dim); font-family: var(--mpv2-font-mono); }
.mpv2-battle-vs { display: grid; grid-template-columns: 1fr auto 1fr; gap: 12px; align-items: center; margin-bottom: 14px; }
.mpv2-fighter { display: flex; flex-direction: column; gap: 8px; }
.mpv2-fighter-row { display: flex; align-items: center; gap: 10px; }
.mpv2-fighter-avatar {
  width: 36px; height: 36px; border-radius: 50%;
  background: linear-gradient(135deg, #8b5cf6, #22d3ee);
  box-shadow: 0 0 12px rgba(139,92,246,0.5);
}
.mpv2-fighter[data-side="right"] .mpv2-fighter-row { flex-direction: row-reverse; }
.mpv2-fighter-name { font-weight: 800; font-size: 0.82rem; }
.mpv2-fighter-lvl  { font-size: 0.66rem; color: var(--mpv2-text-faint); font-family: var(--mpv2-font-mono); }
.mpv2-hp-bar { height: 8px; border-radius: 999px; background: rgba(100,116,139,0.3); overflow: hidden; position: relative; }
.mpv2-hp-fill { height: 100%; border-radius: 999px; background: linear-gradient(90deg, var(--mpv2-green), var(--mpv2-cyan)); position: relative; transition: width var(--mpv2-dur-slow) var(--mpv2-ease-out); }
.mpv2-hp-fill.is-low    { background: linear-gradient(90deg, var(--mpv2-amber), var(--mpv2-red)); }
.mpv2-hp-fill::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.4), transparent);
  animation: mpv2-hp-shine 2s ease-in-out infinite;
}
.mpv2-battle-vs-tag { font-family: var(--mpv2-font-disp); font-weight: 900; color: var(--mpv2-text-faint); font-size: 0.8rem; }
.mpv2-damage { position: absolute; font-family: var(--mpv2-font-mono); font-weight: 900; color: var(--mpv2-red); text-shadow: 0 0 6px rgba(239,68,68,0.8); animation: mpv2-damage-float 1.5s ease-out forwards; pointer-events: none; }
.mpv2-battle-foot { display: flex; align-items: center; justify-content: space-between; font-size: 0.72rem; color: var(--mpv2-text-dim); margin-top: 12px; border-top: 1px dashed var(--mpv2-border); padding-top: 10px; }
.mpv2-battle-log { font-family: var(--mpv2-font-mono); font-size: 0.7rem; color: var(--mpv2-text-dim); padding: 8px 10px; background: rgba(5,5,16,0.4); border-radius: 8px; margin-top: 10px; min-height: 36px; }

/* ── Collections strip ─────────────────────────────────────────────────── */
.mpv2-cols { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
@media (max-width: 1024px) { .mpv2-cols { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px)  { .mpv2-cols { grid-template-columns: 1fr; } }
.mpv2-col-card {
  border-radius: var(--mpv2-radius-lg); overflow: hidden; background: var(--mpv2-bg-panel);
  border: 1px solid var(--mpv2-border); transition: all var(--mpv2-dur-med) var(--mpv2-ease-out);
}
.mpv2-col-card:hover { transform: translateY(-3px); box-shadow: var(--mpv2-shadow-hover); border-color: var(--mpv2-border-hi); }
.mpv2-col-banner { height: 96px; background: linear-gradient(135deg, rgba(139,92,246,0.5), rgba(34,211,238,0.3)); position: relative; }
.mpv2-col-avatar { position: absolute; bottom: -22px; left: 16px; width: 56px; height: 56px; border-radius: 16px; background: linear-gradient(135deg, #8b5cf6, #22d3ee); border: 3px solid var(--mpv2-bg-deep); box-shadow: 0 0 20px rgba(139,92,246,0.4); }
.mpv2-col-body { padding: 30px 16px 16px; }
.mpv2-col-name { font-weight: 900; font-family: var(--mpv2-font-disp); display: flex; align-items: center; gap: 6px; font-size: 1rem; margin-bottom: 12px; }
.mpv2-col-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; margin-bottom: 12px; }
.mpv2-col-stat-lbl { font-size: 0.62rem; color: var(--mpv2-text-faint); text-transform: uppercase; letter-spacing: 0.08em; font-weight: 700; }
.mpv2-col-stat-val { font-size: 0.88rem; font-weight: 800; font-family: var(--mpv2-font-mono); margin-top: 2px; }

/* ── Activity ticker ───────────────────────────────────────────────────── */
.mpv2-ticker {
  padding: 14px 0; margin-top: 40px; border-top: 1px solid var(--mpv2-border);
  border-bottom: 1px solid var(--mpv2-border); background: var(--mpv2-bg-panel);
  overflow: hidden; position: relative;
}
.mpv2-ticker-track { display: flex; gap: 32px; padding: 0 24px; animation: mpv2-ticker-scroll 60s linear infinite; white-space: nowrap; }
.mpv2-ticker-item { display: inline-flex; align-items: center; gap: 8px; font-size: 0.8rem; color: var(--mpv2-text-dim); }
.mpv2-ticker-item strong { color: var(--mpv2-text); font-weight: 800; }
.mpv2-ticker-item .mpv2-icon { width: 22px; height: 22px; border-radius: 6px; display: grid; place-items: center; font-size: 0.72rem; }
.mpv2-ticker-item .mpv2-icon.is-mint { background: rgba(52,211,153,0.18); color: var(--mpv2-green); }
.mpv2-ticker-item .mpv2-icon.is-trade{ background: rgba(139,92,246,0.18); color: var(--mpv2-purple); }
.mpv2-ticker-item .mpv2-icon.is-fuse { background: rgba(244,114,182,0.18); color: var(--mpv2-pink); }
.mpv2-ticker-item .mpv2-icon.is-bid  { background: rgba(34,211,238,0.18); color: var(--mpv2-cyan); }
.mpv2-ticker-item .mpv2-icon.is-win  { background: rgba(245,158,11,0.18); color: var(--mpv2-amber); }

/* ── Footer ────────────────────────────────────────────────────────────── */
.mpv2-foot { text-align: center; padding: 42px 24px; color: var(--mpv2-text-faint); font-size: 0.78rem; }
.mpv2-foot-badges { display: inline-flex; gap: 10px; margin-top: 10px; flex-wrap: wrap; justify-content: center; }
.mpv2-foot-badge { padding: 4px 10px; border-radius: 999px; background: var(--mpv2-bg-panel); border: 1px solid var(--mpv2-border); font-size: 0.68rem; letter-spacing: 0.08em; text-transform: uppercase; font-weight: 700; color: var(--mpv2-text-dim); }

/* ── Skeletons (pre-hydration) ─────────────────────────────────────────── */
.mpv2-skel {
  background: linear-gradient(90deg, rgba(139,92,246,0.06) 0%, rgba(139,92,246,0.18) 50%, rgba(139,92,246,0.06) 100%);
  background-size: 200% 100%; animation: mpv2-skel-shimmer 1.5s infinite;
  border-radius: var(--mpv2-radius-sm);
}
@keyframes mpv2-skel-shimmer { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }

/* ── Animations ────────────────────────────────────────────────────────── */
@keyframes mpv2-particle-drift {
  0%   { transform: translate(0, 0);        opacity: 0; }
  10%  { opacity: 1; }
  90%  { opacity: 1; }
  100% { transform: translate(30px, -40vh); opacity: 0; }
}
@keyframes mpv2-grad-shift { 0%, 100% { background-position: 0% 50%; } 50% { background-position: 100% 50%; } }
@keyframes mpv2-silhouette-float { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-8px); } }
@keyframes mpv2-orbit-rotate { to { transform: rotate(360deg); } }
/* Chip float keyframes — keeps the -50% X centring applied by the slot rule. */
@keyframes mpv2-chip-float {
  0%, 100% { transform: translate(-50%, 0); }
  50%      { transform: translate(-50%, -6px); }
}
@keyframes mpv2-border-spin  { to { --angle: 360deg; } }
@keyframes mpv2-heartbeat { 0%, 100% { opacity: 1; transform: scale(1); } 50% { opacity: 0.6; transform: scale(1.3); } }
@keyframes mpv2-heart-pulse { 0% { transform: scale(1); } 40% { transform: scale(1.4); } 100% { transform: scale(1.1); } }
@keyframes mpv2-fleck-drift {
  0%, 100% { transform: translate(0, 0);   opacity: 0.4; }
  50%      { transform: translate(6px, -8px); opacity: 1; }
}
@keyframes mpv2-card-enter {
  0%   { opacity: 0; transform: translateY(20px) scale(0.98); }
  100% { opacity: 1; transform: translateY(0)    scale(1); }
}
@keyframes mpv2-battle-sweep { 0% { left: -100%; } 100% { left: 100%; } }
@keyframes mpv2-hp-shine     { 0%, 100% { opacity: 0.3; } 50% { opacity: 0.7; } }
@keyframes mpv2-damage-float {
  0%   { transform: translate(0, 0);      opacity: 1; }
  100% { transform: translate(0, -40px);  opacity: 0; }
}
@keyframes mpv2-ticker-scroll { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }

/* ── A11y — reduced motion ─────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  .mpv2 *,
  .mpv2 *::before,
  .mpv2 *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
  }
}

/* ── A11y — focus visibility ───────────────────────────────────────────── */
.mpv2 :focus-visible {
  outline: 2px solid var(--mpv2-cyan);
  outline-offset: 2px;
  border-radius: 8px;
}
