@charset "UTF-8";pre code.hljs{display:block;overflow-x:auto;padding:1em}code.hljs{padding:3px 5px}.hljs{color:#c9d1d9;background:#0d1117}.hljs-doctag,.hljs-keyword,.hljs-meta .hljs-keyword,.hljs-template-tag,.hljs-template-variable,.hljs-type,.hljs-variable.language_{color:#ff7b72}.hljs-title,.hljs-title.class_,.hljs-title.class_.inherited__,.hljs-title.function_{color:#d2a8ff}.hljs-attr,.hljs-attribute,.hljs-literal,.hljs-meta,.hljs-number,.hljs-operator,.hljs-variable,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-id{color:#79c0ff}.hljs-regexp,.hljs-string,.hljs-meta .hljs-string{color:#a5d6ff}.hljs-built_in,.hljs-symbol{color:#ffa657}.hljs-comment,.hljs-code,.hljs-formula{color:#8b949e}.hljs-name,.hljs-quote,.hljs-selector-tag,.hljs-selector-pseudo{color:#7ee787}.hljs-subst{color:#c9d1d9}.hljs-section{color:#1f6feb;font-weight:700}.hljs-bullet{color:#f2cc60}.hljs-emphasis{color:#c9d1d9;font-style:italic}.hljs-strong{color:#c9d1d9;font-weight:700}.hljs-addition{color:#aff5b4;background-color:#033a16}.hljs-deletion{color:#ffdcd7;background-color:#67060c}html{--tbx-mat-severity-default-background: var(--mat-sys-inverse-surface);--tbx-mat-severity-default-text: var(--mat-sys-inverse-on-surface);--tbx-mat-severity-success-background: #2e7d32;--tbx-mat-severity-success-text: #ffffff;--tbx-mat-severity-error-background: #c62828;--tbx-mat-severity-error-text: #ffffff;--tbx-mat-severity-warning-background: #f9a825;--tbx-mat-severity-warning-text: #ffffff;--tbx-mat-severity-information-background: #1565c0;--tbx-mat-severity-information-text: #ffffff;--tbx-mat-severity-help-background: #1976d2;--tbx-mat-severity-help-text: #ffffff}.tbx-mat-severity-inverted{--tbx-mat-severity-default-background: var(--mat-sys-surface);--tbx-mat-severity-default-text: var(--mat-sys-on-surface);--tbx-mat-severity-success-background: #ffffff;--tbx-mat-severity-success-text: #2e7d32;--tbx-mat-severity-error-background: #ffffff;--tbx-mat-severity-error-text: #c62828;--tbx-mat-severity-warning-background: #ffffff;--tbx-mat-severity-warning-text: #f9a825;--tbx-mat-severity-information-background: #ffffff;--tbx-mat-severity-information-text: #1565c0;--tbx-mat-severity-help-background: #ffffff;--tbx-mat-severity-help-text: #1976d2}html{--tbx-mat-notification-default-background: var(--tbx-mat-severity-default-background);--tbx-mat-notification-default-text: var(--tbx-mat-severity-default-text);--tbx-mat-notification-success-background: var(--tbx-mat-severity-success-background);--tbx-mat-notification-success-text: var(--tbx-mat-severity-success-text);--tbx-mat-notification-error-background: var(--tbx-mat-severity-error-background);--tbx-mat-notification-error-text: var(--tbx-mat-severity-error-text);--tbx-mat-notification-warning-background: var(--tbx-mat-severity-warning-background);--tbx-mat-notification-warning-text: var(--tbx-mat-severity-warning-text);--tbx-mat-notification-information-background: var(--tbx-mat-severity-information-background);--tbx-mat-notification-information-text: var(--tbx-mat-severity-information-text);--tbx-mat-notification-help-background: var(--tbx-mat-severity-help-background);--tbx-mat-notification-help-text: var(--tbx-mat-severity-help-text)}html{--tbx-mat-notification-action-text-opacity: .8;--tbx-mat-notification-action-filled-container-opacity: var(--tbx-mat-notification-action-text-opacity);--tbx-mat-notification-action-tonal-container-opacity: .55;--tbx-mat-notification-action-outlined-opacity: var(--tbx-mat-notification-action-text-opacity);--tbx-mat-notification-action-elevated-opacity: var(--tbx-mat-notification-action-text-opacity);--tbx-mat-notification-action-icon-opacity: var(--tbx-mat-notification-action-text-opacity);--tbx-mat-notification-close-icon-opacity: var(--tbx-mat-notification-action-text-opacity);--tbx-mat-notification-action-filled-hover-state-layer-opacity: .3;--tbx-mat-notification-action-tonal-hover-state-layer-opacity: var(--tbx-mat-notification-action-filled-hover-state-layer-opacity)}.tbx-mat-notification-snackbar-default{--mat-snack-bar-container-color: var(--tbx-mat-notification-default-background);--mat-snack-bar-supporting-text-color: var(--tbx-mat-notification-default-text);--tbx-mat-notification-action-icon-color: color-mix(in srgb, var(--tbx-mat-notification-default-text) calc(var(--tbx-mat-notification-action-icon-opacity) * 100%), transparent);--tbx-mat-notification-action-icon-state-layer-color: var(--tbx-mat-notification-default-text);--tbx-mat-notification-close-icon-color: color-mix(in srgb, var(--tbx-mat-notification-default-text) calc(var(--tbx-mat-notification-close-icon-opacity) * 100%), transparent);--tbx-mat-notification-close-icon-state-layer-color: var(--tbx-mat-notification-default-text);--mat-snack-bar-button-color: color-mix(in srgb, var(--tbx-mat-notification-default-text) calc(var(--tbx-mat-notification-action-text-opacity) * 100%), transparent);--mat-button-text-label-text-color: color-mix(in srgb, var(--tbx-mat-notification-default-text) calc(var(--tbx-mat-notification-action-text-opacity) * 100%), transparent);--mat-button-text-state-layer-color: var(--tbx-mat-notification-default-text);--mat-button-text-ripple-color: color-mix(in srgb, var(--tbx-mat-notification-default-text) calc(var(--mat-sys-pressed-state-layer-opacity) * 100%), transparent);--mat-button-filled-container-color: color-mix(in srgb, var(--tbx-mat-notification-default-text) calc(var(--tbx-mat-notification-action-filled-container-opacity) * 100%), transparent);--mat-button-filled-label-text-color: var(--tbx-mat-notification-default-background);--mat-button-filled-state-layer-color: var(--tbx-mat-notification-default-background);--mat-button-filled-hover-state-layer-opacity: var(--tbx-mat-notification-action-filled-hover-state-layer-opacity);--mat-button-filled-ripple-color: color-mix(in srgb, var(--tbx-mat-notification-default-background) calc(var(--mat-sys-pressed-state-layer-opacity) * 100%), transparent);--mat-button-tonal-container-color: color-mix(in srgb, var(--tbx-mat-notification-default-text) calc(var(--tbx-mat-notification-action-tonal-container-opacity) * 100%), transparent);--mat-button-tonal-label-text-color: var(--tbx-mat-notification-default-background);--mat-button-tonal-state-layer-color: var(--tbx-mat-notification-default-background);--mat-button-tonal-hover-state-layer-opacity: var(--tbx-mat-notification-action-tonal-hover-state-layer-opacity);--mat-button-tonal-ripple-color: color-mix(in srgb, var(--tbx-mat-notification-default-background) calc(var(--mat-sys-pressed-state-layer-opacity) * 100%), transparent);--mat-button-outlined-label-text-color: color-mix(in srgb, var(--tbx-mat-notification-default-text) calc(var(--tbx-mat-notification-action-outlined-opacity) * 100%), transparent);--mat-button-outlined-outline-color: var(--tbx-mat-notification-default-text);--mat-button-outlined-state-layer-color: var(--tbx-mat-notification-default-text);--mat-button-outlined-ripple-color: color-mix(in srgb, var(--tbx-mat-notification-default-text) calc(var(--mat-sys-pressed-state-layer-opacity) * 100%), transparent);--mat-button-protected-label-text-color: color-mix(in srgb, var(--tbx-mat-notification-default-text) calc(var(--tbx-mat-notification-action-elevated-opacity) * 100%), transparent);--mat-button-protected-container-color: var(--tbx-mat-notification-default-background);--mat-button-protected-state-layer-color: var(--tbx-mat-notification-default-text);--mat-button-protected-container-elevation-shadow: var(--mat-sys-level1);--mat-button-protected-hover-container-elevation-shadow: var(--mat-sys-level2);--mat-button-protected-focus-container-elevation-shadow: var(--mat-sys-level1);--mat-button-protected-pressed-container-elevation-shadow: var(--mat-sys-level1);--mat-button-protected-ripple-color: color-mix(in srgb, var(--tbx-mat-notification-default-text) calc(var(--mat-sys-pressed-state-layer-opacity) * 100%), transparent)}.tbx-mat-notification-snackbar-success{--mat-snack-bar-container-color: var(--tbx-mat-notification-success-background);--mat-snack-bar-supporting-text-color: var(--tbx-mat-notification-success-text);--tbx-mat-notification-action-icon-color: color-mix(in srgb, var(--tbx-mat-notification-success-text) calc(var(--tbx-mat-notification-action-icon-opacity) * 100%), transparent);--tbx-mat-notification-action-icon-state-layer-color: var(--tbx-mat-notification-success-text);--tbx-mat-notification-close-icon-color: color-mix(in srgb, var(--tbx-mat-notification-success-text) calc(var(--tbx-mat-notification-close-icon-opacity) * 100%), transparent);--tbx-mat-notification-close-icon-state-layer-color: var(--tbx-mat-notification-success-text);--mat-snack-bar-button-color: color-mix(in srgb, var(--tbx-mat-notification-success-text) calc(var(--tbx-mat-notification-action-text-opacity) * 100%), transparent);--mat-button-text-label-text-color: color-mix(in srgb, var(--tbx-mat-notification-success-text) calc(var(--tbx-mat-notification-action-text-opacity) * 100%), transparent);--mat-button-text-state-layer-color: var(--tbx-mat-notification-success-text);--mat-button-text-ripple-color: color-mix(in srgb, var(--tbx-mat-notification-success-text) calc(var(--mat-sys-pressed-state-layer-opacity) * 100%), transparent);--mat-button-filled-container-color: color-mix(in srgb, var(--tbx-mat-notification-success-text) calc(var(--tbx-mat-notification-action-filled-container-opacity) * 100%), transparent);--mat-button-filled-label-text-color: var(--tbx-mat-notification-success-background);--mat-button-filled-state-layer-color: var(--tbx-mat-notification-success-background);--mat-button-filled-hover-state-layer-opacity: var(--tbx-mat-notification-action-filled-hover-state-layer-opacity);--mat-button-filled-ripple-color: color-mix(in srgb, var(--tbx-mat-notification-success-background) calc(var(--mat-sys-pressed-state-layer-opacity) * 100%), transparent);--mat-button-tonal-container-color: color-mix(in srgb, var(--tbx-mat-notification-success-text) calc(var(--tbx-mat-notification-action-tonal-container-opacity) * 100%), transparent);--mat-button-tonal-label-text-color: var(--tbx-mat-notification-success-background);--mat-button-tonal-state-layer-color: var(--tbx-mat-notification-success-background);--mat-button-tonal-hover-state-layer-opacity: var(--tbx-mat-notification-action-tonal-hover-state-layer-opacity);--mat-button-tonal-ripple-color: color-mix(in srgb, var(--tbx-mat-notification-success-background) calc(var(--mat-sys-pressed-state-layer-opacity) * 100%), transparent);--mat-button-outlined-label-text-color: color-mix(in srgb, var(--tbx-mat-notification-success-text) calc(var(--tbx-mat-notification-action-outlined-opacity) * 100%), transparent);--mat-button-outlined-outline-color: var(--tbx-mat-notification-success-text);--mat-button-outlined-state-layer-color: var(--tbx-mat-notification-success-text);--mat-button-outlined-ripple-color: color-mix(in srgb, var(--tbx-mat-notification-success-text) calc(var(--mat-sys-pressed-state-layer-opacity) * 100%), transparent);--mat-button-protected-label-text-color: color-mix(in srgb, var(--tbx-mat-notification-success-text) calc(var(--tbx-mat-notification-action-elevated-opacity) * 100%), transparent);--mat-button-protected-container-color: var(--tbx-mat-notification-success-background);--mat-button-protected-state-layer-color: var(--tbx-mat-notification-success-text);--mat-button-protected-container-elevation-shadow: var(--mat-sys-level1);--mat-button-protected-hover-container-elevation-shadow: var(--mat-sys-level2);--mat-button-protected-focus-container-elevation-shadow: var(--mat-sys-level1);--mat-button-protected-pressed-container-elevation-shadow: var(--mat-sys-level1);--mat-button-protected-ripple-color: color-mix(in srgb, var(--tbx-mat-notification-success-text) calc(var(--mat-sys-pressed-state-layer-opacity) * 100%), transparent)}.tbx-mat-notification-snackbar-error{--mat-snack-bar-container-color: var(--tbx-mat-notification-error-background);--mat-snack-bar-supporting-text-color: var(--tbx-mat-notification-error-text);--tbx-mat-notification-action-icon-color: color-mix(in srgb, var(--tbx-mat-notification-error-text) calc(var(--tbx-mat-notification-action-icon-opacity) * 100%), transparent);--tbx-mat-notification-action-icon-state-layer-color: var(--tbx-mat-notification-error-text);--tbx-mat-notification-close-icon-color: color-mix(in srgb, var(--tbx-mat-notification-error-text) calc(var(--tbx-mat-notification-close-icon-opacity) * 100%), transparent);--tbx-mat-notification-close-icon-state-layer-color: var(--tbx-mat-notification-error-text);--mat-snack-bar-button-color: color-mix(in srgb, var(--tbx-mat-notification-error-text) calc(var(--tbx-mat-notification-action-text-opacity) * 100%), transparent);--mat-button-text-label-text-color: color-mix(in srgb, var(--tbx-mat-notification-error-text) calc(var(--tbx-mat-notification-action-text-opacity) * 100%), transparent);--mat-button-text-state-layer-color: var(--tbx-mat-notification-error-text);--mat-button-text-ripple-color: color-mix(in srgb, var(--tbx-mat-notification-error-text) calc(var(--mat-sys-pressed-state-layer-opacity) * 100%), transparent);--mat-button-filled-container-color: color-mix(in srgb, var(--tbx-mat-notification-error-text) calc(var(--tbx-mat-notification-action-filled-container-opacity) * 100%), transparent);--mat-button-filled-label-text-color: var(--tbx-mat-notification-error-background);--mat-button-filled-state-layer-color: var(--tbx-mat-notification-error-background);--mat-button-filled-hover-state-layer-opacity: var(--tbx-mat-notification-action-filled-hover-state-layer-opacity);--mat-button-filled-ripple-color: color-mix(in srgb, var(--tbx-mat-notification-error-background) calc(var(--mat-sys-pressed-state-layer-opacity) * 100%), transparent);--mat-button-tonal-container-color: color-mix(in srgb, var(--tbx-mat-notification-error-text) calc(var(--tbx-mat-notification-action-tonal-container-opacity) * 100%), transparent);--mat-button-tonal-label-text-color: var(--tbx-mat-notification-error-background);--mat-button-tonal-state-layer-color: var(--tbx-mat-notification-error-background);--mat-button-tonal-hover-state-layer-opacity: var(--tbx-mat-notification-action-tonal-hover-state-layer-opacity);--mat-button-tonal-ripple-color: color-mix(in srgb, var(--tbx-mat-notification-error-background) calc(var(--mat-sys-pressed-state-layer-opacity) * 100%), transparent);--mat-button-outlined-label-text-color: color-mix(in srgb, var(--tbx-mat-notification-error-text) calc(var(--tbx-mat-notification-action-outlined-opacity) * 100%), transparent);--mat-button-outlined-outline-color: var(--tbx-mat-notification-error-text);--mat-button-outlined-state-layer-color: var(--tbx-mat-notification-error-text);--mat-button-outlined-ripple-color: color-mix(in srgb, var(--tbx-mat-notification-error-text) calc(var(--mat-sys-pressed-state-layer-opacity) * 100%), transparent);--mat-button-protected-label-text-color: color-mix(in srgb, var(--tbx-mat-notification-error-text) calc(var(--tbx-mat-notification-action-elevated-opacity) * 100%), transparent);--mat-button-protected-container-color: var(--tbx-mat-notification-error-background);--mat-button-protected-state-layer-color: var(--tbx-mat-notification-error-text);--mat-button-protected-container-elevation-shadow: var(--mat-sys-level1);--mat-button-protected-hover-container-elevation-shadow: var(--mat-sys-level2);--mat-button-protected-focus-container-elevation-shadow: var(--mat-sys-level1);--mat-button-protected-pressed-container-elevation-shadow: var(--mat-sys-level1);--mat-button-protected-ripple-color: color-mix(in srgb, var(--tbx-mat-notification-error-text) calc(var(--mat-sys-pressed-state-layer-opacity) * 100%), transparent)}.tbx-mat-notification-snackbar-warning{--mat-snack-bar-container-color: var(--tbx-mat-notification-warning-background);--mat-snack-bar-supporting-text-color: var(--tbx-mat-notification-warning-text);--tbx-mat-notification-action-icon-color: color-mix(in srgb, var(--tbx-mat-notification-warning-text) calc(var(--tbx-mat-notification-action-icon-opacity) * 100%), transparent);--tbx-mat-notification-action-icon-state-layer-color: var(--tbx-mat-notification-warning-text);--tbx-mat-notification-close-icon-color: color-mix(in srgb, var(--tbx-mat-notification-warning-text) calc(var(--tbx-mat-notification-close-icon-opacity) * 100%), transparent);--tbx-mat-notification-close-icon-state-layer-color: var(--tbx-mat-notification-warning-text);--mat-snack-bar-button-color: color-mix(in srgb, var(--tbx-mat-notification-warning-text) calc(var(--tbx-mat-notification-action-text-opacity) * 100%), transparent);--mat-button-text-label-text-color: color-mix(in srgb, var(--tbx-mat-notification-warning-text) calc(var(--tbx-mat-notification-action-text-opacity) * 100%), transparent);--mat-button-text-state-layer-color: var(--tbx-mat-notification-warning-text);--mat-button-text-ripple-color: color-mix(in srgb, var(--tbx-mat-notification-warning-text) calc(var(--mat-sys-pressed-state-layer-opacity) * 100%), transparent);--mat-button-filled-container-color: color-mix(in srgb, var(--tbx-mat-notification-warning-text) calc(var(--tbx-mat-notification-action-filled-container-opacity) * 100%), transparent);--mat-button-filled-label-text-color: var(--tbx-mat-notification-warning-background);--mat-button-filled-state-layer-color: var(--tbx-mat-notification-warning-background);--mat-button-filled-hover-state-layer-opacity: var(--tbx-mat-notification-action-filled-hover-state-layer-opacity);--mat-button-filled-ripple-color: color-mix(in srgb, var(--tbx-mat-notification-warning-background) calc(var(--mat-sys-pressed-state-layer-opacity) * 100%), transparent);--mat-button-tonal-container-color: color-mix(in srgb, var(--tbx-mat-notification-warning-text) calc(var(--tbx-mat-notification-action-tonal-container-opacity) * 100%), transparent);--mat-button-tonal-label-text-color: var(--tbx-mat-notification-warning-background);--mat-button-tonal-state-layer-color: var(--tbx-mat-notification-warning-background);--mat-button-tonal-hover-state-layer-opacity: var(--tbx-mat-notification-action-tonal-hover-state-layer-opacity);--mat-button-tonal-ripple-color: color-mix(in srgb, var(--tbx-mat-notification-warning-background) calc(var(--mat-sys-pressed-state-layer-opacity) * 100%), transparent);--mat-button-outlined-label-text-color: color-mix(in srgb, var(--tbx-mat-notification-warning-text) calc(var(--tbx-mat-notification-action-outlined-opacity) * 100%), transparent);--mat-button-outlined-outline-color: var(--tbx-mat-notification-warning-text);--mat-button-outlined-state-layer-color: var(--tbx-mat-notification-warning-text);--mat-button-outlined-ripple-color: color-mix(in srgb, var(--tbx-mat-notification-warning-text) calc(var(--mat-sys-pressed-state-layer-opacity) * 100%), transparent);--mat-button-protected-label-text-color: color-mix(in srgb, var(--tbx-mat-notification-warning-text) calc(var(--tbx-mat-notification-action-elevated-opacity) * 100%), transparent);--mat-button-protected-container-color: var(--tbx-mat-notification-warning-background);--mat-button-protected-state-layer-color: var(--tbx-mat-notification-warning-text);--mat-button-protected-container-elevation-shadow: var(--mat-sys-level1);--mat-button-protected-hover-container-elevation-shadow: var(--mat-sys-level2);--mat-button-protected-focus-container-elevation-shadow: var(--mat-sys-level1);--mat-button-protected-pressed-container-elevation-shadow: var(--mat-sys-level1);--mat-button-protected-ripple-color: color-mix(in srgb, var(--tbx-mat-notification-warning-text) calc(var(--mat-sys-pressed-state-layer-opacity) * 100%), transparent)}.tbx-mat-notification-snackbar-information{--mat-snack-bar-container-color: var(--tbx-mat-notification-information-background);--mat-snack-bar-supporting-text-color: var(--tbx-mat-notification-information-text);--tbx-mat-notification-action-icon-color: color-mix(in srgb, var(--tbx-mat-notification-information-text) calc(var(--tbx-mat-notification-action-icon-opacity) * 100%), transparent);--tbx-mat-notification-action-icon-state-layer-color: var(--tbx-mat-notification-information-text);--tbx-mat-notification-close-icon-color: color-mix(in srgb, var(--tbx-mat-notification-information-text) calc(var(--tbx-mat-notification-close-icon-opacity) * 100%), transparent);--tbx-mat-notification-close-icon-state-layer-color: var(--tbx-mat-notification-information-text);--mat-snack-bar-button-color: color-mix(in srgb, var(--tbx-mat-notification-information-text) calc(var(--tbx-mat-notification-action-text-opacity) * 100%), transparent);--mat-button-text-label-text-color: color-mix(in srgb, var(--tbx-mat-notification-information-text) calc(var(--tbx-mat-notification-action-text-opacity) * 100%), transparent);--mat-button-text-state-layer-color: var(--tbx-mat-notification-information-text);--mat-button-text-ripple-color: color-mix(in srgb, var(--tbx-mat-notification-information-text) calc(var(--mat-sys-pressed-state-layer-opacity) * 100%), transparent);--mat-button-filled-container-color: color-mix(in srgb, var(--tbx-mat-notification-information-text) calc(var(--tbx-mat-notification-action-filled-container-opacity) * 100%), transparent);--mat-button-filled-label-text-color: var(--tbx-mat-notification-information-background);--mat-button-filled-state-layer-color: var(--tbx-mat-notification-information-background);--mat-button-filled-hover-state-layer-opacity: var(--tbx-mat-notification-action-filled-hover-state-layer-opacity);--mat-button-filled-ripple-color: color-mix(in srgb, var(--tbx-mat-notification-information-background) calc(var(--mat-sys-pressed-state-layer-opacity) * 100%), transparent);--mat-button-tonal-container-color: color-mix(in srgb, var(--tbx-mat-notification-information-text) calc(var(--tbx-mat-notification-action-tonal-container-opacity) * 100%), transparent);--mat-button-tonal-label-text-color: var(--tbx-mat-notification-information-background);--mat-button-tonal-state-layer-color: var(--tbx-mat-notification-information-background);--mat-button-tonal-hover-state-layer-opacity: var(--tbx-mat-notification-action-tonal-hover-state-layer-opacity);--mat-button-tonal-ripple-color: color-mix(in srgb, var(--tbx-mat-notification-information-background) calc(var(--mat-sys-pressed-state-layer-opacity) * 100%), transparent);--mat-button-outlined-label-text-color: color-mix(in srgb, var(--tbx-mat-notification-information-text) calc(var(--tbx-mat-notification-action-outlined-opacity) * 100%), transparent);--mat-button-outlined-outline-color: var(--tbx-mat-notification-information-text);--mat-button-outlined-state-layer-color: var(--tbx-mat-notification-information-text);--mat-button-outlined-ripple-color: color-mix(in srgb, var(--tbx-mat-notification-information-text) calc(var(--mat-sys-pressed-state-layer-opacity) * 100%), transparent);--mat-button-protected-label-text-color: color-mix(in srgb, var(--tbx-mat-notification-information-text) calc(var(--tbx-mat-notification-action-elevated-opacity) * 100%), transparent);--mat-button-protected-container-color: var(--tbx-mat-notification-information-background);--mat-button-protected-state-layer-color: var(--tbx-mat-notification-information-text);--mat-button-protected-container-elevation-shadow: var(--mat-sys-level1);--mat-button-protected-hover-container-elevation-shadow: var(--mat-sys-level2);--mat-button-protected-focus-container-elevation-shadow: var(--mat-sys-level1);--mat-button-protected-pressed-container-elevation-shadow: var(--mat-sys-level1);--mat-button-protected-ripple-color: color-mix(in srgb, var(--tbx-mat-notification-information-text) calc(var(--mat-sys-pressed-state-layer-opacity) * 100%), transparent)}.tbx-mat-notification-snackbar-help{--mat-snack-bar-container-color: var(--tbx-mat-notification-help-background);--mat-snack-bar-supporting-text-color: var(--tbx-mat-notification-help-text);--tbx-mat-notification-action-icon-color: color-mix(in srgb, var(--tbx-mat-notification-help-text) calc(var(--tbx-mat-notification-action-icon-opacity) * 100%), transparent);--tbx-mat-notification-action-icon-state-layer-color: var(--tbx-mat-notification-help-text);--tbx-mat-notification-close-icon-color: color-mix(in srgb, var(--tbx-mat-notification-help-text) calc(var(--tbx-mat-notification-close-icon-opacity) * 100%), transparent);--tbx-mat-notification-close-icon-state-layer-color: var(--tbx-mat-notification-help-text);--mat-snack-bar-button-color: color-mix(in srgb, var(--tbx-mat-notification-help-text) calc(var(--tbx-mat-notification-action-text-opacity) * 100%), transparent);--mat-button-text-label-text-color: color-mix(in srgb, var(--tbx-mat-notification-help-text) calc(var(--tbx-mat-notification-action-text-opacity) * 100%), transparent);--mat-button-text-state-layer-color: var(--tbx-mat-notification-help-text);--mat-button-text-ripple-color: color-mix(in srgb, var(--tbx-mat-notification-help-text) calc(var(--mat-sys-pressed-state-layer-opacity) * 100%), transparent);--mat-button-filled-container-color: color-mix(in srgb, var(--tbx-mat-notification-help-text) calc(var(--tbx-mat-notification-action-filled-container-opacity) * 100%), transparent);--mat-button-filled-label-text-color: var(--tbx-mat-notification-help-background);--mat-button-filled-state-layer-color: var(--tbx-mat-notification-help-background);--mat-button-filled-hover-state-layer-opacity: var(--tbx-mat-notification-action-filled-hover-state-layer-opacity);--mat-button-filled-ripple-color: color-mix(in srgb, var(--tbx-mat-notification-help-background) calc(var(--mat-sys-pressed-state-layer-opacity) * 100%), transparent);--mat-button-tonal-container-color: color-mix(in srgb, var(--tbx-mat-notification-help-text) calc(var(--tbx-mat-notification-action-tonal-container-opacity) * 100%), transparent);--mat-button-tonal-label-text-color: var(--tbx-mat-notification-help-background);--mat-button-tonal-state-layer-color: var(--tbx-mat-notification-help-background);--mat-button-tonal-hover-state-layer-opacity: var(--tbx-mat-notification-action-tonal-hover-state-layer-opacity);--mat-button-tonal-ripple-color: color-mix(in srgb, var(--tbx-mat-notification-help-background) calc(var(--mat-sys-pressed-state-layer-opacity) * 100%), transparent);--mat-button-outlined-label-text-color: color-mix(in srgb, var(--tbx-mat-notification-help-text) calc(var(--tbx-mat-notification-action-outlined-opacity) * 100%), transparent);--mat-button-outlined-outline-color: var(--tbx-mat-notification-help-text);--mat-button-outlined-state-layer-color: var(--tbx-mat-notification-help-text);--mat-button-outlined-ripple-color: color-mix(in srgb, var(--tbx-mat-notification-help-text) calc(var(--mat-sys-pressed-state-layer-opacity) * 100%), transparent);--mat-button-protected-label-text-color: color-mix(in srgb, var(--tbx-mat-notification-help-text) calc(var(--tbx-mat-notification-action-elevated-opacity) * 100%), transparent);--mat-button-protected-container-color: var(--tbx-mat-notification-help-background);--mat-button-protected-state-layer-color: var(--tbx-mat-notification-help-text);--mat-button-protected-container-elevation-shadow: var(--mat-sys-level1);--mat-button-protected-hover-container-elevation-shadow: var(--mat-sys-level2);--mat-button-protected-focus-container-elevation-shadow: var(--mat-sys-level1);--mat-button-protected-pressed-container-elevation-shadow: var(--mat-sys-level1);--mat-button-protected-ripple-color: color-mix(in srgb, var(--tbx-mat-notification-help-text) calc(var(--mat-sys-pressed-state-layer-opacity) * 100%), transparent)}.tbx-mat-notification-action-icon-button.mat-mdc-icon-button{--mat-icon-button-icon-color: var(--tbx-mat-notification-action-icon-color);--mat-icon-button-state-layer-color: var(--tbx-mat-notification-action-icon-state-layer-color)}.tbx-mat-notification-close-icon-button.mat-mdc-icon-button{--mat-icon-button-icon-color: var(--tbx-mat-notification-close-icon-color);--mat-icon-button-state-layer-color: var(--tbx-mat-notification-close-icon-state-layer-color)}.mat-mdc-snack-bar-container .mdc-snackbar__surface{position:relative;overflow:hidden}.mat-mdc-snack-bar-container .tbx-mat-notification-snackbar-countdown{position:absolute;bottom:0;left:0;right:0;height:var(--tbx-mat-notification-countdown-height, .1875rem);background:currentColor;opacity:var(--tbx-mat-notification-countdown-opacity, .4);transform-origin:left;animation:countdown linear forwards}@keyframes countdown{0%{transform:scaleX(1)}to{transform:scaleX(0)}}html{-webkit-tap-highlight-color:transparent}.hljs-title,.hljs-title.class_,.hljs-title.class_.inherited__,.hljs-title.function_{color:#e3c9ff}:root{--font-sans: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--font-mono: "JetBrains Mono", "SF Mono", "Fira Code", "Cascadia Code", monospace;--accent: #6366f1;--accent-hover: #4f46e5;--accent-glow: #a5b4fc;--accent-on: #ffffff;--sev-default-bg: var(--surf-2);--sev-default-fg: var(--text);--sev-success-bg: #2e7d32;--sev-error-bg: #c62828;--sev-warning-bg: #f9a825;--sev-information-bg: #1565c0;--sev-help-bg: #1976d2;--sev-on: #ffffff;--panel-max: 72rem;--ease-std: cubic-bezier(.2, 0, 0, 1);--ease-emph: cubic-bezier(.3, 0, 0, 1);--dur-1: .12s;--dur-2: .2s;--dur-3: .32s;--r-xs: 4px;--r-sm: 8px;--r-md: 12px;--r-lg: 16px;--r-xl: 24px;--r-full: 999px}:root,[data-theme=light]{--bg: #fafafa;--surf-0: #ffffff;--surf-1: #f8fafc;--surf-2: #f1f5f9;--surf-3: #e2e8f0;--border: #e2e8f0;--border-strong: #cbd5e1;--text: #0f172a;--text-2: #334155;--text-muted: #64748b;--text-faint: #94a3b8;--code-fg: #6d28d9;--code-bg: #f1f5f9;--brand-gradient: radial-gradient(circle at bottom right, rgba(20, 184, 166, .45), transparent 70%), linear-gradient(135deg, #dbeafe 0%, #bae6fd 50%, #2dd4bf 100%);--brand-gradient-linear: linear-gradient(135deg, #dbeafe 0%, #bae6fd 50%, #2dd4bf 100%);--brand-text: #0f172a;--brand-text-muted: #334155;--elev-1: 0 1px 2px rgba(15, 23, 42, .06), 0 1px 3px rgba(15, 23, 42, .08);--elev-2: 0 2px 6px rgba(15, 23, 42, .08), 0 4px 12px rgba(15, 23, 42, .06);--elev-3: 0 6px 16px rgba(15, 23, 42, .12), 0 2px 6px rgba(15, 23, 42, .08);--color-bg: var(--bg);--color-surface: var(--surf-0);--color-text: var(--text);--color-text-muted: var(--text-muted);--color-border: var(--border);--color-primary: var(--accent);--color-primary-hover: var(--accent-hover);--color-accent: var(--accent);--color-success: #22c55e;--color-warning: #f59e0b;--color-error: #ef4444;--color-info: #3b82f6;--app-brand-gradient: var(--brand-gradient)}[data-theme=dark]{--bg: #0b0d13;--surf-0: #101420;--surf-1: #141828;--surf-2: #1a1f31;--surf-3: #232a40;--border: #232a40;--border-strong: #323a55;--text: #e6ebf5;--text-2: #cbd5e1;--text-muted: #94a3b8;--text-faint: #64748b;--code-fg: #c4b5fd;--code-bg: #1a1f31;--brand-gradient: radial-gradient(circle at bottom right, rgba(20, 184, 166, .4), transparent 70%), linear-gradient(135deg, #0f1226 0%, #0f1a30 50%, #0a2a48 100%);--brand-gradient-linear: linear-gradient(135deg, #0f1226 0%, #0f1a30 50%, #0a2a48 100%);--brand-text: #f1f5f9;--brand-text-muted: #94a3b8;--elev-1: 0 1px 2px rgba(0, 0, 0, .4), 0 1px 3px rgba(0, 0, 0, .35);--elev-2: 0 2px 6px rgba(0, 0, 0, .5), 0 4px 12px rgba(0, 0, 0, .35);--elev-3: 0 8px 24px rgba(0, 0, 0, .55)}[data-accent=indigo]{--accent: #6366f1;--accent-hover: #4f46e5;--accent-glow: #a5b4fc}[data-accent=azure]{--accent: #3b82f6;--accent-hover: #2563eb;--accent-glow: #93c5fd}[data-accent=sky]{--accent: #0ea5e9;--accent-hover: #0284c7;--accent-glow: #7dd3fc}[data-accent=sapphire]{--accent: #1d4ed8;--accent-hover: #1e40af;--accent-glow: #93c5fd}[data-accent=teal]{--accent: #14b8a6;--accent-hover: #0d9488;--accent-glow: #5eead4}[data-accent=violet]{--accent: #8b5cf6;--accent-hover: #7c3aed;--accent-glow: #c4b5fd}[data-accent=rose]{--accent: #f43f5e;--accent-hover: #e11d48;--accent-glow: #fda4af}[data-width=comfortable]{--panel-max: 72rem}[data-width=wide]{--panel-max: 84rem}[data-width=full]{--panel-max: 100%}html{--mat-sys-background: light-dark(#fef8fc, #151316);--mat-sys-error: light-dark(#ba1a1a, #ffb4ab);--mat-sys-error-container: light-dark(#ffdad6, #93000a);--mat-sys-inverse-on-surface: light-dark(#f5eff4, #323033);--mat-sys-inverse-primary: light-dark(#d5baff, #7d00fa);--mat-sys-inverse-surface: light-dark(#323033, #e6e1e6);--mat-sys-on-background: light-dark(#1d1b1e, #e6e1e6);--mat-sys-on-error: light-dark(#ffffff, #690005);--mat-sys-on-error-container: light-dark(#93000a, #ffdad6);--mat-sys-on-primary: light-dark(#ffffff, #42008a);--mat-sys-on-primary-container: light-dark(#5f00c0, #ecdcff);--mat-sys-on-primary-fixed: light-dark(#270057, #270057);--mat-sys-on-primary-fixed-variant: light-dark(#5f00c0, #5f00c0);--mat-sys-on-secondary: light-dark(#ffffff, #352d40);--mat-sys-on-secondary-container: light-dark(#4b4357, #eadef7);--mat-sys-on-secondary-fixed: light-dark(#1f182a, #1f182a);--mat-sys-on-secondary-fixed-variant: light-dark(#4b4357, #4b4357);--mat-sys-on-surface: light-dark(#1d1b1e, #e6e1e6);--mat-sys-on-surface-variant: light-dark(#49454e, #e8e0eb);--mat-sys-on-tertiary: light-dark(#ffffff, #42008a);--mat-sys-on-tertiary-container: light-dark(#5f00c0, #ecdcff);--mat-sys-on-tertiary-fixed: light-dark(#270057, #270057);--mat-sys-on-tertiary-fixed-variant: light-dark(#5f00c0, #5f00c0);--mat-sys-outline: light-dark(#7b757f, #958e99);--mat-sys-outline-variant: light-dark(#cbc4cf, #49454e);--mat-sys-primary: light-dark(#7d00fa, #d5baff);--mat-sys-primary-container: light-dark(#ecdcff, #5f00c0);--mat-sys-primary-fixed: light-dark(#ecdcff, #ecdcff);--mat-sys-primary-fixed-dim: light-dark(#d5baff, #d5baff);--mat-sys-scrim: light-dark(#000000, #000000);--mat-sys-secondary: light-dark(#645b70, #cec2db);--mat-sys-secondary-container: light-dark(#eadef7, #4b4357);--mat-sys-secondary-fixed: light-dark(#eadef7, #eadef7);--mat-sys-secondary-fixed-dim: light-dark(#cec2db, #cec2db);--mat-sys-shadow: light-dark(#000000, #000000);--mat-sys-surface: light-dark(#fef8fc, #151316);--mat-sys-surface-bright: light-dark(#fef8fc, #3b383c);--mat-sys-surface-container: light-dark(#f2ecf1, #211f22);--mat-sys-surface-container-high: light-dark(#ede6eb, #2b292d);--mat-sys-surface-container-highest: light-dark(#e6e1e6, #363437);--mat-sys-surface-container-low: light-dark(#f8f2f6, #1d1b1e);--mat-sys-surface-container-lowest: light-dark(#ffffff, #0f0d11);--mat-sys-surface-dim: light-dark(#ded8dd, #151316);--mat-sys-surface-tint: light-dark(#7d00fa, #d5baff);--mat-sys-surface-variant: light-dark(#e8e0eb, #49454e);--mat-sys-tertiary: light-dark(#7d00fa, #d5baff);--mat-sys-tertiary-container: light-dark(#ecdcff, #5f00c0);--mat-sys-tertiary-fixed: light-dark(#ecdcff, #ecdcff);--mat-sys-tertiary-fixed-dim: light-dark(#d5baff, #d5baff);--mat-sys-neutral-variant20: #332f37;--mat-sys-neutral10: #1d1b1e;--mat-sys-level0: 0px 0px 0px 0px rgba(0, 0, 0, .2), 0px 0px 0px 0px rgba(0, 0, 0, .14), 0px 0px 0px 0px rgba(0, 0, 0, .12);--mat-sys-level1: 0px 2px 1px -1px rgba(0, 0, 0, .2), 0px 1px 1px 0px rgba(0, 0, 0, .14), 0px 1px 3px 0px rgba(0, 0, 0, .12);--mat-sys-level2: 0px 3px 3px -2px rgba(0, 0, 0, .2), 0px 3px 4px 0px rgba(0, 0, 0, .14), 0px 1px 8px 0px rgba(0, 0, 0, .12);--mat-sys-level3: 0px 3px 5px -1px rgba(0, 0, 0, .2), 0px 6px 10px 0px rgba(0, 0, 0, .14), 0px 1px 18px 0px rgba(0, 0, 0, .12);--mat-sys-level4: 0px 5px 5px -3px rgba(0, 0, 0, .2), 0px 8px 10px 1px rgba(0, 0, 0, .14), 0px 3px 14px 2px rgba(0, 0, 0, .12);--mat-sys-level5: 0px 7px 8px -4px rgba(0, 0, 0, .2), 0px 12px 17px 2px rgba(0, 0, 0, .14), 0px 5px 22px 4px rgba(0, 0, 0, .12);--mat-sys-body-large: 400 1rem / 1.5rem var(--font-sans);--mat-sys-body-large-font: var(--font-sans);--mat-sys-body-large-line-height: 1.5rem;--mat-sys-body-large-size: 1rem;--mat-sys-body-large-tracking: .031rem;--mat-sys-body-large-weight: 400;--mat-sys-body-medium: 400 .875rem / 1.25rem var(--font-sans);--mat-sys-body-medium-font: var(--font-sans);--mat-sys-body-medium-line-height: 1.25rem;--mat-sys-body-medium-size: .875rem;--mat-sys-body-medium-tracking: .016rem;--mat-sys-body-medium-weight: 400;--mat-sys-body-small: 400 .75rem / 1rem var(--font-sans);--mat-sys-body-small-font: var(--font-sans);--mat-sys-body-small-line-height: 1rem;--mat-sys-body-small-size: .75rem;--mat-sys-body-small-tracking: .025rem;--mat-sys-body-small-weight: 400;--mat-sys-display-large: 400 3.562rem / 4rem var(--font-sans);--mat-sys-display-large-font: var(--font-sans);--mat-sys-display-large-line-height: 4rem;--mat-sys-display-large-size: 3.562rem;--mat-sys-display-large-tracking: -.016rem;--mat-sys-display-large-weight: 400;--mat-sys-display-medium: 400 2.812rem / 3.25rem var(--font-sans);--mat-sys-display-medium-font: var(--font-sans);--mat-sys-display-medium-line-height: 3.25rem;--mat-sys-display-medium-size: 2.812rem;--mat-sys-display-medium-tracking: 0;--mat-sys-display-medium-weight: 400;--mat-sys-display-small: 400 2.25rem / 2.75rem var(--font-sans);--mat-sys-display-small-font: var(--font-sans);--mat-sys-display-small-line-height: 2.75rem;--mat-sys-display-small-size: 2.25rem;--mat-sys-display-small-tracking: 0;--mat-sys-display-small-weight: 400;--mat-sys-headline-large: 400 2rem / 2.5rem var(--font-sans);--mat-sys-headline-large-font: var(--font-sans);--mat-sys-headline-large-line-height: 2.5rem;--mat-sys-headline-large-size: 2rem;--mat-sys-headline-large-tracking: 0;--mat-sys-headline-large-weight: 400;--mat-sys-headline-medium: 400 1.75rem / 2.25rem var(--font-sans);--mat-sys-headline-medium-font: var(--font-sans);--mat-sys-headline-medium-line-height: 2.25rem;--mat-sys-headline-medium-size: 1.75rem;--mat-sys-headline-medium-tracking: 0;--mat-sys-headline-medium-weight: 400;--mat-sys-headline-small: 400 1.5rem / 2rem var(--font-sans);--mat-sys-headline-small-font: var(--font-sans);--mat-sys-headline-small-line-height: 2rem;--mat-sys-headline-small-size: 1.5rem;--mat-sys-headline-small-tracking: 0;--mat-sys-headline-small-weight: 400;--mat-sys-label-large: 500 .875rem / 1.25rem var(--font-sans);--mat-sys-label-large-font: var(--font-sans);--mat-sys-label-large-line-height: 1.25rem;--mat-sys-label-large-size: .875rem;--mat-sys-label-large-tracking: .006rem;--mat-sys-label-large-weight: 500;--mat-sys-label-large-weight-prominent: 700;--mat-sys-label-medium: 500 .75rem / 1rem var(--font-sans);--mat-sys-label-medium-font: var(--font-sans);--mat-sys-label-medium-line-height: 1rem;--mat-sys-label-medium-size: .75rem;--mat-sys-label-medium-tracking: .031rem;--mat-sys-label-medium-weight: 500;--mat-sys-label-medium-weight-prominent: 700;--mat-sys-label-small: 500 .688rem / 1rem var(--font-sans);--mat-sys-label-small-font: var(--font-sans);--mat-sys-label-small-line-height: 1rem;--mat-sys-label-small-size: .688rem;--mat-sys-label-small-tracking: .031rem;--mat-sys-label-small-weight: 500;--mat-sys-title-large: 400 1.375rem / 1.75rem var(--font-sans);--mat-sys-title-large-font: var(--font-sans);--mat-sys-title-large-line-height: 1.75rem;--mat-sys-title-large-size: 1.375rem;--mat-sys-title-large-tracking: 0;--mat-sys-title-large-weight: 400;--mat-sys-title-medium: 500 1rem / 1.5rem var(--font-sans);--mat-sys-title-medium-font: var(--font-sans);--mat-sys-title-medium-line-height: 1.5rem;--mat-sys-title-medium-size: 1rem;--mat-sys-title-medium-tracking: .009rem;--mat-sys-title-medium-weight: 500;--mat-sys-title-small: 500 .875rem / 1.25rem var(--font-sans);--mat-sys-title-small-font: var(--font-sans);--mat-sys-title-small-line-height: 1.25rem;--mat-sys-title-small-size: .875rem;--mat-sys-title-small-tracking: .006rem;--mat-sys-title-small-weight: 500;--mat-sys-corner-extra-large: 28px;--mat-sys-corner-extra-large-top: 28px 28px 0 0;--mat-sys-corner-extra-small: 4px;--mat-sys-corner-extra-small-top: 4px 4px 0 0;--mat-sys-corner-full: 9999px;--mat-sys-corner-large: 16px;--mat-sys-corner-large-end: 0 16px 16px 0;--mat-sys-corner-large-start: 16px 0 0 16px;--mat-sys-corner-large-top: 16px 16px 0 0;--mat-sys-corner-medium: 12px;--mat-sys-corner-none: 0;--mat-sys-corner-small: 8px;--mat-sys-dragged-state-layer-opacity: .16;--mat-sys-focus-state-layer-opacity: .12;--mat-sys-hover-state-layer-opacity: .08;--mat-sys-pressed-state-layer-opacity: .12;color-scheme:light}[data-theme=dark]{color-scheme:dark}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-family:var(--font-sans);color:var(--text);background:#1a1a2e;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden}body{min-height:100vh;min-height:100dvh;background:var(--bg);font-family:var(--font-sans);font-feature-settings:"cv11","ss01";overflow:hidden}a{color:inherit;text-decoration:none}code,kbd,pre{font-family:var(--font-mono);font-feature-settings:"liga" 0}.material-symbols-rounded{font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 24;-webkit-user-select:none;user-select:none;line-height:1}*{scrollbar-width:none}*::-webkit-scrollbar{width:0;height:0}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}@keyframes fade-rise{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.fade-rise{animation:fade-rise var(--dur-3) var(--ease-emph) both}.h-eyebrow{display:inline-block;font-family:var(--font-mono);font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.14em;color:var(--accent)}.h-1{font-size:clamp(2rem,3.6vw,2.75rem);font-weight:700;letter-spacing:-.02em;line-height:1.1;color:var(--text)}.h-2{font-size:1.5rem;font-weight:700;letter-spacing:-.012em;line-height:1.25;color:var(--text)}.page-sticky{position:sticky;top:0;z-index:5;background:var(--brand-gradient);background-attachment:fixed;margin:0 -2.5rem;padding:.5rem 2.5rem 0}.page-divider{height:1px;border:0;margin:.75rem 0 0;background:var(--border)}@media(max-width:1200px){.page-sticky{margin:0 -2.5rem;padding:.5rem 2.5rem 0}}@media(max-width:960px),(max-height:500px){.page-sticky{margin:0 -1.25rem;padding:.5rem 1.25rem 0}}.code-block{position:relative;display:flow-root;margin:0 0 1rem}.code-copy{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:1px solid #3a3a52;border-radius:6px;background:#2a2a3e;color:#cdd6f4;cursor:pointer;transition:background var(--dur-1),border-color var(--dur-1),color var(--dur-1)}.code-copy:before{content:"";display:inline-block;width:14px;height:14px;background-color:currentColor;mask-repeat:no-repeat;mask-size:contain;mask-position:center;-webkit-mask-repeat:no-repeat;-webkit-mask-size:contain;-webkit-mask-position:center;mask-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M16 1H4c-1.1 0-2 .9-2 2v14h2V3h12V1zm3 4H8c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h11c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zm0 16H8V7h11v14z'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M16 1H4c-1.1 0-2 .9-2 2v14h2V3h12V1zm3 4H8c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h11c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zm0 16H8V7h11v14z'/%3E%3C/svg%3E")}.code-copy:hover{background:#363649;border-color:#4e4e66;color:#fff}.code-copy[data-copied=true]{color:#86efac}.code-copy[data-copied=true]:before{mask-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41z'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41z'/%3E%3C/svg%3E")}.code-block>.code-copy{position:absolute;top:.5rem;right:.5rem}.breadcrumbs{display:flex;align-items:center;gap:.5rem;font-family:var(--font-mono);font-size:.8125rem;color:var(--text-muted);min-width:0;margin-bottom:.75rem}.breadcrumbs a{color:var(--text-muted);text-decoration:none}.breadcrumbs a:hover{color:var(--text)}.crumb-sep{opacity:.4}.crumb-current{color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.filter-chips{display:flex;flex-wrap:wrap;gap:.375rem}.filter-select{display:none;height:40px;width:100%;padding:0 2rem 0 .75rem;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surf-0);color:var(--text);font-family:var(--font-mono);font-size:.8125rem;appearance:none;cursor:pointer;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%2364748b'><path d='M5 7l5 6 5-6z'/></svg>");background-repeat:no-repeat;background-position:right .5rem center;background-size:1rem}.filter-select:focus{outline:none;border-color:var(--accent)}@media(max-width:640px),(max-height:500px){.filter-chips{display:none}.filter-select{display:block}}.page-title-row{display:flex;align-items:center;gap:.75rem;min-width:0}mat-icon.page-icon{flex-shrink:0;font-size:31px;width:31px;height:31px;line-height:1;color:var(--accent);overflow:visible}@media(max-width:640px),(max-height:500px){.page-title-row{gap:.625rem}mat-icon.page-icon{font-size:27px;width:27px;height:27px}}.h-3{font-size:1.125rem;font-weight:600;line-height:1.3;color:var(--text)}.p-lead{font-size:1.0625rem;color:var(--text-2);line-height:1.65}.p-muted{color:var(--text-muted);font-size:.9375rem}.btn{display:inline-flex;align-items:center;gap:.4375rem;height:40px;padding:0 1rem;border:none;border-radius:var(--r-sm);font-family:var(--font-sans);font-size:.875rem;font-weight:500;text-decoration:none;cursor:pointer;transition:background var(--dur-1),color var(--dur-1),border-color var(--dur-1),transform var(--dur-1);white-space:nowrap}.btn:active{transform:translateY(1px)}.btn--primary{background:var(--accent);color:var(--accent-on);box-shadow:var(--elev-1)}.btn--primary:hover{background:var(--accent-hover)}.btn--outline{background:var(--surf-0);color:var(--text-2);border:1px solid var(--border-strong)}.btn--outline:hover{background:var(--surf-1);color:var(--text)}.btn--ghost{color:var(--text-2);background:transparent}.btn--ghost:hover{background:var(--surf-2);color:var(--text)}.btn--sm{height:32px;padding:0 .75rem;font-size:.8125rem}.btn--lg{height:44px;padding:0 1.25rem;font-size:.9375rem}.btn .btn-icon{font-size:1.125rem;width:1.125rem;height:1.125rem;line-height:1;flex-shrink:0}.btn tbx-github-icon.btn-icon{font-size:1.25rem;width:1.25rem;height:1.25rem}.btn tbx-storybook-icon.btn-icon{font-size:1rem;width:1rem;height:1rem}.btn tbx-npm-icon.btn-icon{font-size:.9375rem;width:.9375rem;height:.9375rem}.card{background:var(--surf-0);border:1px solid var(--border);border-radius:var(--r-md);transition:border-color var(--dur-1),box-shadow var(--dur-1),transform var(--dur-1)}.card--hover:hover{border-color:var(--border-strong);box-shadow:var(--elev-2)}.chip{display:inline-flex;align-items:center;gap:.25rem;font-family:var(--font-mono);font-size:.6875rem;font-weight:500;padding:.1875rem .5rem;border-radius:var(--r-full);border:1px solid var(--border);background:var(--surf-1);color:var(--text-2);letter-spacing:.02em;white-space:nowrap}.chip[data-layer=foundation]{background:color-mix(in oklch,var(--accent) 14%,var(--surf-1));color:var(--accent);border-color:color-mix(in oklch,var(--accent) 28%,transparent)}.chip[data-layer=services]{background:color-mix(in oklch,#14b8a6 14%,var(--surf-1));color:#0d9488;border-color:color-mix(in oklch,#14b8a6 28%,transparent)}.chip[data-layer=components]{background:color-mix(in oklch,#8b5cf6 14%,var(--surf-1));color:#7c3aed;border-color:color-mix(in oklch,#8b5cf6 28%,transparent)}[data-theme=dark] .chip[data-layer=services]{color:#5eead4}[data-theme=dark] .chip[data-layer=components]{color:#c4b5fd}a[target=_blank]:after{content:"arrow_outward";font-family:Material Symbols Rounded;font-size:.9em;font-weight:400;font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 24;vertical-align:middle;margin-left:.15em;line-height:1;text-decoration:none;display:inline-block}.mat-mdc-tab-body-wrapper{flex:1;min-height:0}.mat-mdc-tab-body-content{overflow-y:auto!important;overscroll-behavior:contain;padding:0 0 2rem}.mat-mdc-tab-body-content h2,.mat-mdc-tab-body-content h3,.mat-mdc-tab-body-content h4{color:var(--text);font-weight:600;line-height:1.3}.mat-mdc-tab-body-content h2{font-size:1.35rem;margin:2rem 0 .75rem;padding-bottom:.25rem;border-bottom:1px solid var(--color-border)}.mat-mdc-tab-body-content h3{font-size:1.15rem;margin:1.25rem 0 .375rem}.mat-mdc-tab-body-content h4{font-size:.9375rem;font-weight:600;margin:1rem 0 .375rem;color:var(--color-text-muted)}.mat-mdc-tab-body-content p{margin-bottom:1em;font-size:.9375rem;line-height:1.7}.mat-mdc-tab-body-content a{color:var(--color-primary);text-decoration:none}.mat-mdc-tab-body-content a:hover{text-decoration:underline}.mat-mdc-tab-body-content ul,.mat-mdc-tab-body-content ol{padding-left:1.5em;margin-bottom:1em}.mat-mdc-tab-body-content li{margin-bottom:.25em}.mat-mdc-tab-body-content code{font-family:var(--font-mono);font-size:.875em;background:var(--code-bg);color:var(--code-fg);padding:.15em .4em;border-radius:4px}.mat-mdc-tab-body-content pre{font-family:var(--font-mono);font-size:.85rem;line-height:1.65;background:#1e1e2e;color:#cdd6f4;padding:1rem 1.25rem;border-radius:8px;overflow-x:auto;margin-bottom:1.25rem}.mat-mdc-tab-body-content pre code{background:none;color:inherit;padding:0;font-size:inherit}.mat-mdc-tab-body-content table{width:100%;border-collapse:collapse;font-size:.875rem;margin-bottom:1.5rem;table-layout:fixed}.mat-mdc-tab-body-content table th:first-child,.mat-mdc-tab-body-content table td:first-child{width:30%}.mat-mdc-tab-body-content table th:nth-child(2):not(:last-child),.mat-mdc-tab-body-content table td:nth-child(2):not(:last-child){width:15%}.mat-mdc-tab-body-content table th:last-child,.mat-mdc-tab-body-content table td:last-child{width:auto}.mat-mdc-tab-body-content table td{overflow-wrap:anywhere}.mat-mdc-tab-body-content th{text-align:left;font-family:var(--font-mono);font-size:.6875rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);padding:.625rem .875rem;background:var(--surf-1);border-bottom:1px solid var(--border)}.mat-mdc-tab-body-content td{padding:.625rem .875rem;border-bottom:1px solid var(--border);color:var(--text-2);vertical-align:top}.mat-mdc-tab-body-content tbody tr:last-child td{border-bottom:none}.mat-mdc-tab-body-content tbody tr:hover td{background:var(--surf-1)}.mat-mdc-tab-body-content blockquote{border-left:3px solid var(--color-border);padding:.5rem 1rem;color:var(--color-text-muted);margin-bottom:1em}.mat-mdc-tab-body-content .flow-diagram{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin:1rem 0 1.25rem;padding:1rem;background:#f8fafc;border:1px solid var(--color-border);border-radius:8px}.mat-mdc-tab-body-content .flow-box{display:inline-block;padding:.375rem .75rem;background:#fff;border:1px solid var(--color-border);border-radius:6px;font-size:.8125rem;font-weight:500;color:#334155;white-space:nowrap}.mat-mdc-tab-body-content .flow-arrow{color:var(--color-text-muted);font-size:.875rem}@media(max-width:640px),(max-height:500px){.mat-mdc-tab-body-wrapper{flex:unset;min-height:unset}.mat-mdc-tab-body{overflow:visible!important;position:relative!important;height:auto!important;width:100%!important}.mat-mdc-tab-body:not(.mat-mdc-tab-body-active){display:none!important}.mat-mdc-tab-body-content{overflow:visible!important;width:100%!important;padding:0 0 2rem}.mat-mdc-tab-body-content table,.mat-mdc-tab-body-content table thead,.mat-mdc-tab-body-content table tbody{display:block}.mat-mdc-tab-body-content table tr{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid var(--color-border)}.mat-mdc-tab-body-content table th,.mat-mdc-tab-body-content table td{width:auto!important;border-bottom:none}.mat-mdc-tab-body-content table tr>:nth-child(3){grid-column:1/-1;padding-left:calc(.75rem + .4em);padding-top:0}.mat-mdc-tab-body-content table tr:has(>:nth-child(3))>:nth-child(1),.mat-mdc-tab-body-content table tr:has(>:nth-child(3))>:nth-child(2){padding-bottom:.25rem}.mat-mdc-tab-body-content table tr:not(:has(>:nth-child(3))){grid-template-columns:1fr}.mat-mdc-tab-body-content table tr:not(:has(>:nth-child(3)))>:last-child{padding-left:calc(.75rem + .4em)}.mat-mdc-tab-body-content table tr:not(:has(>:nth-child(3)))>:first-child{padding-bottom:.25rem}.mat-mdc-tab-body-content table tr:not(:has(>:nth-child(3)))>:last-child{padding-top:0}.mat-mdc-tab-body-content table.meta-table tr:not(:has(>:nth-child(3))){grid-template-columns:auto 1fr}.mat-mdc-tab-body-content table.meta-table tr:not(:has(>:nth-child(3)))>:first-child{padding:.55rem .75rem}.mat-mdc-tab-body-content table.meta-table tr:not(:has(>:nth-child(3)))>:last-child{padding:.55rem .75rem;text-align:right}.mat-mdc-tab-body-content table thead th:nth-child(3),.mat-mdc-tab-body-content table thead th:nth-child(2):last-child{display:none}.mat-mdc-tab-body-content table .kind-chip,.mat-mdc-tab-body-content table .chip{margin-left:-.5rem}}
