/* TBH Market Observer — "Arcane Terminal" theme.
   Warm-obsidian base + molten-gold primary + arcane-violet secondary.
   Display/sans/mono font trio, layered tinted shadows, grain texture. */

@import url("https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,500;12..96,600;12..96,700;12..96,800&family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@500;600;700&display=swap");

:root {
  /* ---- surfaces: a real base -> raised -> floating layering system ---- */
  --bg: #09070e;
  --surface-base: #110d1a;
  --surface-raised: #17121f;
  --surface-float: #1d1726;
  --row-alt: rgba(255, 255, 255, .018);

  /* ---- hairlines ---- */
  --line: rgba(233, 226, 245, .085);
  --line-soft: rgba(233, 226, 245, .05);
  --line-strong: rgba(233, 226, 245, .16);

  /* ---- ink ---- */
  --ink: #ece7f3;
  --ink-dim: #9b93ac;
  --ink-faint: #645c77;

  /* ---- brand: molten gold (primary), derived tints ---- */
  --ember: #f0a838;
  --ember-bright: #ffc869;
  --ember-deep: #d4842a;
  --ember-soft: rgba(240, 168, 56, .14);
  --ember-line: rgba(240, 168, 56, .34);

  /* ---- secondary: arcane violet (focus / cool accents) ---- */
  --arcane: #8b7bf2;
  --arcane-bright: #a99bff;
  --arcane-soft: rgba(139, 123, 242, .15);
  --arcane-line: rgba(139, 123, 242, .4);

  /* ---- semantic (harmonized with GRADE_COLORS in gear_db.js) ---- */
  --accent: var(--ember);
  --accent-2: var(--arcane);
  --ok: #57d172;
  --stale: #e8c24a;
  --bad: #f2545f;

  /* ---- type ---- */
  --display: "Bricolage Grotesque", "Inter", system-ui, sans-serif;
  --sans: "Inter", "Segoe UI", system-ui, -apple-system, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, "Cascadia Code", Consolas, monospace;

  /* ---- radii ---- */
  --r-sm: 9px;
  --r-md: 13px;
  --r-lg: 17px;
  --r-xl: 22px;

  /* ---- spacing scale ---- */
  --sp-1: 4px; --sp-2: 8px; --sp-3: 12px; --sp-4: 16px;
  --sp-5: 22px; --sp-6: 30px; --sp-7: 44px; --sp-8: 64px;

  /* ---- motion ---- */
  --ease-spring: cubic-bezier(.34, 1.4, .5, 1);
  --ease-out: cubic-bezier(.22, .72, .2, 1);
  --t-fast: .14s;
  --t-med: .22s;

  /* ---- layered, color-tinted shadows ---- */
  --sh-1: 0 1px 2px rgba(0, 0, 0, .35);
  --sh-card:
    inset 0 1px 0 rgba(255, 255, 255, .035),
    0 2px 6px -2px rgba(0, 0, 0, .5),
    0 20px 44px -20px rgba(6, 3, 14, .85);
  --sh-float:
    inset 0 1px 0 rgba(255, 255, 255, .05),
    0 4px 12px -4px rgba(0, 0, 0, .55),
    0 28px 64px -16px rgba(0, 0, 0, .7);
  --sh-ember: 0 6px 22px -7px rgba(240, 168, 56, .5);
  --sh-arcane: 0 0 0 3px var(--arcane-soft);

  --maxw: 1180px;
  --footer-reserve: 170px;
}

* { box-sizing: border-box; }
[hidden] { display: none !important; }
html, body { height: 100%; }
body {
  margin: 0; background: var(--bg); color: var(--ink);
  font-family: var(--sans); font-size: 13px; line-height: 1.55;
  min-height: 100%;
  -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
  background-image:
    radial-gradient(1100px 520px at 84% -12%, rgba(139, 123, 242, .14), transparent 60%),
    radial-gradient(900px 460px at 4% -6%, rgba(240, 168, 56, .09), transparent 58%),
    radial-gradient(760px 700px at 96% 108%, rgba(139, 123, 242, .07), transparent 60%);
  background-attachment: fixed;
  padding-bottom: var(--footer-reserve);
}
/* fine grain for depth — soft-light blended SVG noise, fixed overlay */
body::before {
  content: ""; position: fixed; inset: 0; z-index: -1; pointer-events: none;
  opacity: .5; mix-blend-mode: soft-light;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
body.dragging::after {
  content: ""; position: fixed; inset: 12px; z-index: 80;
  border: 2px dashed var(--ember); border-radius: var(--r-xl);
  background: var(--ember-soft); pointer-events: none;
}

::selection { background: rgba(240, 168, 56, .28); color: #fff; }
:focus-visible { outline: none; }

/* ---- site header ---- */
.site-header {
  position: sticky; top: 0; z-index: 40;
  border-bottom: 1px solid var(--line);
  background: linear-gradient(180deg, rgba(13, 10, 20, .9), rgba(10, 8, 16, .72));
  backdrop-filter: blur(14px) saturate(1.4);
  -webkit-backdrop-filter: blur(14px) saturate(1.4);
}
.site-header-inner {
  max-width: var(--maxw); margin: 0 auto; padding: 13px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: var(--sp-4);
}
.brand { display: flex; align-items: center; gap: 13px; }
.brand-mark {
  position: relative; display: grid; place-items: center;
  width: 44px; height: 44px; flex: none;
  border-radius: 13px; color: var(--ember-bright);
  background:
    radial-gradient(120% 120% at 30% 12%, rgba(240, 168, 56, .35), transparent 60%),
    linear-gradient(160deg, #221a30, #120e1c);
  border: 1px solid var(--ember-line);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .08), 0 8px 20px -10px rgba(240, 168, 56, .55);
}
.brand-text h1 {
  margin: 0; font-family: var(--display); font-size: 18px; font-weight: 700;
  letter-spacing: -.02em; line-height: 1.05;
  background: linear-gradient(100deg, #fff 30%, #d9cfee);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.subtitle { margin: 3px 0 0; color: var(--ink-dim); font-size: 12px; }
.data-credit { margin: 3px 0 0; color: var(--ink-faint); font-size: 11px; }
.head-link {
  color: var(--ember); text-decoration: none;
  border-bottom: 1px solid transparent; transition: border-color var(--t-fast);
}
.head-link:hover { border-bottom-color: var(--ember); }
.icon-btn {
  background: var(--surface-raised); border: 1px solid var(--line); color: var(--ink-dim);
  width: 39px; height: 39px; border-radius: 11px; cursor: pointer; flex: none;
  display: grid; place-items: center;
  transition: color var(--t-fast), border-color var(--t-fast),
              transform var(--t-fast) var(--ease-spring), box-shadow var(--t-med);
}
.icon-btn:hover { color: var(--ember-bright); border-color: var(--ember-line); transform: translateY(-1px); }
.icon-btn:active { transform: translateY(0); }
.icon-btn:focus-visible { border-color: var(--arcane); box-shadow: var(--sh-arcane); color: var(--ink); }
.gear-icon {
  width: 20px; height: 20px; display: block;
  background: url("/data/settings_gear.png") center / contain no-repeat;
  opacity: .72;
}
.icon-btn:hover .gear-icon, .icon-btn:focus-visible .gear-icon { opacity: 1; }

/* ---- site nav ---- */
.site-nav { display: flex; gap: 3px; flex: 1; justify-content: center; }
.nav-link {
  position: relative; padding: 8px 15px; border-radius: 10px; text-decoration: none;
  color: var(--ink-dim); font-weight: 600; font-size: 13px; letter-spacing: -.005em;
  transition: color var(--t-fast), background var(--t-fast);
}
.nav-link:hover { color: var(--ink); background: rgba(255, 255, 255, .04); }
.nav-link:focus-visible { color: var(--ink); box-shadow: var(--sh-arcane); }
.nav-link.active { color: #fff; }
.nav-link.active::after {
  content: ""; position: absolute; left: 14px; right: 14px; bottom: 1px; height: 2px;
  border-radius: 2px; background: linear-gradient(90deg, var(--ember), var(--ember-bright));
  box-shadow: 0 0 10px rgba(240, 168, 56, .7);
}

/* ---- placeholder pages ---- */
.placeholder {
  margin-top: var(--sp-6); padding: 72px 32px; text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: var(--sp-4);
}
.placeholder-icon {
  width: 90px; height: 90px; border-radius: var(--r-xl); display: grid; place-items: center;
  color: var(--ember); border: 1px solid var(--line);
  background: radial-gradient(circle at 50% 32%, var(--ember-soft), transparent 70%), var(--surface-raised);
  box-shadow: var(--sh-card);
}
.placeholder .badge {
  font-size: 11px; letter-spacing: .9px; text-transform: uppercase; font-weight: 700;
  color: var(--ember-bright); background: var(--ember-soft); border: 1px solid var(--ember-line);
  padding: 4px 12px; border-radius: 999px;
}
.placeholder h2 { margin: 4px 0 0; font-family: var(--display); font-size: 25px; letter-spacing: -.02em; }
.placeholder p { margin: 0; color: var(--ink-dim); max-width: 480px; line-height: 1.7; }

@media (prefers-reduced-motion: reduce) {
  .btn.primary:hover:not(:disabled) { transform: none; }
  .btn.primary:hover:not(:disabled)::after { animation: none; }
}

/* ---- site footer ---- */
.site-footer {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 35;
  border-top: 1px solid var(--line);
  background: rgba(8, 6, 13, .94);
  backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
}
.footer-inner {
  max-width: var(--maxw); margin: 0 auto; padding: 16px 24px 14px;
  text-align: center; color: var(--ink-dim); font-size: 11.5px; line-height: 1.5;
}
.footer-inner p { margin: 3px 0; }
.footer-credit { margin-top: 5px; }
.foot-link {
  color: var(--ink); text-decoration: none;
  border-bottom: 1px solid transparent; transition: color var(--t-fast), border-color var(--t-fast);
}
.foot-link:hover { color: var(--ember); border-bottom-color: var(--ember); }
.foot-link.tg { color: #4cb4f0; display: inline-flex; align-items: center; gap: 4px; }
.foot-link.tg:hover { color: #6fc8ff; border-bottom-color: #6fc8ff; }
.tg-ico { flex: none; }
.footer-inner .dot { opacity: .4; margin: 0 5px; }
.claude-credit { display: inline-flex; align-items: center; vertical-align: -2px; margin-left: 5px; color: #d97757; }
.claude-spark { flex: none; }

/* ---- footer mascots (animated pixel sprites standing on the divider line) ---- */
.footer-mascots {
  position: absolute; left: 50%; top: 1px;
  transform: translate(-50%, -100%);
  display: flex; align-items: flex-end; gap: 16px;
  pointer-events: none; z-index: 2;
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, .6));
}
.mascot {
  flex: none; display: block;
  background-repeat: no-repeat;
  image-rendering: pixelated; image-rendering: crisp-edges;
  pointer-events: auto; cursor: pointer;
}
.mascot.sorcerer {
  width: 61px; height: 55px;
  background-image: url(/static/img/mascots/sorcerer.png);
  background-size: 976px 55px;
  animation: mascot-sorcerer 1.033s steps(16) infinite;
}
.mascot.hunter {
  width: 80px; height: 54px;
  background-image: url(/static/img/mascots/hunter.png);
  background-size: 1920px 54px;
  animation: mascot-hunter 2.05s steps(24) infinite;
}
.mascot.ranger {
  width: 67px; height: 55px;
  background-image: url(/static/img/mascots/ranger.png);
  background-size: 1072px 55px;
  animation: mascot-ranger 1.033s steps(16) infinite;
}
.mascot.skeleton {
  width: 40px; height: 44px;
  margin-bottom: 16px;
  background-image: url(/static/img/mascots/burning_skeleton.png);
  background-size: 960px 44px;
  animation: mascot-skeleton 2.133s steps(24) infinite, mascot-bob 2.4s ease-in-out infinite;
}
@keyframes mascot-sorcerer { from { background-position: 0 0; } to { background-position: -976px 0; } }
@keyframes mascot-hunter   { from { background-position: 0 0; } to { background-position: -1920px 0; } }
@keyframes mascot-ranger   { from { background-position: 0 0; } to { background-position: -1072px 0; } }
@keyframes mascot-skeleton { from { background-position: 0 0; } to { background-position: -960px 0; } }
@keyframes mascot-bob { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-4px); } }

/* flying pixel hearts spawned on mascot click (see mascots.js) */
.heart-burst-layer { position: fixed; inset: 0; overflow: hidden; pointer-events: none; z-index: 9999; }
.heart-particle { position: absolute; width: 26px; height: 22px; will-change: transform, opacity; }
.heart-particle svg { width: 100%; height: 100%; display: block; filter: drop-shadow(0 1px 1px rgba(0, 0, 0, .45)); }
/* rare coin drop (1/10 on mascot click) — Arcana-rarity glow, a bit larger than hearts */
.coin-particle {
  position: absolute; width: 68px; height: 68px;
  will-change: transform, opacity; image-rendering: pixelated; image-rendering: crisp-edges;
  filter: drop-shadow(0 0 4px rgba(162, 59, 240, .95)) drop-shadow(0 0 9px rgba(162, 59, 240, .6));
}
.coin-particle img { width: 100%; height: 100%; display: block; }

.rare-banner {
  position: fixed; inset: 0; z-index: 9998; display: grid; place-items: center;
  padding: 20px; pointer-events: none; background: rgba(4, 3, 8, .62);
  animation: rare-banner-show 2s ease both;
}
.rare-banner img {
  display: block; max-width: min(760px, 92vw); max-height: 78vh; border-radius: 14px;
  border: 1px solid var(--ember-line); box-shadow: 0 22px 70px rgba(0, 0, 0, .72), var(--sh-ember);
}
@keyframes rare-banner-show {
  0%, 100% { opacity: 0; transform: scale(.96); }
  10%, 88% { opacity: 1; transform: scale(1); }
}

@media (max-width: 520px) {
  .footer-mascots { gap: 9px; transform: translate(-50%, -100%) scale(.82); transform-origin: bottom center; }
}
@media (prefers-reduced-motion: reduce) {
  .mascot { animation-play-state: paused !important; }
  .mascot.skeleton { animation: none; }
}

/* ---- decorative butterfly next to the settings button (128x48 sprite, 2 frames) ---- */
.butterfly {
  flex: none; display: block; width: 20px; height: 15px;
  background: url(/static/img/mascots/butterfly.png) no-repeat;
  background-size: 40px 15px;
  image-rendering: pixelated; image-rendering: crisp-edges;
  pointer-events: none;
  filter: drop-shadow(0 0 3px rgba(139, 123, 242, .85)) drop-shadow(0 0 6px rgba(139, 123, 242, .5));
  animation: butterfly-flap .28s steps(2) infinite, butterfly-float 4s ease-in-out infinite;
}
@keyframes butterfly-flap  { from { background-position: 0 0; } to { background-position: -40px 0; } }
@keyframes butterfly-float { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-7px); } }
@media (prefers-reduced-motion: reduce) { .butterfly { animation: none; } }

/* ---- page container ---- */
.page {
  max-width: var(--maxw); margin: 0 auto; padding: var(--sp-5) 24px var(--sp-7);
  display: flex; flex-direction: column; gap: var(--sp-4);
}
#loadedState { display: flex; flex-direction: column; gap: var(--sp-4); }
.card {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .015), transparent 120px),
    var(--surface-base);
  border: 1px solid var(--line);
  border-radius: var(--r-lg); box-shadow: var(--sh-card);
}

/* ---- empty / drop state ---- */
.dropzone {
  display: flex; flex-direction: column; align-items: center; text-align: center;
  gap: var(--sp-3); padding: 66px 28px; margin-top: var(--sp-5);
  background:
    radial-gradient(560px 240px at 50% 0%, var(--ember-soft), transparent 70%),
    var(--surface-base);
  border: 1.5px dashed var(--line-strong);
  border-radius: var(--r-xl);
  transition: border-color var(--t-med), transform var(--t-med) var(--ease-out);
}
.dropzone:hover { border-color: var(--ember-line); }
.dropzone-icon {
  width: 86px; height: 86px; border-radius: 50%; display: grid; place-items: center;
  color: var(--ember); background: radial-gradient(circle, var(--ember-soft), transparent 70%);
  border: 1px solid var(--ember-line); margin-bottom: 4px;
}
.dropzone h2 { margin: 0; font-family: var(--display); font-size: 22px; letter-spacing: -.02em; }
.dropzone-hint { margin: 0; color: var(--ink-dim); max-width: 460px; line-height: 1.7; }
.dropzone .btn { margin-top: 8px; padding: 11px 24px; }
.dropzone-note { margin: 6px 0 0; color: var(--ink-faint); font-size: 12px; max-width: 480px; }

/* ---- controls card ---- */
.controls { padding: 15px 16px; display: flex; flex-direction: column; gap: var(--sp-3); }
.controls-actions { display: flex; flex-wrap: wrap; gap: 9px; align-items: center; }
.controls-filters {
  display: flex; flex-wrap: wrap; gap: 10px; align-items: center;
  padding-top: var(--sp-3); border-top: 1px solid var(--line-soft);
}
.controls-filters .search { margin-left: auto; }
.controls-actions .search { margin-left: auto; }
.db-subtitle { margin: 0; color: var(--ink-dim); font-size: 13px; line-height: 1.6; }
.db-empty { margin: 18px 4px; text-align: center; color: var(--ink-dim); font-size: 14px; }

/* ---- scan state (replaces the old manual scan button) ---- */
.scan-state { display: flex; flex-wrap: wrap; gap: 10px 16px; align-items: center; }
.scan-banner[hidden] { display: none; }
.scan-banner {
  display: inline-flex; align-items: center; gap: 9px;
  padding: 8px 15px; border-radius: 999px; font-weight: 700; font-size: 13.5px;
  letter-spacing: -.005em; color: #1a1206;
  background: linear-gradient(100deg, var(--ember), var(--ember-bright));
  border: 1px solid var(--ember-line);
  box-shadow: 0 0 0 0 rgba(240, 168, 56, .55);
  animation: scan-pulse 1.6s var(--ease-out) infinite;
}
.scan-dot {
  width: 9px; height: 9px; border-radius: 50%;
  background: #1a1206; box-shadow: 0 0 6px rgba(26, 18, 6, .5);
  animation: scan-blink 1s steps(1) infinite;
}
.last-check { margin: 0; color: var(--ink-dim); font-size: 13px; line-height: 1.6; }
@keyframes scan-pulse {
  0%   { box-shadow: 0 0 0 0 rgba(240, 168, 56, .55); }
  70%  { box-shadow: 0 0 0 12px rgba(240, 168, 56, 0); }
  100% { box-shadow: 0 0 0 0 rgba(240, 168, 56, 0); }
}
@keyframes scan-blink { 0%, 50% { opacity: 1; } 51%, 100% { opacity: .25; } }

.btn {
  background: var(--surface-raised); border: 1px solid var(--line); color: var(--ink);
  padding: 9px 15px; border-radius: var(--r-sm); cursor: pointer; font: inherit; font-weight: 550;
  transition: background var(--t-fast), border-color var(--t-fast), color var(--t-fast),
              transform var(--t-fast) var(--ease-spring), box-shadow var(--t-med);
  white-space: nowrap;
}
.btn:hover:not(:disabled):not(.primary) { border-color: var(--arcane-line); background: rgba(139, 123, 242, .1); transform: translateY(-1px); }
.btn:active:not(:disabled) { transform: translateY(0); }
.btn:focus-visible { outline: none; border-color: var(--arcane); box-shadow: var(--sh-arcane); }
.btn:disabled { opacity: .38; cursor: default; }
.btn.primary {
  position: relative; overflow: hidden;
  background: linear-gradient(180deg, var(--ember-bright), var(--ember-deep));
  color: #2a1604; border: none; font-weight: 700; letter-spacing: -.005em;
  box-shadow: var(--sh-ember), inset 0 1px 0 rgba(255, 255, 255, .4);
}
.btn.primary::after {
  content: ""; position: absolute; top: 0; left: -60%; width: 45%; height: 100%;
  transform: skewX(-20deg); pointer-events: none; opacity: 0;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, .5), transparent);
}
.btn.primary:hover:not(:disabled) {
  filter: brightness(1.05); transform: translateY(-1px);
  box-shadow: 0 10px 26px -8px rgba(240, 168, 56, .6), inset 0 1px 0 rgba(255, 255, 255, .45);
}
.btn.primary:hover:not(:disabled)::after { animation: btn-sheen .6s ease; }
.btn.primary:active:not(:disabled) { transform: translateY(0); box-shadow: var(--sh-ember); }
.btn.primary:focus-visible { box-shadow: var(--sh-arcane), var(--sh-ember); }
@keyframes btn-sheen {
  0% { left: -60%; opacity: 0; }
  18% { opacity: 1; }
  100% { left: 130%; opacity: 0; }
}
.btn.ghost { color: var(--ink-dim); }

/* ---- grade filter buttons ---- */
.filter-bar { flex-direction: row; flex-wrap: wrap; align-items: center; gap: 10px; }
.filter-bar .grade-filter { flex: 1 1 auto; }
.filter-bar .search { margin-left: auto; }
.grade-filter { display: flex; flex-wrap: wrap; gap: 7px; align-items: center; }
.grade-btn {
  --gc: #888;
  background: var(--surface-raised); border: 1.5px solid color-mix(in srgb, var(--gc) 55%, transparent);
  color: var(--gc);
  padding: 5px 12px; border-radius: var(--r-sm); cursor: pointer; font: inherit;
  font-size: 12.5px; font-weight: 600; line-height: 1; opacity: .5;
  transition: opacity var(--t-fast), background var(--t-fast), box-shadow var(--t-med),
              transform var(--t-fast) var(--ease-spring);
}
.grade-btn:hover { opacity: .9; transform: translateY(-1px); }
.grade-btn:focus-visible { outline: none; opacity: 1; box-shadow: 0 0 0 3px color-mix(in srgb, var(--gc) 28%, transparent); }
.grade-btn.on {
  opacity: 1; color: color-mix(in srgb, var(--gc) 75%, #fff);
  background: color-mix(in srgb, var(--gc) 22%, var(--surface-raised));
  box-shadow: 0 0 0 1px var(--gc) inset, 0 4px 14px -6px var(--gc);
}

.ctl { display: inline-flex; align-items: center; gap: 7px; color: var(--ink-dim); }
.ctl.block { display: flex; gap: 9px; margin: 8px 0 16px; }
.search {
  background: var(--surface-raised); border: 1px solid var(--line); color: var(--ink);
  padding: 9px 12px; border-radius: var(--r-sm); font: inherit; min-width: 230px;
  transition: border-color var(--t-fast), box-shadow var(--t-med), background var(--t-fast);
}
.search::placeholder { color: var(--ink-faint); }
.search:hover { border-color: var(--line-strong); }
.search:focus { outline: none; border-color: var(--arcane); box-shadow: var(--sh-arcane); }

select {
  appearance: none; -webkit-appearance: none;
  font: inherit; color: var(--ink); cursor: pointer;
  padding: 9px 32px 9px 13px; border: 1px solid var(--line); border-radius: var(--r-sm);
  background-color: var(--surface-raised);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8'%3E%3Cpath d='M1 1.5l5 5 5-5' fill='none' stroke='%239b93ac' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 11px center; background-size: 11px;
  transition: border-color var(--t-fast), background-color var(--t-fast), box-shadow var(--t-med);
}
select:hover { border-color: var(--line-strong); background-color: var(--surface-float); }
select:focus { outline: none; border-color: var(--arcane); box-shadow: var(--sh-arcane); }
select option { background: var(--surface-float); color: var(--ink); }

/* ---- scrollbars ---- */
* { scrollbar-width: thin; scrollbar-color: #352c48 transparent; }
.table-wrap { scrollbar-color: #352c48 transparent; }
.table-wrap::-webkit-scrollbar, .modal-box::-webkit-scrollbar { width: 11px; height: 11px; }
.table-wrap::-webkit-scrollbar-track, .modal-box::-webkit-scrollbar-track { background: transparent; }
.table-wrap::-webkit-scrollbar-thumb, .modal-box::-webkit-scrollbar-thumb {
  background: #332a45; border-radius: 8px; border: 2px solid var(--surface-base); background-clip: padding-box;
}
.table-wrap::-webkit-scrollbar-thumb:hover, .modal-box::-webkit-scrollbar-thumb:hover { background: #463a5e; }
.table-wrap::-webkit-scrollbar-corner { background: transparent; }

/* ---- stat band ---- */
.stat-band { display: grid; grid-template-columns: 1.6fr 1fr 1fr; gap: var(--sp-4); }
.stat {
  position: relative; overflow: hidden;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .02), transparent 80px),
    var(--surface-base);
  border: 1px solid var(--line); border-radius: var(--r-md);
  padding: 16px 19px; display: flex; flex-direction: column; gap: 3px;
  box-shadow: var(--sh-card);
}
.stat-hero {
  background:
    radial-gradient(440px 200px at 0% 0%, rgba(240, 168, 56, .14), transparent 62%),
    var(--surface-base);
  border-color: var(--ember-line);
}
.stat-hero::after {
  content: ""; position: absolute; top: -1px; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, var(--ember), transparent 70%);
}
.stat-label {
  font-size: 11px; text-transform: uppercase; letter-spacing: .8px; font-weight: 600; color: var(--ink-faint);
}
.stat-value {
  font-size: 27px; font-weight: 700; font-variant-numeric: tabular-nums;
  font-family: var(--mono); letter-spacing: -.5px; line-height: 1.15;
}
.stat-hero .stat-value { color: var(--ok); }
#statTotal { color: var(--ok); }
.stat-sub { font-size: 12px; color: var(--ink-dim); min-height: 16px; }

/* ---- table ---- */
.table-card { overflow: hidden; }
.progress { height: 2px; width: 0; background: var(--ember); transition: width .2s var(--ease-out); opacity: 0; }
.progress.on { opacity: 1; box-shadow: 0 0 10px var(--ember); }
.table-wrap { overflow: auto; max-height: calc(100vh - 360px); min-height: 220px; }
#tbl { width: 100%; border-collapse: collapse; }
#tbl thead th {
  position: sticky; top: 0; z-index: 3;
  background: linear-gradient(180deg, var(--surface-raised), var(--surface-base));
  text-align: left; padding: 12px; font-size: 11px; letter-spacing: .5px;
  text-transform: uppercase; font-weight: 600; color: var(--ink-dim);
  border-bottom: 1px solid var(--line); cursor: pointer; user-select: none; white-space: nowrap;
  transition: color var(--t-fast);
}
#tbl thead th[data-col]:hover { color: var(--ember-bright); }
#tbl thead th.sort-asc::after { content: " ▲"; color: var(--ember); font-size: 9px; }
#tbl thead th.sort-desc::after { content: " ▼"; color: var(--ember); font-size: 9px; }
#tbl thead th.c-icon, #tbl thead th:first-child { cursor: default; }
#tbl tbody td { padding: 8px 12px; border-bottom: 1px solid var(--line-soft); white-space: nowrap; }
#tbl tbody tr:last-child td { border-bottom: none; }
#tbl tbody tr:nth-child(even) { background: var(--row-alt); }
#tbl tbody tr { transition: background var(--t-fast); }
#tbl tbody tr:hover { background: rgba(139, 123, 242, .07); }
.mono { font-family: var(--mono); font-variant-numeric: tabular-nums; }
.c-name { width: 100%; }
.c-id, .c-lvl, .c-qty, .c-low, .c-vol { text-align: right; }
.c-grade { font-weight: 600; }
.c-type { color: var(--ink-dim); }
.c-low { font-weight: 600; }
.muted { color: var(--ink-faint); font-style: italic; font-weight: 400; }
.c-upd { text-align: center; font-weight: 700; }
.c-upd .upd-mark { display: block; line-height: 1.1; }
.c-upd .upd-time { display: block; font-size: 10px; font-weight: 500; color: var(--ink-faint); letter-spacing: .2px; margin-top: 1px; }
.f-ok { color: var(--ok); } .f-stale { color: var(--stale); } .f-bad { color: var(--bad); }
#tbl tbody tr { cursor: default; }

/* signature: rarity glow behind each icon */
.c-icon { width: 54px; }
.icon-wrap {
  position: relative; display: grid; place-items: center;
  width: 36px; height: 36px; border-radius: var(--r-sm); cursor: help;
}
.icon-wrap::before {
  content: ""; position: absolute; inset: -3px; border-radius: 10px;
  background: radial-gradient(circle at 50% 45%, var(--glow), transparent 70%);
  opacity: .45; filter: blur(2px); transition: opacity var(--t-med), transform var(--t-med) var(--ease-out);
}
tr:hover .icon-wrap::before { opacity: .75; transform: scale(1.1); }
.icon-wrap img { position: relative; width: 30px; height: 30px; image-rendering: -webkit-optimize-contrast; }

/* ---- status line ---- */
.status-line { margin: 2px 4px 0; color: var(--ink-dim); font-size: 12px; min-height: 18px; }
.status-line.err { color: var(--bad); }

/* ---- stats card (hover) — floating layer ---- */
.stats-card {
  position: fixed; z-index: 90; width: 300px; max-width: calc(100vw - 32px);
  background: var(--surface-float); border: 1px solid var(--line-strong); border-radius: var(--r-md);
  box-shadow: var(--sh-float); padding: 14px; pointer-events: none;
  opacity: 0; transform: translateY(6px) scale(.98);
  transition: opacity var(--t-fast), transform var(--t-med) var(--ease-spring);
}
.stats-card.show { opacity: 1; transform: translateY(0) scale(1); }
.card-head { display: flex; gap: 11px; align-items: center; margin-bottom: 10px; }
.card-icon { position: relative; width: 44px; height: 44px; display: grid; place-items: center; border-radius: 10px; flex: none; }
.card-icon::before {
  content: ""; position: absolute; inset: -3px; border-radius: 12px;
  background: radial-gradient(circle, var(--glow), transparent 70%); opacity: .5; filter: blur(3px);
}
.card-icon img { position: relative; width: 38px; height: 38px; }
.card-name { font-family: var(--display); font-weight: 700; font-size: 14.5px; letter-spacing: -.01em; }
.card-sub { color: var(--ink-dim); font-size: 12px; margin-top: 2px; }
.card-loading { color: var(--ink-faint); font-style: italic; padding: 6px 0; }
.card-block { border-top: 1px solid var(--line); padding-top: 8px; margin-top: 8px; }
.card-block-h { font-size: 10px; text-transform: uppercase; letter-spacing: .5px; color: var(--ink-faint); margin-bottom: 5px; }
.card-stat { display: flex; justify-content: space-between; gap: 12px; padding: 1px 0; }
.card-stat b { font-family: var(--mono); color: var(--ok); }
.card-note { color: var(--ink-dim); font-size: 11.5px; margin-bottom: 2px; }
.stat-tier {
  font-size: 9px; font-weight: 700; letter-spacing: .3px; color: var(--ember);
  background: var(--ember-soft); border-radius: 4px; padding: 1px 4px;
  font-family: var(--sans); vertical-align: middle;
}
.stat-chance { font-size: 10px; color: var(--ink-faint); font-family: var(--mono); }
.card-chips { display: flex; gap: 6px; flex-wrap: wrap; }
.chip { display: inline-flex; align-items: center; gap: 4px; background: var(--surface-raised); border: 1px solid var(--line); border-radius: 7px; padding: 2px 7px; font-size: 11px; color: var(--ink-dim); }
.chip-icon { width: 14px; height: 14px; object-fit: contain; }
.card-foot { margin-top: 9px; font-size: 11px; font-weight: 600; }
.card-foot.yes { color: var(--ok); } .card-foot.no { color: var(--bad); }

/* ---- settings modal — floating layer ---- */
.modal { position: fixed; inset: 0; z-index: 100; display: none; }
.modal.show { display: block; animation: modal-in .2s var(--ease-out); }
.modal-backdrop { position: absolute; inset: 0; background: rgba(6, 4, 12, .68); backdrop-filter: blur(4px); }
.modal-box {
  position: relative; margin: 8vh auto 0; width: min(540px, 92vw); max-height: 84vh; overflow: auto;
  background: var(--surface-float); border: 1px solid var(--line-strong); border-radius: var(--r-xl); padding: 26px 28px;
  box-shadow: var(--sh-float);
  animation: modalbox-in .26s var(--ease-spring);
}
@keyframes modal-in { from { opacity: 0; } to { opacity: 1; } }
@keyframes modalbox-in { from { opacity: 0; transform: translateY(14px) scale(.97); } to { opacity: 1; transform: translateY(0) scale(1); } }
.modal-box h2 { margin: 0 0 14px; font-family: var(--display); letter-spacing: -.02em; }
.settings-controls { display: flex; align-items: flex-end; gap: 12px; margin: 8px 0 16px; }
.settings-controls .ctl.block { flex: 1; margin: 0; align-items: flex-start; flex-direction: column; }
.settings-controls select { width: 100%; }
.modal-box h3 { margin: 4px 0 8px; font-size: 14px; color: var(--ink); font-family: var(--display); }
.about-body { color: var(--ink-dim); line-height: 1.6; white-space: pre-line; margin: 0 0 18px; }
.about-body .about-sections { list-style: none; margin: 2px 0 18px; padding: 0; white-space: normal; display: grid; gap: 10px; }
.about-body .about-sections li {
  position: relative; padding: 12px 14px 12px 16px;
  background: var(--surface-raised); border: 1px solid var(--line); border-radius: var(--r-md);
  color: var(--ink-dim); font-size: 13px; line-height: 1.55;
  border-left: 3px solid var(--ember);
}
.about-body .about-sec { color: var(--ember-bright); font-weight: 700; }

/* ---- site-wide status banner ---- */
.status-banner { border-bottom: 1px solid var(--line); }
.status-banner-inner {
  max-width: var(--maxw); margin: 0 auto; padding: 9px 24px;
  display: flex; align-items: center; gap: 9px; font-size: 12.5px; line-height: 1.4;
}
.status-banner-ico { flex: none; }
.status-banner-text { flex: 1; }
.status-banner-close {
  flex: none; background: none; border: none; color: inherit; opacity: .55;
  font-size: 18px; line-height: 1; cursor: pointer; padding: 0 2px; transition: opacity var(--t-fast), transform var(--t-fast) var(--ease-spring);
}
.status-banner-close:hover { opacity: 1; transform: scale(1.15); }
.status-banner.level-info { background: var(--arcane-soft); color: var(--arcane-bright); border-bottom-color: var(--arcane-line); }
.status-banner.level-warning { background: rgba(232, 194, 74, .1); color: var(--stale); border-bottom-color: rgba(232, 194, 74, .28); }
.status-banner.level-danger { background: rgba(242, 84, 95, .12); color: #f99098; border-bottom-color: rgba(242, 84, 95, .3); }

/* ---- grade composition bar (Inventory · Items shown) ---- */
.grade-bar { display: flex; width: 100%; height: 7px; border-radius: 4px; overflow: hidden; margin-top: 8px; box-shadow: inset 0 0 0 1px rgba(0, 0, 0, .3); }
.grade-bar i { display: block; height: 100%; }
.grade-legend { display: flex; gap: 9px; margin-top: 7px; flex-wrap: wrap; }
.grade-legend span { display: flex; align-items: center; gap: 3px; font-size: 9.5px; color: var(--ink-faint); }
.grade-legend .sw { width: 7px; height: 7px; border-radius: 50%; display: inline-block; flex: none; }

/* ---- market movers page ---- */
.movers-title { margin: 0; font-family: var(--display); font-size: 17px; font-weight: 700; letter-spacing: -.02em; }
.movers-meta { color: var(--ink-faint); font-size: 12px; margin-left: auto; font-family: var(--mono); }
.movers-cols { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-4); }
.movers-col { overflow: hidden; padding: 0; }
.movers-col-head {
  display: flex; align-items: baseline; gap: 8px; padding: 13px 15px;
  font-size: 11px; text-transform: uppercase; letter-spacing: .7px; font-weight: 700;
  border-bottom: 1px solid var(--line-soft);
}
.movers-col-head.up { color: var(--ok); background: linear-gradient(180deg, rgba(87, 209, 114, .08), transparent); }
.movers-col-head.down { color: var(--bad); background: linear-gradient(180deg, rgba(242, 84, 95, .08), transparent); }
.movers-col-sub { color: var(--ink-faint); font-size: 10px; font-weight: 500; letter-spacing: .3px; text-transform: none; }
.movers-list { display: flex; flex-direction: column; }
.movers-row {
  display: grid; grid-template-columns: 40px minmax(0, 1fr) auto; align-items: center; gap: 10px;
  padding: 9px 15px; border-bottom: 1px solid var(--line-soft); cursor: default;
  transition: background var(--t-fast);
}
.movers-row:last-child { border-bottom: none; }
.movers-row:hover { background: rgba(139, 123, 242, .07); }
.movers-name { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.movers-item { font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.movers-grade { font-size: 11px; font-weight: 600; }
.movers-num { display: flex; flex-direction: column; align-items: flex-end; gap: 2px; white-space: nowrap; }
.movers-price { font-weight: 600; font-family: var(--mono); }
.movers-delta { font-size: 10px; font-weight: 700; border-radius: 5px; padding: 1px 5px; font-family: var(--mono); }
.movers-delta.up { color: var(--ok); background: rgba(87, 209, 114, .13); }
.movers-delta.down { color: var(--bad); background: rgba(242, 84, 95, .13); }
.movers-none { color: var(--ink-dim); font-size: 13px; text-align: center; padding: 22px 8px; margin: 0; }

/* ---- leaderboard ---- */
.lb-auth { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-4); width: 100%; }
.lb-account { display: flex; flex-direction: column; gap: 10px; min-width: 0; }
.lb-who { color: var(--ink-dim); }
.lb-who .lb-name { color: var(--ember-bright); font-weight: 700; }
.lb-actions { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.btn.lb-logout { color: var(--ink-dim); text-decoration: none; }
.btn.lb-logout:hover:not(:disabled) { color: var(--ink); border-color: var(--arcane-line); background: rgba(139, 123, 242, .1); }
.lb-avatar {
  flex: none; display: block; width: 56px; height: 56px; border-radius: 12px;
  overflow: hidden; border: 1px solid var(--line); background: var(--surface-raised);
  transition: border-color var(--t-fast), box-shadow var(--t-med), transform var(--t-fast) var(--ease-spring);
}
.lb-avatar:hover { border-color: var(--ember-line); box-shadow: 0 0 0 3px var(--ember-soft); transform: translateY(-1px); }
.lb-avatar img { width: 100%; height: 100%; display: block; object-fit: cover; }
.lb-subrow { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: 12px; }
.lb-subrow .db-subtitle { margin: 0; }
.btn.steam-btn {
  display: inline-flex; align-items: center; gap: 9px; text-decoration: none;
  color: #2a1604; padding: 10px 19px; text-transform: uppercase;
  letter-spacing: .6px; font-weight: 700; font-size: 13px;
}
.btn.steam-btn .steam-logo { flex: none; }
.lb-table thead th { cursor: default; }
.lb-table .c-rank { width: 56px; text-align: right; color: var(--ink-dim); font-weight: 700; font-family: var(--mono); }
.lb-table .c-player { width: 100%; }
.lb-table .c-items { text-align: right; color: var(--ink-dim); font-family: var(--mono); }
.lb-table .c-value { text-align: right; font-weight: 600; white-space: nowrap; font-family: var(--mono); }
.lb-table .player-name { vertical-align: middle; }
a.player-name { color: var(--ink); text-decoration: none; transition: color var(--t-fast); }
a.player-name:hover { color: var(--ember); text-decoration: underline; }
.lb-top td { font-weight: 600; }
.lb-top-1 .c-rank { color: #f0c850; }
.lb-top-2 .c-rank { color: #cfd6e0; }
.lb-top-3 .c-rank { color: #d0883e; }
.lb-top-1 .c-value { color: #f0c850; }

/* ---- responsive ---- */
@media (max-width: 820px) {
  .stat-band { grid-template-columns: 1fr 1fr; }
  .stat-hero { grid-column: 1 / -1; }
  .controls-filters .search { margin-left: 0; flex: 1 1 100%; }
  .movers-cols { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
  :root { --footer-reserve: 230px; }
  .site-header-inner { flex-wrap: wrap; padding-left: 14px; padding-right: 14px; }
  .page { padding-left: 14px; padding-right: 14px; }
  .status-banner-inner { padding-left: 14px; padding-right: 14px; }
  .site-nav { order: 3; flex: 1 1 100%; justify-content: flex-start; gap: 2px; overflow-x: auto; }
  .nav-link { padding: 7px 11px; }
  .stat-band { grid-template-columns: 1fr; }
  .subtitle { display: none; }
  .c-vol, .c-type { display: none; }
  .table-wrap { max-height: none; }
  .footer-inner { padding: 12px 12px 10px; font-size: 10.5px; line-height: 1.4; }
  .settings-controls { align-items: stretch; flex-direction: column; }
}
