/* Markdown Styles — used by both info page and challenge details */
.markdown h1 { font-size: 2rem; margin: 2rem 0 1rem; }
.markdown h2 { font-size: 1.5rem; margin: 1.75rem 0 0.75rem; border-bottom: 1px solid var(--border); padding-bottom: 0.5rem; }
.markdown h3 { font-size: 1.2rem; margin: 1.5rem 0 0.5rem; }
.markdown p  { margin-bottom: 1rem; color: var(--text-dim); }
.markdown strong { color: var(--text); }

.markdown a { color: var(--accent); }
.markdown a:hover { text-decoration: underline; }

.markdown ul, .markdown ol { padding-left: 1.5rem; margin-bottom: 1rem; }
.markdown ul { list-style: disc; }
.markdown ol { list-style: decimal; }
.markdown li { margin-bottom: 0.4rem; color: var(--text-dim); }
.markdown li::marker { color: var(--accent); }

.markdown img { max-width: 100%; border-radius: var(--radius); }

.markdown code {
  background: rgba(59, 130, 246, 0.1);
  padding: 0.15em 0.35em;
  border-radius: 4px;
  font-size: 0.9em;
  color: var(--accent);
}

.markdown pre {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow-x: auto;
  margin-bottom: 1rem;
}

.markdown pre code {
  display: block;
  padding: 1rem;
  background: none;
  color: var(--text);
}

.markdown table { width: 100%; border-collapse: collapse; margin-bottom: 1rem; }
.markdown th { background: var(--bg-card); text-align: left; font-weight: 600; }
.markdown th, .markdown td { padding: 0.5rem 0.75rem; border: 1px solid var(--border); font-size: 0.875rem; }
.markdown td { color: var(--text-dim); }

.markdown blockquote {
  border-left: 3px solid var(--accent);
  padding: 0.5rem 1rem;
  margin: 1rem 0;
  color: var(--text-dim);
}

.markdown hr {
  border: none;
  border-top: 1px solid var(--border);
  margin: 1.5rem 0;
}
