/* Color tokens, reset, and body base come from theme.css — load it first. */
body { padding: 24px 16px 64px; }
.wrap { max-width: 720px; margin: 0 auto; }
.brand {
  display: flex; align-items: center; gap: 10px;
  font-weight: 700; font-size: 18px; color: var(--muted);
  margin-bottom: 16px;
}
.brand a { color: inherit; text-decoration: none; }
.brand .dot { font-size: 22px; }
.card {
  background: var(--card);
  border: 4px solid var(--line);
  border-radius: 14px;
  padding: 22px 24px;
  box-shadow: 0 2px 8px rgba(0,0,0,.04);
  margin-bottom: 20px;
}
h1 { font-size: 22px; margin: 0 0 4px; }
.meta {
  display: grid; grid-template-columns: auto 1fr; gap: 4px 14px;
  font-size: 14px; color: var(--muted); margin: 14px 0 0;
}
.meta b { color: var(--ink); font-weight: 600; }
.pill {
  display: inline-block; padding: 2px 10px; border-radius: 999px;
  font-size: 12px; font-weight: 700; background: var(--red-soft); color: var(--red);
  border: 4px solid var(--red);
}
.pill.med { background: var(--amber-soft); color: var(--amber); border-color: var(--amber); }
.pill.low { background: var(--accent-soft); color: var(--accent); border-color: var(--accent); }
.subject { font-weight: 700; font-size: 16px; margin: 18px 0 8px; }
blockquote {
  margin: 0; padding: 14px 16px; border-left: 4px solid var(--accent);
  background: var(--accent-soft); border-radius: 0 10px 10px 0; font-size: 15px;
}
.signed { display: block; margin-top: 8px; font-style: italic; color: var(--muted); }
.q { margin-bottom: 22px; }
.q h3 { font-size: 16px; margin: 0 0 10px; }
.opt {
  display: block; border: 1.5px solid var(--line); border-radius: 10px;
  padding: 11px 14px; margin-bottom: 8px; cursor: pointer;
  transition: border-color .15s, background .15s; font-size: 14.5px;
}
.opt:hover { border-color: #ccc8ef; }
.opt input { margin-right: 10px; accent-color: var(--accent); }
.opt.sel { border-color: var(--accent); background: var(--accent-soft); }
.opt.correct { border-color: var(--green); background: var(--green-soft); }
.opt.wrong { border-color: var(--red); background: var(--red-soft); }
.opt .tag { float: right; font-weight: 700; font-size: 13px; }
.opt.correct .tag { color: var(--green); }
.opt.wrong .tag { color: var(--red); }
button {
  background: var(--accent); color: #fff; border: 0; border-radius: 10px;
  padding: 12px 22px; font-size: 15px; font-weight: 700; cursor: pointer;
}
button:hover { filter: brightness(1.06); }
button.ghost { background: transparent; color: var(--accent); border: 1.5px solid var(--accent); margin-left: 10px; }
.result { margin-top: 18px; }
.banner {
  border-radius: 12px; padding: 18px 20px; font-size: 16px; font-weight: 600;
  display: flex; align-items: center; gap: 12px;
}
.banner .ico { font-size: 28px; }
.banner.win { background: var(--green-soft); color: var(--green); border: 1.5px solid var(--green); }
.banner.fail { background: var(--red-soft); color: var(--red); border: 1.5px solid var(--red); }
.explain {
  margin-top: 12px; font-size: 14px; background: #f9f8ff;
  border: 1px solid var(--line); border-radius: 10px; padding: 12px 15px;
}
.explain p { margin: 0 0 10px; }
.explain p:last-child { margin: 0; }
.note {
  margin-top: 12px; font-style: italic; color: var(--muted);
  border-left: 3px solid #ccc8ef; padding-left: 12px;
}
.hidden { display: none; }

/* ---- Ticket queue (index) ---- */
.lead { color: var(--muted); margin: 0 0 20px; font-size: 15px; }
.queue { list-style: none; padding: 0; margin: 0; }
.ticket-row {
  display: flex; align-items: center; gap: 14px;
  background: var(--card); border: 4px solid var(--line); border-radius: 12px;
  padding: 16px 18px; margin-bottom: 12px; text-decoration: none; color: var(--ink);
  transition: border-color .15s, transform .05s;
}
.ticket-row:hover { border-color: #ccc8ef; transform: translateY(-1px); }
.ticket-row .id { font-weight: 700; color: var(--muted); font-size: 14px; min-width: 56px; }
.ticket-row .body { flex: 1; }
.ticket-row .body .t { font-weight: 700; font-size: 15px; }
.ticket-row .body .s { font-size: 13px; color: var(--muted); }
.status {
  font-size: 12px; font-weight: 700; padding: 4px 11px; border-radius: 999px;
  white-space: nowrap; border: 4px solid;
}
.status.open { background: var(--accent-soft); color: var(--accent); border-color: var(--accent); }
.status.resolved { background: var(--green-soft); color: var(--green); border-color: var(--green); }
.queue-foot { margin-top: 18px; font-size: 13px; color: var(--muted); }
.queue-foot button { font-size: 13px; padding: 7px 14px; }

/* ---- Dark mode: override hardcoded light fills (tokens flip via theme.css) ---- */
html[data-theme="dark"] .opt:hover,
html[data-theme="dark"] .ticket-row:hover { border-color: #4a4170; }
html[data-theme="dark"] .explain { background: #1b1726; }
html[data-theme="dark"] .note { border-left-color: #4a4170; }
