/* === GameTrack.gg: Pokémon GO Tracker Layout (Compact chips, subdued inactive, non-sticky toolbar) === */

/* Type Color Variables */
:root{
  --type-Bug:#A6B91A; --type-Dark:#705746; --type-Dragon:#6F35FC; --type-Electric:#F7D02C;
  --type-Fairy:#D685AD; --type-Fighting:#C22E28; --type-Fire:#EE8130; --type-Flying:#A98FF3;
  --type-Ghost:#735797; --type-Grass:#7AC74C; --type-Ground:#E2BF65; --type-Ice:#96D9D6;
  --type-Normal:#A8A77A; --type-Poison:#A33EA1; --type-Psychic:#F95587; --type-Rock:#B6A136;
  --type-Steel:#B7B7CE; --type-Water:#6390F0;
}

/* Toolbar (non-sticky) */
.toolbar {
  background: var(--bg);
  border-bottom: 1px solid rgba(255,255,255,.06);
  padding: var(--s-3) 0;
  margin-bottom: var(--s-3);
}
.toolbar-row { display: grid; gap: var(--s-2); grid-template-columns: 1fr; }
.toolbar .controls { display: flex; flex-wrap: wrap; gap: var(--s-2); }
.input, .select {
  background: var(--bg-card);
  color: var(--fg);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: var(--radius);
  padding: 10px 12px;
  min-width: 200px;
}
.counter {
  display: inline-flex; align-items: center; gap: 8px; padding: 8px 10px;
  border-radius: 999px; background: #121a17; border: 1px solid rgba(255,255,255,.08); font-size: var(--text-sm);
}

/* Type chips (compact) */
.chip-row { display: flex; gap: 6px; flex-wrap: wrap; }
.chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 999px;
  font-size: 0.85rem;
  line-height: 1.2;
  cursor: pointer; user-select: none;
  color: var(--fg);
  transition: transform .15s ease, background .15s ease, color .15s ease, border-color .15s ease;
}
.chip:hover { transform: translateY(-1px); }
.chip.active { color: #fff; border-color: transparent; }

/* Inactive subdued backgrounds by type */
.chip.type-Bug{ background: color-mix(in oklab, var(--type-Bug) 14%, transparent); border-color: color-mix(in oklab,var(--type-Bug) 50%, transparent); }
.chip.type-Dark{ background: color-mix(in oklab, var(--type-Dark) 14%, transparent); border-color: color-mix(in oklab,var(--type-Dark) 50%, transparent); }
.chip.type-Dragon{ background: color-mix(in oklab, var(--type-Dragon) 14%, transparent); border-color: color-mix(in oklab,var(--type-Dragon) 50%, transparent); }
.chip.type-Electric{ background: color-mix(in oklab, var(--type-Electric) 14%, transparent); border-color: color-mix(in oklab,var(--type-Electric) 50%, transparent); color:#e9e9e9; }
.chip.type-Fairy{ background: color-mix(in oklab, var(--type-Fairy) 14%, transparent); border-color: color-mix(in oklab,var(--type-Fairy) 50%, transparent); }
.chip.type-Fighting{ background: color-mix(in oklab, var(--type-Fighting) 14%, transparent); border-color: color-mix(in oklab,var(--type-Fighting) 50%, transparent); }
.chip.type-Fire{ background: color-mix(in oklab, var(--type-Fire) 14%, transparent); border-color: color-mix(in oklab,var(--type-Fire) 50%, transparent); }
.chip.type-Flying{ background: color-mix(in oklab, var(--type-Flying) 14%, transparent); border-color: color-mix(in oklab,var(--type-Flying) 50%, transparent); }
.chip.type-Ghost{ background: color-mix(in oklab, var(--type-Ghost) 14%, transparent); border-color: color-mix(in oklab,var(--type-Ghost) 50%, transparent); }
.chip.type-Grass{ background: color-mix(in oklab, var(--type-Grass) 14%, transparent); border-color: color-mix(in oklab,var(--type-Grass) 50%, transparent); }
.chip.type-Ground{ background: color-mix(in oklab, var(--type-Ground) 14%, transparent); border-color: color-mix(in oklab,var(--type-Ground) 50%, transparent); }
.chip.type-Ice{ background: color-mix(in oklab, var(--type-Ice) 14%, transparent); border-color: color-mix(in oklab,var(--type-Ice) 50%, transparent); }
.chip.type-Normal{ background: color-mix(in oklab, var(--type-Normal) 14%, transparent); border-color: color-mix(in oklab,var(--type-Normal) 50%, transparent); }
.chip.type-Poison{ background: color-mix(in oklab, var(--type-Poison) 14%, transparent); border-color: color-mix(in oklab,var(--type-Poison) 50%, transparent); }
.chip.type-Psychic{ background: color-mix(in oklab, var(--type-Psychic) 14%, transparent); border-color: color-mix(in oklab,var(--type-Psychic) 50%, transparent); }
.chip.type-Rock{ background: color-mix(in oklab, var(--type-Rock) 14%, transparent); border-color: color-mix(in oklab,var(--type-Rock) 50%, transparent); }
.chip.type-Steel{ background: color-mix(in oklab, var(--type-Steel) 14%, transparent); border-color: color-mix(in oklab,var(--type-Steel) 50%, transparent); }
.chip.type-Water{ background: color-mix(in oklab, var(--type-Water) 14%, transparent); border-color: color-mix(in oklab,var(--type-Water) 50%, transparent); }

/* Active vivid fills */
.chip.type-Bug.active{ background: var(--type-Bug); }
.chip.type-Dark.active{ background: var(--type-Dark); }
.chip.type-Dragon.active{ background: var(--type-Dragon); }
.chip.type-Electric.active{ background: var(--type-Electric); color:#000; }
.chip.type-Fairy.active{ background: var(--type-Fairy); }
.chip.type-Fighting.active{ background: var(--type-Fighting); }
.chip.type-Fire.active{ background: var(--type-Fire); }
.chip.type-Flying.active{ background: var(--type-Flying); }
.chip.type-Ghost.active{ background: var(--type-Ghost); }
.chip.type-Grass.active{ background: var(--type-Grass); }
.chip.type-Ground.active{ background: var(--type-Ground); color:#000; }
.chip.type-Ice.active{ background: var(--type-Ice); color:#000; }
.chip.type-Normal.active{ background: var(--type-Normal); color:#000; }
.chip.type-Poison.active{ background: var(--type-Poison); }
.chip.type-Psychic.active{ background: var(--type-Psychic); }
.chip.type-Rock.active{ background: var(--type-Rock); color:#000; }
.chip.type-Steel.active{ background: var(--type-Steel); color:#000; }
.chip.type-Water.active{ background: var(--type-Water); }

/* Grid */
.dex-grid { display: grid; gap: var(--s-3); grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); }

/* Card */
.dex { background: var(--bg-card); border: 1px solid rgba(255,255,255,.08); border-radius: var(--radius); padding: var(--s-3); position: relative; transition: transform .2s ease, border-color .2s ease; }
.dex:hover { transform: translateY(-2px); border-color: var(--accent); }

/* Obvious owned state */
.dex.owned {
  border-color: var(--accent, #22c55e);
  box-shadow: 0 0 0 2px rgba(34, 197, 94, 0.35), 0 0 12px rgba(34, 197, 94, 0.25);
  background: color-mix(in srgb, var(--bg-card, #111) 85%, #22c55e 15%);
  transition: box-shadow 0.2s ease, background 0.2s ease, border-color 0.2s ease;
}

/* Corner checkmark ribbon */
.dex.owned::after {
  content: "✓";
  position: absolute;
  top: 8px;
  right: 10px;
  font-weight: 700;
  opacity: 0.9;
  background: #22c55e;
  color: #0b1c0f;
  border-radius: 999px;
  width: 20px;
  height: 20px;
  display: grid;
  place-items: center;
  box-shadow: 0 0 0 2px rgba(0,0,0,0.2);
  pointer-events: none;
  font-size: 14px;
}
.dex-top {
  position: relative;            /* lets us absolutely center the name */
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 32px;
  margin-bottom: var(--s-2);
}
.dex-name {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
  white-space: nowrap;
}
.dex-num { font-weight: 700; font-size: var(--text-sm); color: var(--muted); }
/* Unified badge row for form and shiny badges - consistent height so images align */
.badge-row, .badges, .labels {
  display: flex;
  align-items: center;
  gap: 6px;
  min-height: 24px;                   /* reserve space even when no badges */
  margin-bottom: 6px;                 /* consistent spacing above sprite area */
  justify-content: center;
  pointer-events: none;
}
.form-badge, .variant-badge, .badge, .tag, .pill {
  display: inline-flex;
  align-items: center;
  height: 17px;
  padding: 0 6px;
  font-size: 0.68rem;
  line-height: 1;
  color: #000;
  border-radius: 999px;
  pointer-events: auto;
}
.form-badge {
  background: #a7f3d0;
}
.variant-badge {
  background: #fde68a;       /* soft amber so it reads as 'special' */
}
.variant-badge.badge-dynamax {
  background: rgba(99, 102, 241, .18);
  color: #aab0ff;   /* indigo vibe */
}
.variant-badge.badge-gigamax {
  background: rgba(244, 63, 94, .18);
  color: #ffabb9;   /* rose vibe */
}
.variant-badge.badge-costume {
  background: rgba(234, 179, 8, .18);
  color: #ffe08a;   /* amber vibe */
}
/* Sprite container: flex-center, fixed height, no overflow  */
.sprite {
  position: relative;               /* required for any overlays */
  height: 120px;                    /* roomy for legends/dragons */
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--s-2);              /* breathing room so tails/horns don't touch edges */
  box-sizing: border-box;
  overflow: hidden;                 /* no spillover outside the box */
  border-radius: var(--radius);
  background: transparent !important;  /* remove gray - blend with card */
  border: 0 !important;                /* remove inner border */
  box-shadow: none !important;         /* if any */
  color: var(--muted-foreground);
  margin-bottom: var(--s-2);
}
.sprite.missing-shiny::after{
  content:"✦"; position:absolute; inset:0; display:grid; place-items:center;
  font-size:28px; line-height:1; opacity:.35; color:var(--muted-foreground, #889096);
  pointer-events:none;
}

/* The actual <img> element */
.sprite-img {
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;              /* keep aspect ratio, fit inside */
  display: block;
  image-rendering: auto;            /* avoid pixelation—POGO PNGs look best this way */
}

/* When loader leaves it blank intentionally */
.sprite-img.missing {
  content: "";
}

/* Toggles */
.toggles { display: flex !important; flex-wrap: wrap; gap: 8px; justify-content: space-between; }
.toggle { flex: 1 1 30%; display: flex; align-items: center; justify-content: center; gap: 6px; background: #0f1512; border: 1px solid rgba(255,255,255,.08); padding: 6px 8px; border-radius: 8px; font-size: var(--text-sm); min-width: 88px; text-align: center; }
.toggle input { accent-color: var(--accent); }

/* Footer row */
.toolbar-foot { display: flex; align-items: center; gap: var(--s-2); margin-top: var(--s-2); flex-wrap: wrap; }

@media (min-width: 860px) { .toolbar-row { grid-template-columns: 1.2fr .8fr; } }

.empty { text-align: center; color: var(--muted); padding: 10vh 0; }


/* Type dots on cards */
.type-dots{
  display:inline-flex;
  align-items:center;
  justify-self: end;   /* pushes dots to the right within the right column */
  gap:6px;
}
.type-dot{
  width:10px;
  height:10px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.25);
  box-shadow: 0 0 0 1px rgba(255,255,255,.08) inset;
}


/* Card tooltip with types (shows on hover of entire card) */
.type-pop{
  position: absolute;
  top: 8px;
  left: 8px;
  padding: 4px 8px;
  border-radius: 999px;
  background: rgba(0,0,0,.6);
  border: 1px solid rgba(255,255,255,.12);
  font-size: 0.8rem;
  color: #e6edf3;
  opacity: 0;
  transform: translateY(-4px);
  transition: opacity .15s ease, transform .15s ease;
  pointer-events: none;
  backdrop-filter: blur(2px);
}
.dex:hover .type-pop,
.dex:focus-within .type-pop,
.dex:focus .type-pop,
.dex.show-tip .type-pop{
  opacity: 1;
  transform: translateY(0);
}
