canonrs-server 0.1.0

CanonRS server-side rendering support
/* ═══════════════════════════════════════════════════════════════
   INPUT OTP - Family C Forms tokens compliant
   State via data-rs-state — zero pseudo-class state selectors
   ═══════════════════════════════════════════════════════════════ */

[data-rs-input-otp] {
  position: absolute;
  inset: 0;
  opacity: 0;
  pointer-events: none;
}

[data-rs-input-otp-container] {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
}

[data-rs-input-otp-container][data-rs-state~="disabled"] {
  opacity: var(--input-disabled-opacity);
  cursor: not-allowed;
  pointer-events: none;
}

[data-rs-input-otp-container][data-rs-state~="disabled"] [data-rs-input-otp-slot] {
  background: var(--input-otp-slot-disabled-bg);
  color: var(--input-otp-slot-disabled-fg);
}

[data-rs-input-otp-slots] {
  display: flex;
  gap: var(--space-xs);
}

[data-rs-input-otp-slot] {
  width: var(--input-otp-slot-size);
  height: var(--input-otp-slot-size);
  border-radius: var(--input-otp-slot-radius);
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--input-otp-slot-bg);
  color: var(--input-otp-slot-fg);
  border: var(--input-otp-slot-border);
  font-family: var(--input-otp-font-family);
  font-size: var(--input-otp-font-size);
  font-weight: var(--input-otp-font-weight);
  transition: background var(--motion-duration-fast) var(--motion-ease-standard),
              border-color var(--motion-duration-fast) var(--motion-ease-standard);
}

[data-rs-input-otp-slot][data-rs-state~="active"] {
  background: var(--input-otp-slot-active-bg);
  border-color: var(--input-otp-slot-active-border);
  box-shadow: var(--input-focus-ring-shadow);
}