/* ==========================================================
   NIGGLET · POKÉMON GANGSTER · styles.css
   Burnt-Sunset Holo TCG · Burnt Orange / Gold / Cocoa
   ========================================================== */

*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }

:root {
  /* burnt sunset palette — pulled from the Chamo / Nigglett cards */
  --sun-1: #ffd27a;    /* pale gold */
  --sun-2: #f0a02a;    /* tcg gold */
  --sun-3: #d3631a;    /* burnt orange */
  --sun-4: #8a3a14;    /* roasted brick */
  --cocoa: #3a1d0e;    /* deep cocoa */
  --ink:   #1a0e06;    /* near-black ink */
  --tan-1: #f6e6c1;    /* card stock highlight */
  --tan-2: #e6c98a;    /* card stock mid */
  --tan-3: #c79a4e;    /* card stock shadow */
  --red:   #b81b1b;    /* fire red, like card energy */
  --rouge: #6f1212;
  --teal:  #2a8f9a;    /* solana cyan */
  --violet:#5e2bd5;    /* dark energy */
  --leaf:  #4a8f2e;
  --pgold-1:#fff3b0;
  --pgold-2:#e6b53c;
  --pgold-3:#8a5a14;

  --shadow-card: 0 18px 30px -18px rgba(40,18,4,.55), 0 6px 14px -6px rgba(40,18,4,.4);
}

/* ---------- backdrop ---------- */
body {
  font-family: "Cabin", system-ui, sans-serif;
  color: var(--ink);
  min-height: 100vh;
  background:
    radial-gradient(ellipse at 18% 8%,  rgba(255,210,122,.55), transparent 55%),
    radial-gradient(ellipse at 82% 12%, rgba(255,160,60,.45),  transparent 55%),
    radial-gradient(ellipse at 50% 110%, rgba(58,29,14,.7),    transparent 60%),
    linear-gradient(180deg, #f7c873 0%, #e08a2c 22%, #a8430f 60%, #4a1c08 100%);
  background-attachment: fixed;
  -webkit-font-smoothing: antialiased;
  position: relative;
}

/* binder rings / leather backdrop */
body::before {
  content: "";
  position: fixed; inset: 0;
  background:
    repeating-linear-gradient(
      90deg,
      transparent 0 calc(50% - 2px),
      rgba(255, 220, 140, .12) calc(50% - 2px) calc(50% - 1px),
      transparent calc(50% - 1px) calc(50% + 1px),
      rgba(0,0,0,.18) calc(50% + 1px) calc(50% + 2px),
      transparent calc(50% + 2px) 100%
    ),
    radial-gradient(circle at 50% 8%,  rgba(0,0,0,.22) 0 6px, transparent 7px),
    radial-gradient(circle at 50% 28%, rgba(0,0,0,.22) 0 6px, transparent 7px),
    radial-gradient(circle at 50% 50%, rgba(0,0,0,.22) 0 6px, transparent 7px),
    radial-gradient(circle at 50% 72%, rgba(0,0,0,.22) 0 6px, transparent 7px),
    radial-gradient(circle at 50% 92%, rgba(0,0,0,.22) 0 6px, transparent 7px);
  pointer-events: none;
  z-index: 0;
  opacity: 0.5;
}
body.no-binder::before { display: none; }

/* film grain */
body::after {
  content: "";
  position: fixed; inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.5 0'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='0.55'/></svg>");
  pointer-events: none;
  z-index: 1;
  opacity: 0.12;
  mix-blend-mode: multiply;
}
body.no-grain::after { display: none; }

/* shimmer band across the whole page like a holo sheet */
.shimmer-band {
  position: fixed; inset: 0;
  background: linear-gradient(115deg,
    transparent 30%,
    rgba(255,255,255,.08) 45%,
    rgba(255,255,255,.20) 50%,
    rgba(255,255,255,.08) 55%,
    transparent 70%);
  pointer-events: none;
  z-index: 2;
  mix-blend-mode: soft-light;
}

.bay { position: relative; z-index: 3; padding: 56px 0; }
.frame { max-width: 1200px; margin: 0 auto; padding: 0 28px; }

/* ---------- top marquee ---------- */
.top-marquee {
  position: relative; z-index: 5;
  background: var(--cocoa);
  color: var(--sun-1);
  border-bottom: 3px solid var(--sun-2);
  border-top: 3px solid var(--sun-2);
  overflow: hidden;
  font-family: "Russo One", sans-serif;
  letter-spacing: 0.12em;
  font-size: 13px;
  padding: 9px 0;
}
.top-marquee .track {
  display: inline-flex; gap: 36px;
  white-space: nowrap;
  animation: tmarq 38s linear infinite;
}
.top-marquee .dot { color: var(--sun-3); margin: 0 12px; font-style: normal; }
@keyframes tmarq { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ============================================================
   TCG CARD FRAME — gold leaf border with inner cocoa rail.
   Reusable wrapper for every card surface on the page.
   ============================================================ */
.tcg-frame {
  position: relative;
  padding: 10px;
  border-radius: 18px;
  background:
    linear-gradient(135deg, var(--pgold-1) 0%, var(--pgold-2) 40%, var(--pgold-3) 75%, var(--pgold-2) 100%);
  box-shadow:
    inset 0 0 0 2px rgba(255,255,255,.5),
    inset 0 0 0 3px rgba(122,70,14,.7),
    inset 0 0 0 5px rgba(255,235,180,.55),
    0 22px 40px -22px rgba(28,12,4,.7),
    0 8px 18px -8px rgba(28,12,4,.5);
}
.tcg-frame::before {
  /* gold filigree corners */
  content: "";
  position: absolute; inset: 4px;
  border-radius: 14px;
  background:
    radial-gradient(circle at 8px 8px,   rgba(255,255,255,.6) 0 2px, transparent 3px),
    radial-gradient(circle at calc(100% - 8px) 8px,   rgba(255,255,255,.6) 0 2px, transparent 3px),
    radial-gradient(circle at 8px calc(100% - 8px),   rgba(255,255,255,.6) 0 2px, transparent 3px),
    radial-gradient(circle at calc(100% - 8px) calc(100% - 8px), rgba(255,255,255,.6) 0 2px, transparent 3px);
  pointer-events: none;
}
.tcg-frame.holo::after {
  content: "";
  position: absolute; inset: 4px;
  border-radius: 14px;
  background: linear-gradient(115deg,
    transparent 25%,
    rgba(255,210,255,.18) 40%,
    rgba(180,255,255,.22) 48%,
    rgba(255,235,140,.22) 55%,
    transparent 75%);
  background-size: 220% 220%;
  animation: holosheen 7s ease-in-out infinite;
  pointer-events: none;
  mix-blend-mode: screen;
}
@keyframes holosheen {
  0% { background-position: 0% 0%; }
  50% { background-position: 100% 100%; }
  100% { background-position: 0% 0%; }
}
.tcg-inner {
  position: relative;
  border-radius: 11px;
  padding: 22px;
  background:
    radial-gradient(ellipse at 30% 0%, var(--tan-1) 0%, var(--tan-2) 55%, var(--tan-3) 100%);
  box-shadow:
    inset 0 0 0 1px rgba(122,70,14,.4),
    inset 0 0 22px rgba(122,70,14,.2);
  overflow: hidden;
}
.tcg-inner::before {
  /* paper texture */
  content: "";
  position: absolute; inset: 0;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(122,70,14,.07) 0 1px, transparent 1px),
    radial-gradient(circle at 70% 80%, rgba(122,70,14,.06) 0 1px, transparent 1px);
  background-size: 6px 6px, 9px 9px;
  pointer-events: none;
  opacity: .9;
}

/* ============================================================
   HERO — gigantic TCG card
   ============================================================ */
.hero { padding-top: 38px; }
.hero .frame {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
  gap: 40px;
  align-items: center;
}
.hero-card {
  width: 100%;
  max-width: 580px;
  margin: 0 auto;
}
.hero-card .tcg-inner { padding: 14px 16px 18px; }

.card-top {
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  align-items: center;
  gap: 10px;
  margin-bottom: 4px;
}
.basic-tag {
  background: var(--cocoa); color: var(--sun-1);
  font-family: "Russo One", sans-serif;
  font-size: 11px; letter-spacing: 0.12em;
  padding: 4px 8px; border-radius: 3px;
  border: 2px solid var(--pgold-2);
}
.card-name {
  font-family: "Bowlby One SC", "Bowlby One", sans-serif;
  font-size: 36px;
  color: #fff;
  -webkit-text-stroke: 2px var(--ink);
  text-shadow:
    3px 3px 0 var(--ink),
    0 0 10px rgba(255,200,80,.35);
  letter-spacing: 0.02em;
  line-height: 1;
  white-space: nowrap;
}
.card-name .ticker {
  display: inline-block;
  font-family: "Russo One", sans-serif;
  font-size: 16px;
  margin-left: 10px;
  background: var(--red); color: #fff;
  padding: 4px 10px; border-radius: 4px;
  border: 2px solid var(--ink);
  -webkit-text-stroke: 0;
  text-shadow: none;
  vertical-align: middle;
}
.card-hp {
  font-family: "Bowlby One SC", sans-serif;
  font-size: 30px; color: #fff;
  -webkit-text-stroke: 2px var(--ink);
  text-shadow: 2px 2px 0 var(--ink);
  line-height: 1;
}
.card-hp .hp-label { font-size: 14px; margin-right: 4px; color: var(--red); }
.type-orb {
  width: 38px; height: 38px; border-radius: 50%;
  background:
    radial-gradient(circle at 30% 30%, #6a4bd8, #2a0c7a 70%, #0a0220 100%);
  box-shadow: inset 0 0 0 2px var(--ink), inset -3px -4px 8px rgba(0,0,0,.5), inset 3px 4px 8px rgba(255,255,255,.25);
  position: relative;
}
.type-orb::after {
  content: ""; position: absolute; inset: 8px;
  background: radial-gradient(circle at 35% 30%, rgba(255,255,255,.5), transparent 60%);
  border-radius: 50%;
}
.subname {
  font-family: "Russo One", sans-serif;
  font-size: 11px; letter-spacing: 0.16em;
  color: var(--cocoa);
  margin-bottom: 8px;
}

.card-art {
  position: relative;
  height: 320px;
  border-radius: 8px;
  overflow: hidden;
  background:
    radial-gradient(circle at 50% 60%, #ffba6b 0%, #c8551a 45%, #5a1e08 100%);
  border: 3px solid var(--pgold-3);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.4);
  display: flex; align-items: center; justify-content: center;
}
.first-ed {
  position: absolute; top: 10px; left: 10px; z-index: 4;
  background: var(--red); color: #fff;
  padding: 4px 10px;
  font-family: "Russo One", sans-serif;
  font-size: 11px; letter-spacing: 0.1em;
  border: 2px solid var(--ink);
  border-radius: 3px;
  transform: rotate(-6deg);
  box-shadow: 2px 2px 0 var(--ink);
}
.card-art .medallion {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
}
.medallion .ring {
  width: 88%; aspect-ratio: 1; border-radius: 50%;
  border: 6px solid var(--pgold-2);
  box-shadow:
    inset 0 0 0 2px var(--pgold-3),
    inset 0 0 0 8px var(--pgold-1),
    inset 0 0 0 10px var(--pgold-3);
  background: transparent;
  position: absolute;
}
.medallion .inner-ring {
  width: 70%; aspect-ratio: 1; border-radius: 50%;
  border: 2px dashed rgba(255,255,255,.4);
  position: absolute;
}
.card-art .hero-mole {
  position: relative;
  z-index: 3;
  max-height: 86%;
  max-width: 82%;
  object-fit: contain;
  filter: drop-shadow(0 12px 12px rgba(0,0,0,.5));
  animation: bob 3.6s ease-in-out infinite;
}
@keyframes bob {
  0%, 100% { transform: translateY(0) rotate(-1deg); }
  50%      { transform: translateY(-8px) rotate(1deg); }
}
.solana-coin {
  position: absolute; bottom: 14px; left: 14px;
  width: 78px; height: 78px; border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, #2a1a0a, #0a0500);
  display: flex; align-items: center; justify-content: center;
  text-align: center;
  border: 3px solid var(--pgold-2);
  box-shadow: 0 6px 12px rgba(0,0,0,.45);
  z-index: 4;
}
.solana-coin .lbl {
  font-family: "Russo One", sans-serif;
  font-size: 8px; color: var(--sun-1);
  letter-spacing: 0.12em;
}
.solana-coin .sym {
  font-family: "Bowlby One", sans-serif;
  font-size: 11px;
  background: linear-gradient(90deg, #9945ff, #14f195);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  margin-top: 2px;
}
.city {
  position: absolute; left: 0; right: 0; bottom: 0; height: 38%;
  background:
    linear-gradient(180deg, transparent 0%, rgba(58,29,14,.55) 100%),
    repeating-linear-gradient(90deg,
      transparent 0 16px,
      rgba(40,15,4,.4) 16px 22px,
      transparent 22px 36px,
      rgba(40,15,4,.4) 36px 44px);
  z-index: 2;
}

.dex-strip {
  background: var(--tan-1);
  border: 2px solid var(--cocoa);
  border-radius: 30px;
  text-align: center;
  font-family: "Cabin", sans-serif;
  font-size: 13px; font-weight: 600;
  padding: 6px 14px;
  margin: 14px 0 12px;
  color: var(--ink);
}

.attacks { display: flex; flex-direction: column; gap: 12px; }
.ability {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 12px;
  align-items: start;
  border-bottom: 2px dashed var(--cocoa);
  padding-bottom: 12px;
}
.ability .tag {
  background: var(--red); color: #fff;
  font-family: "Russo One", sans-serif;
  font-size: 12px; letter-spacing: 0.06em;
  padding: 4px 10px; border-radius: 4px;
  border: 2px solid var(--ink);
}
.ability .body { font-size: 14px; line-height: 1.45; }
.ability .body b {
  display: block;
  font-family: "Bowlby One SC", sans-serif;
  font-size: 22px;
  color: var(--red);
  -webkit-text-stroke: 1px var(--ink);
  letter-spacing: 0.01em;
  line-height: 1.05;
  margin-bottom: 4px;
}

.attack {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 12px;
  align-items: center;
  border-bottom: 2px dashed var(--cocoa);
  padding-bottom: 12px;
}
.attack:last-child { border-bottom: none; padding-bottom: 0; }
.energy-row { display: flex; gap: 4px; flex-shrink: 0; }
.at-name {
  display: flex; flex-direction: column; gap: 2px;
}
.at-name b {
  font-family: "Bowlby One SC", sans-serif;
  font-size: 24px;
  color: var(--ink);
  letter-spacing: 0.01em;
  line-height: 1;
}
.at-name .flavor { font-size: 12.5px; line-height: 1.45; color: var(--cocoa); }
.dmg {
  font-family: "Bowlby One SC", sans-serif;
  font-size: 30px;
  color: var(--ink);
  -webkit-text-stroke: 1px var(--ink);
  text-shadow: 2px 2px 0 rgba(255,235,180,.6);
}

/* energy icons */
.energy {
  display: inline-block;
  width: 22px; height: 22px; border-radius: 50%;
  border: 2px solid var(--ink);
  box-shadow: inset -2px -3px 5px rgba(0,0,0,.35), inset 2px 3px 5px rgba(255,255,255,.35);
  position: relative;
}
.energy.dark      { background: radial-gradient(circle at 30% 30%, #6a4bd8, #1a0850 80%); }
.energy.fire      { background: radial-gradient(circle at 30% 30%, #ffcf6a, #c4321a 60%, #5a1208 100%); }
.energy.colorless { background: radial-gradient(circle at 30% 30%, #fffaf0, #c8b690 80%); }
.energy.gold      { background: radial-gradient(circle at 30% 30%, #fff3b0, #c98a14 70%); }

.wrr {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin: 14px 0 12px;
}
.pill {
  background: var(--tan-1);
  border: 2px solid var(--cocoa);
  border-radius: 30px;
  font-size: 11px;
  font-family: "Russo One", sans-serif;
  letter-spacing: 0.06em;
  padding: 6px 10px;
  text-align: center;
  display: flex; align-items: center; justify-content: center; gap: 6px;
  color: var(--cocoa);
}
.pill b { color: var(--ink); }

.card-foot {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 10px;
  align-items: center;
  font-family: "Cabin", sans-serif;
  font-size: 11px;
  border-top: 1px dashed var(--cocoa);
  padding-top: 10px;
  color: var(--cocoa);
}
.card-foot .nm { font-style: italic; }
.card-foot .num {
  display: flex; align-items: center; gap: 8px; justify-content: center;
  font-family: "Russo One", sans-serif;
  font-size: 11px;
}
.nig-pill {
  background: var(--ink); color: var(--sun-1);
  padding: 2px 6px; border-radius: 2px;
  font-family: "Bowlby One SC", sans-serif;
  font-size: 10px;
  letter-spacing: 0.08em;
}
.card-foot .rarity {
  text-align: right;
  font-family: "Russo One", sans-serif;
  color: var(--red);
}

/* hero CTA side */
.hero-cta { display: flex; flex-direction: column; gap: 24px; }
.hero-blurb {
  font-family: "Cabin", sans-serif;
  font-size: 19px;
  line-height: 1.55;
  color: var(--tan-1);
  text-shadow: 1px 1px 0 rgba(0,0,0,.45);
  text-wrap: pretty;
}
.hero-blurb b { color: #fff; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; }
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: "Bowlby One SC", sans-serif;
  font-size: 16px;
  letter-spacing: 0.04em;
  padding: 14px 22px;
  border-radius: 6px;
  border: 3px solid var(--ink);
  background: linear-gradient(180deg, var(--sun-1) 0%, var(--sun-2) 100%);
  color: var(--ink);
  text-decoration: none;
  box-shadow: 4px 4px 0 var(--ink);
  transition: transform .12s ease, box-shadow .12s ease;
  cursor: pointer;
}
.btn:hover { transform: translate(-2px,-2px); box-shadow: 6px 6px 0 var(--ink); }
.btn.red { background: linear-gradient(180deg, #ff5050 0%, #b81b1b 100%); color: #fff; }
.btn.ghost {
  background: transparent;
  color: var(--tan-1);
  border-color: var(--tan-1);
  box-shadow: 4px 4px 0 rgba(0,0,0,.4);
}

/* ============================================================
   SECTION HEADS
   ============================================================ */
.section-head { text-align: center; margin-bottom: 30px; }
.section-stamp {
  display: inline-block;
  font-family: "Russo One", sans-serif;
  font-size: 12px;
  letter-spacing: 0.18em;
  color: var(--sun-1);
  background: var(--cocoa);
  padding: 6px 14px;
  border-radius: 4px;
  border: 2px solid var(--sun-2);
}
.section-title {
  font-family: "Bowlby One SC", sans-serif;
  font-size: clamp(40px, 6vw, 72px);
  color: #fff;
  -webkit-text-stroke: 3px var(--ink);
  text-shadow: 5px 5px 0 var(--ink), 0 0 24px rgba(255,160,60,.6);
  letter-spacing: 0.01em;
  line-height: 1;
  margin: 14px 0 10px;
}
.section-title .gold {
  background: linear-gradient(180deg, var(--sun-1) 0%, var(--sun-2) 50%, var(--sun-3) 100%);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  -webkit-text-stroke: 0;
  text-shadow: 4px 4px 0 var(--ink);
}
.section-deck {
  font-size: 17px;
  line-height: 1.55;
  max-width: 720px;
  margin: 0 auto;
  color: var(--tan-1);
  text-shadow: 1px 1px 0 rgba(0,0,0,.4);
  text-wrap: pretty;
}

/* ============================================================
   POKÉDEX
   ============================================================ */
.dex-wrap { display: grid; grid-template-columns: 320px 1fr; gap: 28px; align-items: stretch; }
.dex-device {
  background: linear-gradient(180deg, #d12020 0%, #8d0d0d 100%);
  border: 4px solid var(--ink);
  border-radius: 16px 30px 16px 16px;
  padding: 14px;
  box-shadow: 6px 6px 0 var(--cocoa), inset 0 0 0 2px rgba(255,255,255,.18);
  display: flex; flex-direction: column; gap: 10px;
}
.led-row { display: flex; align-items: center; gap: 6px; }
.led {
  width: 38px; height: 38px; border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, #9fd8ff, #1d7be0 60%, #082658);
  border: 3px solid var(--ink);
  box-shadow: inset 2px 3px 6px rgba(255,255,255,.45), inset -2px -3px 6px rgba(0,0,0,.5);
}
.led-sm {
  width: 14px; height: 14px; border-radius: 50%;
  border: 2px solid var(--ink);
}
.led-sm.r { background: #ff4040; }
.led-sm.y { background: #f7d83c; }
.led-sm.g { background: #4ed14e; }
.screen {
  background: #1c1a0a;
  color: #6cf07a;
  font-family: "VT323", monospace;
  font-size: 16px;
  border: 3px solid var(--ink);
  border-radius: 6px;
  padding: 10px 12px;
  line-height: 1.35;
  box-shadow: inset 0 0 18px rgba(0,255,80,.18);
  text-shadow: 0 0 4px rgba(108,240,122,.7);
}
.screen .no { font-size: 12px; opacity: .75; }
.screen .nm { font-size: 26px; line-height: 1; margin: 4px 0; color: #b6ffc0; }
.screen .ty { font-size: 12px; color: var(--sun-1); letter-spacing: 0.1em; }
.screen .cry { margin-top: 8px; color: #f0c; }
.blink { animation: bl 1s steps(1) infinite; }
@keyframes bl { 50% { opacity: 0; } }
.pad {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
}
.pad span, .pad b {
  height: 22px; border-radius: 4px;
  background: var(--ink);
  border: 2px solid #4a0808;
}
.pad b { background: var(--cocoa); }

.dex-card .tcg-inner { padding: 24px; height: 100%; }
.dex-card { display: flex; }
.dex-card .meta {
  font-family: "Russo One", sans-serif;
  font-size: 11px; letter-spacing: 0.14em;
  color: var(--red);
  margin-bottom: 4px;
}
.dex-card h3 {
  font-family: "Bowlby One SC", sans-serif;
  font-size: 32px;
  color: var(--ink);
  letter-spacing: 0.01em;
  margin: 0 0 10px;
}
.dex-card p { font-size: 15px; line-height: 1.55; margin: 0 0 10px; }
.dex-card p i { color: var(--rouge); font-weight: 600; }

.stat-bars { margin-top: 14px; display: flex; flex-direction: column; gap: 7px; }
.stat-row { display: grid; grid-template-columns: 110px 1fr 44px; gap: 10px; align-items: center; }
.stat-row .l { font-family: "Russo One", sans-serif; font-size: 11px; letter-spacing: 0.1em; color: var(--cocoa); }
.stat-row .v { font-family: "Bowlby One", sans-serif; font-size: 16px; color: var(--ink); text-align: right; }
.bar {
  height: 14px; background: var(--cocoa); border-radius: 7px;
  border: 2px solid var(--ink);
  overflow: hidden;
  position: relative;
}
.bar i {
  display: block; height: 100%;
  background: linear-gradient(90deg, var(--sun-2), var(--red));
}
.bar.y i { background: linear-gradient(90deg, #f7d83c, #f0a02a); }
.bar.p i { background: linear-gradient(90deg, #7d4fb8, #c4321a); }
.bar.g i { background: linear-gradient(90deg, #6acb4a, #2a8f9a); }

/* ============================================================
   EVOLUTION CHAIN
   ============================================================ */
.evo-chain {
  display: grid;
  grid-template-columns: 1fr auto 1fr auto 1fr;
  gap: 14px;
  align-items: stretch;
}
.evo-card .tcg-inner { padding: 18px; height: 100%; display: flex; flex-direction: column; }
.evo-card .stage-tag {
  font-family: "Russo One", sans-serif;
  font-size: 11px;
  letter-spacing: 0.12em;
  color: var(--red);
  margin-bottom: 8px;
}
.evo-card .pic {
  height: 130px;
  border-radius: 8px;
  background:
    radial-gradient(ellipse at 50% 30%, var(--sun-1) 0%, var(--sun-2) 40%, var(--sun-3) 100%);
  border: 2px solid var(--cocoa);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 12px;
  position: relative;
}
.evo-card .pic .glyph {
  font-family: "Bowlby One SC", sans-serif;
  font-size: 64px; color: var(--ink);
  text-shadow: 4px 4px 0 rgba(255,235,180,.5);
}
.evo-card h3 {
  font-family: "Bowlby One SC", sans-serif;
  font-size: 22px; margin: 0 0 6px;
  color: var(--ink); letter-spacing: 0.01em;
}
.evo-card .flavor {
  font-family: "Cabin", sans-serif;
  font-style: italic;
  font-size: 13px; color: var(--rouge);
  margin-bottom: 10px;
  border-left: 3px solid var(--red);
  padding-left: 10px;
}
.evo-card .body { font-size: 14px; line-height: 1.5; color: var(--ink); }

.evo-arrow {
  font-family: "Bowlby One SC", sans-serif;
  font-size: 50px;
  color: var(--sun-1);
  text-shadow: 4px 4px 0 var(--ink);
  align-self: center;
}

/* ============================================================
   BINDER · trading cards
   ============================================================ */
.binder {
  background:
    linear-gradient(180deg, rgba(58,29,14,.85) 0%, rgba(20,8,2,.85) 100%);
  border-radius: 18px;
  padding: 26px;
  border: 4px solid var(--cocoa);
  box-shadow:
    inset 0 0 0 2px var(--pgold-2),
    inset 0 0 0 3px var(--cocoa),
    inset 0 0 0 4px var(--pgold-2),
    0 18px 30px -16px rgba(0,0,0,.7);
  position: relative;
}
.binder::before {
  content: "";
  position: absolute; left: 14px; right: 14px; top: 14px; bottom: 14px;
  border: 2px dashed rgba(255,210,140,.25);
  border-radius: 12px;
  pointer-events: none;
}
.sleeves {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  position: relative;
}
.sleeve {
  background: rgba(255,255,255,.06);
  border-radius: 10px;
  padding: 8px;
  border: 1px solid rgba(255,210,140,.18);
  display: flex; flex-direction: column;
  transition: transform .2s ease;
}
.sleeve:hover { transform: translateY(-4px) rotate(-1deg); }
.sleeve img {
  width: 100%; display: block;
  border-radius: 8px;
  box-shadow:
    0 12px 24px -10px rgba(0,0,0,.6),
    0 0 0 1px rgba(0,0,0,.6);
}
.sleeve .caption {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: 8px;
  font-family: "Russo One", sans-serif;
  font-size: 11px;
  letter-spacing: 0.08em;
  color: var(--sun-1);
}
.sleeve .caption .num { color: var(--sun-2); }
.sleeve.placeholder {
  aspect-ratio: 5 / 7;
  display: flex; align-items: center; justify-content: center;
  background:
    repeating-linear-gradient(45deg,
      rgba(255,255,255,.03) 0 10px,
      rgba(255,255,255,.06) 10px 20px);
}
.sleeve.placeholder .back {
  width: 80%; height: 80%;
  border-radius: 10px;
  background:
    radial-gradient(circle at 50% 50%, var(--red) 0 22%, #fff 22% 24%, var(--red) 24% 32%, var(--cocoa) 32% 33%, #fff 33% 35%, var(--cocoa) 35% 50%);
  position: relative;
  border: 4px solid var(--cocoa);
  box-shadow: inset 0 0 0 2px #fff;
}
.sleeve.placeholder .back::after {
  content: "?";
  position: absolute;
  inset: 0;
  display: flex; align-items: center; justify-content: center;
  font-family: "Bowlby One SC", sans-serif;
  font-size: 60px;
  color: var(--ink);
}
.binder-foot {
  display: flex; justify-content: space-between;
  margin-top: 18px;
  font-family: "Russo One", sans-serif;
  font-size: 11px;
  letter-spacing: 0.1em;
  color: var(--sun-1);
}

/* ============================================================
   FIVE FAMILIES
   ============================================================ */
.families {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 14px;
  align-items: stretch;
}
.family .tcg-inner { padding: 18px; height: 100%; display: flex; flex-direction: column; }
.family .roman {
  font-family: "Bowlby One SC", sans-serif;
  font-size: 56px;
  color: var(--red);
  -webkit-text-stroke: 2px var(--ink);
  text-shadow: 4px 4px 0 rgba(255,235,180,.6);
  line-height: 0.9;
  margin-bottom: 4px;
}
.family .nm {
  font-family: "Bowlby One SC", sans-serif;
  font-size: 20px;
  color: var(--ink);
  margin-bottom: 4px;
  line-height: 1.05;
}
.family .role {
  font-family: "Russo One", sans-serif;
  font-size: 10px;
  letter-spacing: 0.12em;
  color: var(--cocoa);
  margin-bottom: 10px;
  text-transform: uppercase;
}
.family ul { list-style: none; padding: 0; margin: 0; flex: 1; }
.family ul li {
  font-size: 13px; line-height: 1.45;
  padding: 6px 0 6px 16px;
  border-bottom: 1px dashed rgba(58,29,14,.3);
  position: relative;
}
.family ul li:last-child { border-bottom: none; }
.family ul li::before {
  content: "▸";
  position: absolute; left: 0;
  color: var(--red);
  font-weight: 800;
}

/* ============================================================
   TOKENOMICS
   ============================================================ */
.token-wrap {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 28px;
  align-items: stretch;
}
.cardback {
  background:
    radial-gradient(circle at 50% 0%, #2a0c7a 0%, #0a0220 70%);
  color: var(--sun-1);
  border-radius: 18px;
  border: 5px solid var(--pgold-2);
  box-shadow:
    inset 0 0 0 2px var(--cocoa),
    inset 0 0 0 3px var(--pgold-2),
    0 18px 30px -16px rgba(0,0,0,.7);
  padding: 24px 26px;
  position: relative;
  overflow: hidden;
}
.cardback::before {
  /* big pokéball on the back */
  content: "";
  position: absolute;
  right: -80px; bottom: -100px;
  width: 320px; height: 320px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 50% 50%,
      var(--red) 0 32%,
      var(--ink) 32% 36%,
      var(--tan-1) 36% 39%,
      var(--ink) 39% 41%,
      var(--tan-1) 41% 50%,
      transparent 50%);
  opacity: .25;
}
.cardback .pstamp {
  display: inline-block;
  background: var(--red);
  color: #fff;
  padding: 4px 10px;
  font-family: "Russo One", sans-serif;
  font-size: 11px;
  letter-spacing: 0.14em;
  border: 2px solid var(--ink);
  border-radius: 3px;
  margin-bottom: 14px;
}
.cardback h3 {
  font-family: "Bowlby One SC", sans-serif;
  font-size: 30px;
  color: #fff;
  -webkit-text-stroke: 2px var(--ink);
  text-shadow: 3px 3px 0 var(--ink);
  margin: 0 0 4px;
}
.cardback h3 small {
  display: block;
  font-family: "Russo One", sans-serif;
  font-size: 11px;
  letter-spacing: 0.14em;
  color: var(--sun-2);
  margin-top: 6px;
  -webkit-text-stroke: 0;
  text-shadow: none;
}
.tline {
  display: flex; justify-content: space-between;
  font-family: "Cabin", sans-serif;
  font-size: 15px;
  padding: 9px 0;
  border-bottom: 1px dashed rgba(255,210,140,.28);
}
.tline:last-of-type { border-bottom: none; }
.tline span { color: var(--tan-2); }
.tline b { color: #fff; font-family: "Russo One", sans-serif; font-size: 14px; letter-spacing: 0.04em; }
.tline b.red { color: #ff7373; }

.notice-card .tcg-inner { padding: 24px; }
.notice-card h4 {
  font-family: "Bowlby One SC", sans-serif;
  font-size: 24px;
  margin: 0 0 14px;
  color: var(--ink);
}
.notice-card .row {
  display: flex; justify-content: space-between;
  padding: 8px 0;
  border-bottom: 1px dashed var(--cocoa);
  font-family: "Cabin", sans-serif;
  font-size: 14px;
}
.notice-card .row span { color: var(--cocoa); }
.notice-card .row b { font-family: "Russo One", sans-serif; font-size: 12px; letter-spacing: 0.08em; color: var(--ink); }
.red-stamp {
  display: inline-block;
  margin-top: 14px;
  padding: 6px 14px;
  background: var(--red); color: #fff;
  font-family: "Russo One", sans-serif;
  font-size: 12px;
  letter-spacing: 0.12em;
  border: 2px solid var(--ink);
  border-radius: 3px;
  transform: rotate(-1deg);
}

/* ============================================================
   HOW TO COP
   ============================================================ */
.cop-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
.step .tcg-inner { padding: 22px 18px; height: 100%; display: flex; flex-direction: column; }
.step .n {
  font-family: "Bowlby One SC", sans-serif;
  font-size: 48px;
  color: var(--red);
  -webkit-text-stroke: 2px var(--ink);
  text-shadow: 3px 3px 0 rgba(255,235,180,.6);
  line-height: 1;
  margin-bottom: 8px;
}
.step h5 {
  font-family: "Bowlby One SC", sans-serif;
  font-size: 20px;
  margin: 0 0 8px;
  color: var(--ink);
}
.step p { font-size: 14px; line-height: 1.55; margin: 0; }
.step a { color: var(--rouge); font-weight: 700; }

/* ============================================================
   WANTED
   ============================================================ */
.wanted-frame { max-width: 900px; margin: 0 auto; }
.wanted .topline {
  text-align: center;
  font-family: "Russo One", sans-serif;
  font-size: 12px;
  letter-spacing: 0.2em;
  color: var(--red);
  margin-bottom: 6px;
}
.wanted .word {
  text-align: center;
  font-family: "Bowlby One SC", sans-serif;
  font-size: 84px;
  color: var(--ink);
  letter-spacing: 0.02em;
  margin: 0;
  line-height: 1;
}
.wanted .word .gold {
  background: linear-gradient(180deg, var(--sun-1), var(--sun-3));
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
}
.wanted .crime {
  text-align: center;
  font-family: "Russo One", sans-serif;
  font-size: 15px;
  letter-spacing: 0.1em;
  color: var(--cocoa);
  margin: 10px 0 6px;
}
.wanted .reward {
  text-align: center;
  font-family: "Bowlby One SC", sans-serif;
  font-size: 22px;
  color: var(--red);
  margin: 6px 0;
}
.wanted .smallprint {
  text-align: center;
  font-family: "Cabin", sans-serif;
  font-style: italic;
  font-size: 13px;
  color: var(--cocoa);
  margin: 8px 0;
}
.wanted .frames {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin: 18px 0;
}
.wanted .ph {
  aspect-ratio: 1;
  background: linear-gradient(135deg, var(--cocoa), var(--ink));
  border: 4px solid var(--pgold-2);
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-family: "Bowlby One SC", sans-serif;
  font-size: 60px;
  color: var(--sun-1);
}
.wanted .sig {
  text-align: right;
  font-family: "Cabin", sans-serif;
  font-style: italic;
  color: var(--cocoa);
  margin-top: 14px;
}

/* ============================================================
   STREET CODE
   ============================================================ */
.code-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.code-q .tcg-inner { padding: 18px 20px; }
.code-q .q {
  font-family: "Bowlby One SC", sans-serif;
  font-size: 18px;
  color: var(--ink);
  margin-bottom: 8px;
  line-height: 1.2;
}
.code-q .a {
  font-family: "Cabin", sans-serif;
  font-size: 14px;
  line-height: 1.55;
  color: var(--cocoa);
}

/* ============================================================
   RECEIPT / FOOTER
   ============================================================ */
.footer-card .tcg-inner { padding: 30px; }
.footer-card h4 {
  font-family: "Bowlby One SC", sans-serif;
  font-size: 28px;
  color: var(--ink);
  margin: 0 0 4px;
  letter-spacing: 0.01em;
}
.footer-card .sub {
  font-family: "Russo One", sans-serif;
  font-size: 12px;
  letter-spacing: 0.14em;
  color: var(--red);
  margin-bottom: 18px;
}
.footer-card .grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 6px 22px;
  margin-bottom: 18px;
}
.footer-card .r {
  display: flex; justify-content: space-between;
  padding: 8px 0;
  border-bottom: 1px dashed var(--cocoa);
  font-family: "Cabin", sans-serif;
  font-size: 14px;
}
.footer-card .r b { font-family: "Russo One", sans-serif; font-size: 12px; letter-spacing: 0.06em; }
.footer-card .r a { color: var(--rouge); text-decoration: none; }
.disclaim {
  background: var(--tan-1);
  border: 1px dashed var(--cocoa);
  border-radius: 6px;
  padding: 14px 16px;
  font-family: "Cabin", sans-serif;
  font-size: 12px;
  line-height: 1.55;
  color: var(--cocoa);
}
.footstrip {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px dashed var(--cocoa);
  font-family: "Cabin", sans-serif;
  font-size: 12px;
  color: var(--cocoa);
}
.footstrip .nm { font-style: italic; }
.footstrip .num {
  display: flex; gap: 8px; justify-content: center; align-items: center;
  font-family: "Russo One", sans-serif;
}
.footstrip .rarity {
  text-align: right;
  font-family: "Russo One", sans-serif;
  color: var(--red);
}

/* ============================================================
   STICKY BURROW CHIP
   ============================================================ */
.burrow-chip {
  position: fixed;
  right: 22px; bottom: 22px;
  width: 260px;
  z-index: 50;
  background: var(--cocoa);
  border: 3px solid var(--pgold-2);
  border-radius: 12px;
  box-shadow: 0 14px 28px -12px rgba(0,0,0,.7), inset 0 0 0 2px var(--ink);
  color: var(--sun-1);
  overflow: hidden;
  font-family: "Cabin", sans-serif;
}
.burrow-chip .hd {
  display: flex; justify-content: space-between;
  background: var(--ink);
  padding: 6px 10px;
  font-family: "Russo One", sans-serif;
  font-size: 10px;
  letter-spacing: 0.12em;
  color: var(--sun-2);
}
.burrow-chip .bd { padding: 12px; }
.burrow-chip .big {
  font-family: "Bowlby One SC", sans-serif;
  font-size: 18px;
  line-height: 1.1;
  color: #fff;
  margin-bottom: 6px;
}
.burrow-chip .sm { font-size: 12px; line-height: 1.45; color: var(--tan-2); margin-bottom: 10px; }
.burrow-chip a {
  display: block;
  background: var(--red);
  color: #fff;
  text-align: center;
  padding: 9px 10px;
  border-radius: 6px;
  border: 2px solid var(--ink);
  text-decoration: none;
  font-family: "Bowlby One SC", sans-serif;
  letter-spacing: 0.04em;
  font-size: 14px;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  .hero .frame { grid-template-columns: 1fr; }
  .dex-wrap { grid-template-columns: 1fr; }
  .evo-chain { grid-template-columns: 1fr; }
  .evo-arrow { transform: rotate(90deg); justify-self: center; }
  .families { grid-template-columns: repeat(2, 1fr); }
  .cop-row { grid-template-columns: repeat(2, 1fr); }
  .token-wrap { grid-template-columns: 1fr; }
  .sleeves { grid-template-columns: repeat(2, 1fr); }
  .wanted .word { font-size: 60px; }
}
@media (max-width: 640px) {
  .frame { padding: 0 16px; }
  .families { grid-template-columns: 1fr; }
  .cop-row { grid-template-columns: 1fr; }
  .code-grid { grid-template-columns: 1fr; }
  .footer-card .grid { grid-template-columns: 1fr; }
  .sleeves { grid-template-columns: 1fr; }
  .wrr { grid-template-columns: 1fr; }
  .card-top { grid-template-columns: 1fr auto; gap: 8px; }
  .card-name { font-size: 28px; }
  .card-hp { font-size: 24px; }
  .type-orb, .basic-tag { grid-row: 2; }
  .hero-card { max-width: 100%; }
  .card-art { height: 240px; }
  .wanted .word { font-size: 44px; }
  .burrow-chip { right: 10px; bottom: 10px; width: 220px; }
  .stat-row { grid-template-columns: 90px 1fr 38px; }
  .ability { grid-template-columns: 1fr; }
  .attack { grid-template-columns: auto 1fr; }
  .attack .dmg { grid-column: 1 / -1; text-align: right; }
}
