/* bountynet-genesis docs — tactical HUD retheme
 *
 * Palette shifts toward near-black + lime accents (Gemini reference),
 * retaining cs16.css dialog chrome where it's working. Typography
 * splits: system-ui for body readability, VT323 for UI/code/headings
 * to keep the CRT vibe on things that benefit from it.
 *
 * Load order:
 *   1. cs16.min.css (CDN) — dialog chrome, buttons, inputs
 *   2. this file     — palette overrides, typography split, new components
 */

@import url('https://fonts.googleapis.com/css2?family=VT323&family=JetBrains+Mono:wght@400;600&display=swap');

/* =============================================================
 * Design tokens
 * ============================================================= */
:root {
  /* Backgrounds */
  --bg:            #0b0d08;
  --bg-panel:      #11140d;
  --bg-inset:      #070802;
  --bg-data:       #050601;

  /* Borders */
  --border-dark:   #000000;
  --border-mid:    #1a1f12;
  --border-light:  #2b3022;

  /* Text */
  --text:          #f0f1eb;     /* ivory — primary body */
  --text-2:        #d8ded3;     /* secondary body */
  --text-dim:      rgba(222, 223, 214, 0.62);
  --text-3:        #7a8572;     /* tertiary metadata */

  /* Accents */
  --accent:        #c4b550;     /* cs16 gold — primary UI accent */
  --accent-glow:   #e6d661;     /* high-vis gold for active/focus */
  --accent-lime:   #a3e635;     /* tactical lime — LIVE state only */
  --accent-lime-d: #5a8f1f;
  --accent-error:  #d46a5f;

  /* Monochrome glow shadow for active chips */
  --glow-lime:     0 0 10px rgba(163, 230, 53, 0.35),
                   0 0 2px rgba(163, 230, 53, 0.6);
  --glow-gold:     0 0 8px rgba(230, 214, 97, 0.25);
}

/* =============================================================
 * Base / reset / typography split
 * ============================================================= */
body {
  background: var(--bg);
  margin: 0;
  padding: 0;
  min-height: 100vh;
  color: var(--text);
  /* Body = system sans for longform readability */
  font-family: system-ui, -apple-system, "Segoe UI", Roboto,
               "Helvetica Neue", Arial, sans-serif;
  font-size: 15px;
  font-weight: 400;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  position: relative;
  overflow-x: hidden;
}

/* UI elements = VT323 for the tactical HUD feel */
.cs-btn,
.cs-input,
.cs-select,
.heading .text,
summary .text,
.cs-checkbox__label,
.cs-input__label,
.label,
legend,
.vx-label,
.vx-copy,
.vx-rail-link,
.verify-phase-label,
#verify-phase,
#verify-count,
.verify-result-label {
  font-family: "VT323", "Courier New", monospace;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* Monospace for code blocks and hex data */
code, pre, .vx-hex, .verify-result-hex, .vx-data-block {
  font-family: "JetBrains Mono", "VT323", "Courier New", monospace;
}

/* Headings */
h1, h2, h3 {
  font-family: "VT323", "Courier New", monospace;
  font-weight: 400;
  letter-spacing: 0.04em;
  text-transform: none;
  color: var(--text);
  margin: 0.6em 0 0.4em;
}

/* =============================================================
 * Background Value X watermark — hex dump drifting behind content
 * ============================================================= */
.vx-watermark {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
  white-space: pre;
  font-family: "JetBrains Mono", "VT323", monospace;
  font-size: 12px;
  line-height: 14px;
  color: var(--border-light);
  opacity: 0.25;
  user-select: none;
  animation: vx-drift 140s linear infinite;
}

@keyframes vx-drift {
  from { transform: translateY(0); }
  to   { transform: translateY(-40%); }
}

.page {
  position: relative;
  z-index: 1;
  max-width: 980px;
  margin: 0 auto;
  padding: 28px 20px 72px;
  display: flex;
  flex-direction: column;
  gap: 22px;
}

/* =============================================================
 * cs-dialog — force inline stacking + content color overrides
 * ============================================================= */
.cs-dialog[open] {
  position: static;
  display: block;
  margin: 0;
  max-width: 100%;
  box-shadow: 8px 8px 0 rgba(0, 0, 0, 0.55),
              0 0 0 1px var(--border-mid);
}

.cs-dialog form {
  max-width: 100%;
}

/* =============================================================
 * <details> styled like a <dialog> — collapsible deep dives
 * ============================================================= */
details.cs-dialog {
  display: block;
  margin: 0;
  padding: 0;
  background: var(--bg-panel);
  border: 2px solid var(--border-dark);
  border-top-color: var(--border-light);
  border-left-color: var(--border-light);
  box-shadow: 4px 4px 0 rgba(0, 0, 0, 0.55);
  color: var(--text);
}

details.cs-dialog > summary {
  list-style: none;
  cursor: pointer;
  user-select: none;
  padding: 0 10px;
  margin: 0;
  background: linear-gradient(to bottom, #1d2318 0%, #0f1209 100%);
  color: var(--text-2);
  border-bottom: 1px solid var(--border-dark);
  display: flex;
  align-items: center;
  min-height: 30px;
  font-weight: normal;
  transition: filter 120ms ease;
}

details.cs-dialog > summary:hover {
  filter: brightness(1.25);
}

details.cs-dialog > summary::-webkit-details-marker {
  display: none;
}

details.cs-dialog > summary::before {
  content: "[ + ]";
  display: inline-block;
  min-width: 48px;
  color: var(--accent);
  font-family: "VT323", "Courier New", monospace;
  font-size: 1em;
  text-transform: none;
  letter-spacing: 0;
}

details.cs-dialog[open] > summary::before {
  content: "[ - ]";
  color: var(--accent-glow);
}

details.cs-dialog > summary .wrapper {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: "VT323", "Courier New", monospace;
}

details.cs-dialog > summary .wrapper .icon {
  width: 12px;
  height: 12px;
  background: var(--accent);
  border: 1px solid var(--border-dark);
  box-shadow: 0 0 4px rgba(196, 181, 80, 0.35);
}

details.cs-dialog > summary .wrapper .text {
  margin: 0;
  font-size: 1em;
  color: var(--text);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

details.cs-dialog > .content {
  background: var(--bg-panel);
  color: var(--text);
  padding: 16px 20px 18px;
  line-height: 1.6;
  border-top: 1px solid var(--border-mid);
}

/* =============================================================
 * Shared content styling
 * ============================================================= */
.cs-dialog .content,
details.cs-dialog .content {
  max-height: none !important;
  overflow: visible !important;
  line-height: 1.6;
  color: var(--text);
  padding: 16px 22px 18px;
  -webkit-user-select: text !important;
  user-select: text !important;
}

.cs-dialog .content h1,
details.cs-dialog .content h1 {
  font-size: 1.75em;
  margin: 0.3em 0 0.4em;
  color: var(--text);
  font-weight: 400;
  letter-spacing: 0.02em;
  font-family: "VT323", monospace;
}

.cs-dialog .content h2.inline-h,
details.cs-dialog .content h2.inline-h {
  font-size: 1.1em;
  margin: 1.4em 0 0.5em;
  color: var(--accent-glow);
  font-weight: 400;
  font-family: "VT323", monospace;
  border-bottom: 1px solid var(--border-mid);
  padding-bottom: 4px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.cs-dialog .content p,
details.cs-dialog .content p {
  margin: 0.6em 0;
  color: var(--text);
}

.cs-dialog .content p.small,
details.cs-dialog .content p.small {
  font-size: 0.92em;
  color: var(--text-dim);
}

.cs-dialog .content strong,
details.cs-dialog .content strong {
  color: var(--text);
  font-weight: 600;
}

.cs-dialog .content em,
details.cs-dialog .content em {
  color: var(--text-2);
}

.cs-dialog .content a,
details.cs-dialog .content a {
  color: var(--accent-glow);
  text-decoration: underline;
  text-underline-offset: 2px;
  text-decoration-color: var(--accent);
  transition: color 120ms ease;
}

.cs-dialog .content a:hover,
details.cs-dialog .content a:hover {
  color: var(--accent-lime);
  text-decoration-color: var(--accent-lime);
}

.cs-dialog .content code,
details.cs-dialog .content code {
  background: var(--bg-inset);
  padding: 1px 6px;
  border: 1px solid var(--border-mid);
  font-family: "JetBrains Mono", "VT323", monospace;
  color: var(--accent-glow);
  font-size: 0.88em;
  -webkit-user-select: text !important;
  user-select: text !important;
  word-break: break-all;
}

.cs-dialog .content pre.code,
details.cs-dialog .content pre.code,
.cs-dialog .content pre.banner,
details.cs-dialog .content pre.banner {
  background: var(--bg-inset);
  color: var(--text);
  padding: 14px 16px;
  border: 2px solid var(--border-dark);
  border-top-color: var(--border-light);
  border-left-color: var(--border-light);
  margin: 14px 0;
  overflow-x: auto;
  font-family: "JetBrains Mono", "VT323", monospace;
  font-size: 13px;
  line-height: 1.48;
  white-space: pre;
}

.cs-dialog .content pre.banner {
  color: var(--accent-lime);
  font-family: "VT323", monospace;
  font-size: 15px;
  line-height: 1.05;
  text-align: center;
  border: none;
  background: transparent;
  padding: 0;
  margin: 6px 0 18px;
  text-shadow: 0 0 6px rgba(163, 230, 53, 0.45);
}

/* =============================================================
 * vx-data-block — dedicated style for long hex / CBOR / data
 * ============================================================= */
.vx-data-block {
  position: relative;
  font-family: "JetBrains Mono", "VT323", monospace;
  background: var(--bg-data);
  color: var(--accent-glow);
  padding: 18px 14px 14px;
  border: 1px solid var(--border-light);
  box-shadow: inset 0 0 0 1px var(--border-dark),
              0 0 0 1px var(--border-dark);
  font-size: 12px;
  line-height: 1.5;
  overflow-x: auto;
  white-space: pre;
  margin: 14px 0;
  -webkit-user-select: text !important;
  user-select: text !important;
  word-break: normal;
}

.vx-data-block::before {
  content: "ENCLAVE_DATA_STREAM";
  position: absolute;
  top: 4px;
  right: 10px;
  font-family: "VT323", monospace;
  font-size: 10px;
  color: var(--text-3);
  opacity: 0.6;
  letter-spacing: 1px;
  text-transform: uppercase;
}

/* Tables */
table.cs-table {
  width: 100%;
  border-collapse: collapse;
  margin: 12px 0;
  background: var(--bg-inset);
  border: 2px solid var(--border-dark);
  border-top-color: var(--border-light);
  border-left-color: var(--border-light);
  color: var(--text);
  font-family: "JetBrains Mono", "VT323", monospace;
  font-size: 13px;
}

table.cs-table th,
table.cs-table td {
  padding: 8px 12px;
  text-align: left;
  border-bottom: 1px solid var(--border-mid);
  border-right: 1px solid var(--border-mid);
  vertical-align: top;
}

table.cs-table th {
  background: #171c10;
  color: var(--accent);
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: 11px;
  font-family: "VT323", monospace;
}

table.cs-table td.ok {
  color: var(--accent-lime);
  font-weight: 600;
  text-shadow: 0 0 4px rgba(163, 230, 53, 0.3);
}

table.cs-table td.warn { color: var(--accent-glow); }
table.cs-table td.bad  { color: var(--accent-error); font-weight: 600; }
table.cs-table td.not  { color: var(--text-3); font-style: italic; }

table.cs-table tr:last-child td { border-bottom: none; }
table.cs-table td:last-child,
table.cs-table th:last-child { border-right: none; }

/* Ordered list — used for mandates */
.cs-dialog .content ol,
details.cs-dialog .content ol {
  padding-left: 1.2em;
  margin: 0.4em 0;
}

.cs-dialog .content ol.mandates {
  list-style: none;
  padding-left: 0;
  counter-reset: mandate;
}

.cs-dialog .content ol.mandates > li {
  counter-increment: mandate;
  margin: 14px 0;
  padding: 12px 14px 12px 56px;
  position: relative;
  background: var(--bg-inset);
  border: 1px solid var(--border-mid);
  border-left: 3px solid var(--accent);
}

.cs-dialog .content ol.mandates > li::before {
  content: "[ " counter(mandate, upper-roman) " ]";
  position: absolute;
  left: 10px;
  top: 12px;
  color: var(--accent);
  font-family: "VT323", monospace;
  font-size: 14px;
  text-transform: uppercase;
}

.cs-dialog .content ol.mandates > li strong {
  display: block;
  color: var(--accent-glow);
  font-family: "VT323", monospace;
  font-size: 16px;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  margin-bottom: 4px;
}

/* Mermaid */
.mermaid {
  background: var(--bg-inset);
  padding: 16px 12px;
  border: 2px solid var(--border-dark);
  border-top-color: var(--border-light);
  border-left-color: var(--border-light);
  margin: 14px 0;
  overflow-x: auto;
  text-align: center;
  color: var(--text);
}

.mermaid svg {
  max-width: 100%;
  height: auto !important;
  font-family: "VT323", monospace !important;
}

/* Hero menu of buttons */
.cs-dialog .footer-btns {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 14px;
  padding: 0;
  list-style: none;
}

.cs-dialog .footer-btns .cs-btn {
  text-decoration: none;
  display: inline-block;
}

/* =============================================================
 * Button / input interactivity (cs16 overrides)
 * ============================================================= */
.cs-btn {
  transition: filter 100ms ease, color 100ms ease;
}

.cs-btn:hover:not(:disabled) {
  filter: brightness(1.18);
  color: var(--accent-glow);
  cursor: crosshair;
}

.cs-btn:active:not(:disabled) {
  filter: brightness(0.9);
}

.cs-input:focus, .cs-select:focus, input[type="text"]:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 1px var(--accent),
              0 0 6px rgba(196, 181, 80, 0.35);
  background: var(--bg-data);
}

/* =============================================================
 * Floating right-rail navigation
 * ============================================================= */
.vx-side-rail {
  position: fixed;
  right: 18px;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  flex-direction: column;
  gap: 22px;
  z-index: 100;
  pointer-events: none;   /* children re-enable */
}

.vx-rail-link {
  pointer-events: auto;
  font-family: "VT323", "Courier New", monospace;
  text-transform: uppercase;
  color: var(--text-3);
  text-decoration: none;
  font-size: 13px;
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  letter-spacing: 3px;
  padding: 8px 4px 8px 8px;
  border-right: 2px solid transparent;
  transition: color 120ms ease,
              border-right-color 120ms ease,
              text-shadow 120ms ease;
}

.vx-rail-link:hover {
  color: var(--accent-lime);
  border-right-color: var(--accent-lime);
  text-shadow: 0 0 6px rgba(163, 230, 53, 0.5);
  cursor: crosshair;
}

@media (max-width: 1100px) {
  .vx-side-rail { display: none; }
}

/* =============================================================
 * #verifier — the live in-browser Value X widget
 * ============================================================= */
#verifier {
  margin: 16px 0;
  padding: 14px;
  background: var(--bg-inset);
  border: 2px solid var(--border-dark);
  border-top-color: var(--border-light);
  border-left-color: var(--border-light);
  color: var(--text);
}

.verify-controls {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  margin-bottom: 10px;
  padding-bottom: 10px;
  border-bottom: 1px dashed var(--border-light);
}

.verify-controls label {
  color: var(--accent);
  font-size: 12px;
  padding-right: 2px;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.verify-controls select,
.verify-controls input[type="text"] {
  background: var(--bg-data);
  color: var(--text);
  border: 2px solid var(--border-dark);
  border-top-color: var(--border-mid);
  border-left-color: var(--border-mid);
  padding: 5px 8px;
  font-family: "JetBrains Mono", "VT323", monospace;
  font-size: 12px;
  min-width: 140px;
}

.verify-controls .cs-btn {
  margin-left: auto;
}

.verify-controls .cs-btn:first-of-type {
  margin-left: 0;
}

.verify-status {
  display: flex;
  gap: 8px;
  align-items: center;
  font-size: 13px;
  margin-bottom: 8px;
  color: var(--text);
  font-family: "VT323", monospace;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.verify-phase-label { color: var(--accent); }
#verify-phase { color: var(--accent-lime); font-weight: 600; }
.verify-count-sep { opacity: 0.35; }
#verify-count { opacity: 0.85; color: var(--text-2); }

.verify-log {
  height: 240px;
  overflow-y: auto;
  overflow-x: auto;
  background: var(--bg-data);
  border: 2px solid var(--border-dark);
  border-top-color: #000;
  border-left-color: #000;
  padding: 10px 12px;
  font-family: "JetBrains Mono", "VT323", monospace;
  font-size: 12px;
  line-height: 1.4;
  color: var(--text-2);
  white-space: pre;
}

.verify-log .verify-line { padding: 0; color: var(--text-2); }
.verify-log .verify-line.dim { color: var(--text-3); font-style: italic; }
.verify-log .verify-line.ok { color: var(--accent-lime); font-weight: 600; }
.verify-log .verify-line.warn { color: var(--accent-glow); }
.verify-log .verify-line.err { color: var(--accent-error); font-weight: 600; }

.verify-result {
  margin-top: 14px;
  padding: 12px 14px;
  background: var(--bg-panel);
  border: 2px solid var(--border-dark);
  border-top-color: var(--border-light);
  border-left-color: var(--border-light);
}

.verify-result-label {
  color: var(--accent);
  font-size: 11px;
  margin-bottom: 6px;
  text-transform: uppercase;
  letter-spacing: 1px;
  font-family: "VT323", monospace;
}

.verify-result-hex {
  font-family: "JetBrains Mono", monospace;
  font-size: 12px;
  color: var(--accent-glow);
  word-break: break-all;
  padding: 10px 12px;
  background: var(--bg-data);
  border: 1px solid var(--border-dark);
  letter-spacing: 0.01em;
}

.verify-compare {
  margin-top: 10px;
  padding: 9px 12px;
  font-size: 13px;
  line-height: 1.55;
  color: var(--text);
  background: rgba(0, 0, 0, 0.35);
  border-left: 3px solid var(--text-3);
}

.verify-compare.ok {
  background: rgba(163, 230, 53, 0.09);
  border-left-color: var(--accent-lime);
  color: var(--text);
}

.verify-compare.info {
  background: rgba(230, 214, 97, 0.07);
  border-left-color: var(--accent-glow);
}

.verify-compare code {
  background: rgba(0, 0, 0, 0.5) !important;
  color: var(--accent-glow) !important;
}

/* =============================================================
 * Value X lineage chips — copyable hex with copy button
 * ============================================================= */
.vx-lineage {
  margin: 18px 0 6px;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 4px;
}

.vx-lineage .vx-arrow {
  text-align: center;
  color: var(--accent);
  font-size: 18px;
  line-height: 1;
  margin: 4px 0;
  text-shadow: 0 0 5px rgba(196, 181, 80, 0.6);
}

.vx-chip {
  display: flex;
  flex-direction: column;
  gap: 5px;
  padding: 10px 12px;
  background: var(--bg-inset);
  border: 2px solid var(--border-dark);
  border-top-color: var(--border-light);
  border-left-color: var(--border-light);
  box-shadow: 3px 3px 0 rgba(0, 0, 0, 0.5);
  color: var(--text);
}

.vx-chip .vx-label {
  font-size: 11px;
  color: var(--accent);
  letter-spacing: 0.8px;
  text-transform: uppercase;
  font-family: "VT323", monospace;
}

.vx-chip .vx-label .live-dot {
  margin-right: 5px;
}

.vx-chip .vx-hex {
  font-family: "JetBrains Mono", "VT323", monospace;
  font-size: 12px;
  color: var(--accent-glow) !important;
  background: var(--bg-data) !important;
  padding: 7px 10px !important;
  border: 1px solid var(--border-dark);
  word-break: break-all;
  white-space: normal;
  -webkit-user-select: text !important;
  user-select: text !important;
  cursor: text;
  letter-spacing: 0.01em;
  line-height: 1.35;
}

.vx-chip .vx-copy {
  align-self: flex-end;
  background: #1a1f12;
  border: 2px solid var(--border-dark);
  border-top-color: var(--border-light);
  border-left-color: var(--border-light);
  color: var(--accent);
  padding: 3px 14px;
  font-family: "VT323", monospace;
  font-size: 12px;
  cursor: pointer;
  text-transform: uppercase;
  letter-spacing: 1px;
  box-shadow: 1px 1px 0 #000;
  transition: filter 100ms ease, color 100ms ease;
}

.vx-chip .vx-copy:hover {
  filter: brightness(1.3);
  color: var(--accent-glow);
  cursor: crosshair;
}

.vx-chip .vx-copy:active {
  border-top-color: var(--border-dark);
  border-left-color: var(--border-dark);
  border-bottom-color: var(--border-light);
  border-right-color: var(--border-light);
  box-shadow: none;
}

.vx-chip .vx-copy.copied {
  background: var(--accent-lime-d);
  color: #0a0a0a;
  border-top-color: var(--accent-lime);
  border-left-color: var(--accent-lime);
}

.vx-chip-live {
  border-color: var(--accent-lime-d);
  border-top-color: var(--accent-lime);
  border-left-color: var(--accent-lime);
  box-shadow: 3px 3px 0 rgba(0, 0, 0, 0.5), var(--glow-lime);
}

/* Pulsing lime dot for the LIVE indicator */
.live-dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  background: var(--accent-lime);
  border: 1px solid var(--border-dark);
  margin-right: 6px;
  box-shadow: 0 0 6px var(--accent-lime);
  animation: live-pulse 1.5s ease-in-out infinite;
  vertical-align: middle;
}

@keyframes live-pulse {
  0%, 100% { opacity: 1; box-shadow: 0 0 8px var(--accent-lime); }
  50%      { opacity: 0.55; box-shadow: 0 0 2px var(--accent-lime); }
}

/* =============================================================
 * Scrollbar — tactical, matching border-dark
 * ============================================================= */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track {
  background: var(--border-dark);
}
::-webkit-scrollbar-thumb {
  background: var(--border-light);
  border: 2px solid var(--border-dark);
}
::-webkit-scrollbar-thumb:hover {
  background: var(--accent);
}

/* =============================================================
 * Small-screen
 * ============================================================= */
@media (max-width: 680px) {
  body { font-size: 14px; }
  .page { padding: 14px 10px 40px; gap: 14px; }
  .cs-dialog .content h1 { font-size: 1.3em; }
  .cs-dialog .content pre.banner { font-size: 10px; }
  .verify-controls {
    flex-direction: column;
    align-items: stretch;
  }
  .verify-controls .cs-btn {
    margin-left: 0;
    width: 100%;
  }
  .verify-log { height: 200px; font-size: 11px; }
  .verify-result-hex { font-size: 11px; }
  table.cs-table th, table.cs-table td { padding: 6px 8px; font-size: 11px; }
}
