/* Shared edge-scanner styles. Every page uses this CSS — keeps nav/banner/header consistent. */
:root {
  --bg:#0c0f14; --fg:#e6edf3;
  --acc:#3fb950; --warn:#f0883e; --dim:#8b949e; --red:#f85149; --blue:#79c0ff;
  --card:#1a1f29; --panel:#1f2937; --border:#2d3748;
}
* { box-sizing: border-box; }
html, body { height: auto; min-height: 100vh; overflow-y: auto; }
body {
  margin: 0;
  font: 14px/1.5 ui-monospace, SFMono-Regular, Menlo, monospace;
  background: var(--bg); color: var(--fg);
}

/* Banner — paper-mode notice */
.banner {
  background: linear-gradient(90deg, #1a2a4a, #142037);
  color: var(--blue);
  padding: 10px 22px;
  text-align: center;
  font-size: 13px;
  border-bottom: 1px solid var(--border);
}
.banner strong { color: var(--blue); }
.banner a { color: var(--acc); text-decoration: underline; }

/* Header — same on every page */
header {
  padding: 14px 22px;
  border-bottom: 1px solid #1f2937;
  display: flex;
  gap: 18px;
  align-items: center;
  flex-wrap: wrap;
}
header h1 {
  font-size: 18px;
  margin: 0;
  color: var(--acc);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 700;
  letter-spacing: -0.3px;
}
header h1 a { color: inherit; text-decoration: none; display: inline-flex; align-items: center; gap: 8px; }
nav { display: flex; gap: 4px; flex-wrap: wrap; }
nav a {
  color: var(--fg);
  text-decoration: none;
  padding: 6px 12px;
  border-radius: 6px;
  opacity: .75;
  font-size: 14px;
  transition: opacity .15s, background .15s, color .15s;
}
nav a:hover { opacity: 1; color: var(--acc); background: var(--panel); }
nav a.active { opacity: 1; color: var(--acc); background: var(--panel); }
header .ts { color: var(--dim); font-size: 12px; margin-left: auto; }

main { padding: 18px 22px; max-width: 1400px; margin: 0 auto; }

/* KPI cards (bankroll / CLV) */
.kpi {
  display: inline-block;
  margin-right: 14px; margin-bottom: 12px;
  padding: 12px 16px;
  background: var(--panel);
  border-radius: 8px;
  min-width: 150px;
  border: 1px solid var(--border);
}
.kpi .lbl { display: block; color: var(--dim); font-size: 11px; text-transform: uppercase; letter-spacing: .5px; }
.kpi .val { display: block; font-size: 22px; color: var(--acc); font-weight: 700; margin-top: 4px; }
.kpi .val.pos { color: var(--acc); }
.kpi .val.neg { color: var(--red); }

/* Tables */
table { width: 100%; border-collapse: collapse; border: 1px solid #1f2937; border-radius: 8px; overflow: hidden; }
th, td { padding: 8px 12px; border-bottom: 1px solid #1f2937; text-align: left; white-space: nowrap; }
th {
  color: var(--dim); font-weight: 500; font-size: 11px;
  text-transform: uppercase; letter-spacing: .5px;
  background: transparent;
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  user-select: none;
  padding: 10px 12px;
}
th:hover { color: var(--acc); background: transparent; }
th.active { color: var(--acc); background: transparent; }
th .arr { font-size: 9px; opacity: .4; margin-left: 4px; }
th.active .arr { opacity: 1; }
/* table outer border subtle, no rounded "card" look */
table { border: none; border-radius: 0; }
tbody td { border-bottom: 1px solid #1a1f29; }
tbody tr:hover { background: #11151c; }

/* Buttons / pills */
.pill {
  display: inline-block;
  padding: 2px 9px;
  border-radius: 10px;
  background: var(--panel);
  font-size: 11px;
  font-weight: bold;
}
.pill.edge, .edge { color: var(--acc); font-weight: bold; }
.pill.arb { color: var(--warn); font-weight: bold; }
.pill.stale { color: var(--blue); font-weight: bold; }
.neg { color: var(--red); font-weight: bold; }
.pos { color: var(--acc); font-weight: bold; }
.conf, .conf-lo { color: var(--dim); }
.conf-hi { color: var(--acc); font-weight: bold; }
.conf-mid { color: var(--warn); }

/* Search bar */
.toolbar { display: flex; flex-direction: column; align-items: center; gap: 8px; margin: 6px 0 14px; }
.search {
  background: var(--panel);
  border: 1px solid var(--border);
  color: var(--fg);
  padding: 10px 16px;
  border-radius: 8px;
  font: 14px ui-monospace;
  width: 100%;
  max-width: 520px;
  text-align: center;
}
.search:focus { outline: none; border-color: var(--acc); box-shadow: 0 0 0 3px rgba(63,185,80,.15); }
.count { color: var(--dim); font-size: 12px; text-align: center; }
.clear { color: var(--blue); text-decoration: none; font-size: 12px; margin-left: 10px; }
.clear:hover { text-decoration: underline; }

/* Lucide icons */
.ic { width: 14px; height: 14px; display: inline-block; vertical-align: -2px; stroke-width: 2; }
.ic.logo { width: 18px; height: 18px; color: var(--acc); }

/* Links */
.booklink { color: var(--fg); text-decoration: none; border-bottom: 1px dotted var(--dim); }
.booklink:hover { color: var(--acc); border-bottom-color: var(--acc); }
.detail { color: var(--blue); text-decoration: none; font-size: 16px; }
.detail:hover { filter: brightness(1.4); }

/* Intro panel (home page) */
.intro {
  background: linear-gradient(180deg, #16202c, #0c0f14);
  border: 1px solid #1f2937;
  border-radius: 10px;
  padding: 18px 22px;
  margin-bottom: 18px;
  line-height: 1.55;
}
.intro h2 { margin: 0 0 8px; font-size: 16px; color: var(--acc); }
.intro .legend { display: grid; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); gap: 12px; margin-top: 14px; }
.intro .legend .item { background: #11151c; padding: 10px 12px; border-radius: 6px; border: 1px solid #1f2937; }
.intro .legend .item b { display: block; color: var(--blue); margin-bottom: 4px; }
.intro .small { color: var(--dim); font-size: 12px; margin-top: 10px; }

@media (max-width: 720px) {
  nav a { padding: 5px 9px; font-size: 13px; }
  th, td { padding: 5px 7px; font-size: 12px; }
  .kpi { min-width: 130px; padding: 9px 12px; }
  header .ts { display: none; }
}
