:root {
  color-scheme: dark;
  --bg: #070b12;
  --bg-elevated: #0b111c;
  --panel: #101827;
  --panel-2: #121c2d;
  --panel-3: #0d1522;
  --line: rgba(148, 163, 184, 0.18);
  --line-strong: rgba(191, 204, 221, 0.28);
  --text: #f7f9fc;
  --muted: #a6b1c2;
  --soft: #77869a;
  --brand: #58dcc4;
  --brand-strong: #24c8b3;
  --gold: #f0cf73;
  --blue: #85a7ff;
  --red: #ef646d;
  --shadow: 0 24px 70px rgba(0, 0, 0, 0.34);
  --shadow-soft: 0 16px 40px rgba(0, 0, 0, 0.22);
  --radius-xl: 24px;
  --radius-lg: 18px;
  --radius-md: 14px;
  --max-width: 1320px;
  --header-height: 58px;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* { box-sizing: border-box; }
[hidden] { display: none !important; }
html { scroll-behavior: smooth; }
body {
  min-height: 100vh;
  margin: 0;
  color: var(--text);
  background:
    radial-gradient(circle at 16% -8%, rgba(88, 220, 196, 0.13), transparent 34rem),
    radial-gradient(circle at 86% 0%, rgba(133, 167, 255, 0.11), transparent 32rem),
    linear-gradient(180deg, #070b12 0%, #0a101a 45%, #070b12 100%);
}
body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background-image: linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,0.022) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: linear-gradient(to bottom, black 0%, transparent 78%);
}

button, input, select { font: inherit; }
button, a { -webkit-tap-highlight-color: transparent; }
a { color: inherit; }
code {
  display: inline-block;
  max-width: 100%;
  padding: 0.1rem 0.4rem;
  border: 1px solid rgba(88, 220, 196, 0.22);
  border-radius: 0.5rem;
  color: #e8fffb;
  background: rgba(88, 220, 196, 0.075);
  overflow-wrap: anywhere;
}

.skip-link {
  position: absolute;
  top: -100px;
  left: 1rem;
  z-index: 30;
  padding: 0.8rem 1rem;
  border-radius: 999px;
  color: #061018;
  background: var(--brand);
  font-weight: 850;
  text-decoration: none;
}
.skip-link:focus { top: 1rem; }

.site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  border-bottom: 1px solid var(--line);
  background: rgba(7, 11, 18, 0.82);
  backdrop-filter: blur(18px);
}
.nav-shell,
.section-shell {
  width: min(calc(100% - clamp(28px, 4.6vw, 72px)), var(--max-width));
  margin-inline: auto;
}
.nav-shell {
  min-height: var(--header-height);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.25rem;
}
.brand {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  min-width: 0;
  text-decoration: none;
}
.brand-logo {
  width: 34px;
  height: 34px;
  flex: 0 0 auto;
  border-radius: 10px;
  box-shadow: 0 10px 26px rgba(0,0,0,0.28);
}
.brand strong { display: block; letter-spacing: -0.03em; line-height: 1.05; }
.brand small { display: block; margin-top: 0.1rem; color: var(--muted); font-weight: 620; }
.nav-actions { display: flex; align-items: center; justify-content: flex-end; gap: 0.7rem; flex-wrap: wrap; }

.format-switch {
  display: inline-flex;
  align-items: center;
  padding: 0.28rem;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255,255,255,0.045);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}
.format-toggle {
  min-height: 34px;
  padding: 0 0.85rem;
  border: 0;
  border-radius: 999px;
  color: var(--muted);
  background: transparent;
  cursor: pointer;
  font-weight: 850;
  font-size: 0.84rem;
  transition: background 160ms ease, color 160ms ease, box-shadow 160ms ease;
}
.format-toggle.active {
  color: #071018;
  background: var(--brand);
  box-shadow: 0 8px 24px rgba(88, 220, 196, 0.25);
}
.format-toggle:not(.active):hover { color: var(--text); background: rgba(255,255,255,0.06); }

.ghost-button,
.primary-button,
.close-button,
.favorite-button,
.entry-item,
.roster-item { border: 0; cursor: pointer; }
.ghost-button {
  min-height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 0.95rem;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: #e8eef6;
  background: rgba(255,255,255,0.045);
  text-decoration: none;
  font-weight: 780;
  font-size: 0.9rem;
  transition: transform 160ms ease, border-color 160ms ease, background 160ms ease;
}
.ghost-button:hover,
.ghost-button:focus-visible { transform: translateY(-1px); border-color: var(--line-strong); background: rgba(255,255,255,0.075); }
.ghost-button.compact { min-height: 36px; font-size: 0.84rem; }
.primary-button {
  width: 100%;
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  color: #061018;
  font-weight: 900;
  background: linear-gradient(135deg, var(--brand), var(--gold));
  box-shadow: 0 16px 34px rgba(88, 220, 196, 0.17);
  transition: transform 160ms ease, filter 160ms ease, box-shadow 160ms ease;
}
.primary-button:hover,
.primary-button:focus-visible { transform: translateY(-1px); filter: brightness(1.03); box-shadow: 0 20px 44px rgba(88, 220, 196, 0.22); }

.hero {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(380px, 0.82fr);
  gap: clamp(1.2rem, 3vw, 2.25rem);
  align-items: stretch;
  padding-block: clamp(1.3rem, 3vw, 2.25rem) 0.85rem;
}
.hero-copy { align-self: center; }
.eyebrow {
  margin: 0 0 0.75rem;
  color: var(--brand);
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.17em;
  font-weight: 950;
}
.hero h1 {
  max-width: 780px;
  margin: 0;
  font-size: clamp(3rem, 5.4vw, 5.05rem);
  line-height: 0.96;
  letter-spacing: -0.075em;
}
.hero-text {
  max-width: 720px;
  margin: 1.15rem 0 0;
  color: var(--muted);
  font-size: clamp(1rem, 1.6vw, 1.14rem);
  line-height: 1.72;
}

.hero-card,
.controls,
.sidebar,
.content-area,
.about-data,
.detail-dialog .dialog-inner {
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  background: linear-gradient(180deg, rgba(16,24,39,0.94), rgba(11,17,28,0.94));
  box-shadow: var(--shadow-soft);
}
.hero-card {
  min-height: 390px;
  max-height: 500px;
  display: grid;
  grid-template-rows: auto 1fr;
  padding: 1.1rem;
  overflow: hidden;
}
.entry-panel-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  padding-bottom: 0.9rem;
  border-bottom: 1px solid var(--line);
}
.stat-label {
  display: block;
  margin-bottom: 0.42rem;
  color: var(--soft);
  font-size: 0.75rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}
.hero-card strong {
  display: block;
  max-width: 430px;
  font-size: 1rem;
  line-height: 1.35;
  letter-spacing: -0.02em;
}
.entry-count {
  flex: 0 0 auto;
  min-width: 42px;
  min-height: 32px;
  display: inline-grid;
  place-items: center;
  border-radius: 999px;
  color: #061018;
  background: linear-gradient(135deg, var(--brand), var(--gold));
  font-size: 0.82rem;
  font-weight: 950;
}
.entry-list {
  min-height: 0;
  overflow: auto;
  display: grid;
  align-content: start;
  gap: 0.66rem;
  padding: 0.85rem 0.22rem 0 0;
}
.entry-list::-webkit-scrollbar,
.roster-list::-webkit-scrollbar,
.dialog-inner::-webkit-scrollbar,
.data-table-wrap::-webkit-scrollbar { width: 10px; height: 10px; }
.entry-list::-webkit-scrollbar-thumb,
.roster-list::-webkit-scrollbar-thumb,
.dialog-inner::-webkit-scrollbar-thumb,
.data-table-wrap::-webkit-scrollbar-thumb { background: rgba(148,163,184,0.25); border-radius: 999px; }
.entry-item {
  width: 100%;
  display: grid;
  grid-template-columns: 48px minmax(0, 1fr) auto;
  align-items: center;
  gap: 0.78rem;
  padding: 0.66rem;
  border: 1px solid var(--line);
  border-radius: 16px;
  color: var(--text);
  background: rgba(255,255,255,0.035);
  text-align: left;
  transition: transform 150ms ease, border-color 150ms ease, background 150ms ease;
}
.entry-item:hover,
.entry-item:focus-visible { transform: translateY(-1px); border-color: rgba(88,220,196,0.42); background: rgba(88,220,196,0.07); }
.entry-thumb {
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #0a1422;
}
.entry-thumb img { width: 100%; height: 100%; object-fit: contain; }
.entry-meta { min-width: 0; }
.entry-meta strong,
.entry-meta small { display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.entry-meta small { margin-top: 0.12rem; color: var(--muted); font-weight: 650; }
.entry-empty { color: var(--muted); margin: 0; padding: 1rem; }
.format-badge {
  border-radius: 999px;
  padding: 0.36rem 0.58rem;
  color: #071018;
  background: var(--brand);
  font-size: 0.7rem;
  font-weight: 950;
}
.format-badge.singles { background: var(--blue); color: #071018; }
.format-badge.doubles { background: var(--gold); color: #071018; }
.format-badge.other { color: var(--text); background: rgba(255,255,255,0.12); }

.controls {
  padding: 0.9rem;
  display: grid;
  grid-template-columns: minmax(280px, 1.2fr) minmax(520px, 1fr);
  gap: 0.95rem;
  align-items: end;
}
.search-panel label,
.filter-grid label {
  display: grid;
  gap: 0.5rem;
  color: var(--muted);
  font-size: 0.8rem;
  font-weight: 850;
}
.search-box {
  height: 54px;
  display: flex;
  align-items: center;
  gap: 0.74rem;
  padding-inline: 0.95rem 1.05rem;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: rgba(255,255,255,0.04);
  transition: border-color 150ms ease, box-shadow 150ms ease, background 150ms ease;
}
.search-box:focus-within { border-color: rgba(88,220,196,0.66); background: rgba(255,255,255,0.06); box-shadow: 0 0 0 4px rgba(88,220,196,0.1); }
.search-box svg { width: 21px; height: 21px; fill: var(--soft); flex: 0 0 auto; }
.search-box input { min-width: 0; width: 100%; border: 0; outline: 0; color: var(--text); background: transparent; font-size: 0.98rem; }
.search-box input::placeholder { color: #6e7b8f; }
.filter-grid { display: grid; grid-template-columns: repeat(5, minmax(106px, 1fr)); gap: 0.72rem; align-items: end; }
select {
  width: 100%;
  height: 46px;
  padding: 0 0.75rem;
  border: 1px solid var(--line);
  border-radius: 14px;
  color: var(--text);
  background: #0f1827;
  outline: none;
  font-weight: 740;
}
select:focus-visible { border-color: rgba(88,220,196,0.66); box-shadow: 0 0 0 4px rgba(88,220,196,0.10); }
.checkbox-label {
  min-height: 46px;
  grid-auto-flow: column;
  align-items: center;
  justify-content: center;
  gap: 0.5rem !important;
  padding-inline: 0.7rem;
  border: 1px solid var(--line);
  border-radius: 14px;
  color: var(--text) !important;
  background: rgba(255,255,255,0.04);
  cursor: pointer;
}
.checkbox-label input { accent-color: var(--brand); }

.layout {
  display: grid;
  grid-template-columns: minmax(260px, 305px) minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
  padding-block: 1rem;
}
.sidebar,
.content-area { padding: 1rem; }
.sidebar {
  position: sticky;
  top: calc(var(--header-height) + 1rem);
  max-height: calc(100vh - var(--header-height) - 2rem);
  overflow: hidden;
  display: grid;
  grid-template-rows: auto 1fr;
}
.panel-heading { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-bottom: 0.95rem; }
.panel-heading h2 { margin: 0; font-size: 1.12rem; letter-spacing: -0.035em; }
.pill {
  flex: 0 0 auto;
  padding: 0.42rem 0.62rem;
  border: 1px solid rgba(88,220,196,0.23);
  border-radius: 999px;
  color: #e6fffb;
  background: rgba(88,220,196,0.085);
  font-size: 0.72rem;
  font-weight: 900;
}
.roster-list { display: grid; align-content: start; gap: 0.6rem; overflow: auto; padding-right: 0.22rem; }
.roster-item {
  width: 100%;
  display: grid;
  grid-template-columns: 46px minmax(0, 1fr) auto;
  gap: 0.7rem;
  align-items: center;
  padding: 0.62rem;
  border: 1px solid transparent;
  border-radius: 16px;
  color: var(--text);
  background: rgba(255,255,255,0.035);
  text-align: left;
  transition: background 150ms ease, border-color 150ms ease, transform 150ms ease;
}
.roster-item:hover,
.roster-item.active { border-color: rgba(88,220,196,0.34); background: rgba(88,220,196,0.065); }
.roster-item:hover { transform: translateY(-1px); }
.roster-thumb,
.mini-fallback {
  width: 46px;
  height: 46px;
  display: grid;
  place-items: center;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 14px;
  color: var(--brand);
  background: #0a1422;
  font-weight: 950;
}
.roster-thumb img { width: 100%; height: 100%; object-fit: contain; }
.roster-meta { min-width: 0; }
.roster-meta strong,
.roster-meta small { display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.roster-meta small { margin-top: 0.12rem; color: var(--muted); font-weight: 650; }
.content-area { min-height: 560px; }
.card-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(min(100%, 292px), 1fr)); gap: 0.95rem; }
.pokemon-card {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  background: linear-gradient(180deg, rgba(18,28,45,0.96), rgba(12,19,31,0.96));
  box-shadow: 0 12px 36px rgba(0,0,0,0.22);
  transition: transform 170ms ease, box-shadow 170ms ease, border-color 170ms ease;
}
.pokemon-card:hover { transform: translateY(-3px); box-shadow: var(--shadow); border-color: rgba(88,220,196,0.30); }
.load-more-results {
  grid-column: 1 / -1;
  justify-self: center;
  min-width: 150px;
  margin: 0.35rem 0 0.75rem;
}
.result-position {
  position: absolute;
  z-index: 2;
  top: 0.85rem;
  left: 0.85rem;
  color: var(--text);
  font-size: 0.78rem;
  font-weight: 750;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.favorite-button {
  position: absolute;
  z-index: 2;
  top: 0.85rem;
  right: 0.85rem;
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  border: 1px solid var(--line);
  border-radius: 50%;
  color: var(--gold);
  background: rgba(7,11,18,0.76);
  font-size: 1.18rem;
  line-height: 1;
}
.favorite-button.active { border-color: rgba(240,207,115,0.44); background: rgba(240,207,115,0.14); }
.pokemon-art { position: relative; min-height: 200px; display: grid; place-items: end center; padding: 2.1rem 1rem 0.35rem; }
.pokemon-art::after {
  content: "";
  position: absolute;
  bottom: 0.45rem;
  width: 166px;
  height: 166px;
  border: 1px solid rgba(255,255,255,0.075);
  border-radius: 50%;
  background: radial-gradient(circle, rgba(88,220,196,0.14), rgba(133,167,255,0.08) 58%, transparent 59%);
}
.pokemon-art img { position: relative; z-index: 1; width: min(184px, 82%); height: 164px; object-fit: contain; filter: drop-shadow(0 18px 22px rgba(0,0,0,0.42)); }
.pokemon-fallback {
  position: relative;
  z-index: 1;
  width: 142px;
  height: 142px;
  display: grid;
  place-items: center;
  border: 1px solid var(--line);
  border-radius: 50%;
  color: var(--brand);
  background: rgba(88,220,196,0.08);
  font-size: 2.4rem;
  font-weight: 950;
  letter-spacing: -0.08em;
}
.entry-thumb .pokemon-fallback,
.roster-thumb .pokemon-fallback { width: 100%; height: 100%; border-radius: inherit; font-size: 1rem; }
.pokemon-card-body { position: relative; padding: 1rem; }
.card-title-row { display: flex; justify-content: space-between; gap: 1rem; }
.dex-number { display: inline-block; margin-bottom: 0.16rem; color: var(--soft); font-size: 0.72rem; font-weight: 900; letter-spacing: 0.04em; }
.pokemon-card h3 { margin: 0; font-size: 1.25rem; letter-spacing: -0.04em; }
.type-row { display: flex; flex-wrap: wrap; gap: 0.4rem; margin: 0.78rem 0; }
.type-chip {
  min-height: 29px;
  display: inline-flex;
  align-items: center;
  gap: 0.34rem;
  padding: 0.32rem 0.58rem;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: #dce6f2;
  background: rgba(255,255,255,0.04);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.02em;
}
.type-chip img { width: 17px; height: 17px; object-fit: contain; }
.quick-facts { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 0.58rem; margin-bottom: 0.92rem; }
.fact { min-width: 0; padding: 0.68rem; border: 1px solid var(--line); border-radius: 14px; background: rgba(255,255,255,0.035); }
.fact span { display: block; color: var(--soft); font-size: 0.68rem; font-weight: 850; }
.fact strong { display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; margin-top: 0.18rem; font-size: 0.9rem; }
.empty-state {
  min-height: 320px;
  display: grid;
  place-items: center;
  text-align: center;
  padding: 2rem;
  border: 1.5px dashed rgba(148,163,184,0.28);
  border-radius: var(--radius-xl);
  color: var(--muted);
  background: rgba(255,255,255,0.025);
}
.empty-state strong { display: block; margin-bottom: 0.5rem; color: var(--text); font-size: 1.22rem; }
.empty-state .primary-button { max-width: 210px; margin: 1rem auto 0; }

.about-data {
  margin-block: 1rem 4rem;
  padding: 1.15rem;
  display: grid;
  grid-template-columns: minmax(0, 0.78fr) minmax(330px, 1fr);
  gap: 1.4rem;
  align-items: start;
}
.about-data h2 { margin: 0; font-size: 1.3rem; letter-spacing: -0.04em; }
.about-data p { color: var(--muted); line-height: 1.65; }
.setup-steps { margin: 0; display: grid; gap: 0.62rem; color: var(--muted); }
.setup-steps li { padding-left: 0.22rem; }

.detail-dialog { width: min(980px, calc(100% - 36px)); max-height: min(820px, calc(100vh - 42px)); padding: 0; border: 0; border-radius: 22px; color: var(--text); background: transparent; }
.detail-dialog::backdrop { background: rgba(0,0,0,0.64); backdrop-filter: blur(10px); }
.dialog-inner { position: relative; overflow: auto; max-height: min(820px, calc(100vh - 42px)); padding: clamp(0.95rem, 2.4vw, 1.25rem); padding-top: clamp(1.2rem, 2.4vw, 1.45rem); }
.close-button {
  position: absolute;
  top: 0.85rem;
  right: 0.85rem;
  z-index: 4;
  width: 36px;
  height: 36px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(148,163,184,0.26);
  border-radius: 12px;
  color: #dce6f2;
  background: rgba(9,14,23,0.92);
  font-size: 1.25rem;
  line-height: 1;
  box-shadow: 0 14px 34px rgba(0,0,0,0.25);
  transition: transform 150ms ease, border-color 150ms ease, background 150ms ease;
}
.close-button:hover,
.close-button:focus-visible { transform: translateY(-1px); border-color: rgba(88,220,196,0.46); background: rgba(18,28,45,0.96); }
.detail-hero { display: grid; grid-template-columns: 220px minmax(0, 1fr); gap: 1rem; align-items: center; padding-right: 2.5rem; }
.detail-art { min-height: 204px; display: grid; place-items: center; border: 1px solid var(--line); border-radius: 20px; background: rgba(255,255,255,0.03); }
.detail-art img { width: 178px; max-width: 88%; height: 178px; object-fit: contain; filter: drop-shadow(0 20px 26px rgba(0,0,0,0.45)); }
.detail-art .pokemon-fallback { width: 142px; height: 142px; }
.detail-title h2 { margin: 0.18rem 0 0; font-size: clamp(2rem, 4.2vw, 3.45rem); line-height: 0.98; letter-spacing: -0.07em; }
.detail-title p { max-width: 740px; color: var(--muted); line-height: 1.64; }
.detail-format-chip { display: inline-flex; align-items: center; width: fit-content; margin-top: 0.72rem; padding: 0.42rem 0.7rem; border-radius: 999px; color: #071018; background: var(--brand); font-size: 0.75rem; font-weight: 950; }
.detail-format-chip.singles { background: var(--blue); }
.detail-format-chip.doubles { background: var(--gold); }
.detail-metrics { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 0.66rem; margin-top: 0.9rem; }
.metric { padding: 0.72rem; border: 1px solid var(--line); border-radius: 15px; background: rgba(255,255,255,0.035); }
.metric span { display: block; color: var(--soft); font-size: 0.68rem; font-weight: 900; text-transform: uppercase; letter-spacing: 0.08em; }
.metric strong { display: block; margin-top: 0.18rem; line-height: 1.25; font-size: 0.98rem; }
.detail-sections { display: grid; gap: 0.75rem; margin-top: 0.9rem; }
.detail-section { padding: 0.82rem; border: 1px solid var(--line); border-radius: 18px; background: rgba(255,255,255,0.028); }
.detail-section h3 { margin: 0 0 0.8rem; font-size: 1rem; letter-spacing: -0.025em; }
.format-block { display: grid; gap: 0.8rem; }
.format-block + .format-block { margin-top: 0.95rem; padding-top: 0.95rem; border-top: 1px solid var(--line); }
.format-heading { display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.format-heading h4 { margin: 0; font-size: 0.98rem; letter-spacing: -0.02em; }
.battle-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 0.72rem; }
.data-table-wrap { overflow: auto; border: 1px solid var(--line); border-radius: 14px; background: rgba(0,0,0,0.12); }
table { width: 100%; min-width: 500px; border-collapse: collapse; font-size: 0.82rem; }
th, td { padding: 0.58rem; border-bottom: 1px solid rgba(148,163,184,0.15); text-align: left; }
th { color: #b8c4d4; background: rgba(255,255,255,0.045); font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.08em; }
tr:last-child td { border-bottom: 0; }
td { color: #e4ebf5; }
.percent-bar { position: relative; min-width: 118px; height: 30px; overflow: hidden; border: 1px solid var(--line); border-radius: 999px; background: rgba(255,255,255,0.05); }
.percent-bar span { position: absolute; inset: 0 auto 0 0; width: var(--value, 0%); border-radius: inherit; background: linear-gradient(90deg, var(--brand), var(--gold)); }
.percent-bar b { position: relative; z-index: 1; display: grid; place-items: center; height: 100%; color: #f7f9fc; font-size: 0.76rem; text-shadow: 0 1px 6px rgba(0,0,0,0.35); }
.learnable-moves-table { min-width: 620px; }
.learnable-moves-table td:first-child { font-weight: 850; color: #f7f9fc; }
.move-category {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 68px;
  padding: 0.18rem 0.46rem;
  border: 1px solid rgba(148,163,184,0.22);
  border-radius: 999px;
  background: rgba(148,163,184,0.09);
  color: #dbeafe;
  font-size: 0.72rem;
  font-weight: 900;
}
.move-category.physical { border-color: rgba(248,113,113,0.32); background: rgba(248,113,113,0.12); color: #fecaca; }
.move-category.special { border-color: rgba(96,165,250,0.34); background: rgba(96,165,250,0.12); color: #bfdbfe; }
.move-category.status { border-color: rgba(52,211,153,0.32); background: rgba(52,211,153,0.12); color: #bbf7d0; }
.move-type-label {
  display: inline-flex;
  align-items: center;
  gap: 0.34rem;
  min-width: 0;
  font-weight: 850;
  white-space: nowrap;
}
.move-type-label img {
  width: 18px;
  height: 18px;
  object-fit: contain;
  flex: 0 0 auto;
}
.stat-bars { display: grid; gap: 0.58rem; }
.stat-row { display: grid; grid-template-columns: 70px 1fr 44px; align-items: center; gap: 0.68rem; color: var(--muted); font-size: 0.84rem; font-weight: 720; }
.stat-track { height: 10px; overflow: hidden; border-radius: 999px; background: rgba(255,255,255,0.06); }
.stat-fill { width: var(--stat, 0%); height: 100%; border-radius: inherit; background: var(--stat-color, var(--brand)); box-shadow: 0 0 18px color-mix(in srgb, var(--stat-color, var(--brand)) 42%, transparent); }

@media (max-width: 1180px) {
  .controls { grid-template-columns: 1fr; }
  .filter-grid { grid-template-columns: repeat(5, minmax(0, 1fr)); }
}
@media (max-width: 1040px) {
  .hero { grid-template-columns: 1fr; padding-top: clamp(2rem, 5vw, 3.5rem); }
  .hero-card { min-height: 300px; max-height: 420px; }
  .layout { grid-template-columns: 1fr; }
  .sidebar { position: static; max-height: none; }
  .roster-list { grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); max-height: 280px; }
}
@media (max-width: 860px) {
  :root { --header-height: auto; }
  .nav-shell { min-height: 0; align-items: flex-start; flex-direction: column; padding-block: 0.9rem; }
  .nav-actions { width: 100%; justify-content: flex-start; }
  .desktop-heading { display: none; }
  .filter-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .detail-hero { grid-template-columns: 1fr; margin-top: 0; padding-right: 0; }
  .detail-art { min-height: 220px; }
  .detail-metrics { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .battle-grid { grid-template-columns: 1fr; }
  .about-data { grid-template-columns: 1fr; }
}
@media (max-width: 620px) {
  .nav-shell,
  .section-shell { width: min(calc(100% - 22px), var(--max-width)); }
  .hero { padding-top: 1rem; }
  .hero h1 { font-size: clamp(2.45rem, 12.4vw, 3.9rem); }
  .hero-text { font-size: 0.98rem; }
  .entry-item { grid-template-columns: 46px minmax(0, 1fr); }
  .format-badge { grid-column: 2; justify-self: start; }
  .filter-grid { grid-template-columns: 1fr; }
  .quick-facts { grid-template-columns: 1fr; }
  .pokemon-art { min-height: 176px; }
  .detail-metrics { grid-template-columns: 1fr; }
  .detail-title h2 { font-size: clamp(2.15rem, 12vw, 3.2rem); }
  .roster-list { grid-template-columns: 1fr; }
  table { min-width: 460px; }
}
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; scroll-behavior: auto !important; transition-duration: 0.01ms !important; }
}

/* v6 refinements */
:root { --max-width: 1380px; }
.hero { padding-block: clamp(0.55rem, 1.7vw, 1.25rem) 0.75rem; grid-template-columns: minmax(0, 1fr) minmax(420px, 0.76fr); }
.hero h1 { font-size: clamp(3rem, 5vw, 4.75rem); max-width: 900px; }
.hero-card { min-height: 360px; }
.stat-label { color: var(--brand); }
.controls { grid-template-columns: minmax(420px, 1.45fr) minmax(360px, 0.8fr); align-items: end; }
.filter-grid { grid-template-columns: minmax(138px, 1fr) minmax(162px, 1fr) minmax(128px, 0.78fr); }
.search-panel label { margin: 0; }
.search-label-row { display: flex; align-items: center; justify-content: space-between; gap: 0.75rem; margin-bottom: 0.5rem; color: var(--muted); font-size: 0.8rem; font-weight: 850; }
.search-help { position: relative; display: inline-flex; }
.search-help-button {
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(88,220,196,0.35);
  border-radius: 50%;
  color: #e8fffb;
  background: rgba(88,220,196,0.09);
  font-weight: 950;
  cursor: help;
}
.search-help-popover {
  position: absolute;
  right: 0;
  top: calc(100% + 0.65rem);
  z-index: 35;
  width: min(460px, calc(100vw - 42px));
  padding: 1rem;
  border: 1px solid rgba(88,220,196,0.28);
  border-radius: 18px;
  color: var(--text);
  background: rgba(10, 16, 26, 0.98);
  box-shadow: 0 28px 80px rgba(0,0,0,0.42);
  opacity: 0;
  pointer-events: none;
  transform: translateY(-4px);
  transition: opacity 150ms ease, transform 150ms ease;
}
.search-help:hover .search-help-popover,
.search-help:focus-within .search-help-popover { opacity: 1; pointer-events: auto; transform: translateY(0); }
.search-help-popover strong { display: block; margin-bottom: 0.35rem; letter-spacing: -0.02em; }
.search-help-popover p { margin: 0 0 0.75rem; color: var(--muted); line-height: 1.55; }
.search-help-popover dl { margin: 0; display: grid; gap: 0.62rem; }
.search-help-popover dt { color: var(--brand); font-weight: 900; font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.1em; }
.search-help-popover dd { margin: 0; color: var(--muted); line-height: 1.65; }
.search-help-popover code { margin: 0 0.15rem 0.25rem 0; }
.entry-item { grid-template-columns: 32px 48px minmax(0, 1fr); padding: 0.7rem; }
.entry-index {
  width: 30px;
  height: 30px;
  display: grid;
  place-items: center;
  border-radius: 10px;
  color: #0a101a;
  background: var(--brand);
  font-size: 0.74rem;
  font-weight: 950;
}
.entry-types { display: flex !important; gap: 0.34rem; flex-wrap: wrap; margin-top: 0.34rem; white-space: normal !important; }
.entry-types .type-chip { min-height: 24px; padding: 0.22rem 0.46rem; font-size: 0.66rem; }
.entry-types .type-chip img { width: 14px; height: 14px; }
.format-badge { display: none; }
.sidebar { grid-template-rows: auto minmax(0, 1fr); }
.roster-list { gap: 0.66rem; }
.recent-item {
  width: 100%;
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr);
  gap: 0.72rem;
  align-items: center;
  padding: 0.72rem;
  border: 1px solid var(--line);
  border-radius: 16px;
  color: var(--text);
  background: rgba(255,255,255,0.035);
  text-align: left;
  cursor: pointer;
  transition: transform 150ms ease, border-color 150ms ease, background 150ms ease;
}
.recent-item:hover,
.recent-item:focus-visible,
.recent-item.active { transform: translateY(-1px); border-color: rgba(88,220,196,0.42); background: rgba(88,220,196,0.065); }
.recent-item.suggestion { border-style: dashed; }
.recent-icon {
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(88,220,196,0.22);
  border-radius: 13px;
  color: var(--brand);
  background: rgba(88,220,196,0.08);
  font-weight: 950;
}
.recent-item strong,
.recent-item small { display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.recent-item small { margin-top: 0.16rem; color: var(--muted); font-weight: 650; }
.detail-dialog { width: min(1180px, calc(100% - 34px)); max-height: min(840px, calc(100vh - 34px)); }
.dialog-inner { max-height: min(840px, calc(100vh - 34px)); }
.close-button {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  font-size: 1.38rem;
  line-height: 1;
}
.detail-hero { grid-template-columns: 240px minmax(0, 1fr); }
.detail-art { min-height: 224px; }
.detail-art img { width: 198px; height: 198px; }
.detail-loading { padding: 4rem 1rem; text-align: center; color: var(--muted); }
.detail-section.nested { padding: 0; border: 0; background: transparent; }
.detail-section.nested h3 { padding-inline: 0.1rem; }
.battle-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
@media (max-width: 1180px) {
  .controls { grid-template-columns: 1fr; }
  .filter-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 1040px) {
  .hero { grid-template-columns: 1fr; padding-top: 0.9rem; }
}
@media (max-width: 860px) {
  .search-help-popover { left: auto; right: -0.25rem; }
  .filter-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 620px) {
  .hero { padding-top: 0.65rem; }
  .entry-item { grid-template-columns: 30px 46px minmax(0, 1fr); }
  .filter-grid { grid-template-columns: 1fr; }
  .detail-dialog { width: min(100% - 18px, 1180px); }
  .close-button { top: 0.62rem; right: 0.62rem; }
}

/* v7 refinements */
.hero { padding-block: clamp(1.1rem, 2.3vw, 1.9rem) 0.85rem; }
.percent-bar span { background: linear-gradient(90deg, #22c55e, #6ee7a8); }
.recent-empty {
  margin: 0;
  padding: 0.9rem;
  border: 1px dashed var(--line);
  border-radius: 16px;
  color: var(--muted);
  background: rgba(255,255,255,0.025);
  font-weight: 650;
  line-height: 1.5;
}
.search-help-popover { width: min(540px, calc(100vw - 42px)); }
@media (max-width: 1040px) { .hero { padding-top: clamp(1.3rem, 3.5vw, 2.2rem); } }
@media (max-width: 620px) { .hero { padding-top: 1.05rem; } }

/* v8 refinements */
.hero { padding-block: clamp(1.45rem, 2.8vw, 2.25rem) 0.9rem; }
.search-action-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.72rem;
  align-items: center;
}
.search-submit {
  height: 54px;
  min-width: 112px;
  padding: 0 1.2rem;
  border: 0;
  border-radius: 16px;
  color: #061018;
  background: var(--brand);
  box-shadow: 0 14px 34px rgba(88, 220, 196, 0.18);
  font-weight: 950;
  cursor: pointer;
  transition: transform 160ms ease, filter 160ms ease, box-shadow 160ms ease;
}
.search-submit:hover,
.search-submit:focus-visible { transform: translateY(-1px); filter: brightness(1.04); box-shadow: 0 18px 42px rgba(88, 220, 196, 0.22); }
.search-help-popover {
  position: fixed;
  top: var(--help-top, calc(var(--header-height) + 1rem));
  left: var(--help-left, 1rem);
  right: auto;
  width: var(--help-width, min(540px, calc(100vw - 42px)));
  max-height: min(68vh, 560px);
  overflow: auto;
}
.search-help-popover .plain-code {
  display: inline;
  padding: 0;
  border: 0;
  border-radius: 0;
  color: #e8fffb;
  background: transparent;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;
  font-size: 0.92em;
  font-weight: 850;
}
.loading-row,
.skeleton-card { pointer-events: none; }
.skeleton,
.skeleton-line,
.skeleton-tile,
.skeleton-art {
  position: relative;
  overflow: hidden;
  background: rgba(255,255,255,0.06) !important;
}
.skeleton::after,
.skeleton-line::after,
.skeleton-tile::after,
.skeleton-art::after {
  content: "";
  position: absolute;
  inset: 0;
  transform: translateX(-100%);
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.08), transparent);
  animation: skeleton-sweep 1.4s ease-in-out infinite;
}
.skeleton-line {
  display: block;
  height: 12px;
  border-radius: 999px;
  margin: 0.24rem 0;
}
.skeleton-line.wide { width: 76%; }
.skeleton-line.short { width: 44%; }
.skeleton-tile {
  display: block;
  min-height: 52px;
  border-radius: 14px;
  border: 1px solid var(--line);
}
.skeleton-card { min-height: 420px; }
.skeleton-card .pokemon-card-body { display: grid; gap: 0.76rem; }
@keyframes skeleton-sweep { to { transform: translateX(100%); } }
.api-main { padding-block: clamp(1.7rem, 3vw, 2.6rem) 4rem; }
.api-hero {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(360px, 0.65fr);
  gap: clamp(1rem, 3vw, 2rem);
  align-items: start;
}
.api-panel,
.endpoint-card {
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  background: linear-gradient(180deg, rgba(16,24,39,0.94), rgba(11,17,28,0.94));
  box-shadow: var(--shadow-soft);
}
.api-panel { padding: 1.15rem; }
.api-panel h1 { margin: 0; font-size: clamp(2.55rem, 5vw, 4.9rem); line-height: 0.96; letter-spacing: -0.075em; }
.api-panel p { color: var(--muted); line-height: 1.7; }
.endpoint-grid { display: grid; gap: 0.95rem; margin-top: 1rem; }
.endpoint-card { padding: 1rem; }
.endpoint-card h2 { margin: 0 0 0.7rem; font-size: 1.08rem; letter-spacing: -0.035em; }
.endpoint-card p,
.endpoint-card li { color: var(--muted); line-height: 1.65; }
.endpoint-card pre {
  margin: 0.74rem 0;
  padding: 0.85rem;
  overflow: auto;
  border: 1px solid var(--line);
  border-radius: 14px;
  color: #e8fffb;
  background: rgba(0,0,0,0.18);
}
.endpoint-card code { white-space: nowrap; }
.api-table { width: 100%; min-width: 0; }
.api-table td:first-child { color: var(--brand); font-weight: 900; }
@media (max-width: 1180px) {
  .search-action-row { grid-template-columns: minmax(0, 1fr) auto; }
}
@media (max-width: 900px) {
  .api-hero { grid-template-columns: 1fr; }
}
@media (max-width: 620px) {
  .hero { padding-top: 1.3rem; }
  .search-action-row { grid-template-columns: 1fr; }
  .search-submit { width: 100%; }
  .search-help-popover { width: min(540px, calc(100vw - 24px)); left: 12px !important; }
}

/* v9 refinements */
.search-action-row { grid-template-columns: 1fr; }
.filter-grid { grid-template-columns: minmax(138px, 0.85fr) minmax(168px, 1fr) minmax(150px, 0.8fr) minmax(132px, 0.72fr); }
.rank-help {
  display: block;
  margin-top: 0.36rem;
  color: var(--muted);
  line-height: 1.55;
}
.search-help-popover dd code,
.search-help-popover .plain-code { white-space: nowrap; }
@media (max-width: 1180px) {
  .filter-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}
@media (max-width: 860px) {
  .filter-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 620px) {
  .filter-grid { grid-template-columns: 1fr; }
}

/* v10 end-user polish */
.controls {
  grid-template-columns: minmax(340px, 0.76fr) minmax(640px, 1.24fr);
}
.filter-grid {
  grid-template-columns: minmax(118px, 0.72fr) minmax(190px, 1.22fr) minmax(146px, 0.78fr) minmax(156px, 0.72fr);
}
.checkbox-label {
  white-space: nowrap;
  padding-inline: 0.78rem;
}
.search-box input::placeholder { color: #c7d0df; opacity: 0.78; }
.search-help-popover p,
.search-help-popover dd,
.search-help-popover .rank-help {
  color: #f7f9fc;
}
.search-help-popover dt { color: #8ff3e5; }
.search-help-popover code,
.search-help-popover .plain-code { color: #f7f9fc; }
.percent-bar span { background: var(--brand) !important; }
.close-button {
  border-radius: 50%;
  display: inline-grid;
  place-items: center;
  line-height: 1;
  font-size: 1.35rem;
  padding: 0 0 0.04rem;
}
.teammate-table { min-width: 320px; }
.api-panel p,
.endpoint-card p,
.endpoint-card li,
.api-table td { color: #dce6f2; }
.endpoint-card h2 { color: var(--text); }
.endpoint-card pre { background: rgba(255,255,255,0.045); }
@media (max-width: 1180px) {
  .controls { grid-template-columns: 1fr; }
  .filter-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}
@media (max-width: 860px) {
  .filter-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 620px) {
  .filter-grid { grid-template-columns: 1fr; }
}

/* v11 end-user refinements */
@view-transition { navigation: auto; }
body { animation: page-fade-in 180ms ease-out both; }
@keyframes page-fade-in { from { opacity: 0; } to { opacity: 1; } }

.controls {
  grid-template-columns: minmax(280px, 1fr) auto;
}
.filter-grid {
  grid-template-columns: repeat(4, 156px);
  justify-content: end;
}
.filter-grid label,
.checkbox-label {
  width: 156px;
  min-width: 156px;
}
.checkbox-label {
  justify-content: center;
}
.search-box {
  max-width: 100%;
}
.sidebar .pill#resultCount {
  display: none;
}
.battle-grid-columns {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: start;
}
.battle-column {
  display: grid;
  gap: 0.72rem;
  align-content: start;
}
.search-help-popover p,
.search-help-popover dd,
.search-help-popover .rank-help {
  color: #f7f9fc;
  font-weight: 650;
}
.search-help-popover code,
.search-help-popover .plain-code {
  display: inline;
  padding: 0;
  border: 0;
  border-radius: 0;
  color: #f7f9fc;
  background: transparent;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;
  font-size: 0.92em;
  font-weight: 850;
  white-space: nowrap;
}
.search-help-popover dt {
  color: #8ff3e5;
  font-weight: 850;
}
.ghost-button[aria-current="page"] {
  border-color: rgba(88, 220, 196, 0.44);
  color: #e8fffb;
  background: rgba(88, 220, 196, 0.1);
}
@media (max-width: 1180px) {
  .controls { grid-template-columns: 1fr; }
  .filter-grid { justify-content: start; grid-template-columns: repeat(4, 156px); }
}
@media (max-width: 860px) {
  .filter-grid { grid-template-columns: repeat(2, 156px); }
  .battle-grid-columns { grid-template-columns: 1fr; }
}
@media (max-width: 620px) {
  .filter-grid { grid-template-columns: 1fr; }
  .filter-grid label,
  .checkbox-label { width: 100%; min-width: 0; }
}
.single-api-hero {
  grid-template-columns: 1fr;
}
.single-api-hero .api-panel {
  max-width: 940px;
}
.endpoint-card ul {
  margin: 0.5rem 0 0;
  padding-left: 1.2rem;
}

/* v12 polish */
.search-help-popover dl { gap: 0.72rem; }
.search-help-popover .rank-help,
.search-help-popover .rank-help .plain-code {
  display: inline;
  padding: 0;
  border: 0;
  border-radius: 0;
  color: #f7f9fc;
  background: transparent;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;
  font-size: 0.92em;
  font-weight: 850;
  line-height: 1.65;
  white-space: normal;
}
.search-help-popover .rank-help .plain-code { white-space: nowrap; }
.api-main.section-shell {
  width: min(calc(100% - clamp(28px, 4.6vw, 72px)), 1080px);
}
.api-hero-compact {
  grid-template-columns: minmax(0, 1fr) minmax(260px, 320px);
  align-items: stretch;
}
.api-hero-compact .api-panel { max-width: none; }
.api-hero-compact .api-panel h1 { font-size: clamp(2.35rem, 5vw, 4.25rem); }
.api-side-card {
  display: grid;
  align-content: start;
  gap: 0.75rem;
  padding: 1rem;
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  background: linear-gradient(180deg, rgba(16,24,39,0.94), rgba(11,17,28,0.94));
  box-shadow: var(--shadow-soft);
}
.api-side-card h2 { margin: 0; font-size: 1.15rem; letter-spacing: -0.03em; }
.api-side-card p { margin: 0; color: #dce6f2; line-height: 1.6; }
.discord-button {
  min-height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  padding: 0 0.95rem;
  border: 1px solid rgba(133, 167, 255, 0.44);
  border-radius: 999px;
  color: #f7f9fc;
  background: linear-gradient(135deg, rgba(88, 101, 242, 0.95), rgba(88, 220, 196, 0.22));
  text-decoration: none;
  font-weight: 900;
  font-size: 0.9rem;
  box-shadow: 0 12px 30px rgba(88, 101, 242, 0.18);
  transition: transform 160ms ease, filter 160ms ease, box-shadow 160ms ease;
}
.discord-button:hover,
.discord-button:focus-visible { transform: translateY(-1px); filter: brightness(1.05); box-shadow: 0 16px 38px rgba(88, 101, 242, 0.24); }
.discord-button-large { width: 100%; min-height: 42px; margin-top: 0.3rem; }
.endpoint-grid { max-width: 1080px; }
.endpoint-card { overflow: hidden; }
.endpoint-card pre { max-width: 100%; }
@media (max-width: 900px) {
  .api-hero-compact { grid-template-columns: 1fr; }
  .api-side-card { order: -1; }
}
@media (max-width: 620px) {
  .api-main.section-shell { width: min(calc(100% - 24px), 1080px); }
  .discord-button { width: 100%; }
}

/* v13 refinements */
.page-api .nav-shell,
.api-main.section-shell {
  width: min(calc(100% - clamp(28px, 4.6vw, 72px)), 980px);
}
.endpoint-grid {
  max-width: 980px;
}
.search-help-popover {
  position: fixed !important;
  top: 50% !important;
  left: 50% !important;
  right: auto !important;
  width: min(560px, calc(100vw - 32px)) !important;
  max-height: min(76vh, 640px);
  transform: translate(-50%, -50%) scale(0.98) !important;
}
.search-help:hover .search-help-popover,
.search-help:focus-within .search-help-popover {
  transform: translate(-50%, -50%) scale(1) !important;
}
.search-help-popover p,
.search-help-popover dd,
.search-help-popover .rank-help,
.search-help-popover .rank-help .plain-code,
.search-help-popover code,
.search-help-popover .plain-code {
  color: #f7f9fc;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;
  font-size: 0.92rem;
  font-weight: 850;
  line-height: 1.65;
  letter-spacing: 0;
}
.search-help-popover p,
.search-help-popover dd,
.search-help-popover .rank-help {
  font-family: inherit;
  font-size: 0.92rem;
  font-weight: 650;
}
.search-help-popover .rank-help,
.search-help-popover .rank-help .plain-code {
  display: inline;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
}
.search-help-popover code,
.search-help-popover .plain-code {
  display: inline;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  white-space: nowrap;
}
.api-hero-compact {
  grid-template-columns: minmax(0, 1fr) minmax(240px, 300px);
}
.api-hero-compact .api-panel h1 {
  font-size: clamp(2.2rem, 4.6vw, 3.75rem);
}
@media (max-width: 900px) {
  .page-api .nav-shell,
  .api-main.section-shell {
    width: min(calc(100% - 24px), 980px);
  }
}
@media (max-width: 620px) {
  .discord-button { width: auto; }
  .nav-actions .discord-button { min-width: 0; }
}

/* v13.1 popup typography and API width */
.page-api .nav-shell,
.api-main.section-shell {
  width: min(calc(100% - clamp(28px, 4.6vw, 72px)), 960px);
}
.endpoint-grid { max-width: 960px; }
.search-help-popover p,
.search-help-popover dd,
.search-help-popover .rank-help,
.search-help-popover .rank-help .plain-code,
.search-help-popover code,
.search-help-popover .plain-code {
  color: #f7f9fc !important;
  font-family: inherit !important;
  font-size: 0.92rem !important;
  font-weight: 620 !important;
  line-height: 1.65 !important;
  letter-spacing: 0 !important;
}
.search-help-popover code,
.search-help-popover .plain-code,
.search-help-popover .rank-help,
.search-help-popover .rank-help .plain-code {
  display: inline !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  white-space: normal;
}
.search-help-popover code,
.search-help-popover .plain-code { white-space: nowrap; }
@media (max-width: 900px) {
  .page-api .nav-shell,
  .api-main.section-shell {
    width: min(calc(100% - 24px), 960px);
  }
}


/* v14 fixed centered advanced-search popover */
.search-help-popover {
  z-index: 1200 !important;
  overflow: auto;
  visibility: hidden;
}
.search-help:hover .search-help-popover,
.search-help:focus-within .search-help-popover,
.search-help-popover.is-visible {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  transform: translate(-50%, -50%) scale(1) !important;
}
.search-help-button[aria-expanded="true"] {
  border-color: rgba(143, 243, 229, 0.82);
  box-shadow: 0 0 0 4px rgba(88, 220, 196, 0.12);
}

/* v15 cursor-anchored advanced search popover */
.search-help-popover {
  position: fixed !important;
  top: var(--help-top, 88px) !important;
  left: var(--help-left, 16px) !important;
  right: auto !important;
  width: var(--help-width, min(560px, calc(100vw - 28px))) !important;
  max-height: min(76vh, 640px) !important;
  z-index: 2400 !important;
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
  overflow: auto !important;
  transform: translateY(-6px) scale(0.985) !important;
  transform-origin: top left !important;
  transition: opacity 130ms ease, transform 130ms ease, visibility 130ms ease !important;
}
.search-help:hover .search-help-popover,
.search-help:focus-within .search-help-popover,
.search-help-popover.is-visible {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  transform: translateY(0) scale(1) !important;
}

/* v24 season selector + quieter battle-desk theme */
:root {
  --bg: #11130f;
  --bg-elevated: #171b16;
  --panel: #1d211a;
  --panel-2: #24291f;
  --panel-3: #151914;
  --line: rgba(232, 238, 216, 0.15);
  --line-strong: rgba(232, 238, 216, 0.28);
  --text: #f5f2e9;
  --muted: #b9b7aa;
  --soft: #8d9182;
  --brand: #a8d95f;
  --brand-strong: #7fbd48;
  --gold: #f0c65a;
  --blue: #8bb7ff;
  --red: #ff7a66;
  --shadow: 0 18px 46px rgba(0, 0, 0, 0.28);
  --shadow-soft: 0 10px 24px rgba(0, 0, 0, 0.18);
  --radius-xl: 10px;
  --radius-lg: 8px;
  --radius-md: 7px;
  font-family: "Segoe UI", system-ui, -apple-system, BlinkMacSystemFont, "Helvetica Neue", Arial, sans-serif;
}

body {
  color: var(--text);
  background:
    linear-gradient(135deg, #11130f 0%, #18151b 48%, #101716 100%) !important;
  font-weight: 520;
}

body::before {
  background-image:
    linear-gradient(rgba(232, 238, 216, 0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(232, 238, 216, 0.028) 1px, transparent 1px) !important;
  background-size: 44px 44px !important;
  mask-image: linear-gradient(to bottom, black 0%, transparent 86%) !important;
}

h1,
h2,
h3,
.brand strong,
.entry-meta strong,
.pokemon-card h3,
.detail-title h2 {
  letter-spacing: 0 !important;
  font-family: inherit !important;
}

h1,
.detail-title h2 {
  font-weight: 760 !important;
}

h2,
h3,
.brand strong,
.entry-meta strong,
.pokemon-card h3 {
  font-weight: 720 !important;
}

.site-header {
  border-bottom-color: rgba(232, 238, 216, 0.12) !important;
  background: rgba(17, 19, 15, 0.92) !important;
  backdrop-filter: blur(12px) !important;
}

.hero-card,
.controls,
.battle-entry-panel,
.pokemon-card,
.detail-section,
.detail-art,
.metric,
.data-table-wrap,
.search-help-popover,
.empty-state,
.roster-panel,
.battle-column,
.api-panel,
.endpoint-card {
  border-radius: 8px !important;
  border-color: rgba(232, 238, 216, 0.14) !important;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.045), rgba(255, 255, 255, 0.018)),
    rgba(29, 33, 26, 0.92) !important;
  box-shadow: var(--shadow-soft) !important;
}

.pokemon-card:hover,
.entry-item:focus-visible,
.roster-item.active {
  transform: none !important;
  border-color: rgba(168, 217, 95, 0.42) !important;
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.22) !important;
}

.primary-button,
.ghost-button,
.discord-button,
.search-submit,
.search-help-button,
.search-help-close,
.favorite-button,
.open-profile,
.entry-action,
.format-toggle,
.season-picker select {
  border-radius: 7px !important;
  box-shadow: none !important;
  letter-spacing: 0 !important;
}

.primary-button,
.search-submit,
.format-toggle.active {
  border: 1px solid rgba(210, 242, 140, 0.72) !important;
  color: #10130d !important;
  background: #c9eb78 !important;
}

.primary-button:hover,
.primary-button:focus-visible,
.search-submit:hover,
.search-submit:focus-visible,
.format-toggle.active:hover {
  filter: none !important;
  background: #d8f58d !important;
  transform: none !important;
}

.ghost-button,
.discord-button,
.search-help-button,
.search-help-close,
.favorite-button,
.format-toggle {
  color: var(--text) !important;
  background: rgba(255, 255, 255, 0.055) !important;
  border-color: rgba(232, 238, 216, 0.18) !important;
}

.discord-button:hover,
.ghost-button:hover,
.search-help-button:hover,
.search-help-close:hover {
  border-color: rgba(168, 217, 95, 0.45) !important;
  background: rgba(168, 217, 95, 0.12) !important;
  transform: none !important;
}

.season-picker {
  display: inline-grid;
  gap: 0.28rem;
  min-width: 138px;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 680;
}

.season-picker span {
  line-height: 1;
}

.season-picker select {
  min-height: 38px;
  width: 100%;
  padding: 0 2rem 0 0.72rem;
  color: var(--text);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.03)),
    #1b2018 !important;
  border: 1px solid rgba(232, 238, 216, 0.2);
  font-size: 0.88rem;
  font-weight: 640;
}

.search-box,
.filter-grid select,
.search-box input {
  border-radius: 7px !important;
}

.pokemon-art,
.detail-art {
  background:
    linear-gradient(135deg, rgba(168, 217, 95, 0.10), transparent 46%),
    linear-gradient(315deg, rgba(255, 122, 102, 0.09), transparent 42%),
    #141813 !important;
}

.stat-label,
.eyebrow,
.search-help-popover dt {
  color: #c9eb78 !important;
  letter-spacing: 0.04em !important;
}

.type-chip,
code,
.plain-code {
  border-radius: 6px !important;
}

.percent-bar span {
  background: linear-gradient(90deg, #a8d95f, #f0c65a, #ff7a66) !important;
  box-shadow: none !important;
}

@media (max-width: 760px) {
  .nav-actions {
    align-items: stretch !important;
  }

  .season-picker {
    width: 100%;
  }
}

/* v16 button-anchored advanced search popover */
.search-help-popover {
  position: fixed !important;
  top: var(--help-top, 88px) !important;
  left: var(--help-left, 16px) !important;
  right: auto !important;
  width: var(--help-width, min(560px, calc(100vw - 28px))) !important;
  max-height: min(76vh, 640px) !important;
  z-index: 2600 !important;
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
  overflow: auto !important;
  transform: translateY(-6px) scale(0.985) !important;
  transform-origin: top right !important;
  transition: opacity 130ms ease, transform 130ms ease, visibility 130ms ease !important;
}
.search-help:hover .search-help-popover,
.search-help:focus-within .search-help-popover,
.search-help-popover.is-visible {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  transform: translateY(0) scale(1) !important;
}


/* v17 advanced search hover behavior */
.search-help-popover > strong,
.search-help-popover strong {
  color: #8ff3e5 !important;
}
.search-help:hover .search-help-popover:not(.is-visible),
.search-help:focus-within .search-help-popover:not(.is-visible) {
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
  transform: translateY(-6px) scale(0.985) !important;
}
.search-help-popover {
  pointer-events: none !important;
}
.search-help-popover.is-visible {
  pointer-events: none !important;
}

/* v18 mobile-first explorer refinements */
@media (max-width: 760px) {
  :root {
    --mobile-gap: 0.72rem;
  }

  body.page-explorer {
    overflow-x: hidden;
  }

  .page-explorer main {
    display: flex;
    flex-direction: column;
    gap: var(--mobile-gap);
  }

  .page-explorer .nav-shell,
  .page-explorer .section-shell {
    width: min(calc(100% - 18px), var(--max-width));
  }

  .page-explorer .site-header {
    position: sticky;
  }

  .page-explorer .nav-shell {
    padding-block: 0.72rem;
    gap: 0.72rem;
  }

  .page-explorer .brand span {
    min-width: 0;
  }

  .page-explorer .brand strong {
    max-width: 220px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 0.95rem;
  }

  .page-explorer .brand small {
    display: none;
  }

  .page-explorer .brand-logo {
    width: 32px;
    height: 32px;
    border-radius: 9px;
  }

  .page-explorer .nav-actions {
    gap: 0.5rem;
  }

  .page-explorer .format-switch {
    order: 1;
    width: 100%;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .page-explorer .format-toggle {
    width: 100%;
  }

  .page-explorer .ghost-button,
  .page-explorer .discord-button {
    flex: 1 1 0;
    min-width: 0;
  }

  .page-explorer .controls {
    order: 1;
    padding: 0.72rem;
    margin-top: 0.2rem;
    grid-template-columns: 1fr;
    gap: 0.72rem;
    border-radius: 18px;
  }

  .page-explorer .search-label-row {
    align-items: center;
  }

  .page-explorer .search-box {
    height: 48px;
    border-radius: 14px;
    padding-inline: 0.82rem;
  }

  .page-explorer .search-box input {
    font-size: 0.94rem;
  }

  .page-explorer .filter-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.58rem;
  }

  .page-explorer .filter-grid label,
  .page-explorer .checkbox-label {
    width: 100%;
    min-width: 0;
    font-size: 0.72rem;
  }

  .page-explorer .filter-grid select,
  .page-explorer .checkbox-label {
    min-height: 42px;
    border-radius: 13px;
  }

  .page-explorer .checkbox-label {
    justify-content: flex-start;
    padding-inline: 0.74rem;
  }

  .page-explorer .hero {
    order: 2;
    display: block;
    padding-block: 0;
  }

  .page-explorer .hero-copy {
    display: none !important;
  }

  .page-explorer .battle-entry-panel {
    min-height: min(62vh, 620px);
    max-height: none;
    height: calc(100dvh - 298px);
    padding: 0.82rem;
    border-radius: 18px;
  }

  .page-explorer .entry-panel-header {
    padding-bottom: 0.72rem;
  }

  .page-explorer .stat-label {
    font-size: 0.68rem;
    letter-spacing: 0.12em;
  }

  .page-explorer .hero-card strong {
    font-size: 0.95rem;
  }

  .page-explorer .entry-count {
    min-width: 38px;
    min-height: 30px;
  }

  .page-explorer .entry-list {
    gap: 0.5rem;
    padding-top: 0.7rem;
  }

  .page-explorer .entry-item {
    grid-template-columns: 34px 46px minmax(0, 1fr);
    gap: 0.62rem;
    padding: 0.56rem;
    border-radius: 14px;
  }

  .page-explorer .entry-index {
    width: 30px;
    height: 30px;
    font-size: 0.78rem;
  }

  .page-explorer .entry-thumb {
    width: 46px;
    height: 46px;
    border-radius: 12px;
  }

  .page-explorer .entry-meta strong {
    font-size: 0.95rem;
  }

  .page-explorer .entry-types {
    margin-top: 0.28rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.28rem;
  }

  .page-explorer .entry-types .type-chip {
    padding: 0.24rem 0.42rem;
    font-size: 0.64rem;
  }

  .page-explorer .entry-types .type-chip img {
    width: 14px;
    height: 14px;
  }

  .page-explorer .layout,
  .page-explorer .sidebar,
  .page-explorer .content-area,
  .page-explorer .pokemon-grid,
  .page-explorer #pokemonGrid,
  .page-explorer #emptyState {
    display: none !important;
  }
}

@media (max-width: 430px) {
  .page-explorer .filter-grid {
    grid-template-columns: 1fr;
  }

  .page-explorer .battle-entry-panel {
    height: calc(100dvh - 392px);
    min-height: 360px;
  }
}

@media (max-width: 760px) {
  .detail-dialog {
    width: 100vw !important;
    max-width: 100vw !important;
    height: 100dvh !important;
    max-height: 100dvh !important;
    margin: 0 !important;
    border-radius: 0 !important;
  }

  .detail-dialog::backdrop {
    background: rgba(0,0,0,0.72);
    backdrop-filter: blur(8px);
  }

  .detail-dialog .dialog-inner,
  .dialog-inner {
    width: 100%;
    height: 100dvh !important;
    max-height: 100dvh !important;
    overflow: auto;
    padding: calc(0.86rem + env(safe-area-inset-top)) 0.82rem calc(1rem + env(safe-area-inset-bottom));
    padding-top: calc(3.25rem + env(safe-area-inset-top));
    border: 0;
    border-radius: 0;
    background:
      radial-gradient(circle at 12% 0%, rgba(88, 220, 196, 0.12), transparent 18rem),
      linear-gradient(180deg, rgba(16,24,39,0.98), rgba(7,11,18,0.99));
  }

  .close-button {
    position: fixed;
    top: calc(0.72rem + env(safe-area-inset-top));
    right: 0.82rem;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    padding: 0 0 0.03rem !important;
    line-height: 1;
    font-size: 1.36rem;
    background: rgba(8, 13, 22, 0.88);
    backdrop-filter: blur(12px);
  }

  .detail-hero {
    grid-template-columns: 104px minmax(0, 1fr) !important;
    gap: 0.76rem;
    align-items: center;
    padding-right: 3rem;
  }

  .detail-art {
    min-height: 110px;
    border-radius: 18px;
  }

  .detail-art img {
    width: 92px;
    height: 92px;
  }

  .detail-art .pokemon-fallback {
    width: 82px;
    height: 82px;
    font-size: 1.15rem;
  }

  .detail-title .eyebrow {
    margin-bottom: 0.36rem;
    font-size: 0.62rem;
    letter-spacing: 0.14em;
  }

  .detail-title h2 {
    font-size: clamp(1.8rem, 9vw, 2.65rem);
    line-height: 1;
    letter-spacing: -0.055em;
  }

  .detail-title .type-row {
    margin-top: 0.62rem;
    gap: 0.32rem;
  }

  .detail-title .type-chip {
    padding: 0.3rem 0.48rem;
    font-size: 0.67rem;
  }

  .detail-metrics {
    grid-template-columns: 1fr;
    gap: 0.46rem;
    margin-top: 0.72rem;
  }

  .metric {
    padding: 0.64rem 0.68rem;
    border-radius: 14px;
  }

  .metric span {
    font-size: 0.62rem;
  }

  .metric strong {
    font-size: 0.9rem;
  }

  .detail-sections {
    gap: 0.68rem;
    margin-top: 0.82rem;
  }

  .detail-section {
    padding: 0.76rem;
    border-radius: 17px;
    background: rgba(255,255,255,0.034);
  }

  .detail-section h3 {
    margin-bottom: 0.64rem;
    font-size: 0.96rem;
  }

  .battle-grid,
  .battle-grid-columns {
    grid-template-columns: 1fr !important;
    gap: 0.7rem;
  }

  .battle-column {
    gap: 0.7rem;
  }

  .data-table-wrap {
    max-width: 100%;
    border-radius: 13px;
    -webkit-overflow-scrolling: touch;
  }

  table {
    min-width: 430px;
    font-size: 0.78rem;
  }

  th, td {
    padding: 0.52rem;
  }

  .stat-row {
    grid-template-columns: 44px minmax(0, 1fr) 38px;
    gap: 0.52rem;
    font-size: 0.8rem;
  }

  .percent-bar {
    min-width: 96px;
    height: 28px;
  }
}

@media (max-width: 380px) {
  .detail-hero {
    grid-template-columns: 1fr !important;
    padding-right: 3rem;
  }

  .detail-art {
    min-height: 132px;
  }

  .detail-art img {
    width: 112px;
    height: 112px;
  }
}

/* v19 mobile polish: compact explorer title, no horizontal profile data, better touch help */
@media (max-width: 760px) {
  html,
  body.page-explorer {
    min-height: 100%;
    overflow-x: hidden !important;
  }

  .page-explorer main {
    display: flex !important;
    flex-direction: column !important;
    gap: 0.78rem !important;
    padding-bottom: calc(1.05rem + env(safe-area-inset-bottom));
  }

  .page-explorer .nav-shell,
  .page-explorer .section-shell {
    width: min(calc(100% - 20px), var(--max-width)) !important;
  }

  .page-explorer .hero {
    display: contents !important;
  }

  .page-explorer .hero-copy {
    order: 1 !important;
    display: block !important;
    width: min(calc(100% - 20px), var(--max-width));
    margin-inline: auto;
    padding: 0.96rem 0 0.04rem;
  }

  .page-explorer .hero-copy .eyebrow {
    display: block !important;
    margin: 0;
    color: var(--brand) !important;
    font-size: clamp(0.78rem, 3.25vw, 0.92rem);
    line-height: 1.35;
    letter-spacing: 0.13em;
  }

  .page-explorer .hero-copy h1,
  .page-explorer .hero-copy .hero-text {
    display: none !important;
  }

  .page-explorer .controls {
    order: 2 !important;
    margin-top: 0 !important;
    padding: 0.78rem !important;
    border-radius: 18px !important;
  }

  .page-explorer .battle-entry-panel {
    order: 3 !important;
    width: min(calc(100% - 20px), var(--max-width));
    margin: 0 auto !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    padding: 0.82rem !important;
    border-radius: 18px !important;
    overflow: hidden !important;
  }

  .page-explorer .entry-list {
    max-height: clamp(360px, 58dvh, 680px);
    min-height: 300px;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    padding: 0.7rem 0.08rem 0.16rem 0 !important;
    overscroll-behavior: contain;
  }

  .page-explorer .entry-item {
    grid-template-columns: 32px 44px minmax(0, 1fr) !important;
    min-width: 0;
  }

  .page-explorer .entry-meta,
  .page-explorer .entry-types {
    min-width: 0;
  }

  .page-explorer .search-help-popover {
    width: min(560px, calc(100vw - 20px)) !important;
    max-height: min(76dvh, 640px) !important;
  }

  .page-explorer .search-help-button {
    cursor: pointer;
    touch-action: manipulation;
  }
}

@media (max-width: 430px) {
  .page-explorer .entry-list {
    max-height: clamp(340px, 54dvh, 610px) !important;
    min-height: 280px !important;
  }

  .page-explorer .battle-entry-panel {
    height: auto !important;
    min-height: 0 !important;
  }
}

@media (max-width: 760px) {
  .detail-dialog,
  .detail-dialog .dialog-inner,
  .detail-content,
  .detail-sections,
  .detail-section,
  .battle-grid,
  .battle-grid-columns,
  .battle-column,
  .data-table-wrap {
    min-width: 0 !important;
    max-width: 100% !important;
  }

  .detail-dialog .dialog-inner,
  .dialog-inner {
    overflow-x: hidden !important;
  }

  .detail-content {
    display: block;
    width: 100%;
  }

  .detail-hero {
    grid-template-columns: 96px minmax(0, 1fr) !important;
    gap: 0.72rem !important;
    padding-right: 2.7rem !important;
  }

  .detail-art {
    min-height: 102px !important;
    border-radius: 16px !important;
  }

  .detail-art img {
    width: 86px !important;
    height: 86px !important;
  }

  .detail-title h2 {
    overflow-wrap: anywhere;
  }

  .detail-title .type-row {
    display: flex;
    flex-wrap: wrap;
    min-width: 0;
  }

  .detail-metrics {
    grid-template-columns: 1fr !important;
  }

  .metric strong {
    white-space: normal;
    overflow-wrap: anywhere;
  }

  .detail-section {
    padding: 0.78rem !important;
    border-radius: 17px !important;
  }

  .battle-grid,
  .battle-grid-columns {
    display: grid !important;
    grid-template-columns: 1fr !important;
  }

  .data-table-wrap {
    overflow: visible !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
  }

  .data-table-wrap table.responsive-data-table,
  .data-table-wrap table {
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
    border-collapse: separate !important;
    border-spacing: 0 !important;
    font-size: 0.8rem !important;
  }

  .data-table-wrap thead {
    display: none !important;
  }

  .data-table-wrap tbody {
    display: grid !important;
    gap: 0.5rem !important;
    width: 100% !important;
  }

  .data-table-wrap tr {
    display: grid !important;
    width: 100% !important;
    gap: 0.3rem !important;
    padding: 0.62rem !important;
    border: 1px solid rgba(148, 163, 184, 0.16) !important;
    border-radius: 14px !important;
    background: rgba(255,255,255,0.036) !important;
  }

  .data-table-wrap td {
    display: grid !important;
    grid-template-columns: minmax(76px, 0.42fr) minmax(0, 1fr) !important;
    align-items: start !important;
    gap: 0.64rem !important;
    width: 100% !important;
    min-width: 0 !important;
    padding: 0.12rem 0 !important;
    border: 0 !important;
    color: #eef5fb !important;
    text-align: right !important;
    overflow-wrap: anywhere !important;
  }

  .data-table-wrap td::before {
    content: attr(data-label);
    color: var(--soft);
    font-size: 0.67rem;
    font-weight: 950;
    text-align: left;
    text-transform: uppercase;
    letter-spacing: 0.07em;
  }

  .data-table-wrap td > * {
    min-width: 0;
    justify-self: end;
  }

  .data-table-wrap .percent-bar {
    width: min(150px, 100%) !important;
    min-width: 0 !important;
    height: 26px !important;
    justify-self: end;
  }

  .data-table-wrap .percent-bar b {
    font-size: 0.72rem !important;
  }

  .forms-table td[data-label="Stats"] {
    grid-template-columns: 1fr !important;
    text-align: left !important;
  }

  .forms-table td[data-label="Stats"]::before {
    margin-bottom: 0.18rem;
  }

  .form-stat-line {
    display: flex;
    flex-wrap: wrap;
    gap: 0.28rem;
    justify-self: start !important;
    text-align: left;
  }

  .form-stat-line span {
    padding: 0.22rem 0.38rem;
    border: 1px solid rgba(148, 163, 184, 0.16);
    border-radius: 999px;
    color: #eef5fb;
    background: rgba(255,255,255,0.04);
    font-size: 0.72rem;
    font-weight: 800;
  }

  .stat-row {
    grid-template-columns: 42px minmax(0, 1fr) 34px !important;
    gap: 0.46rem !important;
  }
}

@media (max-width: 380px) {
  .detail-hero {
    grid-template-columns: 1fr !important;
    padding-right: 2.7rem !important;
  }

  .detail-art {
    min-height: 128px !important;
  }

  .detail-art img {
    width: 108px !important;
    height: 108px !important;
  }
}

/* v20 mobile refinement + toggleable advanced search help */
.search-help-popover {
  pointer-events: none !important;
}
.search-help-popover.is-visible {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  transform: translateY(0) scale(1) !important;
}
.search-help:hover .search-help-popover:not(.is-visible),
.search-help:focus-within .search-help-popover:not(.is-visible) {
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
  transform: translateY(-6px) scale(0.985) !important;
}
.search-help-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.85rem;
  margin-bottom: 0.35rem;
}
.search-help-header strong {
  margin: 0 !important;
  color: #8ff3e5 !important;
}
.search-help-close {
  width: 30px;
  height: 30px;
  flex: 0 0 auto;
  display: grid;
  place-items: center;
  border: 1px solid rgba(143, 243, 229, 0.28);
  border-radius: 999px;
  color: #f7f9fc;
  background: rgba(255,255,255,0.06);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.07);
  cursor: pointer;
  font-size: 1.08rem;
  font-weight: 900;
  line-height: 1;
  transition: background 140ms ease, border-color 140ms ease, transform 140ms ease;
}
.search-help-close:hover,
.search-help-close:focus-visible {
  border-color: rgba(143, 243, 229, 0.72);
  background: rgba(88,220,196,0.14);
  outline: none;
  transform: translateY(-1px);
}

@media (max-width: 760px) {
  .page-explorer .nav-shell {
    width: min(calc(100% - 24px), var(--max-width)) !important;
    padding-block: 0.88rem !important;
    gap: 0.82rem !important;
  }

  .page-explorer .nav-actions {
    gap: 0.62rem !important;
  }

  .page-explorer main {
    gap: 0.96rem !important;
    padding-bottom: calc(1.25rem + env(safe-area-inset-bottom)) !important;
  }

  .page-explorer .section-shell,
  .page-explorer .hero-copy,
  .page-explorer .battle-entry-panel {
    width: min(calc(100% - 24px), var(--max-width)) !important;
  }

  .page-explorer .hero-copy {
    padding: 1.12rem 0 0.08rem !important;
  }

  .page-explorer .controls {
    padding: 0.98rem !important;
    border-radius: 20px !important;
  }

  .page-explorer .filter-grid {
    gap: 0.68rem !important;
  }

  .page-explorer .battle-entry-panel {
    padding: 0.98rem !important;
    border-radius: 20px !important;
  }

  .page-explorer .entry-list {
    padding-top: 0.78rem !important;
  }

  .page-explorer .search-help-popover {
    width: min(560px, calc(100vw - 24px)) !important;
    max-height: min(72dvh, 620px) !important;
  }

  .search-help-button {
    cursor: pointer !important;
  }

  .detail-dialog,
  .detail-dialog .dialog-inner,
  .detail-content,
  .detail-sections,
  .detail-section,
  .battle-grid,
  .battle-grid-columns,
  .battle-column,
  .data-table-wrap {
    min-width: 0 !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }

  .detail-dialog {
    width: 100vw !important;
    max-width: 100vw !important;
    height: 100dvh !important;
    max-height: 100dvh !important;
  }

  .detail-dialog .dialog-inner,
  .dialog-inner {
    width: 100% !important;
    overflow-x: hidden !important;
    padding-left: max(0.72rem, env(safe-area-inset-left)) !important;
    padding-right: max(0.72rem, env(safe-area-inset-right)) !important;
  }

  .detail-hero {
    grid-template-columns: 92px minmax(0, 1fr) !important;
    gap: 0.76rem !important;
    padding-right: 2.75rem !important;
  }

  .detail-art {
    min-height: 98px !important;
    border-radius: 16px !important;
  }

  .detail-art img {
    width: 82px !important;
    height: 82px !important;
  }

  .detail-title h2,
  .metric strong,
  .detail-title .type-row {
    min-width: 0 !important;
    overflow-wrap: anywhere !important;
  }

  .detail-metrics {
    grid-template-columns: 1fr !important;
  }

  .detail-section {
    padding: 0.82rem !important;
    border-radius: 18px !important;
  }

  .battle-grid,
  .battle-grid-columns {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 0.72rem !important;
  }

  .data-table-wrap {
    overflow-x: hidden !important;
    overflow-y: visible !important;
    border: 1px solid rgba(148, 163, 184, 0.14) !important;
    border-radius: 14px !important;
    background: rgba(0,0,0,0.12) !important;
  }

  .data-table-wrap table.responsive-data-table,
  .data-table-wrap table,
  table.responsive-data-table {
    display: table !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    table-layout: fixed !important;
    border-collapse: collapse !important;
    border-spacing: 0 !important;
    font-size: clamp(0.58rem, 1.75vw, 0.72rem) !important;
  }

  .data-table-wrap thead {
    display: table-header-group !important;
  }

  .data-table-wrap tbody {
    display: table-row-group !important;
    width: auto !important;
  }

  .data-table-wrap tr {
    display: table-row !important;
    width: auto !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
  }

  .data-table-wrap th,
  .data-table-wrap td {
    display: table-cell !important;
    width: auto !important;
    min-width: 0 !important;
    padding: 0.42rem 0.24rem !important;
    border-bottom: 1px solid rgba(148, 163, 184, 0.1) !important;
    text-align: left !important;
    vertical-align: middle !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
    word-break: normal !important;
    color: #eef5fb !important;
  }

  .data-table-wrap td::before {
    content: none !important;
    display: none !important;
  }

  .data-table-wrap td > * {
    justify-self: initial !important;
  }

  .battle-table th:nth-child(1),
  .battle-table td:nth-child(1),
  .teammate-table th:nth-child(1),
  .teammate-table td:nth-child(1),
  .nature-table th:nth-child(1),
  .nature-table td:nth-child(1),
  .stat-points-table th:nth-child(1),
  .stat-points-table td:nth-child(1) {
    width: 10% !important;
  }

  .battle-table th:nth-child(2),
  .battle-table td:nth-child(2) {
    width: 52% !important;
  }

  .battle-table th:nth-child(3),
  .battle-table td:nth-child(3) {
    width: 38% !important;
  }

  .teammate-table th:nth-child(2),
  .teammate-table td:nth-child(2) {
    width: 90% !important;
  }

  .nature-table th:nth-child(2),
  .nature-table td:nth-child(2) { width: 29% !important; }
  .nature-table th:nth-child(3),
  .nature-table td:nth-child(3) { width: 31% !important; }
  .nature-table th:nth-child(4),
  .nature-table td:nth-child(4) { width: 30% !important; }

  .stat-points-table th:nth-child(2),
  .stat-points-table td:nth-child(2) { width: 24% !important; }
  .stat-points-table th:nth-child(n+3),
  .stat-points-table td:nth-child(n+3) { width: 11% !important; text-align: center !important; }

  .forms-table {
    font-size: clamp(0.5rem, 1.52vw, 0.62rem) !important;
  }

  .forms-table th,
  .forms-table td {
    padding: 0.36rem 0.16rem !important;
  }

  .form-stat-line {
    display: block !important;
    line-height: 1.35 !important;
    text-align: left !important;
  }

  .form-stat-line span {
    display: inline !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    font-size: inherit !important;
    font-weight: 750 !important;
  }

  .form-stat-line span + span::before {
    content: " · ";
    color: rgba(238,245,251,0.52);
  }

  .data-table-wrap .percent-bar,
  .percent-bar {
    width: min(76px, 100%) !important;
    min-width: 0 !important;
    height: 22px !important;
  }

  .stat-points-table .percent-bar {
    width: min(54px, 100%) !important;
  }

  .data-table-wrap .percent-bar b,
  .percent-bar b {
    font-size: 0.58rem !important;
  }

  .stat-row {
    grid-template-columns: 38px minmax(0, 1fr) 32px !important;
    gap: 0.44rem !important;
  }
}

@media (max-width: 390px) {
  .detail-dialog .dialog-inner,
  .dialog-inner {
    padding-left: max(0.56rem, env(safe-area-inset-left)) !important;
    padding-right: max(0.56rem, env(safe-area-inset-right)) !important;
  }

  .detail-hero {
    grid-template-columns: 76px minmax(0, 1fr) !important;
    gap: 0.62rem !important;
    padding-right: 2.55rem !important;
  }

  .detail-art {
    min-height: 82px !important;
  }

  .detail-art img {
    width: 70px !important;
    height: 70px !important;
  }

  .detail-title h2 {
    font-size: clamp(1.55rem, 8vw, 2.2rem) !important;
  }

  .data-table-wrap th,
  .data-table-wrap td {
    padding: 0.34rem 0.16rem !important;
  }

  .data-table-wrap .percent-bar,
  .percent-bar {
    width: min(62px, 100%) !important;
    height: 20px !important;
  }

  .stat-points-table .percent-bar {
    width: min(48px, 100%) !important;
  }
}

/* v21 profile/table polish */
.detail-dialog {
  width: min(1240px, calc(100% - 28px)) !important;
}
.detail-dialog .dialog-inner,
.dialog-inner {
  max-width: 100%;
}
.detail-section {
  overflow: hidden;
}
.data-table-wrap {
  width: 100%;
}
.data-table-wrap table {
  font-size: 0.9rem;
}
.data-table-wrap th,
.data-table-wrap td {
  padding: 0.72rem 0.68rem;
  line-height: 1.35;
}
.data-table-wrap th:first-child,
.data-table-wrap td:first-child {
  padding-left: 0.9rem;
}
.percent-bar {
  width: 150px;
  min-width: 136px;
  height: 34px;
}
.percent-bar b {
  font-size: 0.84rem;
}
.battle-table th:nth-child(1),
.battle-table td:nth-child(1),
.teammate-table th:nth-child(1),
.teammate-table td:nth-child(1),
.nature-table th:nth-child(1),
.nature-table td:nth-child(1) {
  width: 12%;
}
.battle-table th:nth-child(2),
.battle-table td:nth-child(2) {
  width: 46%;
}
.battle-table th:nth-child(3),
.battle-table td:nth-child(3) {
  width: 42%;
}
.teammate-table th:nth-child(2),
.teammate-table td:nth-child(2) {
  width: 88%;
}
.forms-table th:nth-child(1),
.forms-table td:nth-child(1) { width: 16%; }
.forms-table th:nth-child(2),
.forms-table td:nth-child(2) { width: 16%; }
.forms-table th:nth-child(3),
.forms-table td:nth-child(3) { width: 24%; }
.forms-table th:nth-child(4),
.forms-table td:nth-child(4) { width: 34%; }
.forms-table th:nth-child(5),
.forms-table td:nth-child(5) { width: 10%; text-align: center; }
.forms-table .form-stat-line {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem 0.55rem;
}
.forms-table .form-stat-line span {
  white-space: nowrap;
}

@media (max-width: 760px) {
  .page-explorer .nav-shell {
    padding-block: 1rem !important;
    gap: 1rem !important;
  }

  .page-explorer .nav-actions {
    gap: 0.72rem !important;
  }

  .page-explorer main {
    gap: 1.08rem !important;
    padding-bottom: calc(1.55rem + env(safe-area-inset-bottom)) !important;
  }

  .page-explorer .section-shell,
  .page-explorer .hero-copy,
  .page-explorer .battle-entry-panel {
    width: min(calc(100% - 28px), var(--max-width)) !important;
  }

  .page-explorer .hero-copy {
    padding-top: 1.28rem !important;
  }

  .page-explorer .controls,
  .page-explorer .battle-entry-panel {
    padding: 1.04rem !important;
  }

  .page-explorer .entry-item {
    min-height: 72px;
  }

  .detail-dialog {
    width: 100vw !important;
    max-width: 100vw !important;
    height: 100dvh !important;
    max-height: 100dvh !important;
  }

  .detail-dialog .dialog-inner,
  .dialog-inner {
    padding-left: max(0.64rem, env(safe-area-inset-left)) !important;
    padding-right: max(0.64rem, env(safe-area-inset-right)) !important;
    overflow-x: hidden !important;
  }

  .detail-section {
    padding: 0.9rem 0.58rem !important;
  }

  .detail-section h3 {
    padding-inline: 0.16rem;
    font-size: 1.08rem !important;
  }

  .data-table-wrap {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
  }

  .data-table-wrap table.responsive-data-table,
  .data-table-wrap table,
  table.responsive-data-table {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    table-layout: fixed !important;
    font-size: clamp(0.76rem, 2.42vw, 0.9rem) !important;
  }

  .data-table-wrap th,
  .data-table-wrap td {
    padding: 0.62rem 0.32rem !important;
    line-height: 1.38 !important;
  }

  .data-table-wrap th:first-child,
  .data-table-wrap td:first-child {
    padding-left: 0.72rem !important;
  }

  .data-table-wrap th {
    font-size: clamp(0.68rem, 2.15vw, 0.78rem) !important;
    letter-spacing: 0.08em !important;
  }

  .battle-table th:nth-child(1),
  .battle-table td:nth-child(1),
  .teammate-table th:nth-child(1),
  .teammate-table td:nth-child(1),
  .nature-table th:nth-child(1),
  .nature-table td:nth-child(1) {
    width: 11% !important;
  }

  .battle-table th:nth-child(2),
  .battle-table td:nth-child(2) {
    width: 43% !important;
  }

  .battle-table th:nth-child(3),
  .battle-table td:nth-child(3) {
    width: 46% !important;
  }

  .teammate-table th:nth-child(2),
  .teammate-table td:nth-child(2) {
    width: 89% !important;
  }

  .nature-table th:nth-child(2),
  .nature-table td:nth-child(2) { width: 28% !important; }
  .nature-table th:nth-child(3),
  .nature-table td:nth-child(3) { width: 34% !important; }
  .nature-table th:nth-child(4),
  .nature-table td:nth-child(4) { width: 27% !important; }

  .battle-table .percent-bar,
  .nature-table .percent-bar,
  .data-table-wrap .percent-bar,
  .percent-bar {
    width: min(122px, 100%) !important;
    min-width: 0 !important;
    height: 30px !important;
  }

  .battle-table .percent-bar b,
  .nature-table .percent-bar b,
  .data-table-wrap .percent-bar b,
  .percent-bar b {
    font-size: 0.76rem !important;
  }

  .stat-points-table {
    font-size: clamp(0.58rem, 1.92vw, 0.7rem) !important;
  }

  .stat-points-table th,
  .stat-points-table td {
    padding: 0.48rem 0.14rem !important;
  }

  .stat-points-table th:first-child,
  .stat-points-table td:first-child {
    padding-left: 0.44rem !important;
  }

  .stat-points-table th:nth-child(1),
  .stat-points-table td:nth-child(1) { width: 8% !important; }
  .stat-points-table th:nth-child(2),
  .stat-points-table td:nth-child(2) { width: 20% !important; }
  .stat-points-table th:nth-child(n+3),
  .stat-points-table td:nth-child(n+3) { width: 12% !important; text-align: center !important; }

  .stat-points-table .percent-bar {
    width: min(72px, 100%) !important;
    height: 24px !important;
  }

  .stat-points-table .percent-bar b {
    font-size: 0.6rem !important;
  }

  .forms-table {
    font-size: clamp(0.62rem, 1.98vw, 0.74rem) !important;
  }

  .forms-table th,
  .forms-table td {
    padding: 0.5rem 0.18rem !important;
    vertical-align: top !important;
  }

  .forms-table th:first-child,
  .forms-table td:first-child {
    padding-left: 0.46rem !important;
  }

  .forms-table th:nth-child(1),
  .forms-table td:nth-child(1) { width: 18% !important; }
  .forms-table th:nth-child(2),
  .forms-table td:nth-child(2) { width: 17% !important; }
  .forms-table th:nth-child(3),
  .forms-table td:nth-child(3) { width: 25% !important; }
  .forms-table th:nth-child(4),
  .forms-table td:nth-child(4) { width: 30% !important; }
  .forms-table th:nth-child(5),
  .forms-table td:nth-child(5) { width: 10% !important; text-align: center !important; }

  .forms-table .form-stat-line {
    display: block !important;
    line-height: 1.34 !important;
  }

  .forms-table .form-stat-line span {
    display: inline !important;
    white-space: normal !important;
    font-weight: 760 !important;
  }

  .forms-table .form-stat-line span + span::before {
    content: " · ";
    color: rgba(238,245,251,0.52);
  }
}

@media (max-width: 390px) {
  .data-table-wrap table.responsive-data-table,
  .data-table-wrap table,
  table.responsive-data-table {
    font-size: clamp(0.7rem, 2.55vw, 0.82rem) !important;
  }

  .data-table-wrap th,
  .data-table-wrap td {
    padding: 0.56rem 0.24rem !important;
  }

  .battle-table .percent-bar,
  .nature-table .percent-bar,
  .data-table-wrap .percent-bar,
  .percent-bar {
    width: min(104px, 100%) !important;
    height: 28px !important;
  }

  .forms-table,
  .stat-points-table {
    font-size: clamp(0.56rem, 2.08vw, 0.68rem) !important;
  }
}

/* v22 metadata + mobile table refinements */
.nature-change {
  display: inline-grid;
  gap: 0.12rem;
  line-height: 1.05;
  font-weight: 900;
  letter-spacing: 0.02em;
}
.nature-change .nature-up { color: #71f0cf; }
.nature-change .nature-down { color: #f6a8b5; }
.nature-neutral { color: #b7c4d4; }
.forms-table th:nth-child(1),
.forms-table td:nth-child(1) { width: 18% !important; }
.forms-table th:nth-child(2),
.forms-table td:nth-child(2) { width: 18% !important; }
.forms-table th:nth-child(3),
.forms-table td:nth-child(3) { width: 26% !important; }
.forms-table th:nth-child(4),
.forms-table td:nth-child(4) { width: 38% !important; }
.form-stat-line span strong,
.form-stat-line span:last-child { color: #f8fbff; }

@media (max-width: 760px) {
  .data-table-wrap th:first-child,
  .data-table-wrap td:first-child {
    padding-left: 0.92rem !important;
  }

  .teammate-table th:nth-child(2),
  .teammate-table td:nth-child(2) {
    padding-left: 1.05rem !important;
    width: 88% !important;
  }

  .nature-table th:nth-child(1),
  .nature-table td:nth-child(1) { width: 11% !important; }
  .nature-table th:nth-child(2),
  .nature-table td:nth-child(2) { width: 27% !important; }
  .nature-table th:nth-child(3),
  .nature-table td:nth-child(3) { width: 36% !important; }
  .nature-table th:nth-child(4),
  .nature-table td:nth-child(4) { width: 26% !important; }

  .nature-change {
    font-size: 0.8rem;
    min-width: 2.8rem;
  }

  .forms-table th:nth-child(1),
  .forms-table td:nth-child(1) { width: 22% !important; }
  .forms-table th:nth-child(2),
  .forms-table td:nth-child(2) { width: 20% !important; }
  .forms-table th:nth-child(3),
  .forms-table td:nth-child(3) { width: 25% !important; }
  .forms-table th:nth-child(4),
  .forms-table td:nth-child(4) { width: 33% !important; }

  .forms-table .form-stat-line {
    line-height: 1.42 !important;
  }
}

@media (max-width: 390px) {
  .teammate-table th:nth-child(2),
  .teammate-table td:nth-child(2) {
    padding-left: 0.9rem !important;
  }
  .nature-change { font-size: 0.74rem; }
}

.forms-metadata-block {
  display: grid;
  gap: 0.85rem;
}

@media (max-width: 760px) {
  .nature-table th:nth-child(4),
  .nature-table td:nth-child(4) {
    padding-left: 1.25rem !important;
  }

  .stat-points-table th:first-child,
  .stat-points-table td:first-child {
    display: none !important;
  }

  .stat-points-table th:nth-child(2),
  .stat-points-table td:nth-child(2) {
    width: 26% !important;
    padding-left: 0.85rem !important;
  }

  .stat-points-table th:nth-child(n+3),
  .stat-points-table td:nth-child(n+3) {
    width: 12.3% !important;
    text-align: center !important;
  }
}

@media (max-width: 390px) {
  .nature-table th:nth-child(4),
  .nature-table td:nth-child(4) {
    padding-left: 0.9rem !important;
  }
}

/* v25: polished Battle Data list on mobile */
.entry-action {
  display: none;
}

@media (min-width: 761px) {
  .entry-item {
    grid-template-columns: 34px 52px minmax(0, 1fr) auto;
  }
  .entry-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 30px;
    padding: 0 0.7rem;
    border: 1px solid rgba(88, 220, 196, 0.22);
    border-radius: 999px;
    color: #dffcf7;
    background: rgba(88, 220, 196, 0.075);
    font-size: 0.72rem;
    font-weight: 900;
  }
}

@media (max-width: 760px) {
  .page-explorer .battle-entry-panel {
    position: relative;
    padding: 0.95rem !important;
    border-radius: 22px !important;
    border-color: rgba(88, 220, 196, 0.20) !important;
    background:
      radial-gradient(circle at 18% 0%, rgba(88, 220, 196, 0.10), transparent 15rem),
      linear-gradient(180deg, rgba(15, 24, 38, 0.98), rgba(8, 13, 23, 0.98)) !important;
    box-shadow: 0 18px 46px rgba(0, 0, 0, 0.32), inset 0 1px 0 rgba(255,255,255,0.045) !important;
  }

  .page-explorer .entry-panel-header {
    align-items: center !important;
    padding: 0.78rem 0.82rem !important;
    border: 1px solid rgba(148, 163, 184, 0.14) !important;
    border-radius: 17px !important;
    background: rgba(255,255,255,0.035) !important;
  }

  .page-explorer .entry-panel-header > div {
    min-width: 0;
  }

  .page-explorer .entry-panel-header .stat-label {
    margin-bottom: 0.22rem !important;
    color: #70ead8 !important;
  }

  .page-explorer .hero-card strong#datasetStatus,
  .page-explorer #datasetStatus {
    color: #f7fbff !important;
    font-size: 0.98rem !important;
    letter-spacing: -0.02em;
  }

  .page-explorer .entry-count {
    min-width: 42px !important;
    height: 34px !important;
    padding: 0 0.55rem !important;
    border: 1px solid rgba(88, 220, 196, 0.35) !important;
    color: #081119 !important;
    background: linear-gradient(135deg, #61e7d0, #e7d379) !important;
    box-shadow: 0 9px 22px rgba(88, 220, 196, 0.16) !important;
  }

  .page-explorer #pokemonCount.entry-count {
    min-width: 0 !important;
    height: auto !important;
    padding: 0 !important;
    border: 0 !important;
    color: #c4f7bd !important;
    background: none !important;
    background-color: transparent !important;
    background-image: none !important;
    box-shadow: none !important;
    border-radius: 0 !important;
  }

  .page-explorer .entry-list {
    display: grid !important;
    gap: 0.72rem !important;
    max-height: clamp(390px, 60dvh, 720px) !important;
    padding: 0.85rem 0.08rem 0.22rem 0 !important;
    scroll-padding: 0.8rem;
  }

  .page-explorer .entry-list::-webkit-scrollbar {
    width: 8px;
  }

  .page-explorer .entry-list::-webkit-scrollbar-thumb {
    background: rgba(88, 220, 196, 0.23);
  }

  .page-explorer .entry-item {
    position: relative;
    min-height: 76px;
    grid-template-columns: 34px 54px minmax(0, 1fr) 28px !important;
    gap: 0.74rem !important;
    align-items: center !important;
    padding: 0.68rem 0.72rem !important;
    border-radius: 18px !important;
    border: 1px solid rgba(148, 163, 184, 0.16) !important;
    background:
      linear-gradient(135deg, rgba(255,255,255,0.055), rgba(255,255,255,0.022)),
      rgba(10, 17, 29, 0.92) !important;
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.18), inset 0 1px 0 rgba(255,255,255,0.035);
  }

  .page-explorer .entry-item::before {
    content: "";
    position: absolute;
    left: 0;
    top: 14px;
    bottom: 14px;
    width: 3px;
    border-radius: 999px;
    background: linear-gradient(180deg, rgba(88,220,196,0.95), rgba(240,207,115,0.78));
    opacity: 0.9;
  }

  .page-explorer .entry-item:active {
    transform: scale(0.992) !important;
    border-color: rgba(88, 220, 196, 0.42) !important;
    background: rgba(88, 220, 196, 0.075) !important;
  }

  .page-explorer .entry-index {
    width: 32px !important;
    height: 32px !important;
    border: 1px solid rgba(88, 220, 196, 0.18) !important;
    border-radius: 12px !important;
    color: #8ff3e5 !important;
    background: rgba(88, 220, 196, 0.075) !important;
    font-size: 0.78rem !important;
    font-weight: 950 !important;
  }

  .page-explorer .entry-thumb {
    width: 54px !important;
    height: 54px !important;
    border-radius: 16px !important;
    border-color: rgba(148, 163, 184, 0.16) !important;
    background:
      radial-gradient(circle at 50% 42%, rgba(88,220,196,0.12), transparent 62%),
      #091422 !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.05);
  }

  .page-explorer .entry-thumb img {
    width: 92% !important;
    height: 92% !important;
    filter: drop-shadow(0 8px 10px rgba(0,0,0,0.34));
  }

  .page-explorer .entry-meta {
    display: grid !important;
    gap: 0.34rem !important;
    min-width: 0 !important;
  }

  .page-explorer .entry-meta strong {
    color: #f8fbff !important;
    font-size: 1.02rem !important;
    line-height: 1.05 !important;
    letter-spacing: -0.035em !important;
  }

  .page-explorer .entry-types {
    margin: 0 !important;
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 0.32rem !important;
    overflow: hidden !important;
  }

  .page-explorer .entry-types .type-chip {
    min-height: 23px !important;
    max-width: 112px !important;
    padding: 0.18rem 0.38rem !important;
    border-radius: 999px !important;
    font-size: 0.62rem !important;
    letter-spacing: 0.035em !important;
  }

  .page-explorer .entry-types .type-chip img {
    width: 13px !important;
    height: 13px !important;
  }

  .page-explorer .entry-action {
    display: grid !important;
    place-items: center !important;
    width: 28px !important;
    height: 28px !important;
    border: 1px solid rgba(148, 163, 184, 0.16) !important;
    border-radius: 999px !important;
    color: transparent !important;
    background: rgba(255,255,255,0.04) !important;
    font-size: 0 !important;
  }

  .page-explorer .entry-action::before {
    content: "›";
    color: #93a4ba;
    font-size: 1.35rem;
    font-weight: 700;
    line-height: 1;
    transform: translateY(-1px);
  }

  .page-explorer .entry-empty {
    border: 1px solid rgba(148, 163, 184, 0.14);
    border-radius: 18px;
    background: rgba(255,255,255,0.035);
    text-align: center;
  }
}

@media (max-width: 390px) {
  .page-explorer .entry-item {
    grid-template-columns: 30px 48px minmax(0, 1fr) 24px !important;
    gap: 0.58rem !important;
    padding: 0.62rem 0.62rem !important;
  }

  .page-explorer .entry-index {
    width: 29px !important;
    height: 29px !important;
    font-size: 0.72rem !important;
  }

  .page-explorer .entry-thumb {
    width: 48px !important;
    height: 48px !important;
    border-radius: 14px !important;
  }

  .page-explorer .entry-meta strong {
    font-size: 0.94rem !important;
  }

  .page-explorer .entry-types .type-chip {
    max-width: 96px !important;
    font-size: 0.58rem !important;
    padding-inline: 0.32rem !important;
  }
}

/* v23 viewport-safe advanced search help */
.search-help-popover {
  box-sizing: border-box !important;
  width: var(--help-width, min(560px, calc(100vw - 28px))) !important;
  max-width: calc(100vw - 16px) !important;
  max-height: var(--help-max-height, calc(100dvh - 28px)) !important;
  overflow-y: auto !important;
  overscroll-behavior: contain;
}

.search-help:hover .search-help-popover:not(.is-visible),
.search-help:focus-within .search-help-popover:not(.is-visible) {
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
  transform: translateY(-6px) scale(0.985) !important;
}

.search-help:hover .search-help-popover.is-visible,
.search-help:focus-within .search-help-popover.is-visible,
.search-help-popover.is-visible {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  transform: translateY(0) scale(1) !important;
}

/* v27 final visual guard */
body {
  background: linear-gradient(135deg, #11130f 0%, #18151b 48%, #101716 100%) !important;
}

.hero-card,
.controls,
.battle-entry-panel,
.pokemon-card,
.detail-section,
.detail-art,
.metric,
.data-table-wrap,
.search-help-popover,
.empty-state,
.battle-column {
  border-radius: 8px !important;
  box-shadow: var(--shadow-soft) !important;
}

.primary-button,
.ghost-button,
.discord-button,
.search-submit,
.search-help-button,
.search-help-close,
.favorite-button,
.open-profile,
.entry-action,
.format-toggle,
.season-picker select {
  border-radius: 7px !important;
  box-shadow: none !important;
}

.primary-button,
.search-submit,
.format-toggle.active {
  color: #10130d !important;
  background: #c9eb78 !important;
}

/* v28 clean data-desk theme */
:root {
  color-scheme: light;
  --bg: #f6f2e8;
  --bg-elevated: #fffdf7;
  --panel: #fffdf7;
  --panel-2: #f2eadc;
  --panel-3: #e8e2d3;
  --line: rgba(39, 48, 45, 0.14);
  --line-strong: rgba(39, 48, 45, 0.28);
  --text: #202725;
  --muted: #626c67;
  --soft: #7e877f;
  --brand: #27776f;
  --brand-strong: #1d5d58;
  --gold: #b8792e;
  --blue: #496f9e;
  --red: #b85d4d;
  --shadow: 0 18px 40px rgba(44, 47, 42, 0.14);
  --shadow-soft: 0 8px 22px rgba(44, 47, 42, 0.09);
  --radius-xl: 8px;
  --radius-lg: 7px;
  --radius-md: 6px;
  font-family: Inter, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

body.page-explorer,
body {
  color: var(--text) !important;
  background:
    linear-gradient(180deg, #f8f5ee 0%, #eef4ee 48%, #f6f0e5 100%) !important;
  font-weight: 450 !important;
}

body::before {
  background-image:
    linear-gradient(rgba(39, 48, 45, 0.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(39, 48, 45, 0.035) 1px, transparent 1px) !important;
  background-size: 52px 52px !important;
  opacity: 0.7 !important;
  mask-image: linear-gradient(to bottom, black 0%, transparent 84%) !important;
}

.site-header {
  background: rgba(255, 253, 247, 0.92) !important;
  border-bottom: 1px solid rgba(39, 48, 45, 0.13) !important;
  backdrop-filter: blur(14px) !important;
}

.brand strong,
.pokemon-card h3,
.entry-meta strong,
.detail-title h2,
h1,
h2,
h3 {
  color: var(--text) !important;
  font-family: inherit !important;
  font-weight: 720 !important;
  letter-spacing: 0 !important;
}

.brand small,
.hero-text,
.search-help-popover p,
.search-help-popover dd,
.quick-facts span,
.metric span,
.entry-empty {
  color: var(--muted) !important;
}

.eyebrow,
.stat-label,
.search-help-popover dt,
.dex-number {
  color: var(--brand-strong) !important;
  letter-spacing: 0.045em !important;
}

.hero-card,
.controls,
.battle-entry-panel,
.pokemon-card,
.detail-section,
.detail-art,
.metric,
.data-table-wrap,
.search-help-popover,
.empty-state,
.battle-column,
.entry-item,
.search-box,
.filter-grid label,
.recent-item,
.type-chip,
code,
.plain-code {
  border-radius: 7px !important;
}

.hero-card,
.controls,
.battle-entry-panel,
.pokemon-card,
.detail-section,
.detail-art,
.metric,
.data-table-wrap,
.search-help-popover,
.empty-state,
.battle-column {
  color: var(--text) !important;
  border: 1px solid rgba(39, 48, 45, 0.13) !important;
  background: rgba(255, 253, 247, 0.94) !important;
  box-shadow: var(--shadow-soft) !important;
}

.pokemon-card:hover,
.entry-item:hover,
.entry-item:focus-visible,
.recent-item.active {
  transform: none !important;
  border-color: rgba(39, 119, 111, 0.38) !important;
  background: #ffffff !important;
  box-shadow: 0 12px 28px rgba(44, 47, 42, 0.12) !important;
}

.pokemon-art,
.detail-art,
.entry-thumb {
  background:
    linear-gradient(135deg, rgba(39, 119, 111, 0.12), transparent 54%),
    linear-gradient(315deg, rgba(184, 93, 77, 0.10), transparent 50%),
    #f2eadc !important;
  border-color: rgba(39, 48, 45, 0.12) !important;
}

.nav-actions {
  align-items: center !important;
  gap: 0.52rem !important;
}

.season-picker {
  display: inline-flex !important;
  align-items: center !important;
  min-width: 128px !important;
  width: auto !important;
}

.season-picker span {
  display: none !important;
}

.season-picker select,
.format-switch,
.ghost-button,
.discord-button {
  min-height: 40px !important;
  border-radius: 6px !important;
}

.season-picker select {
  appearance: none !important;
  width: 100% !important;
  min-width: 128px !important;
  padding: 0 2rem 0 0.78rem !important;
  color: var(--text) !important;
  border: 1px solid rgba(39, 48, 45, 0.18) !important;
  background-color: rgba(255, 253, 247, 0.9) !important;
  background-image:
    linear-gradient(45deg, transparent 50%, #626c67 50%),
    linear-gradient(135deg, #626c67 50%, transparent 50%) !important;
  background-position:
    calc(100% - 15px) 17px,
    calc(100% - 10px) 17px !important;
  background-size: 5px 5px, 5px 5px !important;
  background-repeat: no-repeat !important;
  box-shadow: none !important;
  font-size: 0.9rem !important;
  font-weight: 620 !important;
}

.format-switch {
  padding: 0.2rem !important;
  border: 1px solid rgba(39, 48, 45, 0.16) !important;
  background: rgba(255, 253, 247, 0.88) !important;
  box-shadow: none !important;
}

.format-toggle {
  min-height: 32px !important;
  border-radius: 5px !important;
  color: var(--muted) !important;
  background: transparent !important;
  box-shadow: none !important;
  font-weight: 650 !important;
}

.format-toggle.active {
  color: #fffdf7 !important;
  background: var(--brand) !important;
  border-color: var(--brand) !important;
  box-shadow: none !important;
}

.primary-button,
.search-submit {
  color: #fffdf7 !important;
  background: var(--brand) !important;
  border: 1px solid var(--brand-strong) !important;
  border-radius: 6px !important;
  box-shadow: none !important;
  font-weight: 700 !important;
}

.ghost-button,
.discord-button,
.search-help-button,
.search-help-close,
.favorite-button,
.entry-action {
  color: var(--text) !important;
  background: rgba(255, 253, 247, 0.88) !important;
  border: 1px solid rgba(39, 48, 45, 0.18) !important;
  border-radius: 6px !important;
  box-shadow: none !important;
  font-weight: 650 !important;
}

.primary-button:hover,
.primary-button:focus-visible,
.search-submit:hover,
.search-submit:focus-visible,
.ghost-button:hover,
.ghost-button:focus-visible,
.discord-button:hover,
.discord-button:focus-visible,
.season-picker select:hover,
.season-picker select:focus-visible,
.format-toggle:not(.active):hover {
  transform: none !important;
  filter: none !important;
  outline: none !important;
  border-color: rgba(39, 119, 111, 0.46) !important;
  background-color: #ffffff !important;
  box-shadow: 0 0 0 3px rgba(39, 119, 111, 0.12) !important;
}

.primary-button:hover,
.primary-button:focus-visible,
.search-submit:hover,
.search-submit:focus-visible {
  color: #fffdf7 !important;
  background: var(--brand-strong) !important;
}

.search-box,
.filter-grid select,
.search-box input {
  color: var(--text) !important;
  background: #fffdf7 !important;
  border-color: rgba(39, 48, 45, 0.16) !important;
  box-shadow: none !important;
}

.filter-grid label {
  color: var(--muted) !important;
  background: rgba(255, 253, 247, 0.72) !important;
  border-color: rgba(39, 48, 45, 0.12) !important;
}

.type-chip,
code,
.plain-code {
  color: var(--brand-strong) !important;
  background: rgba(39, 119, 111, 0.09) !important;
  border: 1px solid rgba(39, 119, 111, 0.18) !important;
}

.percent-bar {
  background: #ebe4d6 !important;
}

.percent-bar span {
  background: linear-gradient(90deg, #27776f, #b8792e, #b85d4d) !important;
  box-shadow: none !important;
}

table,
th,
td {
  color: var(--text) !important;
  border-color: rgba(39, 48, 45, 0.12) !important;
}

th {
  background: #f2eadc !important;
}

@media (max-width: 760px) {
  .nav-actions {
    width: 100% !important;
    align-items: stretch !important;
    gap: 0.5rem !important;
  }

  .season-picker,
  .season-picker select,
  .format-switch,
  .ghost-button,
  .discord-button {
    width: 100% !important;
  }
}

/* v29 header control alignment */
.season-picker {
  height: 40px !important;
}

.season-picker select {
  box-sizing: border-box !important;
  height: 40px !important;
  min-height: 40px !important;
  line-height: 1 !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

/* v30 obsidian grove dark theme */
:root {
  color-scheme: dark;
  --bg: #0b100f;
  --bg-elevated: #111a17;
  --panel: #141f1a;
  --panel-2: #1b2a22;
  --panel-3: #0f1715;
  --line: rgba(214, 232, 218, 0.15);
  --line-strong: rgba(214, 232, 218, 0.28);
  --text: #edf4e8;
  --muted: #b9c8bd;
  --soft: #91a396;
  --brand: #65d9b8;
  --brand-strong: #38b892;
  --gold: #f0c36d;
  --blue: #8cb8d8;
  --red: #ff8c79;
  --shadow: 0 18px 46px rgba(0, 0, 0, 0.36);
  --shadow-soft: 0 12px 28px rgba(0, 0, 0, 0.26);
  --radius-xl: 8px;
  --radius-lg: 7px;
  --radius-md: 6px;
}

body.page-explorer,
body {
  color: var(--text) !important;
  background:
    radial-gradient(circle at 18% -12%, rgba(101, 217, 184, 0.16), transparent 34rem),
    radial-gradient(circle at 82% 4%, rgba(240, 195, 109, 0.10), transparent 28rem),
    linear-gradient(135deg, #0b100f 0%, #101813 48%, #151116 100%) !important;
}

body::before {
  background-image:
    linear-gradient(rgba(214, 232, 218, 0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(214, 232, 218, 0.028) 1px, transparent 1px) !important;
  background-size: 48px 48px !important;
  opacity: 0.82 !important;
}

.site-header {
  color: var(--text) !important;
  background: rgba(11, 16, 15, 0.9) !important;
  border-bottom: 1px solid rgba(214, 232, 218, 0.12) !important;
}

.brand strong,
.pokemon-card h3,
.entry-meta strong,
.detail-title h2,
.empty-state strong,
.endpoint-card h2,
h1,
h2,
h3 {
  color: var(--text) !important;
}

.brand small,
.hero-text,
.search-label-row,
.search-help-popover p,
.search-help-popover dd,
.search-help-popover .rank-help,
.quick-facts span,
.fact span,
.metric span,
.entry-meta small,
.roster-meta small,
.detail-title p,
.about-data p,
.setup-steps,
.endpoint-card li,
.api-panel p,
.entry-empty,
.detail-loading {
  color: var(--muted) !important;
}

.eyebrow,
.stat-label,
.search-help-popover dt,
.dex-number,
.page-explorer .entry-index,
.search-help-header strong {
  color: var(--brand) !important;
}

.hero-card,
.controls,
.battle-entry-panel,
.pokemon-card,
.detail-section,
.detail-art,
.metric,
.data-table-wrap,
.search-help-popover,
.empty-state,
.battle-column,
.entry-item,
.recent-item,
.api-panel,
.endpoint-card,
.api-side-card {
  color: var(--text) !important;
  border-color: rgba(214, 232, 218, 0.14) !important;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.045), rgba(255, 255, 255, 0.018)),
    rgba(20, 31, 26, 0.94) !important;
  box-shadow: var(--shadow-soft) !important;
}

.pokemon-card:hover,
.entry-item:hover,
.entry-item:focus-visible,
.recent-item.active {
  color: var(--text) !important;
  border-color: rgba(101, 217, 184, 0.42) !important;
  background:
    linear-gradient(180deg, rgba(101, 217, 184, 0.075), rgba(255, 255, 255, 0.018)),
    rgba(24, 39, 32, 0.96) !important;
  box-shadow: 0 16px 34px rgba(0, 0, 0, 0.32) !important;
}

.pokemon-art,
.detail-art,
.entry-thumb {
  background:
    radial-gradient(circle at 48% 36%, rgba(101, 217, 184, 0.16), transparent 58%),
    linear-gradient(135deg, rgba(240, 195, 109, 0.10), transparent 48%),
    #0f1715 !important;
  border-color: rgba(214, 232, 218, 0.12) !important;
}

.search-box,
.filter-grid label,
.filter-grid select,
.search-box input,
.season-picker select,
.format-switch,
.ghost-button,
.discord-button,
.search-help-button,
.search-help-close,
.favorite-button,
.entry-action,
.form-stat-line,
.nature-change {
  color: var(--text) !important;
  background: rgba(15, 23, 21, 0.94) !important;
  border-color: rgba(214, 232, 218, 0.16) !important;
  box-shadow: none !important;
}

.search-box input::placeholder {
  color: #8fa195 !important;
  opacity: 1 !important;
}

.season-picker select {
  background-color: rgba(15, 23, 21, 0.94) !important;
  background-image:
    linear-gradient(45deg, transparent 50%, var(--muted) 50%),
    linear-gradient(135deg, var(--muted) 50%, transparent 50%) !important;
}

.format-toggle {
  color: var(--muted) !important;
  background: transparent !important;
}

.format-toggle.active,
.primary-button,
.search-submit {
  color: #07110e !important;
  background: linear-gradient(180deg, #7ee8c8 0%, #4fc49f 100%) !important;
  border-color: rgba(126, 232, 200, 0.74) !important;
  box-shadow: none !important;
}

.primary-button:hover,
.primary-button:focus-visible,
.search-submit:hover,
.search-submit:focus-visible,
.format-toggle.active:hover {
  color: #07110e !important;
  background: linear-gradient(180deg, #98f1d8 0%, #65d9b8 100%) !important;
}

.ghost-button:hover,
.ghost-button:focus-visible,
.discord-button:hover,
.discord-button:focus-visible,
.season-picker select:hover,
.season-picker select:focus-visible,
.format-toggle:not(.active):hover,
.search-help-button:hover,
.search-help-close:hover {
  color: var(--text) !important;
  border-color: rgba(101, 217, 184, 0.5) !important;
  background: rgba(24, 39, 32, 0.98) !important;
  box-shadow: 0 0 0 3px rgba(101, 217, 184, 0.12) !important;
}

.type-chip,
code,
.plain-code,
.format-badge.other {
  color: #d8fff1 !important;
  background: rgba(101, 217, 184, 0.12) !important;
  border: 1px solid rgba(101, 217, 184, 0.26) !important;
}

.format-badge.singles,
.format-badge.doubles,
.detail-format-chip {
  color: #07110e !important;
}

.fact,
.metric,
.data-table-wrap,
.percent-bar,
.stat-track {
  background: rgba(9, 14, 13, 0.38) !important;
  border-color: rgba(214, 232, 218, 0.14) !important;
}

.fact strong,
.metric strong,
.form-stat-line span:last-child,
.nature-neutral,
td {
  color: var(--text) !important;
}

table,
th,
td {
  border-color: rgba(214, 232, 218, 0.12) !important;
}

th {
  color: #c9d8ce !important;
  background: rgba(9, 14, 13, 0.48) !important;
}

.percent-bar b {
  color: #f6fff9 !important;
  text-shadow: 0 1px 8px rgba(0, 0, 0, 0.42) !important;
}

.percent-bar span {
  background: linear-gradient(90deg, #65d9b8, #f0c36d, #ff8c79) !important;
}

.stat-track span {
  box-shadow: none !important;
}

.page-explorer .entry-action::before {
  color: #c9d8ce !important;
}

.detail-dialog::backdrop {
  background: rgba(3, 6, 5, 0.72) !important;
}

/* v31 dropdown, ranking, and profile section polish */
.page-explorer .season-picker,
.page-explorer .filter-grid label:not(.checkbox-label) {
  position: relative !important;
}

.page-explorer .season-picker select,
.page-explorer .filter-grid select {
  appearance: none !important;
  -webkit-appearance: none !important;
  color: var(--text) !important;
  background-color: #0a1210 !important;
  background-image: none !important;
  border: 1px solid rgba(101, 217, 184, 0.25) !important;
  border-radius: 7px !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04) !important;
}

.page-explorer .season-picker select {
  min-width: 132px !important;
  padding-right: 2.18rem !important;
  font-weight: 760 !important;
}

.page-explorer .filter-grid label {
  color: #d6e3d9 !important;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.035), rgba(255, 255, 255, 0.012)),
    rgba(10, 18, 16, 0.96) !important;
  border: 1px solid rgba(101, 217, 184, 0.16) !important;
  border-radius: 7px !important;
}

.page-explorer .filter-grid select {
  padding-right: 2.15rem !important;
}

.page-explorer .season-picker::after,
.page-explorer .filter-grid label:not(.checkbox-label)::after {
  content: "" !important;
  position: absolute !important;
  width: 0.48rem !important;
  height: 0.48rem !important;
  border-right: 2px solid var(--brand) !important;
  border-bottom: 2px solid var(--brand) !important;
  pointer-events: none !important;
  transform: rotate(45deg) !important;
}

.page-explorer .season-picker::after {
  right: 0.82rem !important;
  top: 50% !important;
  margin-top: -0.34rem !important;
}

.page-explorer .filter-grid label:not(.checkbox-label)::after {
  right: 0.88rem !important;
  bottom: 1.06rem !important;
}

.page-explorer .season-picker select:hover,
.page-explorer .season-picker select:focus-visible,
.page-explorer .filter-grid select:hover,
.page-explorer .filter-grid select:focus-visible {
  color: var(--text) !important;
  background-color: #0d1815 !important;
  border-color: rgba(101, 217, 184, 0.54) !important;
  box-shadow: 0 0 0 3px rgba(101, 217, 184, 0.12) !important;
}

.page-explorer select option {
  color: var(--text) !important;
  background: #0a1210 !important;
}

.page-explorer .entry-item {
  grid-template-columns: 46px 48px minmax(0, 1fr) auto !important;
}

.page-explorer .entry-index {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 42px !important;
  width: 42px !important;
  height: 30px !important;
  color: #06110e !important;
  background: #65d9b8 !important;
  border: 1px solid rgba(216, 255, 241, 0.35) !important;
  border-radius: 7px !important;
  box-shadow: none !important;
  text-shadow: none !important;
  font-size: 0.82rem !important;
  font-weight: 900 !important;
  line-height: 1 !important;
}

.page-explorer .detail-section.nested,
.page-explorer .battle-column {
  color: var(--text) !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.page-explorer .detail-section.nested {
  padding: 0 !important;
}

.page-explorer .detail-section.nested h3 {
  margin: 0 0 0.52rem !important;
  padding: 0 !important;
}

@media (max-width: 760px) {
  .page-explorer .entry-item {
    grid-template-columns: 42px 54px minmax(0, 1fr) !important;
  }

  .page-explorer .entry-index {
    min-width: 38px !important;
    width: 38px !important;
    height: 30px !important;
    font-size: 0.76rem !important;
  }
}

/* v32 readable terminal theme and Showdown-style stat colors */
:root {
  --bg: #050c08;
  --bg-elevated: #09130d;
  --panel: #0d1811;
  --panel-2: #122016;
  --panel-3: #07110b;
  --line: rgba(114, 255, 171, 0.17);
  --line-strong: rgba(114, 255, 171, 0.34);
  --text: #eff8ee;
  --muted: #b7c8b8;
  --soft: #8fa591;
  --brand: #72ffab;
  --brand-strong: #32c86b;
  --gold: #f2cf5b;
  --red: #e05243;
  --shadow: 0 20px 48px rgba(0, 0, 0, 0.42);
  --shadow-soft: 0 12px 30px rgba(0, 0, 0, 0.32);
  --stat-bad: #e05243;
  --stat-mid: #f2cf5b;
  --stat-good: #a6d854;
  --stat-great: #188a45;
}

body.page-explorer,
body {
  color: var(--text) !important;
  background:
    repeating-linear-gradient(0deg, rgba(114, 255, 171, 0.028) 0 1px, transparent 1px 42px),
    linear-gradient(180deg, rgba(114, 255, 171, 0.055) 0%, transparent 34%),
    linear-gradient(135deg, #050c08 0%, #0b130c 54%, #171407 100%) !important;
  font-family: "Segoe UI", Inter, Roboto, Helvetica, Arial, sans-serif !important;
}

body::before {
  background-image:
    linear-gradient(rgba(114, 255, 171, 0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(114, 255, 171, 0.032) 1px, transparent 1px) !important;
  background-size: 46px 46px !important;
  opacity: 0.58 !important;
}

h1,
h2,
h3,
.brand strong,
.stat-label,
.search-label-row label,
.filter-grid label,
.nav-actions,
.entry-index,
.percent-bar b,
.stat-row,
code,
.plain-code {
  font-family: "Cascadia Code", "JetBrains Mono", "SFMono-Regular", Consolas, monospace !important;
  letter-spacing: 0 !important;
}

.brand small,
.hero-text,
.detail-title p,
.search-help-popover p,
.search-help-popover dd,
td,
button,
input,
select {
  font-family: "Segoe UI", Inter, Roboto, Helvetica, Arial, sans-serif !important;
}

.site-header {
  background: rgba(5, 12, 8, 0.91) !important;
  border-bottom-color: rgba(114, 255, 171, 0.13) !important;
}

.hero-card,
.controls,
.battle-entry-panel,
.pokemon-card,
.detail-section,
.detail-art,
.metric,
.data-table-wrap,
.search-help-popover,
.empty-state,
.entry-item,
.recent-item,
.api-panel,
.endpoint-card,
.api-side-card {
  color: var(--text) !important;
  border-color: rgba(114, 255, 171, 0.15) !important;
  background:
    linear-gradient(180deg, rgba(20, 34, 24, 0.97), rgba(8, 17, 12, 0.96)) !important;
  box-shadow: var(--shadow-soft) !important;
}

.pokemon-card:hover,
.entry-item:hover,
.entry-item:focus-visible,
.recent-item.active {
  border-color: rgba(114, 255, 171, 0.44) !important;
  background:
    linear-gradient(180deg, rgba(27, 48, 32, 0.98), rgba(10, 23, 14, 0.98)) !important;
}

.search-box,
.filter-grid label,
.filter-grid select,
.search-box input,
.season-picker select,
.format-switch,
.ghost-button,
.discord-button,
.search-help-button,
.search-help-close,
.favorite-button,
.entry-action,
.form-stat-line,
.nature-change {
  color: var(--text) !important;
  background: rgba(7, 17, 11, 0.96) !important;
  border-color: rgba(114, 255, 171, 0.2) !important;
}

.format-toggle.active,
.primary-button,
.search-submit {
  color: #041008 !important;
  background: linear-gradient(180deg, #98ffc4 0%, #55d986 100%) !important;
  border-color: rgba(152, 255, 196, 0.72) !important;
}

.type-chip,
code,
.plain-code,
.format-badge.other {
  color: #dffff0 !important;
  background: rgba(114, 255, 171, 0.11) !important;
  border-color: rgba(114, 255, 171, 0.27) !important;
}

.data-table-wrap,
.fact,
.metric,
.percent-bar,
.stat-track {
  background: rgba(4, 10, 7, 0.58) !important;
  border-color: rgba(114, 255, 171, 0.16) !important;
}

th {
  color: #d8ead8 !important;
  background: rgba(12, 25, 16, 0.92) !important;
}

.percent-bar {
  overflow: hidden !important;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.035), rgba(0, 0, 0, 0.12)),
    #0b140d !important;
  border: 1px solid rgba(114, 255, 171, 0.18) !important;
}

.percent-bar span {
  background: var(--bar-color, var(--stat-good)) !important;
  box-shadow:
    inset 0 -1px 0 rgba(0, 0, 0, 0.22),
    0 0 12px rgba(114, 255, 171, 0.12) !important;
}

.percent-bar b {
  color: #f9fff3 !important;
  font-weight: 850 !important;
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.72) !important;
}

.stat-track {
  height: 12px !important;
  border: 1px solid rgba(114, 255, 171, 0.16) !important;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.035), rgba(0, 0, 0, 0.18)),
    #0b140d !important;
}

.stat-fill {
  background: var(--stat-color, var(--stat-good)) !important;
  box-shadow:
    inset 0 -1px 0 rgba(0, 0, 0, 0.22),
    0 0 14px rgba(114, 255, 171, 0.14) !important;
}

.stat-row span {
  color: #c9d9ca !important;
}

.stat-row strong {
  color: #f7fff5 !important;
  font-variant-numeric: tabular-nums;
}

.page-explorer .season-picker select,
.page-explorer .filter-grid select {
  background-color: #07110b !important;
  border-color: rgba(114, 255, 171, 0.24) !important;
}

.page-explorer .season-picker::after,
.page-explorer .filter-grid label:not(.checkbox-label)::after {
  border-color: var(--brand) !important;
}

.page-explorer .battle-entry-panel,
.page-explorer .entry-panel-header,
.page-explorer .entry-item,
.page-explorer .pokemon-card,
.page-explorer .detail-section {
  background:
    linear-gradient(180deg, rgba(20, 34, 24, 0.97), rgba(8, 17, 12, 0.96)) !important;
  border-color: rgba(114, 255, 171, 0.15) !important;
}

.page-explorer .pokemon-art,
.page-explorer .detail-art,
.page-explorer .entry-thumb {
  background:
    linear-gradient(135deg, rgba(114, 255, 171, 0.13), transparent 56%),
    linear-gradient(315deg, rgba(242, 207, 91, 0.10), transparent 52%),
    #0b140d !important;
  border-color: rgba(114, 255, 171, 0.16) !important;
}

.page-explorer .entry-list::-webkit-scrollbar-thumb {
  background: rgba(114, 255, 171, 0.25) !important;
}

/* v33 surface cleanup and profile scroll lock */
:root {
  --control-surface: rgba(7, 17, 11, 0.96);
  --panel-surface: rgba(10, 21, 13, 0.97);
  --panel-surface-deep: rgba(5, 13, 8, 0.98);
}

body.profile-open {
  overflow: hidden !important;
}

.detail-dialog,
.detail-dialog .dialog-inner {
  overscroll-behavior: contain !important;
}

.sidebar,
.content-area,
.detail-dialog .dialog-inner {
  color: var(--text) !important;
  background:
    linear-gradient(180deg, rgba(16, 31, 18, 0.97), rgba(5, 13, 8, 0.98)) !important;
  border: 1px solid rgba(114, 255, 171, 0.16) !important;
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.34) !important;
}

.content-area .panel-heading,
.sidebar .panel-heading {
  background: transparent !important;
  border-color: rgba(114, 255, 171, 0.12) !important;
}

.detail-dialog .dialog-inner {
  background:
    linear-gradient(180deg, rgba(13, 27, 16, 0.99), rgba(4, 11, 7, 0.99)) !important;
}

.page-explorer .detail-section {
  background:
    linear-gradient(180deg, rgba(14, 27, 16, 0.92), rgba(7, 15, 9, 0.94)) !important;
}

.hero h1,
.api-panel h1 {
  font-family: "Segoe UI", Inter, Roboto, Helvetica, Arial, sans-serif !important;
  font-weight: 800 !important;
  letter-spacing: -0.035em !important;
}

.api-panel h1 {
  letter-spacing: -0.025em !important;
}

.dex-number {
  display: none !important;
}

.search-box,
.search-box input,
.page-explorer .filter-grid select {
  background: var(--control-surface) !important;
}

.page-explorer .filter-grid label:not(.checkbox-label) {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
}

.page-explorer .filter-grid select {
  border-color: rgba(114, 255, 171, 0.18) !important;
  box-shadow: none !important;
}

.page-explorer .filter-grid select:hover,
.page-explorer .filter-grid select:focus-visible {
  background: var(--control-surface) !important;
  border-color: rgba(114, 255, 171, 0.38) !important;
  box-shadow: none !important;
  outline: none !important;
}

/* v34 simplified API guide readability */
.api-readable.api-main.section-shell {
  width: min(calc(100% - 24px), 980px) !important;
}

.api-readable .api-hero-compact {
  grid-template-columns: minmax(0, 1fr) minmax(240px, 300px) !important;
  gap: 1rem !important;
}

.api-readable .endpoint-grid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 1rem !important;
  max-width: 900px !important;
  margin-inline: auto !important;
}

.api-readable .endpoint-card,
.api-readable .api-panel,
.api-readable .api-side-card {
  border-radius: 8px !important;
}

.api-readable .endpoint-card {
  padding: clamp(0.95rem, 2vw, 1.2rem) !important;
}

.api-readable .endpoint-card h2 {
  margin-bottom: 0.45rem !important;
  font-size: 1.12rem !important;
  letter-spacing: 0 !important;
}

.api-readable .endpoint-card p,
.api-readable .endpoint-card li,
.api-readable .api-table td {
  color: var(--muted) !important;
  line-height: 1.62 !important;
}

.api-readable .endpoint-card pre {
  box-sizing: border-box !important;
  max-width: 100% !important;
  margin: 0.72rem 0 0 !important;
  padding: 0.9rem !important;
  overflow-x: hidden !important;
  white-space: pre-wrap !important;
  border-radius: 7px !important;
  background: rgba(3, 9, 6, 0.78) !important;
}

.api-readable .endpoint-card pre code {
  display: block !important;
  white-space: pre-wrap !important;
  overflow-wrap: anywhere !important;
  word-break: break-word !important;
  line-height: 1.58 !important;
  font-size: 0.86rem !important;
}

.api-readable .endpoint-card code {
  white-space: normal !important;
}

.api-readable .api-table {
  table-layout: fixed !important;
}

.api-readable .api-table td {
  vertical-align: top !important;
  overflow-wrap: anywhere !important;
}

@media (max-width: 760px) {
  .api-readable .api-hero-compact {
    grid-template-columns: 1fr !important;
  }
}

/* v35 API documentation layout */
body.page-api {
  opacity: 1 !important;
  animation: none !important;
  background:
    repeating-linear-gradient(0deg, rgba(141, 232, 114, 0.026) 0 1px, transparent 1px 44px),
    linear-gradient(180deg, rgba(214, 179, 90, 0.045) 0%, transparent 26%),
    linear-gradient(135deg, #030705 0%, #07110b 48%, #121406 100%) !important;
}

body.page-api::before {
  background-image:
    linear-gradient(rgba(141, 232, 114, 0.038) 1px, transparent 1px),
    linear-gradient(90deg, rgba(141, 232, 114, 0.03) 1px, transparent 1px) !important;
  background-size: 48px 48px !important;
  opacity: 0.48 !important;
}

.api-doc-page {
  --api-ink: #edf7ea;
  --api-muted: #bfd1bf;
  --api-soft: #90a692;
  --api-green: #8de872;
  --api-green-strong: #44c45f;
  --api-amber: #d6b35a;
  --api-panel: rgba(10, 21, 13, 0.96);
  --api-panel-deep: rgba(4, 10, 6, 0.98);
  --api-line: rgba(141, 232, 114, 0.18);
}

.api-doc-page.api-main.section-shell {
  width: min(calc(100% - 28px), 1180px) !important;
}

.api-doc-hero {
  display: grid !important;
  grid-template-columns: minmax(0, 1.45fr) minmax(260px, 0.55fr) !important;
  gap: 1rem !important;
  align-items: stretch !important;
  margin-bottom: 1rem !important;
}

.api-doc-hero .api-panel,
.api-doc-hero .api-side-card {
  background:
    linear-gradient(180deg, rgba(15, 28, 16, 0.96), rgba(4, 10, 6, 0.98)) !important;
  border-color: var(--api-line) !important;
}

.api-doc-hero .api-panel {
  display: grid !important;
  align-content: center !important;
  min-height: 230px !important;
  padding: clamp(1.1rem, 3vw, 1.8rem) !important;
}

.api-doc-hero .api-panel h1 {
  max-width: 760px !important;
  color: var(--api-ink) !important;
  font-size: 3.25rem !important;
  line-height: 1.03 !important;
  letter-spacing: 0 !important;
}

.api-doc-hero .api-panel p {
  max-width: 720px !important;
  margin: 0.95rem 0 0 !important;
  color: var(--api-muted) !important;
  font-size: 1rem !important;
}

.api-hero-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 0.5rem !important;
  margin-top: 1.15rem !important;
}

.api-hero-actions span,
.api-endpoint-line {
  color: var(--api-ink) !important;
  background: rgba(3, 8, 5, 0.78) !important;
  border: 1px solid var(--api-line) !important;
  border-radius: 7px !important;
}

.api-hero-actions span {
  padding: 0.42rem 0.58rem !important;
  font-family: "Cascadia Code", "SFMono-Regular", Consolas, monospace !important;
  font-size: 0.78rem !important;
}

.api-facts {
  align-content: start !important;
}

.api-facts dl {
  display: grid !important;
  gap: 0.62rem !important;
  margin: 0 !important;
}

.api-facts div,
.api-kv-list div {
  display: grid !important;
  gap: 0.12rem !important;
}

.api-facts dt,
.api-kv-list dt {
  color: var(--api-green) !important;
  font-family: "Cascadia Code", "SFMono-Regular", Consolas, monospace !important;
  font-size: 0.72rem !important;
  font-weight: 850 !important;
  text-transform: uppercase !important;
}

.api-facts dd,
.api-kv-list dd {
  margin: 0 !important;
  color: var(--api-ink) !important;
}

.api-doc-layout {
  display: grid !important;
  grid-template-columns: 220px minmax(0, 1fr) !important;
  gap: 1rem !important;
  align-items: start !important;
}

.api-toc {
  position: sticky !important;
  top: 76px !important;
  display: grid !important;
  gap: 0.18rem !important;
  padding: 0.9rem !important;
  color: var(--api-ink) !important;
  background:
    linear-gradient(180deg, rgba(12, 23, 14, 0.94), rgba(4, 10, 6, 0.96)) !important;
  border: 1px solid var(--api-line) !important;
  border-radius: 8px !important;
  box-shadow: var(--shadow-soft) !important;
}

.api-toc strong {
  margin-bottom: 0.42rem !important;
  color: var(--api-green) !important;
  font-family: "Cascadia Code", "SFMono-Regular", Consolas, monospace !important;
  font-size: 0.75rem !important;
  text-transform: uppercase !important;
}

.api-toc a {
  padding: 0.42rem 0.5rem !important;
  color: var(--api-muted) !important;
  border-radius: 6px !important;
  text-decoration: none !important;
  font-size: 0.9rem !important;
}

.api-toc a:hover,
.api-toc a:focus-visible {
  color: var(--api-ink) !important;
  background: rgba(141, 232, 114, 0.11) !important;
  outline: none !important;
}

.api-docs {
  display: grid !important;
  gap: 1rem !important;
  min-width: 0 !important;
}

.api-section {
  scroll-margin-top: 88px !important;
  padding: clamp(1rem, 2.2vw, 1.35rem) !important;
  color: var(--api-ink) !important;
  background:
    linear-gradient(180deg, var(--api-panel), var(--api-panel-deep)) !important;
  border: 1px solid var(--api-line) !important;
  border-radius: 8px !important;
  box-shadow: var(--shadow-soft) !important;
}

.api-section-heading {
  display: grid !important;
  gap: 0.35rem !important;
  margin-bottom: 0.8rem !important;
}

.api-section-heading span {
  color: var(--api-green) !important;
  font-family: "Cascadia Code", "SFMono-Regular", Consolas, monospace !important;
  font-size: 0.72rem !important;
  font-weight: 850 !important;
  text-transform: uppercase !important;
}

.api-section-heading h2 {
  margin: 0 !important;
  color: var(--api-ink) !important;
  font-size: 1.42rem !important;
  letter-spacing: 0 !important;
}

.api-section-heading p {
  max-width: 760px !important;
  margin: 0 !important;
  color: var(--api-muted) !important;
  line-height: 1.62 !important;
}

.api-endpoint-line {
  display: flex !important;
  align-items: baseline !important;
  gap: 0.58rem !important;
  min-width: 0 !important;
  margin: 0.45rem 0 !important;
  padding: 0.58rem 0.66rem !important;
}

.api-endpoint-line b {
  flex: 0 0 auto !important;
  color: #041008 !important;
  background: var(--api-green) !important;
  border-radius: 5px !important;
  padding: 0.16rem 0.32rem !important;
  font-size: 0.68rem !important;
}

.api-endpoint-line code {
  min-width: 0 !important;
  color: var(--api-ink) !important;
  background: transparent !important;
  border: 0 !important;
  overflow-wrap: anywhere !important;
  white-space: normal !important;
}

.api-kv-list {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 0.7rem 1rem !important;
  margin: 0.95rem 0 0 !important;
}

.api-notes {
  margin: 0 !important;
  padding-left: 1.1rem !important;
  color: var(--api-muted) !important;
  line-height: 1.65 !important;
}

.api-doc-page pre {
  margin: 0.78rem 0 0 !important;
  max-width: 100% !important;
  padding: 0.95rem !important;
  overflow-x: hidden !important;
  white-space: pre-wrap !important;
  background:
    linear-gradient(180deg, rgba(3, 8, 5, 0.9), rgba(1, 5, 3, 0.94)) !important;
  border-color: rgba(141, 232, 114, 0.16) !important;
  border-radius: 7px !important;
}

.api-doc-page pre code {
  display: block !important;
  width: 100% !important;
  padding: 0 !important;
  color: #e9f7e5 !important;
  background: transparent !important;
  border: 0 !important;
  white-space: pre-wrap !important;
  overflow-wrap: anywhere !important;
  word-break: break-word !important;
  line-height: 1.58 !important;
  font-size: 0.86rem !important;
}

.api-doc-page code {
  white-space: normal !important;
}

@media (max-width: 920px) {
  .api-doc-hero,
  .api-doc-layout {
    grid-template-columns: 1fr !important;
  }

  .api-doc-hero .api-panel {
    order: 1 !important;
  }

  .api-doc-hero .api-side-card {
    order: 2 !important;
  }

  .api-toc {
    position: static !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .api-toc strong {
    grid-column: 1 / -1 !important;
  }
}

@media (max-width: 620px) {
  .api-doc-page.api-main.section-shell {
    width: min(calc(100% - 18px), 1180px) !important;
  }

  .api-doc-hero .api-panel {
    min-height: 0 !important;
  }

  .api-doc-hero .api-panel h1 {
    font-size: 2.2rem !important;
  }

  .api-toc,
  .api-kv-list {
    grid-template-columns: 1fr !important;
  }

  .api-section {
    padding: 0.9rem !important;
  }
}

/* v36 Battle Data panel refinement */
.page-explorer .battle-entry-panel {
  background:
    linear-gradient(180deg, rgba(11, 23, 14, 0.98), rgba(4, 10, 6, 0.98)) !important;
  border-color: rgba(141, 232, 114, 0.2) !important;
  border-radius: 8px !important;
  box-shadow: 0 18px 42px rgba(0, 0, 0, 0.34) !important;
}

.page-explorer .entry-panel-header {
  align-items: center !important;
  padding: 0 0 0.86rem !important;
  background: transparent !important;
  border: 0 !important;
  border-bottom: 1px solid rgba(141, 232, 114, 0.18) !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

.page-explorer .entry-panel-header .stat-label {
  color: #8de872 !important;
}

.page-explorer .hero-card strong#datasetStatus,
.page-explorer #datasetStatus {
  color: #eef8eb !important;
  font-weight: 850 !important;
  letter-spacing: 0 !important;
}

.page-explorer .entry-count {
  min-width: auto !important;
  min-height: auto !important;
  width: auto !important;
  height: auto !important;
  padding: 0 !important;
  color: #eef8eb !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  font-size: 1rem !important;
  font-weight: 850 !important;
  line-height: 1 !important;
  text-shadow: none !important;
}

.page-explorer .entry-list {
  gap: 0.58rem !important;
  padding: 0.82rem 0.32rem 0.08rem 0 !important;
}

.page-explorer .entry-item {
  min-height: 64px !important;
  grid-template-columns: 38px 50px minmax(0, 1fr) auto !important;
  gap: 0.74rem !important;
  padding: 0.58rem 0.66rem !important;
  border-radius: 8px !important;
  border-color: rgba(141, 232, 114, 0.15) !important;
  background:
    linear-gradient(90deg, rgba(141, 232, 114, 0.075), transparent 38%),
    rgba(5, 13, 8, 0.78) !important;
  box-shadow: none !important;
}

.page-explorer .entry-item::before {
  content: none !important;
}

.page-explorer .entry-item:hover,
.page-explorer .entry-item:focus-visible {
  transform: translateX(2px) !important;
  border-color: rgba(141, 232, 114, 0.38) !important;
  background:
    linear-gradient(90deg, rgba(141, 232, 114, 0.13), transparent 42%),
    rgba(9, 20, 11, 0.94) !important;
  outline: none !important;
}

.page-explorer .entry-index {
  width: 34px !important;
  min-width: 34px !important;
  height: 30px !important;
  color: #bdf8ca !important;
  background: rgba(141, 232, 114, 0.075) !important;
  border: 1px solid rgba(141, 232, 114, 0.2) !important;
  border-radius: 6px !important;
  box-shadow: none !important;
  font-size: 0.78rem !important;
  font-weight: 850 !important;
}

.page-explorer .entry-thumb {
  width: 50px !important;
  height: 50px !important;
  border-radius: 7px !important;
  background:
    radial-gradient(circle at 50% 42%, rgba(141, 232, 114, 0.12), transparent 64%),
    #08110b !important;
  border-color: rgba(141, 232, 114, 0.14) !important;
  box-shadow: none !important;
}

.page-explorer .entry-meta {
  gap: 0.28rem !important;
}

.page-explorer .entry-meta strong {
  color: #f4fbf1 !important;
  font-size: 0.98rem !important;
  line-height: 1.1 !important;
  letter-spacing: 0 !important;
}

.page-explorer .entry-types {
  margin-top: 0.24rem !important;
  gap: 0.28rem !important;
}

.page-explorer .entry-types .type-chip {
  border-radius: 6px !important;
  background: rgba(141, 232, 114, 0.1) !important;
  border-color: rgba(141, 232, 114, 0.18) !important;
}

.page-explorer .entry-action {
  min-height: 30px !important;
  border-radius: 6px !important;
  color: #dff5dd !important;
  background: rgba(141, 232, 114, 0.06) !important;
  border-color: rgba(141, 232, 114, 0.16) !important;
  box-shadow: none !important;
}

.page-explorer .entry-list::-webkit-scrollbar-thumb {
  background: rgba(141, 232, 114, 0.26) !important;
}

@media (max-width: 760px) {
  .page-explorer .battle-entry-panel {
    border-radius: 8px !important;
  }

  .page-explorer .entry-panel-header {
    padding: 0 0 0.72rem !important;
  }

  .page-explorer .entry-item {
    grid-template-columns: 34px 50px minmax(0, 1fr) 28px !important;
    min-height: 68px !important;
    border-radius: 8px !important;
  }

  .page-explorer .entry-count {
    font-size: 0.95rem !important;
  }

  .page-explorer .entry-action {
    border-radius: 6px !important;
  }
}

/* v37 Battle Data header cleanup */
.page-explorer .entry-panel-header {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  align-items: end !important;
  gap: 0.85rem !important;
  min-height: 58px !important;
  padding: 0.1rem 0 0.92rem !important;
  background:
    linear-gradient(90deg, rgba(141, 232, 114, 0.045), transparent 62%) !important;
  border: 0 !important;
  border-bottom: 1px solid rgba(141, 232, 114, 0.18) !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

.page-explorer .entry-panel-header > div {
  display: grid !important;
  gap: 0.28rem !important;
  min-width: 0 !important;
}

.page-explorer .entry-panel-header .stat-label {
  margin: 0 !important;
  color: #7ff28b !important;
  font-size: 0.72rem !important;
  line-height: 1 !important;
  letter-spacing: 0.09em !important;
}

.page-explorer .hero-card strong#datasetStatus,
.page-explorer #datasetStatus {
  color: #f3fbef !important;
  font-size: 1rem !important;
  line-height: 1.15 !important;
  font-weight: 820 !important;
}

.page-explorer #pokemonCount.entry-count {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  align-self: center !important;
  min-width: 0 !important;
  min-height: 0 !important;
  width: auto !important;
  height: auto !important;
  padding: 0 !important;
  color: #c4f7bd !important;
  background: none !important;
  background-color: transparent !important;
  background-image: none !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  font-size: 0.92rem !important;
  font-weight: 850 !important;
  line-height: 1 !important;
  text-shadow: none !important;
}

@media (max-width: 760px) {
  .page-explorer .entry-panel-header {
    min-height: 54px !important;
    padding-bottom: 0.76rem !important;
  }

  .page-explorer #pokemonCount.entry-count {
    font-size: 0.88rem !important;
  }
}

/* v38 Battle Data header background match */
.page-explorer .battle-entry-panel .entry-panel-header {
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
}

.page-explorer .battle-entry-panel #pokemonCount.entry-count,
.page-explorer .battle-entry-panel .entry-panel-header #pokemonCount.entry-count {
  color: #c4f7bd !important;
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

/* v42 mobile expandable search and profile table breathing room */
.mobile-filter-toggle {
  display: none;
}

@media (max-width: 760px) {
  .page-explorer .search-action-row {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    gap: 0.52rem !important;
    align-items: stretch !important;
  }

  .page-explorer .mobile-filter-toggle {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 86px !important;
    min-height: 48px !important;
    padding: 0 0.84rem !important;
    border: 1px solid rgba(114, 255, 171, 0.22) !important;
    border-radius: 14px !important;
    color: var(--text) !important;
    background: rgba(7, 17, 11, 0.96) !important;
    font-weight: 850 !important;
    cursor: pointer !important;
  }

  .page-explorer .mobile-filter-toggle[aria-expanded="true"] {
    color: #041008 !important;
    background: linear-gradient(180deg, #98ffc4 0%, #55d986 100%) !important;
    border-color: rgba(152, 255, 196, 0.72) !important;
  }

  .page-explorer .controls:not(.filters-expanded) .filter-grid {
    display: none !important;
  }

  .page-explorer .controls.filters-expanded .filter-grid {
    display: grid !important;
  }

  .battle-table,
  .nature-table,
  .stat-points-table,
  .teammate-table,
  .learnable-moves-table,
  .battle-table tbody,
  .nature-table tbody,
  .stat-points-table tbody,
  .teammate-table tbody,
  .learnable-moves-table tbody {
    display: grid !important;
    width: 100% !important;
    min-width: 0 !important;
    gap: 0.58rem !important;
    table-layout: auto !important;
  }

  .battle-table thead,
  .nature-table thead,
  .stat-points-table thead,
  .teammate-table thead,
  .learnable-moves-table thead {
    display: none !important;
  }

  .battle-table tr,
  .nature-table tr,
  .stat-points-table tr,
  .teammate-table tr,
  .learnable-moves-table tr {
    display: grid !important;
    width: 100% !important;
    min-width: 0 !important;
    gap: 0.34rem !important;
    padding: 0.68rem !important;
    border: 1px solid rgba(114, 255, 171, 0.16) !important;
    border-radius: 12px !important;
    background: rgba(4, 10, 7, 0.42) !important;
  }

  .battle-table td,
  .nature-table td,
  .stat-points-table td,
  .teammate-table td,
  .learnable-moves-table td {
    display: grid !important;
    grid-template-columns: minmax(5.2rem, 0.38fr) minmax(0, 1fr) !important;
    align-items: start !important;
    gap: 0.54rem !important;
    width: 100% !important;
    min-width: 0 !important;
    padding: 0.1rem 0 !important;
    border: 0 !important;
    text-align: left !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
  }

  .battle-table td::before,
  .nature-table td::before,
  .stat-points-table td::before,
  .teammate-table td::before,
  .learnable-moves-table td::before {
    content: attr(data-label) !important;
    display: block !important;
    color: var(--soft) !important;
    font-size: 0.66rem !important;
    font-weight: 950 !important;
    letter-spacing: 0.06em !important;
    text-align: left !important;
    text-transform: uppercase !important;
  }

  .battle-table td > *,
  .nature-table td > *,
  .stat-points-table td > *,
  .teammate-table td > *,
  .learnable-moves-table td > * {
    min-width: 0 !important;
    max-width: 100% !important;
    justify-self: stretch !important;
  }

  .battle-table td[data-label="Usage"],
  .nature-table td[data-label="Usage"],
  .stat-points-table td[data-label="Usage"] {
    grid-template-columns: 1fr !important;
    gap: 0.26rem !important;
  }

  .battle-table td[data-label="Usage"]::before,
  .nature-table td[data-label="Usage"]::before,
  .stat-points-table td[data-label="Usage"]::before {
    margin-bottom: 0.05rem !important;
  }

  .data-table-wrap .usage-meter,
  .stat-points-table .usage-meter {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 0.24rem !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
  }

  .data-table-wrap .usage-value,
  .stat-points-table .usage-value {
    order: -1 !important;
    width: 100% !important;
    min-width: 0 !important;
    color: #eff8ee !important;
    font-size: 0.76rem !important;
    line-height: 1.1 !important;
    text-align: left !important;
  }

  .data-table-wrap .usage-svg,
  .stat-points-table .usage-svg {
    width: 100% !important;
    min-width: 0 !important;
    height: 10px !important;
    flex: none !important;
  }

  .learnable-moves-table td[data-label="Move"] {
    order: 1 !important;
  }

  .learnable-moves-table td[data-label="Description"] {
    order: 2 !important;
    grid-template-columns: 1fr !important;
    gap: 0.24rem !important;
    margin: 0.16rem 0 0.18rem !important;
    padding-top: 0.46rem !important;
    border-top: 1px solid rgba(114, 255, 171, 0.12) !important;
  }

  .learnable-moves-table td[data-label="Type"] { order: 3 !important; }
  .learnable-moves-table td[data-label="Category"] { order: 4 !important; }
  .learnable-moves-table td[data-label="Power"] { order: 5 !important; }
  .learnable-moves-table td[data-label="Accuracy"] { order: 6 !important; }
  .learnable-moves-table td[data-label="PP"] { order: 7 !important; }

  .learnable-moves-table td[data-label="Description"] .move-description {
    justify-self: stretch !important;
    max-width: 100% !important;
    font-size: 0.76rem !important;
    line-height: 1.45 !important;
    text-align: left !important;
  }
}

/* v41 small project affiliation notice */
.site-footer {
  padding: 0.55rem 0 1.2rem;
  color: var(--muted);
}

.site-footer p {
  max-width: 980px;
  margin: 0;
  font-size: 0.68rem;
  line-height: 1.45;
  opacity: 0.72;
}

.page-api .site-footer {
  margin-top: 0.8rem;
}

.percent-meter {
  display: inline-grid !important;
  grid-template-columns: minmax(86px, 1fr) max-content;
  align-items: center;
  gap: 0.52rem;
  width: min(190px, 100%);
  min-width: 154px;
  max-width: 100%;
}

.percent-meter .percent-bar {
  display: block !important;
  position: relative !important;
  width: 100% !important;
  min-width: 0 !important;
  height: 24px !important;
  margin: 0 !important;
  overflow: hidden !important;
}

.percent-meter .percent-bar > span {
  position: absolute !important;
  inset: 0 auto 0 0 !important;
  display: block !important;
  width: var(--value, 0%) !important;
  height: 100% !important;
}

.percent-meter .percent-value,
.data-table-wrap .percent-meter .percent-value {
  display: block !important;
  min-width: 3.4rem;
  color: var(--text);
  font-size: 0.78rem;
  font-weight: 900;
  line-height: 1;
  text-align: right;
  white-space: nowrap;
}

.stat-points-table .percent-meter {
  grid-template-columns: minmax(58px, 1fr) max-content;
  gap: 0.34rem;
  width: min(132px, 100%);
  min-width: 118px;
}

.stat-points-table .percent-meter .percent-bar {
  height: 20px !important;
}

.stat-points-table .percent-meter .percent-value {
  min-width: 2.8rem;
  font-size: 0.68rem;
}

/* v40 battle data usage bars avoid the legacy percent-bar cascade */
.usage-meter {
  display: inline-flex !important;
  align-items: center;
  justify-content: flex-start;
  gap: 0.58rem;
  width: 190px !important;
  max-width: 100%;
  min-width: 156px;
  vertical-align: middle;
}

.usage-svg {
  display: block !important;
  flex: 0 0 120px;
  width: 120px !important;
  height: 10px !important;
  overflow: visible;
}

.usage-svg-track {
  fill: rgba(4, 10, 7, 0.82);
  stroke: rgba(114, 255, 171, 0.24);
  stroke-width: 1;
}

.usage-svg-fill {
  filter: drop-shadow(0 0 3px rgba(114, 255, 171, 0.26));
}

.usage-track {
  position: relative;
  display: block !important;
  flex: 0 0 120px;
  width: 120px !important;
  height: 10px;
  overflow: hidden;
  border: 1px solid rgba(114, 255, 171, 0.2);
  border-radius: 999px;
  background: rgba(4, 10, 7, 0.82);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.025);
}

.usage-fill {
  position: absolute;
  inset: 0 auto 0 0;
  display: block !important;
  width: var(--value, 0%);
  min-width: 2px;
  height: 100%;
  border-radius: inherit;
  background: var(--bar-color, var(--stat-good));
  box-shadow: 0 0 10px rgba(114, 255, 171, 0.18);
}

.usage-value {
  display: block !important;
  min-width: 3.4rem;
  color: var(--text);
  font-size: 0.78rem;
  font-weight: 900;
  line-height: 1;
  text-align: right;
  white-space: nowrap;
}

.stat-points-table .usage-meter {
  gap: 0.36rem;
  width: 136px !important;
  min-width: 116px;
}

.stat-points-table .usage-track {
  flex-basis: 66px;
  width: 66px !important;
  height: 8px;
}

.stat-points-table .usage-svg {
  flex-basis: 66px;
  width: 66px !important;
  height: 8px !important;
}

.stat-points-table .usage-value {
  min-width: 2.8rem;
  font-size: 0.68rem;
}

/* v41 mobile header, search order, and Battle Data list corrections */
.page-explorer .entry-index {
  width: 34px !important;
  min-width: 34px !important;
  height: 34px !important;
  aspect-ratio: 1 / 1 !important;
  padding: 0 !important;
  border-radius: 7px !important;
  line-height: 1 !important;
}

@media (max-width: 760px) {
  .page-explorer main {
    display: flex !important;
    flex-direction: column !important;
  }

  .page-explorer .controls {
    order: 1 !important;
  }

  .page-explorer .hero {
    order: 2 !important;
    display: block !important;
  }

  .page-explorer .hero-copy,
  .page-explorer .hero-copy .eyebrow {
    display: none !important;
  }

  .page-explorer .nav-shell {
    align-items: stretch !important;
    gap: 0.62rem !important;
  }

  .page-explorer .brand {
    width: 100% !important;
    align-items: flex-start !important;
  }

  .page-explorer .brand strong {
    max-width: none !important;
    overflow: visible !important;
    text-overflow: clip !important;
    white-space: normal !important;
    font-size: 0.86rem !important;
    line-height: 1.14 !important;
  }

  .page-explorer .nav-actions {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    align-items: stretch !important;
    width: 100% !important;
    gap: 0.5rem !important;
  }

  .page-explorer .format-switch {
    grid-column: 1 / -1 !important;
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    width: 100% !important;
    height: 44px !important;
    min-height: 44px !important;
    padding: 0 !important;
    border-radius: 8px !important;
  }

  .page-explorer .format-toggle,
  .page-explorer .ghost-button,
  .page-explorer .discord-button {
    width: 100% !important;
    height: 44px !important;
    min-height: 44px !important;
    padding-block: 0 !important;
    border-radius: 8px !important;
    line-height: 1 !important;
  }

  .page-explorer .battle-entry-panel {
    width: 100% !important;
    height: clamp(460px, 72dvh, 700px) !important;
    min-height: 0 !important;
    max-height: none !important;
    display: grid !important;
    grid-template-rows: auto minmax(0, 1fr) !important;
  }

  .page-explorer .entry-list {
    max-height: none !important;
    min-height: 0 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    content-visibility: visible !important;
    contain: none !important;
    -webkit-overflow-scrolling: touch !important;
  }

  .page-explorer .entry-item {
    grid-template-columns: 34px 50px minmax(0, 1fr) 28px !important;
  }

  .page-explorer .entry-index {
    width: 34px !important;
    min-width: 34px !important;
    height: 34px !important;
    font-size: 0.72rem !important;
  }

  .page-explorer .search-help-popover {
    border: 2px solid rgba(196, 247, 189, 0.58) !important;
    background:
      linear-gradient(180deg, rgba(9, 21, 13, 0.99), rgba(3, 9, 5, 0.99)) !important;
    box-shadow:
      0 0 0 1px rgba(255, 255, 255, 0.08),
      0 22px 70px rgba(0, 0, 0, 0.82),
      0 0 0 999px rgba(0, 0, 0, 0.28) !important;
  }
}

/* v43 mobile header alignment */
@media (max-width: 760px) {
  .page-explorer .brand {
    align-items: center !important;
    min-height: 34px !important;
  }

  .page-explorer .brand span {
    display: flex !important;
    align-items: center !important;
    min-height: 34px !important;
  }

  .page-explorer .brand small {
    display: none !important;
  }

  .page-explorer .brand strong {
    display: flex !important;
    align-items: center !important;
    min-height: 34px !important;
    font-size: 0.9rem !important;
    line-height: 1.08 !important;
  }

  .page-explorer .format-toggle,
  .page-explorer .ghost-button,
  .page-explorer .discord-button {
    font-size: 0.84rem !important;
    font-weight: 850 !important;
  }
}

/* v44 mobile profile: copy-site profile with right-side art */
@media (max-width: 760px) {
  .page-explorer .detail-hero {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 104px !important;
    grid-template-areas: "copy art" !important;
    align-items: center !important;
    gap: 0.76rem !important;
    min-width: 0 !important;
    padding-right: 0 !important;
  }

  .page-explorer .detail-title {
    grid-area: copy !important;
    min-width: 0 !important;
    text-align: left !important;
  }

  .page-explorer .detail-title .eyebrow {
    text-align: left !important;
  }

  .page-explorer .detail-title h2 {
    overflow-wrap: anywhere !important;
    text-align: left !important;
  }

  .page-explorer .detail-title .type-row {
    justify-content: flex-start !important;
  }

  .page-explorer .detail-art {
    grid-area: art !important;
    align-self: center !important;
    width: 100% !important;
  }

  .page-explorer .detail-metrics {
    grid-template-columns: 1fr !important;
    text-align: left !important;
  }

  .page-explorer .metric span,
  .page-explorer .metric strong {
    text-align: left !important;
  }
}

@media (max-width: 390px) {
  .page-explorer .detail-hero {
    grid-template-columns: minmax(0, 1fr) 76px !important;
    gap: 0.62rem !important;
    padding-right: 0 !important;
  }
}

/* v45 mobile profile tables: one row, labels above values */
@media (max-width: 760px) {
  .page-explorer .battle-table tr {
    grid-template-columns: minmax(2rem, 0.45fr) minmax(7rem, 1.35fr) minmax(7.5rem, 1.2fr) !important;
    align-items: stretch !important;
    gap: 0.48rem !important;
    overflow-x: auto !important;
  }

  .page-explorer .teammate-table tr {
    grid-template-columns: minmax(2rem, 0.35fr) minmax(9rem, 1fr) !important;
    align-items: stretch !important;
    gap: 0.48rem !important;
  }

  .page-explorer .nature-table tr {
    grid-template-columns: minmax(2rem, 0.35fr) minmax(5.2rem, 0.8fr) minmax(7.5rem, 1.1fr) minmax(6.8rem, 1fr) !important;
    align-items: stretch !important;
    gap: 0.48rem !important;
    overflow-x: auto !important;
  }

  .page-explorer .stat-points-table tr {
    grid-template-columns: minmax(7.5rem, 1.05fr) repeat(6, minmax(2.65rem, 0.48fr)) !important;
    align-items: stretch !important;
    gap: 0.42rem !important;
    overflow-x: auto !important;
  }

  .page-explorer .battle-table td,
  .page-explorer .nature-table td,
  .page-explorer .stat-points-table td,
  .page-explorer .teammate-table td {
    display: grid !important;
    grid-template-columns: 1fr !important;
    grid-template-rows: auto minmax(0, 1fr) !important;
    align-items: start !important;
    gap: 0.24rem !important;
    width: auto !important;
    min-width: 0 !important;
    padding: 0 !important;
    text-align: left !important;
  }

  .page-explorer .battle-table td::before,
  .page-explorer .nature-table td::before,
  .page-explorer .stat-points-table td::before,
  .page-explorer .teammate-table td::before {
    margin: 0 !important;
    line-height: 1.05 !important;
    white-space: nowrap !important;
  }

  .page-explorer .battle-table td[data-label="Usage"],
  .page-explorer .nature-table td[data-label="Usage"],
  .page-explorer .stat-points-table td[data-label="Usage"] {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto minmax(0, 1fr) !important;
    gap: 0.24rem !important;
  }

  .page-explorer .data-table-wrap .usage-meter,
  .page-explorer .stat-points-table .usage-meter {
    display: inline-flex !important;
    grid-template-columns: none !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 0.34rem !important;
    width: 100% !important;
    min-width: 0 !important;
  }

  .page-explorer .data-table-wrap .usage-value,
  .page-explorer .stat-points-table .usage-value {
    order: 0 !important;
    width: auto !important;
    min-width: 2.4rem !important;
    font-size: 0.68rem !important;
    line-height: 1 !important;
    text-align: right !important;
  }

  .page-explorer .data-table-wrap .usage-svg,
  .page-explorer .stat-points-table .usage-svg {
    flex: 1 1 3.4rem !important;
    width: auto !important;
    min-width: 2.8rem !important;
    max-width: none !important;
    height: 8px !important;
  }
}

/* ============================================================
   v46 — Mobile profile: full layout rework
   ============================================================
   Goals:
   - Sprite on the right of name + typings in the hero
   - Forms & Metadata: card-per-form layout, no horizontal scroll
   - Battle Data: single-column, readable cards with label-value pairs
   - Learnable Moves: compact card grid, fully accessible
   - Generous padding, no overlapping or bunched elements
   ============================================================ */

@media (max-width: 760px) {

  /* ── Dialog shell ── */
  .page-explorer .detail-dialog {
    width: 100% !important;
    max-width: 100% !important;
    max-height: 100% !important;
    height: 100dvh !important;
    margin: 0 !important;
    border-radius: 0 !important;
    border: 0 !important;
  }

  .page-explorer .dialog-inner {
    max-height: 100dvh !important;
    height: 100dvh !important;
    padding: 0 !important;
    border-radius: 0 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch !important;
  }

  /* Scrollable content area inside the dialog */
  .page-explorer .detail-content {
    padding: 1rem 1rem 2.5rem !important;
    display: grid !important;
    gap: 0.85rem !important;
    min-width: 0 !important;
  }

  /* ── Close button: bigger tap target, sticky to top-right ── */
  .page-explorer .detail-dialog .close-button {
    position: sticky !important;
    top: 0.6rem !important;
    float: right !important;
    z-index: 10 !important;
    width: 42px !important;
    height: 42px !important;
    margin: 0.6rem 0 -42px auto !important;
    border-radius: 10px !important;
    background: rgba(15, 22, 14, 0.96) !important;
    border-color: rgba(141, 232, 114, 0.28) !important;
    font-size: 1.35rem !important;
  }

  /* ── Hero: sprite RIGHT of name + types ── */
  .page-explorer .detail-hero {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 110px !important;
    grid-template-rows: auto !important;
    grid-template-areas: "copy art" !important;
    align-items: start !important;
    gap: 0.75rem !important;
    padding: 0 !important;
    padding-top: 0.15rem !important;
    min-width: 0 !important;
  }

  .page-explorer .detail-art {
    grid-area: art !important;
    min-height: 0 !important;
    width: 110px !important;
    height: 110px !important;
    border-radius: 12px !important;
    border-color: rgba(141, 232, 114, 0.18) !important;
    background: rgba(8, 17, 10, 0.72) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    overflow: hidden !important;
    flex-shrink: 0 !important;
  }

  .page-explorer .detail-art img {
    width: 96px !important;
    height: 96px !important;
    max-width: 100% !important;
  }

  .page-explorer .detail-art .pokemon-fallback {
    width: 68px !important;
    height: 68px !important;
    font-size: 1.05rem !important;
  }

  .page-explorer .detail-title {
    grid-area: copy !important;
    min-width: 0 !important;
    text-align: left !important;
    padding-top: 0.1rem !important;
  }

  .page-explorer .detail-title .eyebrow {
    text-align: left !important;
    margin-bottom: 0.38rem !important;
    font-size: 0.66rem !important;
  }

  .page-explorer .detail-title h2 {
    margin: 0 0 0.42rem !important;
    font-size: clamp(1.55rem, 7.5vw, 2.15rem) !important;
    line-height: 1.02 !important;
    letter-spacing: -0.03em !important;
    text-align: left !important;
    overflow-wrap: anywhere !important;
  }

  .page-explorer .detail-title .type-row {
    justify-content: flex-start !important;
    flex-wrap: wrap !important;
    gap: 0.32rem !important;
    margin-bottom: 0.38rem !important;
  }

  /* ── Detail metrics below the hero (top move / item / ability) ── */
  .page-explorer .detail-metrics {
    grid-column: 1 / -1 !important;
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 0.5rem !important;
    margin-top: 0.62rem !important;
  }

  .page-explorer .metric {
    padding: 0.58rem 0.62rem !important;
    border-radius: 8px !important;
    min-width: 0 !important;
  }

  .page-explorer .metric span {
    font-size: 0.6rem !important;
    letter-spacing: 0.06em !important;
    line-height: 1 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    text-align: left !important;
  }

  .page-explorer .metric strong {
    font-size: 0.78rem !important;
    line-height: 1.22 !important;
    margin-top: 0.22rem !important;
    overflow-wrap: anywhere !important;
    text-align: left !important;
  }

  /* ── Section cards ── */
  .page-explorer .detail-sections {
    display: grid !important;
    gap: 0.72rem !important;
    margin-top: 0 !important;
  }

  .page-explorer .detail-section {
    padding: 0.88rem !important;
    border-radius: 10px !important;
    min-width: 0 !important;
    overflow: hidden !important;
  }

  .page-explorer .detail-section > h3 {
    margin: 0 0 0.72rem !important;
    font-size: 0.88rem !important;
    font-weight: 720 !important;
    letter-spacing: 0.03em !important;
    text-transform: uppercase !important;
    color: var(--brand) !important;
  }

  /* ── Base stats ── */
  .page-explorer .stat-bars {
    gap: 0.5rem !important;
  }

  .page-explorer .stat-row {
    grid-template-columns: 2.6rem 1fr 2.4rem !important;
    gap: 0.52rem !important;
    font-size: 0.78rem !important;
    align-items: center !important;
  }

  .page-explorer .stat-track {
    height: 8px !important;
  }

  /* ── Forms and Metadata: card-per-form, no scrolling table ── */
  .page-explorer .forms-metadata-block {
    min-width: 0 !important;
  }

  /* Hide the horizontal-scroll desktop table */
  .page-explorer .forms-desktop-wrap {
    display: none !important;
  }

  /* Inject mobile form cards via a new element created below OR
     we use a ::after pseudo trick — but since JS generates the DOM,
     we handle this by overriding .forms-metadata-block children.
     The JS renders a single .forms-desktop-wrap; we re-render it
     as stacked cards using CSS display tricks on the table. */

  /* Make the table act like stacked cards */
  .page-explorer .forms-table {
    display: block !important;
    min-width: 0 !important;
    width: 100% !important;
    border-collapse: separate !important;
    border-spacing: 0 !important;
  }

  .page-explorer .forms-table thead {
    display: none !important;
  }

  .page-explorer .forms-table tbody {
    display: grid !important;
    gap: 0.62rem !important;
    width: 100% !important;
    min-width: 0 !important;
  }

  .page-explorer .forms-table tr {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    grid-template-rows: auto auto !important;
    gap: 0.5rem 0.75rem !important;
    width: 100% !important;
    min-width: 0 !important;
    padding: 0.72rem !important;
    border: 1px solid rgba(141, 232, 114, 0.15) !important;
    border-radius: 9px !important;
    background: rgba(8, 16, 10, 0.52) !important;
  }

  /* Form name: spans full width on top */
  .page-explorer .forms-table td[data-label="Form"] {
    grid-column: 1 / -1 !important;
    grid-row: 1 !important;
    display: block !important;
    padding: 0 0 0.38rem !important;
    border-bottom: 1px solid rgba(141, 232, 114, 0.1) !important;
    font-size: 0.86rem !important;
    font-weight: 720 !important;
    color: var(--text) !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
  }

  .page-explorer .forms-table td[data-label="Form"]::before {
    content: "Form: " !important;
    color: var(--soft) !important;
    font-size: 0.65rem !important;
    font-weight: 950 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.07em !important;
    display: block !important;
    margin-bottom: 0.2rem !important;
  }

  /* Types: bottom-left */
  .page-explorer .forms-table td[data-label="Types"] {
    grid-column: 1 !important;
    grid-row: 2 !important;
    display: block !important;
    padding: 0 !important;
    font-size: 0.78rem !important;
    color: var(--muted) !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
    min-width: 0 !important;
  }

  .page-explorer .forms-table td[data-label="Types"]::before {
    content: "Types" !important;
    display: block !important;
    color: var(--soft) !important;
    font-size: 0.62rem !important;
    font-weight: 950 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.07em !important;
    margin-bottom: 0.2rem !important;
  }

  /* Abilities: bottom-right */
  .page-explorer .forms-table td[data-label="Abilities"] {
    grid-column: 2 !important;
    grid-row: 2 !important;
    display: block !important;
    padding: 0 !important;
    font-size: 0.78rem !important;
    color: var(--muted) !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
    min-width: 0 !important;
  }

  .page-explorer .forms-table td[data-label="Abilities"]::before {
    content: "Abilities" !important;
    display: block !important;
    color: var(--soft) !important;
    font-size: 0.62rem !important;
    font-weight: 950 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.07em !important;
    margin-bottom: 0.2rem !important;
  }

  /* Stats: spans full width below types/abilities */
  .page-explorer .forms-table td[data-label="Stats"] {
    grid-column: 1 / -1 !important;
    grid-row: 3 !important;
    display: block !important;
    padding: 0.38rem 0 0 !important;
    border-top: 1px solid rgba(141, 232, 114, 0.1) !important;
    min-width: 0 !important;
  }

  .page-explorer .forms-table td[data-label="Stats"]::before {
    content: "Stats" !important;
    display: block !important;
    color: var(--soft) !important;
    font-size: 0.62rem !important;
    font-weight: 950 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.07em !important;
    margin-bottom: 0.32rem !important;
  }

  .page-explorer .form-stat-line {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 0.28rem 0.55rem !important;
    min-width: 0 !important;
  }

  .page-explorer .form-stat-line span {
    display: inline-block !important;
    padding: 0.2rem 0.46rem !important;
    border: 1px solid rgba(141, 232, 114, 0.14) !important;
    border-radius: 6px !important;
    background: rgba(141, 232, 114, 0.055) !important;
    color: var(--text) !important;
    font-size: 0.72rem !important;
    font-weight: 720 !important;
    white-space: nowrap !important;
  }

  /* Also reveal the forms table inside the desktop wrap */
  .page-explorer .forms-desktop-wrap {
    display: block !important;
    overflow: visible !important;
    border: 0 !important;
    background: transparent !important;
    border-radius: 0 !important;
  }

  /* ── Battle Data: single column, card rows ── */
  .page-explorer .battle-grid-columns {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 0.6rem !important;
  }

  .page-explorer .battle-column {
    gap: 0.6rem !important;
  }

  .page-explorer .detail-section.nested {
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
  }

  .page-explorer .detail-section.nested > h3 {
    padding: 0 0.1rem !important;
    margin-bottom: 0.5rem !important;
    font-size: 0.78rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.08em !important;
    color: var(--brand) !important;
    font-weight: 850 !important;
  }

  /* Battle data table rows as cards */
  .page-explorer .battle-table,
  .page-explorer .nature-table,
  .page-explorer .stat-points-table,
  .page-explorer .teammate-table {
    display: block !important;
    min-width: 0 !important;
    width: 100% !important;
  }

  .page-explorer .battle-table thead,
  .page-explorer .nature-table thead,
  .page-explorer .stat-points-table thead,
  .page-explorer .teammate-table thead {
    display: none !important;
  }

  .page-explorer .battle-table tbody,
  .page-explorer .nature-table tbody,
  .page-explorer .stat-points-table tbody,
  .page-explorer .teammate-table tbody {
    display: grid !important;
    gap: 0.42rem !important;
    width: 100% !important;
    min-width: 0 !important;
  }

  /* Each row = horizontal label-value card */
  .page-explorer .battle-table tr,
  .page-explorer .nature-table tr,
  .page-explorer .stat-points-table tr,
  .page-explorer .teammate-table tr {
    display: grid !important;
    grid-template-columns: 1.6rem minmax(0, 1fr) auto !important;
    align-items: center !important;
    gap: 0.46rem 0.6rem !important;
    width: 100% !important;
    min-width: 0 !important;
    padding: 0.52rem 0.66rem !important;
    border: 1px solid rgba(141, 232, 114, 0.13) !important;
    border-radius: 8px !important;
    background: rgba(6, 13, 8, 0.5) !important;
    overflow: hidden !important;
  }

  /* Rank cell (#) */
  .page-explorer .battle-table td[data-label="#"],
  .page-explorer .nature-table td[data-label="#"],
  .page-explorer .stat-points-table td[data-label="#"],
  .page-explorer .teammate-table td[data-label="#"] {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 1.6rem !important;
    min-width: 1.6rem !important;
    height: 1.6rem !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 5px !important;
    background: rgba(141, 232, 114, 0.09) !important;
    color: var(--brand) !important;
    font-size: 0.66rem !important;
    font-weight: 950 !important;
    white-space: nowrap !important;
  }

  .page-explorer .battle-table td[data-label="#"]::before,
  .page-explorer .nature-table td[data-label="#"]::before,
  .page-explorer .stat-points-table td[data-label="#"]::before,
  .page-explorer .teammate-table td[data-label="#"]::before {
    display: none !important;
  }

  /* Name cell */
  .page-explorer .battle-table td[data-label="Name"],
  .page-explorer .nature-table td[data-label="Nature"],
  .page-explorer .teammate-table td[data-label="Name"] {
    display: block !important;
    padding: 0 !important;
    border: 0 !important;
    font-size: 0.85rem !important;
    font-weight: 650 !important;
    color: var(--text) !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
    min-width: 0 !important;
  }

  .page-explorer .battle-table td[data-label="Name"]::before,
  .page-explorer .nature-table td[data-label="Nature"]::before,
  .page-explorer .teammate-table td[data-label="Name"]::before {
    display: none !important;
  }

  /* Usage cell: right-aligned, compact */
  .page-explorer .battle-table td[data-label="Usage"],
  .page-explorer .nature-table td[data-label="Usage"] {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-end !important;
    gap: 0.26rem !important;
    padding: 0 !important;
    border: 0 !important;
    min-width: 0 !important;
  }

  .page-explorer .battle-table td[data-label="Usage"]::before,
  .page-explorer .nature-table td[data-label="Usage"]::before {
    display: none !important;
  }

  .page-explorer .battle-table .usage-meter,
  .page-explorer .nature-table .usage-meter {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-end !important;
    gap: 0.2rem !important;
    width: auto !important;
    min-width: 0 !important;
  }

  .page-explorer .battle-table .usage-value,
  .page-explorer .nature-table .usage-value {
    font-size: 0.74rem !important;
    font-weight: 900 !important;
    color: var(--brand) !important;
    min-width: 0 !important;
    text-align: right !important;
    line-height: 1 !important;
  }

  .page-explorer .battle-table .usage-svg,
  .page-explorer .nature-table .usage-svg {
    width: 64px !important;
    min-width: 0 !important;
    max-width: 64px !important;
    height: 7px !important;
    flex: none !important;
  }

  /* Stat Change cell in nature table */
  .page-explorer .nature-table td[data-label="Stat Change"] {
    grid-column: 2 / -1 !important;
    display: flex !important;
    align-items: center !important;
    gap: 0.36rem !important;
    padding: 0.26rem 0 0 !important;
    border: 0 !important;
    border-top: 1px solid rgba(141, 232, 114, 0.08) !important;
    min-width: 0 !important;
  }

  .page-explorer .nature-table td[data-label="Stat Change"]::before {
    display: none !important;
  }

  /* Stat Spreads: compact chip layout */
  .page-explorer .stat-points-table tr {
    grid-template-columns: 1.6rem 1fr !important;
    grid-template-rows: auto auto !important;
  }

  .page-explorer .stat-points-table td[data-label="Usage"] {
    grid-column: 2 !important;
    grid-row: 1 !important;
    display: flex !important;
    align-items: center !important;
    gap: 0.4rem !important;
    flex-direction: row !important;
    padding: 0 !important;
    border: 0 !important;
    min-width: 0 !important;
  }

  .page-explorer .stat-points-table td[data-label="Usage"]::before {
    display: none !important;
  }

  .page-explorer .stat-points-table .usage-meter {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 0.4rem !important;
    width: auto !important;
    min-width: 0 !important;
  }

  .page-explorer .stat-points-table .usage-value {
    font-size: 0.72rem !important;
    min-width: 2.6rem !important;
    text-align: left !important;
    color: var(--brand) !important;
    font-weight: 900 !important;
    order: -1 !important;
  }

  .page-explorer .stat-points-table .usage-svg {
    width: 56px !important;
    height: 7px !important;
    flex: none !important;
  }

  /* EV stat cells in spread table: wrap into chip row */
  .page-explorer .stat-points-table td[data-label="HP"],
  .page-explorer .stat-points-table td[data-label="Atk"],
  .page-explorer .stat-points-table td[data-label="Def"],
  .page-explorer .stat-points-table td[data-label="SpA"],
  .page-explorer .stat-points-table td[data-label="SpD"],
  .page-explorer .stat-points-table td[data-label="Spe"] {
    display: inline-flex !important;
    align-items: baseline !important;
    gap: 0.22rem !important;
    padding: 0.18rem 0.38rem !important;
    border: 1px solid rgba(141, 232, 114, 0.14) !important;
    border-radius: 5px !important;
    background: rgba(141, 232, 114, 0.055) !important;
    font-size: 0.7rem !important;
    white-space: nowrap !important;
    min-width: 0 !important;
  }

  /* Trick: stat cells share the second row in the grid,
     so we make tbody for stat-points use flex wrapping */
  .page-explorer .stat-points-table tbody {
    display: grid !important;
    gap: 0.48rem !important;
  }

  .page-explorer .stat-points-table tr {
    display: grid !important;
    grid-template-columns: 1.6rem auto 1fr !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    gap: 0.4rem !important;
    overflow: hidden !important;
  }

  /* Slot the stat chips into a flex row spanning col 3 */
  .page-explorer .stat-points-table td[data-label="HP"] { order: 10 !important; }
  .page-explorer .stat-points-table td[data-label="Atk"] { order: 11 !important; }
  .page-explorer .stat-points-table td[data-label="Def"] { order: 12 !important; }
  .page-explorer .stat-points-table td[data-label="SpA"] { order: 13 !important; }
  .page-explorer .stat-points-table td[data-label="SpD"] { order: 14 !important; }
  .page-explorer .stat-points-table td[data-label="Spe"] { order: 15 !important; }
  .page-explorer .stat-points-table td[data-label="Usage"] { order: 2 !important; }
  .page-explorer .stat-points-table td[data-label="#"] { order: 1 !important; }

  .page-explorer .stat-points-table td[data-label="HP"],
  .page-explorer .stat-points-table td[data-label="Atk"],
  .page-explorer .stat-points-table td[data-label="Def"],
  .page-explorer .stat-points-table td[data-label="SpA"],
  .page-explorer .stat-points-table td[data-label="SpD"],
  .page-explorer .stat-points-table td[data-label="Spe"] {
    grid-column: unset !important;
  }

  /* Make the spread row use flex so chips wrap naturally */
  .page-explorer .stat-points-table tr {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
  }

  .page-explorer .stat-points-table td[data-label="#"]::before {
    display: none !important;
  }

  .page-explorer .stat-points-table td[data-label="HP"]::before,
  .page-explorer .stat-points-table td[data-label="Atk"]::before,
  .page-explorer .stat-points-table td[data-label="Def"]::before,
  .page-explorer .stat-points-table td[data-label="SpA"]::before,
  .page-explorer .stat-points-table td[data-label="SpD"]::before,
  .page-explorer .stat-points-table td[data-label="Spe"]::before {
    content: attr(data-label) !important;
    font-size: 0.58rem !important;
    font-weight: 950 !important;
    color: var(--soft) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.06em !important;
    display: block !important;
    line-height: 1 !important;
    margin-bottom: 0.1rem !important;
  }

  /* data-table-wrap: no overflow scroll on mobile */
  .page-explorer .data-table-wrap {
    overflow: visible !important;
    border: 0 !important;
    background: transparent !important;
    border-radius: 0 !important;
  }

  /* ── Learnable Moves: accessible card grid ── */
  .page-explorer .learnable-moves-table {
    display: block !important;
    min-width: 0 !important;
    width: 100% !important;
  }

  .page-explorer .learnable-moves-table thead {
    display: none !important;
  }

  .page-explorer .learnable-moves-table tbody {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 0.48rem !important;
    width: 100% !important;
    min-width: 0 !important;
  }

  .page-explorer .learnable-moves-table tr {
    display: flex !important;
    flex-direction: column !important;
    gap: 0.28rem !important;
    padding: 0.6rem 0.7rem !important;
    border: 1px solid rgba(141, 232, 114, 0.14) !important;
    border-radius: 9px !important;
    background: rgba(7, 15, 9, 0.55) !important;
    min-width: 0 !important;
    overflow: hidden !important;
  }

  /* Move name: prominent */
  .page-explorer .learnable-moves-table td[data-label="Move"] {
    display: block !important;
    padding: 0 !important;
    border: 0 !important;
    font-size: 0.82rem !important;
    font-weight: 780 !important;
    color: var(--text) !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
    line-height: 1.2 !important;
    order: 1 !important;
  }

  .page-explorer .learnable-moves-table td[data-label="Move"]::before {
    display: none !important;
  }

  /* Type: inline chip */
  .page-explorer .learnable-moves-table td[data-label="Type"] {
    display: block !important;
    padding: 0 !important;
    border: 0 !important;
    order: 2 !important;
    min-width: 0 !important;
  }

  .page-explorer .learnable-moves-table td[data-label="Type"]::before {
    display: none !important;
  }

  /* Category, Power, Accuracy, PP: small metadata row */
  .page-explorer .learnable-moves-table td[data-label="Category"] {
    order: 3 !important;
  }

  .page-explorer .learnable-moves-table td[data-label="Power"],
  .page-explorer .learnable-moves-table td[data-label="Accuracy"],
  .page-explorer .learnable-moves-table td[data-label="PP"] {
    display: inline-flex !important;
    align-items: baseline !important;
    gap: 0.2rem !important;
    padding: 0 !important;
    border: 0 !important;
    font-size: 0.7rem !important;
    color: var(--muted) !important;
    white-space: nowrap !important;
    min-width: 0 !important;
  }

  .page-explorer .learnable-moves-table td[data-label="Power"] { order: 4 !important; }
  .page-explorer .learnable-moves-table td[data-label="Accuracy"] { order: 5 !important; }
  .page-explorer .learnable-moves-table td[data-label="PP"] { order: 6 !important; }

  .page-explorer .learnable-moves-table td[data-label="Category"]::before,
  .page-explorer .learnable-moves-table td[data-label="Power"]::before,
  .page-explorer .learnable-moves-table td[data-label="Accuracy"]::before,
  .page-explorer .learnable-moves-table td[data-label="PP"]::before {
    content: attr(data-label) ": " !important;
    font-size: 0.62rem !important;
    font-weight: 950 !important;
    color: var(--soft) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
  }

  /* Description: full-width below all metadata */
  .page-explorer .learnable-moves-table td[data-label="Description"] {
    display: block !important;
    padding: 0.34rem 0 0 !important;
    border: 0 !important;
    border-top: 1px solid rgba(141, 232, 114, 0.09) !important;
    font-size: 0.72rem !important;
    color: var(--muted) !important;
    line-height: 1.45 !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
    order: 8 !important;
    grid-column: 1 / -1 !important;
  }

  .page-explorer .learnable-moves-table td[data-label="Description"]::before {
    display: none !important;
  }

  /* Category pill stays readable */
  .page-explorer .learnable-moves-table .move-category {
    font-size: 0.62rem !important;
    padding: 0.1rem 0.34rem !important;
    min-width: 0 !important;
  }

  /* Type chip in moves table */
  .page-explorer .learnable-moves-table .move-type-label {
    font-size: 0.7rem !important;
    white-space: nowrap !important;
  }

  .page-explorer .learnable-moves-table .move-type-label img {
    width: 14px !important;
    height: 14px !important;
  }
}

/* ── Very small screens (≤390px): tighten further ── */
@media (max-width: 390px) {
  .page-explorer .detail-hero {
    grid-template-columns: minmax(0, 1fr) 88px !important;
  }

  .page-explorer .detail-art {
    width: 88px !important;
    height: 88px !important;
  }

  .page-explorer .detail-art img {
    width: 76px !important;
    height: 76px !important;
  }

  .page-explorer .detail-metrics {
    grid-template-columns: 1fr 1fr 1fr !important;
  }

  .page-explorer .learnable-moves-table tbody {
    grid-template-columns: 1fr !important;
  }

  .page-explorer .forms-table td[data-label="Stats"] .form-stat-line {
    gap: 0.22rem 0.4rem !important;
  }
}

/* v47 profile move data, row assets, and mobile table repairs */
.detail-section > h3 {
  padding-top: 0.18rem;
  margin-bottom: 1rem;
}

.battle-grid-columns {
  padding-top: 0.22rem;
}

.battle-column {
  gap: 1rem;
}

.detail-section.nested > h3 {
  margin-bottom: 0.68rem;
}

.learnable-moves-block {
  display: grid;
  gap: 0.72rem;
}

.learnable-moves-search-shell {
  display: flex;
  align-items: center;
  min-width: 0;
}

.detail-section .learnable-moves-search {
  width: min(340px, 100%);
  min-height: 42px;
  padding: 0.72rem 0.86rem;
  border: 1px solid rgba(141, 232, 114, 0.22);
  border-radius: 10px;
  color: var(--text);
  background: rgba(3, 9, 6, 0.72);
  font: inherit;
  font-size: 0.84rem;
  font-weight: 720;
  outline: none;
}

.detail-section .learnable-moves-search:focus {
  border-color: rgba(141, 232, 114, 0.58);
  box-shadow: 0 0 0 3px rgba(141, 232, 114, 0.12);
}

.learnable-moves-wrap {
  max-height: min(58vh, 620px);
}

.learnable-moves-table {
  min-width: 980px;
}

.learnable-moves-table th:nth-child(1),
.learnable-moves-table td[data-label="Move"] {
  width: 18%;
}

.learnable-moves-table th:nth-child(7),
.learnable-moves-table td[data-label="Description"] {
  width: 34%;
}

.move-description {
  display: block;
  min-width: 0;
  color: #d7e3ee;
  line-height: 1.42;
}

.asset-label {
  display: inline-flex;
  align-items: center;
  gap: 0.52rem;
  min-width: 0;
  max-width: 100%;
  vertical-align: middle;
}

.asset-label-text {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.asset-icon {
  display: inline-grid;
  place-items: center;
  flex: 0 0 32px;
  width: 32px;
  height: 32px;
  overflow: hidden;
  border: 1px solid rgba(148, 163, 184, 0.16);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.045);
}

.asset-icon img {
  display: block;
  width: 86%;
  height: 86%;
  object-fit: contain;
}

.teammate-label .asset-icon {
  flex-basis: 38px;
  width: 38px;
  height: 38px;
}

.asset-icon-fallback {
  display: grid;
  place-items: center;
  width: 100%;
  height: 100%;
  color: var(--brand);
  font-size: 0.68rem;
  font-weight: 950;
}

.moves-table .move-type-label,
.learnable-moves-table .move-type-label {
  justify-content: flex-start;
}

.nature-label {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  min-width: 0;
  max-width: 100%;
}

.nature-change {
  display: inline-flex;
  align-items: baseline;
  gap: 0.08rem;
  white-space: nowrap;
}

.nature-change .nature-separator {
  color: #9fb0c3;
}

.detail-empty {
  padding: 1rem;
  color: var(--muted);
  font-size: 0.84rem;
  font-weight: 720;
}

@media (max-width: 760px) {
  .page-explorer .detail-section > h3 {
    padding-top: 0.1rem !important;
    margin-bottom: 0.86rem !important;
  }

  .page-explorer .battle-grid-columns {
    padding-top: 0.28rem !important;
  }

  .page-explorer .battle-column {
    gap: 0.92rem !important;
  }

  .page-explorer .detail-section.nested > h3 {
    margin-bottom: 0.62rem !important;
  }

  .page-explorer .forms-table tr {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 0.58rem !important;
  }

  .page-explorer .forms-table td,
  .page-explorer .forms-table td[data-label="Form"],
  .page-explorer .forms-table td[data-label="Types"],
  .page-explorer .forms-table td[data-label="Abilities"],
  .page-explorer .forms-table td[data-label="Stats"] {
    grid-column: 1 / -1 !important;
    grid-row: auto !important;
    justify-self: stretch !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    white-space: normal !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    hyphens: manual !important;
  }

  .page-explorer .forms-table td[data-label="Types"],
  .page-explorer .forms-table td[data-label="Abilities"] {
    line-height: 1.35 !important;
  }

  .page-explorer .forms-table .form-stat-line {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 0.32rem 0.42rem !important;
  }

  .page-explorer .forms-table .form-stat-line span {
    white-space: nowrap !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
  }

  .page-explorer .nature-table tr {
    display: grid !important;
    grid-template-columns: 1.6rem minmax(0, 1fr) auto !important;
    align-items: center !important;
  }

  .page-explorer .nature-table td[data-label="#"] {
    grid-column: 1 !important;
  }

  .page-explorer .nature-table td[data-label="Nature"] {
    grid-column: 2 !important;
    display: flex !important;
    align-items: center !important;
    padding: 0 !important;
    border: 0 !important;
    min-width: 0 !important;
    white-space: normal !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
  }

  .page-explorer .nature-table td[data-label="Nature"]::before {
    display: none !important;
  }

  .page-explorer .nature-table .nature-label {
    display: inline-flex !important;
    flex-wrap: wrap !important;
    gap: 0.28rem 0.48rem !important;
    align-items: baseline !important;
  }

  .page-explorer .nature-table td[data-label="Usage"] {
    grid-column: 3 !important;
    display: flex !important;
    align-items: flex-end !important;
    padding: 0 !important;
    border: 0 !important;
  }

  .page-explorer .moves-table tr {
    display: grid !important;
    grid-template-columns: 1.6rem minmax(0, 1fr) auto !important;
    grid-template-areas:
      "rank move usage"
      "rank type usage" !important;
    align-items: center !important;
  }

  .page-explorer .moves-table td[data-label="#"] {
    grid-area: rank !important;
  }

  .page-explorer .moves-table td[data-label="Name"] {
    grid-area: move !important;
    padding: 0 !important;
    border: 0 !important;
  }

  .page-explorer .moves-table td[data-label="Type"] {
    grid-area: type !important;
    display: flex !important;
    padding: 0.12rem 0 0 !important;
    border: 0 !important;
  }

  .page-explorer .moves-table td[data-label="Name"]::before,
  .page-explorer .moves-table td[data-label="Type"]::before {
    display: none !important;
  }

  .page-explorer .moves-table td[data-label="Usage"] {
    grid-area: usage !important;
    padding: 0 !important;
    border: 0 !important;
  }

  .page-explorer .stat-points-table tr {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    gap: 0.36rem 0.22rem !important;
  }

  .page-explorer .stat-points-table td[data-label="#"] {
    order: 1 !important;
    flex: 0 0 1.6rem !important;
  }

  .page-explorer .stat-points-table td[data-label="Usage"] {
    order: 2 !important;
    flex: 1 1 calc(100% - 2.1rem) !important;
    min-width: 0 !important;
  }

  .page-explorer .stat-points-table td[data-label="HP"],
  .page-explorer .stat-points-table td[data-label="ATK"],
  .page-explorer .stat-points-table td[data-label="DEF"],
  .page-explorer .stat-points-table td[data-label="SpA"],
  .page-explorer .stat-points-table td[data-label="SpD"],
  .page-explorer .stat-points-table td[data-label="SPE"] {
    order: 10 !important;
    flex: 1 1 calc(16.666% - 0.22rem) !important;
    justify-content: center !important;
    min-width: 0 !important;
    margin-top: 0.08rem !important;
    padding-inline: 0.18rem !important;
    font-size: 0.64rem !important;
    white-space: nowrap !important;
  }

  .page-explorer .stat-points-table td[data-label="ATK"] { order: 11 !important; }
  .page-explorer .stat-points-table td[data-label="DEF"] { order: 12 !important; }
  .page-explorer .stat-points-table td[data-label="SpA"] { order: 13 !important; }
  .page-explorer .stat-points-table td[data-label="SpD"] { order: 14 !important; }
  .page-explorer .stat-points-table td[data-label="SPE"] { order: 15 !important; }

  .page-explorer .held-item-table .asset-label,
  .page-explorer .teammate-table .asset-label {
    width: 100% !important;
  }

  .page-explorer .asset-label-text {
    white-space: normal !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
  }

  .page-explorer .learnable-moves-search-shell {
    width: 100% !important;
  }

  .page-explorer .detail-section .learnable-moves-search {
    width: 100% !important;
  }

  .page-explorer .learnable-moves-wrap {
    max-height: none !important;
  }

  .page-explorer .learnable-moves-table tbody {
    grid-template-columns: 1fr !important;
  }
}

.move-category-short {
  display: none;
}

@media (max-width: 760px) {
  .page-explorer .detail-metrics {
    grid-template-columns: 1fr !important;
    gap: 0.58rem !important;
    width: 100% !important;
  }

  .page-explorer .detail-hero {
    grid-template-columns: minmax(0, 1fr) 110px !important;
    grid-template-rows: auto auto auto auto !important;
    grid-template-areas: none !important;
  }

  .page-explorer .detail-title {
    display: contents !important;
  }

  .page-explorer .detail-title .eyebrow {
    grid-column: 1 !important;
    grid-row: 1 !important;
  }

  .page-explorer .detail-title h2 {
    grid-column: 1 !important;
    grid-row: 2 !important;
  }

  .page-explorer .detail-title .type-row {
    grid-column: 1 !important;
    grid-row: 3 !important;
  }

  .page-explorer .detail-art {
    grid-column: 2 !important;
    grid-row: 1 / span 3 !important;
  }

  .page-explorer .detail-metrics {
    grid-column: 1 / -1 !important;
    grid-row: 4 !important;
  }

  .page-explorer .metric {
    width: 100% !important;
    min-height: 58px !important;
    padding: 0.78rem 0.88rem !important;
  }

  .page-explorer .metric strong {
    font-size: 0.9rem !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
  }

  .page-explorer .forms-table .form-stat-line span::before,
  .page-explorer .forms-table .form-stat-line span + span::before {
    content: none !important;
    display: none !important;
  }

  .page-explorer .moves-table tr {
    display: grid !important;
    grid-template-columns: 1.6rem minmax(0, 1fr) auto auto !important;
    grid-template-areas: "rank move type usage" !important;
    align-items: center !important;
    gap: 0.42rem 0.5rem !important;
  }

  .page-explorer .moves-table td[data-label="Type"] {
    grid-area: type !important;
    align-self: center !important;
    padding: 0 !important;
  }

  .page-explorer .moves-table .move-type-label {
    font-size: 0.72rem !important;
    gap: 0.24rem !important;
  }

  .page-explorer .moves-table .move-type-label img {
    width: 14px !important;
    height: 14px !important;
  }

  .page-explorer .battle-table td[data-label="Usage"],
  .page-explorer .nature-table td[data-label="Usage"],
  .page-explorer .stat-points-table td[data-label="Usage"] {
    justify-content: flex-end !important;
    justify-self: end !important;
    text-align: right !important;
  }

  .page-explorer .data-table-wrap .usage-meter,
  .page-explorer .stat-points-table .usage-meter {
    align-items: flex-end !important;
    justify-items: end !important;
    margin-left: auto !important;
  }

  .page-explorer .data-table-wrap .usage-value,
  .page-explorer .stat-points-table .usage-value {
    text-align: right !important;
  }

  .page-explorer .data-table-wrap .usage-svg,
  .page-explorer .stat-points-table .usage-svg {
    margin-left: auto !important;
  }

  .page-explorer .stat-points-table td[data-label="HP"],
  .page-explorer .stat-points-table td[data-label="ATK"],
  .page-explorer .stat-points-table td[data-label="DEF"],
  .page-explorer .stat-points-table td[data-label="SpA"],
  .page-explorer .stat-points-table td[data-label="SpD"],
  .page-explorer .stat-points-table td[data-label="SPE"] {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0.16rem !important;
    min-height: 24px !important;
    padding: 0.18rem 0.2rem !important;
    border: 1px solid rgba(141, 232, 114, 0.14) !important;
    border-radius: 5px !important;
    background: rgba(141, 232, 114, 0.055) !important;
    color: var(--text) !important;
    line-height: 1 !important;
  }

  .page-explorer .stat-points-table td[data-label="HP"]::before,
  .page-explorer .stat-points-table td[data-label="ATK"]::before,
  .page-explorer .stat-points-table td[data-label="DEF"]::before,
  .page-explorer .stat-points-table td[data-label="SpA"]::before,
  .page-explorer .stat-points-table td[data-label="SpD"]::before,
  .page-explorer .stat-points-table td[data-label="SPE"]::before {
    content: attr(data-label) !important;
    display: inline !important;
    margin: 0 !important;
    color: var(--soft) !important;
    font-size: 0.54rem !important;
    font-weight: 950 !important;
    letter-spacing: 0.05em !important;
    line-height: 1 !important;
  }

  .page-explorer .learnable-moves-table tr {
    display: grid !important;
    grid-template-columns: minmax(74px, 1.35fr) minmax(46px, 0.78fr) minmax(34px, 0.48fr) minmax(34px, 0.48fr) minmax(34px, 0.48fr) minmax(28px, 0.38fr) !important;
    gap: 0.44rem 0.26rem !important;
    align-items: start !important;
  }

  .page-explorer .learnable-moves-table td[data-label="Move"],
  .page-explorer .learnable-moves-table td[data-label="Type"],
  .page-explorer .learnable-moves-table td[data-label="Category"],
  .page-explorer .learnable-moves-table td[data-label="Power"],
  .page-explorer .learnable-moves-table td[data-label="Accuracy"],
  .page-explorer .learnable-moves-table td[data-label="PP"] {
    display: grid !important;
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto !important;
    align-content: start !important;
    gap: 0.18rem !important;
    min-width: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    font-size: 0.68rem !important;
    line-height: 1.15 !important;
    white-space: normal !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
  }

  .page-explorer .learnable-moves-table td[data-label="Move"] { order: 1 !important; }
  .page-explorer .learnable-moves-table td[data-label="Type"] { order: 2 !important; }
  .page-explorer .learnable-moves-table td[data-label="Category"] { order: 3 !important; }
  .page-explorer .learnable-moves-table td[data-label="Power"] { order: 4 !important; }
  .page-explorer .learnable-moves-table td[data-label="Accuracy"] { order: 5 !important; }
  .page-explorer .learnable-moves-table td[data-label="PP"] { order: 6 !important; }

  .page-explorer .learnable-moves-table td[data-label="Move"]::before { content: "NAME" !important; }
  .page-explorer .learnable-moves-table td[data-label="Type"]::before { content: "TYPE" !important; }
  .page-explorer .learnable-moves-table td[data-label="Category"]::before { content: "CAT" !important; }
  .page-explorer .learnable-moves-table td[data-label="Power"]::before { content: "POW" !important; }
  .page-explorer .learnable-moves-table td[data-label="Accuracy"]::before { content: "ACC" !important; }
  .page-explorer .learnable-moves-table td[data-label="PP"]::before { content: "PP" !important; }

  .page-explorer .learnable-moves-table td[data-label="Move"]::before,
  .page-explorer .learnable-moves-table td[data-label="Type"]::before,
  .page-explorer .learnable-moves-table td[data-label="Category"]::before,
  .page-explorer .learnable-moves-table td[data-label="Power"]::before,
  .page-explorer .learnable-moves-table td[data-label="Accuracy"]::before,
  .page-explorer .learnable-moves-table td[data-label="PP"]::before {
    display: block !important;
    margin: 0 !important;
    color: var(--soft) !important;
    font-size: 0.52rem !important;
    font-weight: 950 !important;
    letter-spacing: 0.06em !important;
    line-height: 1 !important;
    text-align: left !important;
  }

  .page-explorer .learnable-moves-table td[data-label="Description"] {
    order: 7 !important;
    grid-column: 1 / -1 !important;
    margin-top: 0.1rem !important;
  }

  .page-explorer .learnable-moves-table .move-category {
    min-width: 0 !important;
    width: fit-content !important;
    padding: 0.1rem 0.24rem !important;
    font-size: 0.58rem !important;
  }

  .page-explorer .learnable-moves-table .move-category-full {
    display: none !important;
  }

  .page-explorer .learnable-moves-table .move-category-short {
    display: inline !important;
  }

  .page-explorer .learnable-moves-table .move-type-label {
    gap: 0.2rem !important;
    font-size: 0.64rem !important;
  }

  .page-explorer .learnable-moves-table .move-type-label img {
    width: 12px !important;
    height: 12px !important;
  }
}

.form-profile-row {
  cursor: pointer;
}

.form-profile-row:hover,
.form-profile-row:focus-visible {
  background: rgba(141, 232, 114, 0.06);
}

.form-profile-button {
  display: inline-flex;
  align-items: center;
  max-width: 100%;
  padding: 0;
  border: 0;
  color: var(--text);
  background: transparent;
  font: inherit;
  font-weight: 850;
  text-align: left;
  cursor: pointer;
}

.form-profile-button:hover,
.form-profile-row:focus-visible .form-profile-button {
  color: var(--brand);
}

@media (max-width: 760px) {
  .page-explorer .detail-art {
    margin-top: 1rem !important;
  }

  .page-explorer .battle-column {
    gap: 1.35rem !important;
  }

  .page-explorer .detail-section.nested + .detail-section.nested {
    margin-top: 0.35rem !important;
    padding-top: 0.85rem !important;
    border-top: 1px solid rgba(141, 232, 114, 0.11) !important;
  }

  .page-explorer .moves-table tr {
    grid-template-columns: 1.6rem auto minmax(0, 1fr) auto !important;
    grid-template-areas: "rank type move usage" !important;
    gap: 0.42rem 0.44rem !important;
  }

  .page-explorer .moves-table td[data-label="Type"] {
    width: 18px !important;
    min-width: 18px !important;
    justify-content: center !important;
  }

  .page-explorer .moves-table .move-type-label {
    width: 18px !important;
    gap: 0 !important;
  }

  .page-explorer .moves-table .move-type-label span {
    display: none !important;
  }

  .page-explorer .moves-table .move-type-label img {
    width: 16px !important;
    height: 16px !important;
  }

  .page-explorer .battle-table td[data-label="Usage"],
  .page-explorer .nature-table td[data-label="Usage"],
  .page-explorer .stat-points-table td[data-label="Usage"] {
    justify-self: end !important;
    margin-left: auto !important;
  }

  .page-explorer .stat-points-table td[data-label="Usage"] {
    flex: 1 1 calc(100% - 2rem) !important;
  }

  .page-explorer .stat-points-table .usage-meter {
    width: 128px !important;
    max-width: 128px !important;
  }

  .page-explorer .stat-points-table .usage-svg {
    width: 128px !important;
    max-width: 128px !important;
  }

  .page-explorer .learnable-moves-table .move-category {
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    color: var(--text) !important;
    font-size: 0.68rem !important;
    font-weight: 850 !important;
  }

  .page-explorer .learnable-moves-table .move-category-full {
    display: none !important;
  }

  .page-explorer .learnable-moves-table .move-category-short {
    display: inline !important;
  }

  .page-explorer .form-profile-button {
    width: 100% !important;
  }
}

@media (max-width: 760px) {
  .page-explorer .stat-row {
    grid-template-columns: 2rem minmax(0, 1fr) 2.35rem !important;
    gap: 0.42rem !important;
  }

  .page-explorer .stat-track {
    width: calc(100% + 0.72rem) !important;
    margin-left: -0.72rem !important;
  }

  .page-explorer .detail-section.nested.category-held-item {
    padding-top: 1.15rem !important;
    margin-top: 0.55rem !important;
  }

  .page-explorer .stat-points-table td[data-label="Usage"] {
    justify-content: flex-end !important;
    justify-self: stretch !important;
    margin-left: 0 !important;
  }

  .page-explorer .battle-table .usage-meter,
  .page-explorer .nature-table .usage-meter {
    width: 80px !important;
    max-width: 80px !important;
  }

  .page-explorer .battle-table .usage-svg,
  .page-explorer .nature-table .usage-svg {
    width: 80px !important;
    max-width: 80px !important;
  }

  .page-explorer .stat-points-table .usage-meter {
    display: grid !important;
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto !important;
    row-gap: 0.18rem !important;
    width: 176px !important;
    max-width: 176px !important;
    margin-left: auto !important;
    margin-right: 0 !important;
    transform: none !important;
    justify-items: end !important;
  }

  .page-explorer .stat-points-table .usage-value {
    width: 100% !important;
    text-align: right !important;
    order: 2 !important;
    line-height: 1 !important;
  }

  .page-explorer .stat-points-table .usage-svg {
    order: 1 !important;
    width: 176px !important;
    max-width: 176px !important;
    transform: none !important;
  }

  .page-explorer .learnable-moves-table tr {
    grid-template-columns: minmax(70px, 1.2fr) minmax(46px, 0.78fr) minmax(34px, 0.48fr) minmax(34px, 0.48fr) minmax(34px, 0.48fr) minmax(28px, 0.38fr) !important;
  }

  .page-explorer .learnable-moves-table td[data-label="Type"] {
    transform: translateX(-4px) !important;
  }
}

.dialog-actions {
  position: absolute;
  top: 0.85rem;
  right: 0.85rem;
  z-index: 8;
  display: inline-flex;
  align-items: center;
  gap: 0.46rem;
}

.dialog-actions .close-button {
  position: static !important;
  inset: auto !important;
  margin: 0 !important;
}

.profile-favorite-button {
  color: var(--gold) !important;
}

.profile-favorite-button.active {
  border-color: rgba(240,207,115,0.48) !important;
  background: rgba(240,207,115,0.14) !important;
}

.move-info-button {
  display: inline-flex;
  align-items: center;
  max-width: 100%;
  padding: 0;
  border: 0;
  color: #f7f9fc;
  background: transparent;
  font: inherit;
  font-weight: 850;
  text-align: left;
  cursor: pointer;
}

.move-info-button:hover,
.move-info-button:focus-visible,
.move-info-button.active {
  color: var(--brand);
  outline: none;
}

.move-info-popover[hidden] {
  display: none !important;
}

.move-info-popover {
  position: fixed;
  z-index: 10020;
  width: min(280px, calc(100vw - 24px));
  padding: 0.72rem 0.78rem;
  border: 1px solid rgba(88,220,196,0.32);
  border-radius: 10px;
  color: #edf7ff;
  background: rgba(8, 14, 24, 0.98);
  box-shadow: 0 18px 42px rgba(0,0,0,0.38);
}

.move-info-popover strong,
.move-info-popover span {
  display: block;
}

.move-info-popover strong {
  margin-bottom: 0.3rem;
  color: var(--brand);
  font-size: 0.82rem;
}

.move-info-popover span {
  color: var(--muted);
  font-size: 0.8rem;
  line-height: 1.45;
}

.form-type-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.32rem;
  align-items: center;
}

.form-type-list .type-chip {
  min-height: 24px;
  padding: 0.22rem 0.46rem;
  font-size: 0.68rem;
}

.form-type-list .type-chip img {
  width: 14px;
  height: 14px;
}

.page-explorer input[type="search"]::-webkit-search-cancel-button {
  -webkit-appearance: none;
  width: 24px;
  height: 24px;
  margin-left: 0.35rem;
  border: 1px solid rgba(232, 238, 216, 0.22);
  border-radius: 8px;
  background:
    linear-gradient(45deg, transparent 43%, #f7f9fc 44%, #f7f9fc 56%, transparent 57%),
    linear-gradient(-45deg, transparent 43%, #f7f9fc 44%, #f7f9fc 56%, transparent 57%),
    rgba(255,255,255,0.08);
  cursor: pointer;
}

@media (max-width: 760px) {
  .page-explorer .search-help-close {
    width: 38px !important;
    height: 38px !important;
    font-size: 1.35rem !important;
  }

  .page-explorer .mobile-filter-toggle {
    font-size: 0.84rem !important;
    min-height: 54px !important;
    border: 1px solid rgba(214, 232, 218, 0.16) !important;
    border-radius: 16px !important;
    background: var(--control-surface) !important;
    box-shadow: none !important;
  }

  .page-explorer .dialog-actions {
    position: sticky !important;
    top: 0.6rem !important;
    z-index: 20 !important;
    display: flex !important;
    justify-content: flex-end !important;
    width: 100% !important;
    margin: 0.6rem 0 -42px !important;
    padding-right: 0.58rem !important;
  }

  .page-explorer .dialog-actions .close-button {
    position: static !important;
    float: none !important;
    width: 42px !important;
    height: 42px !important;
    margin: 0 !important;
    border-radius: 10px !important;
  }

  .page-explorer .dialog-actions .profile-favorite-button {
    width: 42px !important;
    height: 42px !important;
    align-self: center !important;
    display: grid !important;
    place-items: center !important;
    color: #ff7ab8 !important;
    font-size: 1.02rem !important;
    line-height: 1 !important;
  }

  .page-explorer .detail-art {
    margin-top: 1.45rem !important;
  }

  .page-explorer .forms-table td[data-label="Types"] {
    overflow-wrap: normal !important;
  }

  .page-explorer .forms-table td[data-label="Types"] .form-type-list {
    gap: 0.24rem !important;
  }

  .page-explorer .forms-table td[data-label="Types"] .type-chip {
    min-height: 23px !important;
    padding: 0.2rem 0.38rem !important;
    font-size: 0.66rem !important;
  }

  .page-explorer .forms-table td[data-label="Types"] .type-chip img {
    width: 13px !important;
    height: 13px !important;
  }

  .page-explorer .learnable-moves-wrap {
    overflow-anchor: none !important;
  }
}

/* Final API/mobile alignment refinements */
.favorite-heart-glyph {
  display: inline-block;
  color: #ff7ab8;
  line-height: 1;
  transform: scaleX(1.24) scaleY(0.94);
  transform-origin: center;
}

.page-explorer input[type="search"]::-webkit-search-cancel-button {
  width: 20px !important;
  height: 20px !important;
  border-radius: 7px !important;
  background:
    linear-gradient(45deg, transparent 45%, #f7f9fc 46%, #f7f9fc 54%, transparent 55%),
    linear-gradient(-45deg, transparent 45%, #f7f9fc 46%, #f7f9fc 54%, transparent 55%),
    rgba(255,255,255,0.08) !important;
}

.page-api .nav-shell,
.page-api .api-doc-page.api-main.section-shell {
  width: min(calc(100% - 28px), 1180px) !important;
}

.page-api .api-doc-hero .api-panel h1 {
  max-width: 900px !important;
  font-size: clamp(3rem, 5vw, 4.75rem) !important;
  line-height: 0.96 !important;
  letter-spacing: -0.075em !important;
}

@media (max-width: 760px) {
  .page-explorer .stat-points-table td[data-label="Usage"] {
    justify-content: flex-end !important;
    justify-self: end !important;
    text-align: right !important;
    padding: 0 !important;
    border: 0 !important;
  }

  .page-explorer .stat-points-table .usage-meter {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-end !important;
    gap: 0.2rem !important;
    width: 80px !important;
    min-width: 0 !important;
    max-width: 80px !important;
    margin-left: auto !important;
    margin-right: 0 !important;
    transform: none !important;
  }

  .page-explorer .stat-points-table .usage-value {
    order: initial !important;
    width: auto !important;
    min-width: 0 !important;
    color: var(--brand) !important;
    font-size: 0.74rem !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    text-align: right !important;
  }

  .page-explorer .stat-points-table .usage-svg {
    order: initial !important;
    width: 80px !important;
    min-width: 0 !important;
    max-width: 80px !important;
    height: 7px !important;
    flex: none !important;
    margin-left: auto !important;
    transform: none !important;
  }
}

@media (max-width: 620px) {
  .page-api .nav-shell,
  .page-api .api-doc-page.api-main.section-shell {
    width: min(calc(100% - 24px), 1180px) !important;
  }

  .page-api .api-doc-hero .api-panel h1 {
    font-size: clamp(2.45rem, 12.4vw, 3.9rem) !important;
    line-height: 0.96 !important;
    letter-spacing: -0.075em !important;
  }
}
@media (max-width: 760px) {
  .page-api .brand small {
    display: none !important;
  }
}

/* Final profile table typography alignment */
.page-explorer .moves-table td[data-label="Name"],
.page-explorer .moves-table td[data-label="Type"] {
  font-family: inherit !important;
  font-size: inherit !important;
  font-style: inherit !important;
  font-weight: inherit !important;
  color: inherit !important;
}

.page-explorer .moves-table .move-info-button,
.page-explorer .moves-table .move-type-label,
.page-explorer .moves-table .move-type-label span {
  font-family: inherit !important;
  font-size: inherit !important;
  font-style: inherit !important;
  font-weight: inherit !important;
  line-height: inherit !important;
  color: inherit !important;
  letter-spacing: inherit !important;
  text-transform: inherit !important;
}

@media (max-width: 760px) {
  .page-explorer .moves-table td[data-label="Name"],
  .page-explorer .moves-table td[data-label="Type"] {
    font-size: 0.85rem !important;
    font-weight: 650 !important;
    color: var(--text) !important;
  }
}

/* Final mobile search/filter control alignment */
@media (max-width: 760px) {
  .page-explorer .search-action-row {
    align-items: stretch !important;
  }

  .page-explorer .search-action-row .search-box,
  .page-explorer .mobile-filter-toggle {
    height: 54px !important;
    min-height: 54px !important;
    max-height: 54px !important;
    box-sizing: border-box !important;
    border: 1px solid var(--line) !important;
    border-radius: 16px !important;
  }

  .page-explorer .mobile-filter-toggle {
    align-self: stretch !important;
    background: var(--control-surface) !important;
    box-shadow: none !important;
  }

  .page-explorer .mobile-filter-toggle[aria-expanded="true"] {
    border-color: var(--line) !important;
    border-radius: 16px !important;
  }
}

.static-seo-content {
  padding-block: 1rem;
}

.static-seo-panel {
  margin-block: 1rem;
}

.static-seo-panel h1,
.static-seo-panel h2 {
  margin: 0 0 0.75rem;
  letter-spacing: -0.04em;
}

.static-seo-panel h1 {
  font-size: clamp(2rem, 4vw, 3.8rem);
  line-height: 1;
}

.static-seo-panel h2 {
  margin-top: 1.4rem;
  font-size: 1.22rem;
}

.static-seo-panel p {
  max-width: 860px;
  color: var(--muted);
  line-height: 1.68;
}

.static-seo-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 320px), 1fr));
  gap: 0.9rem;
  align-items: start;
}

.static-seo-table th,
.static-seo-table td {
  text-align: left;
  vertical-align: top;
}

.static-link-list {
  margin: 0;
  padding-left: 1.15rem;
  color: var(--muted);
  line-height: 1.75;
}

.static-link-list a,
.static-seo-table a {
  color: var(--brand);
  font-weight: 780;
}