/* ======================================================================
   CreechDex Companion — styles
   Palette + font sampled from the game (apps/client/src/typography.ts Ink
   tokens + scene art): VT323 pixel font, dark navy panels, cream textboxes,
   gold accents.
   ====================================================================== */

/* VT323 — the game's pixel/terminal font (apps/client loads it the same way,
   from Google Fonts). Falls back to local install / monospace when offline. */
@import url("https://fonts.googleapis.com/css2?family=VT323&display=swap");

:root {
  /* Ink tokens (from typography.ts) */
  --ink-primary: #f8f8f8;
  --ink-secondary: #cccccc;
  --ink-muted: #888888;
  --ink-gold: #f8d020;
  --ink-blue: #aaddff;
  --ink-good: #58e070;
  --ink-bad: #ff8844;
  --ink-overlay: #28303f;
  --ink-remote: #88ffcc;
  --ink-hint: #8a92a8;

  /* Panel palette (sampled from scene art — deep navy game UI) */
  --bg: #11151f;
  --bg-grad-top: #161d2d;
  --panel: #1c2434;
  --panel-2: #232c40;
  --panel-line: #3a4660;
  --panel-edge: #0a0d14;
  --gold-edge: #b9941c;

  /* Cream textbox (dialog box look) */
  --cream: #f4ecd6;
  --cream-line: #c9bd96;
  --cream-ink: #2a2418;

  --font: "VT323", "Courier New", monospace;
}

* { box-sizing: border-box; }

html { background: var(--bg); }

body {
  margin: 0;
  font-family: var(--font);
  font-size: 22px;
  line-height: 1.35;
  color: var(--ink-primary);
  background:
    radial-gradient(circle at 50% -10%, var(--bg-grad-top), var(--bg) 60%) fixed;
  -webkit-font-smoothing: none;
  image-rendering: pixelated;
  letter-spacing: 0.3px;
}

img { image-rendering: pixelated; }

a { color: var(--ink-blue); text-decoration: none; }
a:hover { color: var(--ink-gold); text-decoration: underline; }

.wrap { max-width: 1100px; margin: 0 auto; padding: 0 18px 80px; }

/* ---------------- Top bar ---------------- */
.topbar {
  position: sticky; top: 0; z-index: 50;
  background: linear-gradient(180deg, #0c1018, #141b29);
  border-bottom: 3px solid var(--gold-edge);
  box-shadow: 0 4px 0 #00000055;
}
.topbar-inner {
  max-width: 1100px; margin: 0 auto; padding: 10px 18px;
  display: flex; align-items: center; gap: 18px; flex-wrap: wrap;
}
.brand { display: flex; align-items: baseline; gap: 10px; }
.brand .logo { font-size: 30px; color: var(--ink-gold); text-shadow: 2px 2px 0 #000; }
.brand .sub { font-size: 16px; color: var(--ink-hint); }
.nav { display: flex; gap: 4px; flex-wrap: wrap; margin-left: auto; }
.nav a {
  color: var(--ink-secondary); padding: 4px 12px; border-radius: 3px;
  font-size: 20px;
}
.nav a:hover, .nav a.active { background: var(--panel-2); color: var(--ink-gold); text-decoration: none; }

.spoiler-global {
  display: flex; align-items: center; gap: 8px;
  font-size: 16px; color: var(--ink-hint); cursor: pointer;
  border: 1px solid #3a445c; padding: 3px 9px; border-radius: 3px; background: #161d2c;
}
.spoiler-global:hover { border-color: var(--ink-gold); color: var(--ink-secondary); }
.spoiler-global input { accent-color: var(--ink-gold); }

/* ---------------- Panels ---------------- */
.panel {
  background: linear-gradient(180deg, var(--panel), var(--panel-2));
  border: 2px solid #3a4660;
  border-top-color: #4b597a;
  border-radius: 5px;
  box-shadow: 0 3px 0 var(--panel-edge), inset 0 1px 0 #ffffff10;
  padding: 16px 18px;
  margin: 18px 0;
}
.panel h2, .panel h3 { margin-top: 0; }

h1 { font-size: 40px; color: var(--ink-gold); text-shadow: 2px 2px 0 #000; margin: 22px 0 4px; }
h2 { font-size: 28px; color: var(--ink-primary); border-bottom: 2px solid #3a4660; padding-bottom: 4px; }
h3 { font-size: 23px; color: var(--ink-blue); }
.lede { color: var(--ink-secondary); font-size: 22px; max-width: 760px; }
.muted { color: var(--ink-muted); }
.hint { color: var(--ink-hint); font-size: 17px; }
.crumb { font-size: 17px; color: var(--ink-hint); margin: 16px 0 0; }
.crumb a { color: var(--ink-hint); }

/* ---------------- Cream textbox ---------------- */
.textbox {
  background: var(--cream);
  border: 3px solid var(--cream-line);
  border-radius: 4px;
  box-shadow: inset 0 0 0 2px #ffffffaa, 0 3px 0 #00000055;
  color: var(--cream-ink);
  padding: 12px 16px;
  font-size: 22px;
}
.textbox .speaker { color: #7a5a12; font-size: 18px; display: block; margin-bottom: 2px; }
.textbox.draft::after {
  content: "draft copy"; float: right; font-size: 13px; color: #9b8c5e;
}

/* ---------------- Hero / title ---------------- */
.hero {
  margin: 22px 0;
  border: 3px solid var(--gold-edge);
  border-radius: 6px;
  background: #0b0f18 center/cover no-repeat;
  position: relative; overflow: hidden;
  box-shadow: 0 5px 0 #00000066;
}
.hero .hero-bg { width: 100%; display: block; opacity: 0.55; }
.hero .hero-text {
  position: absolute; inset: 0; display: flex; flex-direction: column;
  justify-content: center; align-items: center; text-align: center; padding: 20px;
  background: radial-gradient(circle at 50% 50%, #00000022, #000000aa);
}
.hero .title { font-size: 56px; color: var(--ink-gold); text-shadow: 3px 3px 0 #000, 0 0 18px #f8d02055; margin: 0; }
.hero .tag { font-size: 24px; color: var(--cream); text-shadow: 2px 2px 0 #000; }
.hero .region { font-size: 18px; color: var(--ink-remote); margin-top: 6px; }

/* ---------------- Card grids ---------------- */
.grid { display: grid; gap: 12px; }
.dex-grid { grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); }
.tile-grid { grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); }

.card {
  background: linear-gradient(180deg, #1d263a, #161d2c);
  border: 2px solid #36415c; border-radius: 5px;
  padding: 10px; text-align: center; color: var(--ink-primary);
  box-shadow: 0 2px 0 var(--panel-edge);
  transition: transform .08s, border-color .08s;
}
.card:hover { transform: translateY(-2px); border-color: var(--ink-gold); text-decoration: none; }
.card .num { font-size: 15px; color: var(--ink-hint); }
.card .sprite { width: 96px; height: 96px; object-fit: contain; margin: 2px auto; display: block; }
.card .cname { font-size: 21px; color: var(--ink-primary); }
.card.area { text-align: left; }
.card.area .role { font-size: 16px; color: var(--ink-hint); display: block; }

/* ---------------- Type badges ---------------- */
.types { display: flex; gap: 5px; justify-content: center; flex-wrap: wrap; }
.type {
  display: inline-block; font-size: 15px; line-height: 1; padding: 4px 9px;
  border-radius: 3px; color: #fff; text-shadow: 1px 1px 0 #00000099;
  border: 1px solid #00000055; text-transform: uppercase; letter-spacing: 1px;
}
.t-normal{background:#9099a1}.t-fire{background:#e6622e}.t-water{background:#3a8ad6}
.t-grass{background:#5ca935}.t-electric{background:#e0b021}.t-ice{background:#69c6c6}
.t-fighting{background:#bb392f}.t-poison{background:#9a489a}.t-ground{background:#c2933b}
.t-flying{background:#8aa6e0}.t-psychic{background:#e0568a}.t-bug{background:#9aa522}
.t-rock{background:#b09a4e}.t-ghost{background:#6a5896}.t-dragon{background:#6a48d6}
.t-dark{background:#4e4438}.t-steel{background:#8a96a6}.t-fairy{background:#e090c0}
.t-none{background:#566}

/* ---------------- Infobox ---------------- */
.detail-head { display: flex; gap: 22px; flex-wrap: wrap; align-items: flex-start; }
.infobox {
  flex: 0 0 280px; background: #161d2c; border: 2px solid #3a4660; border-radius: 6px;
  padding: 14px; text-align: center; box-shadow: 0 3px 0 var(--panel-edge);
}
.infobox .big-sprite {
  width: 192px; height: 192px; object-fit: contain; margin: 0 auto 6px;
  image-rendering: pixelated; display: block;
  background: radial-gradient(circle at 50% 60%, #2a344c, transparent 70%);
}
.infobox .dexno { color: var(--ink-hint); font-size: 18px; }
.infobox .iname { font-size: 30px; color: var(--ink-gold); }
.infobox table { width: 100%; border-collapse: collapse; margin-top: 10px; font-size: 18px; }
.infobox td { padding: 3px 4px; text-align: left; border-bottom: 1px solid #2a3346; }
.infobox td.k { color: var(--ink-hint); width: 45%; }
.detail-body { flex: 1 1 420px; min-width: 320px; }

/* ---------------- Stat bars ---------------- */
.stats { font-size: 18px; }
.stat-row { display: grid; grid-template-columns: 56px 44px 1fr; align-items: center; gap: 8px; margin: 4px 0; }
.stat-row .lbl { color: var(--ink-hint); }
.stat-row .val { color: var(--ink-primary); text-align: right; }
.bar { height: 14px; background: #0d1320; border: 1px solid #2a3346; border-radius: 2px; overflow: hidden; }
.bar > span { display: block; height: 100%; }
.s-lo{background:#e0563f}.s-mid{background:#e0b021}.s-hi{background:#5ca935}.s-vhi{background:#3ad6a0}
.stat-total { color: var(--ink-gold); margin-top: 4px; font-size: 19px; }

/* ---------------- Tables ---------------- */
table.data { width: 100%; border-collapse: collapse; font-size: 18px; margin: 6px 0; }
table.data th { text-align: left; color: var(--ink-gold); border-bottom: 2px solid #3a4660; padding: 5px 8px; font-weight: normal; }
table.data td { padding: 5px 8px; border-bottom: 1px solid #232c40; }
table.data tr:hover td { background: #1a2233; }
.lvl { color: var(--ink-blue); }
.pill { font-size: 14px; padding: 1px 7px; border-radius: 10px; border: 1px solid #3a4660; color: var(--ink-hint); }
.cat-physical{color:#e6884e}.cat-special{color:#6aa6e0}.cat-status{color:#aab}

.rarity-common{color:#9099a1}.rarity-uncommon{color:#5ca935}.rarity-rare{color:#6aa6e0}.rarity-veryrare{color:#e0568a}

.mini-sprite { width: 40px; height: 40px; object-fit: contain; vertical-align: middle; margin-right: 6px; }
.team { display: flex; gap: 10px; flex-wrap: wrap; }
.team .mon {
  background: #161d2c; border: 1px solid #36415c; border-radius: 5px;
  padding: 6px 8px; text-align: center; min-width: 92px;
}
.team .mon img { width: 64px; height: 64px; object-fit: contain; display: block; margin: 0 auto; }
.team .mon .mlvl { font-size: 15px; color: var(--ink-hint); }

.portrait { width: 120px; height: 120px; object-fit: cover; border: 2px solid var(--gold-edge); border-radius: 6px; float: right; margin: 0 0 10px 14px; }

/* ---------------- Spoiler gating ---------------- */
.spoiler {
  position: relative; border: 2px dashed #6a5896; border-radius: 6px;
  background: #1a1626; padding: 14px; margin: 14px 0;
}
.spoiler > .spoiler-content { transition: filter .15s, opacity .15s; }
.spoiler:not(.revealed) > .spoiler-content {
  filter: blur(7px); opacity: 0.45; user-select: none; pointer-events: none;
}
.spoiler-toggle {
  display: inline-flex; align-items: center; gap: 8px; cursor: pointer;
  font-size: 18px; color: #d8c0ff; background: #2a2140; border: 1px solid #6a5896;
  border-radius: 4px; padding: 5px 12px; margin-bottom: 10px;
}
.spoiler-toggle:hover { background: #382a55; color: #fff; }
.spoiler.revealed .spoiler-toggle { color: var(--ink-hint); background: #20283a; border-color: #3a4660; }
.spoiler-warn { font-size: 20px; }

/* Whole-card spoiler veil for dex tiles / area-of-interest */
.veil { position: relative; }
.veil.hidden-spoiler .veil-body { filter: blur(8px); opacity: .4; }
.veil .veil-tag {
  position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
  text-align: center; font-size: 15px; color: #d8c0ff; cursor: pointer;
  background: #1a162688; border: 1px dashed #6a5896; border-radius: 5px;
}
.veil:not(.hidden-spoiler) .veil-tag { display: none; }

/* ---------------- Search ---------------- */
.search-wrap { margin: 14px 0; position: relative; }
#dexsearch, #globalsearch {
  width: 100%; font-family: var(--font); font-size: 21px; color: var(--ink-primary);
  background: #0d1320; border: 2px solid #3a4660; border-radius: 5px; padding: 8px 12px;
}
#dexsearch:focus, #globalsearch:focus { outline: none; border-color: var(--ink-gold); }
.search-results {
  position: absolute; left: 0; right: 0; top: 100%; z-index: 30; margin-top: 4px;
  background: #141b29; border: 2px solid #3a4660; border-radius: 5px; max-height: 360px;
  overflow-y: auto; display: none;
}
.search-results.open { display: block; }
.search-results a { display: flex; gap: 8px; align-items: center; padding: 6px 10px; color: var(--ink-secondary); }
.search-results a:hover { background: var(--panel-2); text-decoration: none; }
.search-results img { width: 32px; height: 32px; object-fit: contain; }
.search-results .kind { margin-left: auto; font-size: 14px; color: var(--ink-hint); }

/* ---------------- Misc layout helpers ---------------- */
.cols { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 14px; }
.kvlist { list-style: none; padding: 0; margin: 0; }
.kvlist li { padding: 3px 0; border-bottom: 1px solid #232c40; }
.kvlist .k { color: var(--ink-hint); }
.tag-row { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }
.dexentry { font-size: 23px; }
.conn { display: flex; gap: 8px; flex-wrap: wrap; }
.conn a { background: #1d263a; border: 1px solid #36415c; border-radius: 4px; padding: 4px 10px; font-size: 18px; }
.beat { border-left: 3px solid var(--gold-edge); padding: 4px 0 4px 14px; margin: 12px 0; }
.beat .bnum { color: var(--ink-gold); font-size: 19px; }
footer { color: var(--ink-hint); font-size: 16px; text-align: center; padding: 30px 0 0; border-top: 1px solid #232c40; margin-top: 40px; }

@media (max-width: 640px) {
  body { font-size: 20px; }
  .nav { width: 100%; }
  .infobox { flex: 1 1 100%; }
}
