/*
 * RAXE Design System — Code Blocks, Sigma Cards, Copy Button
 * Depends on: tokens.css
 */

/* ── Inline code ── */
code {
  font-family: var(--font-mono); font-size: 0.875em;
  color: var(--text-brand); background: rgba(56,189,248,0.08);
  padding: 2px 6px; border-radius: var(--radius-sm);
}

/* ── Inline technical data (IPs, emails, filenames, packages, hashes) ── */
.data {
  font-family: var(--font-mono); font-size: 0.875em;
  color: var(--text-primary); background: rgba(232,244,255,0.06);
  padding: 2px 6px; border-radius: var(--radius-sm);
  white-space: nowrap;
}
/* IOC — indicators of compromise (IPs, domains, hashes) — amber tint */
.data-ioc {
  color: var(--amber); background: rgba(245,158,11,0.08);
  border: 1px solid rgba(245,158,11,0.15);
}
/* File paths, package names — teal tint */
.data-path {
  color: var(--teal); background: rgba(0,229,192,0.06);
}
/* CVE / advisory IDs — magenta tint */
.data-id {
  color: var(--magenta); background: rgba(232,121,249,0.07);
}

/* ── Code block ── */
.code-block-wrap { position: relative; }
pre {
  font-family: var(--font-mono); font-size: var(--fs-mono);
  line-height: 1.65; color: #c8d6e5;
  background: var(--surface-overlay); border: 1px solid var(--border-default);
  border-radius: var(--radius-lg); padding: var(--space-5);
  overflow-x: auto; tab-size: 2;
}
pre code { background: none; padding: 0; font-size: inherit; color: inherit; }

/* ── Copy button ── */
.code-copy {
  position: absolute; top: var(--space-3); right: var(--space-3);
  padding: 4px 10px; border-radius: var(--radius-sm);
  font-family: var(--font-mono); font-size: 10px; letter-spacing: var(--tracking-wide);
  color: var(--text-dim); background: var(--surface-raised);
  border: 1px solid var(--border-default);
  opacity: 0; transition: var(--transition-ui); cursor: pointer;
}
.code-block-wrap:hover .code-copy { opacity: 1; }
.code-copy:hover { color: var(--text-brand); border-color: var(--border-strong); }
.code-copy.copied { color: var(--action-pass-text); border-color: var(--action-pass-text); }

/* ── Install command box ── */
.install-box {
  display: inline-flex; align-items: center; gap: var(--space-3);
  background: var(--surface-overlay); border: 1px solid var(--border-default);
  border-radius: var(--radius-md); padding: var(--space-3) var(--space-4);
  font-family: var(--font-mono); font-size: var(--fs-mono);
  color: var(--text-body);
}
.install-box .copy-btn {
  color: var(--text-dim); padding: 2px; border-radius: var(--radius-sm);
  transition: var(--transition-color); flex-shrink: 0;
}
.install-box .copy-btn:hover { color: var(--text-brand); }

/* ── Attack flow block (ASCII diagrams) ── */
.attack-flow {
  border-left: 3px solid var(--border-strong);
  background: rgba(56,189,248,0.03);
  font-family: var(--font-mono); font-size: var(--fs-mono);
  overflow-x: auto;
}

/* ── Sigma rule card (collapsible) ── */
.sigma-card {
  border: 1px solid var(--border-default); border-radius: var(--radius-lg); overflow: hidden;
  margin-bottom: var(--space-3);
}
.sigma-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--space-3) var(--space-5);
  background: rgba(56,189,248,0.04);
  cursor: pointer; user-select: none;
  transition: background var(--duration-fast) var(--ease-default);
}
.sigma-header:hover { background: rgba(56,189,248,0.08); }
.sigma-header-title {
  font-family: var(--font-mono); font-size: var(--fs-micro);
  color: var(--text-brand); letter-spacing: var(--tracking-wide);
}
.sigma-chevron {
  width: 14px; color: var(--text-dim);
  transition: transform var(--duration-fast) var(--ease-default);
}
.sigma-card.open .sigma-chevron { transform: rotate(180deg); }
.sigma-body {
  max-height: 0; overflow: hidden;
  transition: max-height var(--duration-slow) var(--ease-out);
}
.sigma-card.open .sigma-body { max-height: 600px; }
.sigma-body pre { border: none; border-radius: 0; border-top: 1px solid var(--border-default); }

/* ── Syntax highlighting (Pygments monokai — .codehilite) ── */
.codehilite          { background: var(--surface-overlay); padding: var(--space-5); border-radius: var(--radius-lg); overflow-x: auto; }
.codehilite .k,  .codehilite .kd { color: #66d9ef; }  /* keyword */
.codehilite .s,  .codehilite .s1, .codehilite .s2 { color: #e6db74; }  /* string */
.codehilite .c,  .codehilite .c1 { color: #75715e; }  /* comment */
.codehilite .n              { color: #f8f8f2; }  /* name */
.codehilite .na             { color: #a6e22e; }  /* name.attr */
.codehilite .nv             { color: #f92672; }  /* name.var */
.codehilite .m,  .codehilite .mi { color: #ae81ff; }  /* number */
.codehilite .o              { color: #f92672; }  /* operator */
