canonrs-server 0.1.0

CanonRS server-side rendering support
/* ═══════════════════════════════════════════════════════════════
   CODE BLOCK — Family G Data tokens compliant
   ═══════════════════════════════════════════════════════════════ */

[data-rs-code-block] {
  background: var(--code-block-bg);
  border-radius: var(--code-block-radius);
  border: var(--code-block-border-width) solid var(--code-block-border-color);
  font-family: var(--code-block-font-family);
  font-size: var(--code-block-font-size);
  line-height: var(--code-block-line-height);
  transition: border-color var(--motion-duration-fast) var(--motion-ease-standard);
}

[data-rs-code-header] {
  display: flex;
  align-items: center;
  gap: var(--code-block-header-gap);
  height: var(--code-block-header-height);
  background: var(--code-block-header-bg);
  color: var(--code-block-header-fg);
}

[data-rs-code-language] {
  font-size: var(--code-block-language-font-size);
  color: var(--code-block-language-fg);
}

[data-rs-code-pre] {
  padding-inline: var(--code-block-content-padding-x);
  padding-block: var(--code-block-content-padding-y);
}

[data-rs-code-block][data-rs-line-numbers] [data-rs-code-pre] {
  counter-reset: line;
}

[data-rs-code-block][data-rs-line-numbers] [data-rs-code-line] {
  display: grid;
  grid-template-columns: 3em 1fr;
  gap: var(--space-sm);
}

[data-rs-code-block][data-rs-line-numbers] [data-rs-code-line]::before {
  content: attr(data-rs-line-number);
  text-align: right;
  color: var(--theme-surface-fg-muted);
  padding-right: var(--space-xs);
  border-right: var(--border-thin) solid var(--theme-surface-border);
  user-select: none;
}

[data-rs-code-block][data-rs-state~="copied"] {
  border-color: var(--theme-action-primary-bg);
  box-shadow: var(--shadow-sm);
}

[data-rs-code-block][data-rs-state~="hover"] {
  border-color: var(--theme-surface-border);
}

[data-rs-code-block] [data-rs-copy-button] {
  opacity: var(--opacity-disabled);
  transition: opacity var(--motion-duration-fast) var(--motion-ease-standard);
}

[data-rs-code-block][data-rs-state~="hover"] [data-rs-copy-button] {
  opacity: 1;
}