:root {
  --bg: #0f1320;
  --card: #1a2030;
  --line: #2a3145;
  --fg: #e7ebf3;
  --muted: #97a0b5;
  --accent: #4363d8;
}
* { box-sizing: border-box; }
body {
  margin: 0;
  font: 15px/1.5 -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  background: var(--bg);
  color: var(--fg);
}
.wrap { max-width: 1000px; margin: 0 auto; padding: 32px 20px 80px; }
h1 { margin: 0 0 4px; }
h2 { margin: 32px 0 12px; font-size: 18px; }
.sub, .meta, .hint { color: var(--muted); }
.meta { margin-top: 0; }
code, .mono { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; }
a.back { color: var(--accent); text-decoration: none; }

.card { background: var(--card); border: 1px solid var(--line); border-radius: 12px; padding: 20px; }
.upload { display: flex; gap: 12px; align-items: center; margin: 20px 0; }
.upload input[type=file] { flex: 1; color: var(--fg); }
button {
  background: var(--accent); color: #fff; border: 0; border-radius: 8px;
  padding: 10px 18px; font-size: 15px; cursor: pointer;
}
button:hover { filter: brightness(1.1); }

table { width: 100%; border-collapse: collapse; background: var(--card); border-radius: 12px; overflow: hidden; }
th, td { text-align: left; padding: 10px 12px; border-bottom: 1px solid var(--line); }
th { color: var(--muted); font-weight: 600; font-size: 13px; }
.games tr { cursor: pointer; }
.games tr:hover td { background: #222a3d; }
.ai { color: var(--muted); font-size: 12px; border: 1px solid var(--line); border-radius: 4px; padding: 0 4px; }

.badge { padding: 2px 10px; border-radius: 999px; font-size: 13px; font-weight: 600; white-space: nowrap; }
.v-чисто { background: #1f3a2a; color: #6ee7a0; }
.v-подозрительно { background: #3a341f; color: #ffd866; }
.v-читер { background: #3a1f24; color: #ff7a8a; }
.v-ИИ { background: #232838; color: var(--muted); }

.findings { list-style: none; padding: 0; }
.findings li { background: var(--card); border: 1px solid var(--line); border-radius: 10px; padding: 10px 14px; margin-bottom: 8px; }
.findings .sev { color: var(--muted); font-size: 13px; margin-left: 6px; }
.clean { color: #6ee7a0; }

canvas { background: var(--card); border: 1px solid var(--line); border-radius: 12px; padding: 12px; }

.loader { position: fixed; inset: 0; background: rgba(8,10,18,.8); display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 16px; color: var(--fg); }
.loader.hidden { display: none; }
.spinner { width: 48px; height: 48px; border: 5px solid var(--line); border-top-color: var(--accent);
  border-radius: 50%; animation: spin 1s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
